# 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 product for any application for which it is not intended without the prior written consent of 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; anti-crime 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 majority-owned subsidiaries.
- (Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics.



# **Preliminary User's Manual**

# **V850ES/SG2**

# 32-Bit Single-Chip Microcontroller

# **Hardware**

μPD703262HY μPD703263HY μPD70F3263HY μPD703272HY μPD703273HY μPD70F3273HY μPD703282HY μPD703283HY μPD70F3283HY

Document No. U17644EJ1V0UD00 (1st edition) Date Published September 2005 N CP(K)

# [MEMO]

#### NOTES FOR CMOS DEVICES —

#### (1) VOLTAGE APPLICATION WAVEFORM AT INPUT PIN

Waveform distortion due to input noise or a reflected wave may cause malfunction. If the input of the CMOS device stays in the area between  $V_{\rm IL}$  (MAX) and  $V_{\rm IH}$  (MIN) due to noise, etc., the device may malfunction. Take care to prevent chattering noise from entering the device when the input level is fixed, and also in the transition period when the input level passes through the area between  $V_{\rm IL}$  (MAX) and  $V_{\rm IH}$  (MIN).

# (2) HANDLING OF UNUSED INPUT PINS

Unconnected CMOS device inputs can be cause of malfunction. If an input pin is unconnected, it is possible that an internal input level may be generated due to noise, etc., causing malfunction. CMOS devices behave differently than Bipolar or NMOS devices. Input levels of CMOS devices must be fixed high or low by using pull-up or pull-down circuitry. Each unused pin should be connected to VDD or GND via a resistor if there is a possibility that it will be an output pin. All handling related to unused pins must be judged separately for each device and according to related specifications governing the device.

#### ③ PRECAUTION AGAINST ESD

A strong electric field, when exposed to a MOS device, can cause destruction of the gate oxide and ultimately degrade the device operation. Steps must be taken to stop generation of static electricity as much as possible, and quickly dissipate it when it has occurred. Environmental control must be adequate. When it is dry, a humidifier should be used. It is recommended to avoid using insulators that easily build up static electricity. Semiconductor devices must be stored and transported in an anti-static container, static shielding bag or conductive material. All test and measurement tools including work benches and floors should be grounded. The operator should be grounded using a wrist strap. Semiconductor devices must not be touched with bare hands. Similar precautions need to be taken for PW boards with mounted semiconductor devices.

#### (4) STATUS BEFORE INITIALIZATION

Power-on does not necessarily define the initial status of a MOS device. Immediately after the power source is turned ON, devices with reset functions have not yet been initialized. Hence, power-on does not guarantee output pin levels, I/O settings or contents of registers. A device is not initialized until the reset signal is received. A reset operation must be executed immediately after power-on for devices with reset functions.

### (5) POWER ON/OFF SEQUENCE

In the case of a device that uses different power supplies for the internal operation and external interface, as a rule, switch on the external power supply after switching on the internal power supply. When switching the power supply off, as a rule, switch off the external power supply and then the internal power supply. Use of the reverse power on/off sequences may result in the application of an overvoltage to the internal elements of the device, causing malfunction and degradation of internal elements due to the passage of an abnormal current.

The correct power on/off sequence must be judged separately for each device and according to related specifications governing the device.

# **6** INPUT OF SIGNAL DURING POWER OFF STATE

Do not input signals or an I/O pull-up power supply while the device is not powered. The current injection that results from input of such a signal or I/O pull-up power supply may cause malfunction and the abnormal current that passes in the device at this time may cause degradation of internal elements. Input of signals during the power off state must be judged separately for each device and according to related specifications governing the device.

IECUBE is a registered trademark of NEC Corporation in Japan and Germany.

IEBus and Inter Equipment Bus are trademarks of NEC Electronics Corporation.

Windows and Windows NT are either registered trademarks or trademarks of Microsoft Corporation in the United States and/or other countries.

PC/AT is a trademark of International Business Machines Corporation.

SPARCstation is a trademark of SPARC International, Inc.

Solaris and SunOS are trademarks of Sun Microsystems, Inc.

These commodities, technology or software, must be exported in accordance with the export administration regulations of the exporting country. Diversion contrary to the law of that country is prohibited.

- The information contained in this document is being issued in advance of the production cycle for the product. The parameters for the product may change before final production or NEC Electronics Corporation, at its own discretion, may withdraw the product prior to its production.
- Not all products and/or types are available in every country. Please check with an NEC Electronics sales representative for availability and additional information.
- No part of this document may be copied or reproduced in any form or by any means without the prior written consent of NEC Electronics. NEC Electronics assumes no responsibility for any errors that may appear in this document.
- NEC 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 NEC Electronics products listed in this document or any other liability arising from the use of such products. No license, express, implied or otherwise, is granted under any patents, copyrights or other intellectual property rights of NEC Electronics or others.
- Descriptions of circuits, software and other related information in this document are provided for illustrative purposes
  in semiconductor product operation and application examples. The incorporation of these circuits, software and
  information in the design of a customer's equipment shall be done under the full responsibility of the customer. NEC
  Electronics assumes no responsibility for any losses incurred by customers or third parties arising from the use of
  these circuits, software and information.
- While NEC Electronics endeavors to enhance the quality, reliability and safety of NEC Electronics products, customers agree and acknowledge that the possibility of defects thereof cannot be eliminated entirely. To minimize risks of damage to property or injury (including death) to persons arising from defects in NEC Electronics products, customers must incorporate sufficient safety measures in their design, such as redundancy, fire-containment and anti-failure features.
- NEC Electronics products are classified into the following three quality grades: "Standard", "Special" and "Specific".
   The "Specific" quality grade applies only to NEC Electronics products developed based on a customer-designated "quality assurance program" for a specific application. The recommended applications of an NEC Electronics products depend on its quality grade, as indicated below. Customers must check the quality grade of each NEC Electronics product before using it in a particular application.
  - "Standard": Computers, office equipment, communications equipment, test and measurement equipment, audio and visual equipment, home electronic appliances, machine tools, personal electronic equipment and industrial robots.
  - "Special": Transportation equipment (automobiles, trains, ships, etc.), traffic control systems, anti-disaster systems, anti-crime systems, safety equipment and medical equipment (not specifically designed for life support).
  - "Specific": Aircraft, aerospace equipment, submersible repeaters, nuclear reactor control systems, life support systems and medical equipment for life support, etc.

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

#### (Note)

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

M5D 02.11-1

# **Regional Information**

Some information contained in this document may vary from country to country. Before using any NEC Electronics product in your application, please contact the NEC Electronics office in your country to obtain a list of authorized representatives and distributors. They will verify:

- · Device availability
- · Ordering information
- · Product release schedule
- · Availability of related technical literature
- Development environment specifications (for example, specifications for third-party tools and components, host computers, power plugs, AC supply voltages, and so forth)
- Network requirements

In addition, trademarks, registered trademarks, export restrictions, and other legal issues may also vary from country to country.

#### [GLOBAL SUPPORT]

http://www.necel.com/en/support/support.html

# NEC Electronics America, Inc. (U.S.) NEC Electronics (Europe) GmbH NEC Electronics Hong Kong Ltd.

Santa Clara, California Tel: 408-588-6000 800-366-9782

Duesseldorf, Germany Tel: 0211-65030

# • Sucursal en España

Madrid, Spain Tel: 091-504 27 87

# • Succursale Française

Vélizy-Villacoublay, France Tel: 01-30-675800

# • Filiale Italiana

Milano, Italy Tel: 02-66 75 41

#### Branch The Netherlands

Eindhoven. The Netherlands Tel: 040-2654010

#### Tyskland Filial

Taeby, Sweden Tel: 08-63 87 200

#### United Kingdom Branch

Milton Keynes, UK Tel: 01908-691-133

Hong Kong Tel: 2886-9318

# **NEC Electronics Hong Kong Ltd.**

Seoul Branch Seoul, Korea Tel: 02-558-3737

### **NEC Electronics Shanghai Ltd.**

Shanghai, P.R. China Tel: 021-5888-5400

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

Taipei, Taiwan Tel: 02-2719-2377

# **NEC Electronics Singapore Pte. Ltd.**

Novena Square, Singapore Tel: 6253-8311

J05.6

#### **PREFACE**

#### Readers

This manual is intended for users who wish to understand the functions of the following V850ES/SG2 products operating at 32 MHz and design application systems using these products.

μPD703262HY, 703263HY, 70F3263HY, 703272HY, 703273HY, 70F3273HY,
 703282HY, 703283HY, 70F3283HY

#### **Purpose**

This manual is intended to give users an understanding of the hardware functions of the V850ES/SG2 shown in the **Organization** below.

# Organization

This manual is divided into two parts: Hardware (this manual) and Architecture (V850ES Architecture User's Manual).

#### Hardware

- Pin functions
- CPU function
- On-chip peripheral functions
- Flash memory programming
- Electrical specifications (target)

#### Architecture

- Data types
- Register set
- Instruction format and instruction set
- Interrupts and exceptions
- Pipeline operation

#### **How to Read This Manual**

It is assumed that the readers of this manual have general knowledge in the fields of electrical engineering, logic circuits, and microcontrollers.

To understand the overall functions of the V850ES/SG2

→ Read this manual according to the **CONTENTS**.

To find the details of a register where the name is known

→Use APPENDIX B REGISTER INDEX.

To know the electrical specifications of the V850ES/SG2

→ See CHAPTER 31 ELECTRICAL SPECIFICATIONS (TARGET).

To understand the details of an instruction function

→ Refer to the **V850ES Architecture User's Manual** available separately.

### Register format

→The name of the bit whose number is in angle brackets (<>) in the figure of the register format of each register is defined as a reserved word in the device file.

The "yyy bit of the xxx register" is described as the "xxx.yyy bit" in this manual. Note with caution that if "xxx.yyy" is described as is in a program, however, the compiler/assembler cannot recognize it correctly.

Conventions Data significance:

Higher digits on the left and lower digits on the right

Active low representation:  $\overline{xxx}$  (overscore over pin or signal name)

Memory map address: Higher addresses on the top and lower addresses on

the bottom

**Note:** Footnote for item marked with **Note** in the text

Caution: Information requiring particular attention

**Remark:** Supplementary information Numeric representation: Binary ... xxxx or xxxxB

Decimal ... xxxx

Hexadecimal ... xxxxH

Prefix indicating power of 2 (address space, memory

capacity):  $K \text{ (kilo): } 2^{10} = 1,024$ 

M (mega):  $2^{20} = 1,024^2$ G (giga):  $2^{30} = 1,024^3$ 

# **Related Documents**

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

# Documents related to V850ES/SG2

| Document Name                                                 | Document No. |
|---------------------------------------------------------------|--------------|
| V850ES Architecture User's Manual                             | U15943E      |
| V850ES/SG2 Hardware User's Manual                             | U16541E      |
| V850ES/SG2 (32 MHz Operation Products) Hardware User's Manual | This manual  |

# Documents related to development tools

| Document Name                                |                                                     | Document No. |  |
|----------------------------------------------|-----------------------------------------------------|--------------|--|
| IE-V850ES-G1 (In-Circuit Emulator)           |                                                     | U16313E      |  |
| IE-703288-G1-EM1 (In-Circuit Emulator Option | IE-703288-G1-EM1 (In-Circuit Emulator Option Board) |              |  |
| IE-V850E1-CD-NW (PCMCIA Card Type On-C       | Chip Debug Emulator)                                | U16647E      |  |
| QB-V850ESSX2 (In-Circuit Emulator)           |                                                     | U17091E      |  |
| CA850 Ver. 3.00 C Compiler Package           | Operation                                           | U17293E      |  |
|                                              | C Language                                          | U17291E      |  |
|                                              | Assembly Language                                   | U17292E      |  |
|                                              | Link Directive                                      | U17294E      |  |
| PM+ Ver. 6.00 Project Manager                |                                                     | U17178E      |  |
| ID850 Ver. 3.00 Integrated Debugger          | Operation                                           | U17358E      |  |
| ID850QB Ver. 3.10 Integrated Debugger        | Operation                                           | U17435E      |  |
| TW850 Ver. 2.00 Performance Analysis Tunin   | g Tool                                              | U17241E      |  |
| SM850 Ver. 2.50 System Simulator             | SM850 Ver. 2.50 System Simulator Operation          |              |  |
| SM850 Ver. 2.00 or Later System Simulator    | External Part User Open Interface Specification     | U14873E      |  |
| SM+ System Simulation                        | Operation                                           | U17246E      |  |
|                                              | User Open Interface                                 | U17247E      |  |
| RX850 Ver. 3.20 Real-Time OS                 | 60 Ver. 3.20 Real-Time OS Basics                    |              |  |
| Installation                                 |                                                     | U17419E      |  |
|                                              | Technical                                           | U13431E      |  |
|                                              | Task Debugger                                       | U17420E      |  |
| RX850 Pro Ver. 3.20 Real-Time OS             | Basics                                              | U13773E      |  |
|                                              | Installation                                        | U17421E      |  |
|                                              | Technical                                           | U13772E      |  |
| Task Debugger                                |                                                     | U17422E      |  |
| AZ850 Ver. 3.30 System Performance Analyze   | er                                                  | U17423E      |  |
| PG-FP4 Flash Memory Programmer               |                                                     | U15260E      |  |

# **CONTENTS**

| CHAPTER    | 1 INTRODU          | UCTION                                                              | 22  |
|------------|--------------------|---------------------------------------------------------------------|-----|
| 1.1        | General            |                                                                     | 22  |
| 1.2        | Features           |                                                                     | 26  |
| 1.3        | Application        | Fields                                                              | 27  |
| 1.4        | Ordering Inf       | formation                                                           | 27  |
| 1.5        | Pin Configu        | ration (Top View)                                                   | 27  |
| 1.6        | Function Bl        | ock Configuration                                                   | 30  |
|            | 1.6.1 Interi       | nal block diagram                                                   | 30  |
|            | 1.6.2 Interi       | nal units                                                           | 31  |
| CHAPTER    | 2 PIN FUN          | ICTIONS                                                             | 34  |
| 2.1        | List of Din E      | unctions                                                            | 24  |
| 2.1<br>2.2 |                    | unctions                                                            |     |
| 2.2        |                    | uit Types, I/O Buffer Power Supplies, and Connection of Unused Pins |     |
| 2.3<br>2.4 |                    | uit Types, NO Burier Fower Supplies, and Connection of Onused Fins  |     |
| 2.4        | Cautions           |                                                                     | 47  |
| CHAPTER    | 3 CPU FU           | NCTION                                                              | 48  |
| 3.1        | Features           |                                                                     | 48  |
| 3.2        | <b>CPU Registe</b> | er Set                                                              | 49  |
|            | 3.2.1 Prog         | ram register set                                                    | 50  |
|            | 3.2.2 Syste        | em register set                                                     | 51  |
| 3.3        | Operation M        | lodes                                                               | 57  |
|            | 3.3.1 Spec         | cifying operation mode                                              | 57  |
| 3.4        | Address Sp         | ace                                                                 | 58  |
|            | 3.4.1 CPU          | address space                                                       | 58  |
|            | 3.4.2 Wrap         | paround of CPU address space                                        | 59  |
|            | 3.4.3 Mem          | ory map                                                             | 60  |
|            | 3.4.4 Area         | s                                                                   | 62  |
|            | 3.4.5 Reco         | ommended use of address space                                       | 66  |
|            | 3.4.6 Perip        | oheral I/O registers                                                | 68  |
|            | 3.4.7 Prog         | rammable peripheral I/O registers                                   | 79  |
|            | 3.4.8 Spec         | sial registers                                                      | 80  |
|            | 3.4.9 Caut         | ions                                                                | 84  |
| CHAPTER    | 4 PORT F           | UNCTIONS                                                            | 89  |
| 4.1        | Features           |                                                                     | 89  |
| 4.2        | Basic Port C       | Configuration                                                       | 89  |
| 4.3        | Port Configu       | uration                                                             | 90  |
|            | 4.3.1 Port         | 0                                                                   | 95  |
|            | 4.3.2 Port         | 1                                                                   | 98  |
|            | 4.3.3 Port         | 3                                                                   | 99  |
|            | 434 Port           | 4                                                                   | 105 |

|       |             | 4.3.5  | Port 5                                                                            | 108 |
|-------|-------------|--------|-----------------------------------------------------------------------------------|-----|
|       |             | 4.3.6  | Port 7                                                                            |     |
|       |             | 4.3.7  | Port 9                                                                            |     |
|       |             | 4.3.8  | Port CM                                                                           |     |
|       |             | 4.3.9  | Port CT                                                                           |     |
|       |             | 4.3.10 | Port DH                                                                           |     |
|       |             | 4.3.11 | Port DL                                                                           |     |
|       | 4.4         |        | Diagrams                                                                          |     |
|       | 4.5         |        | egister Settings When Alternate Function Is Used                                  |     |
|       | 4.6         |        | ns                                                                                |     |
|       | 4.0         | 4.6.1  | Cautions on setting port pins                                                     |     |
|       |             | 4.6.2  | Cautions on bit manipulation instruction for port n register (Pn)                 |     |
|       |             | 4.6.3  | Cautions on on-chip debug pins                                                    |     |
|       |             | 4.6.4  | Cautions on P05/INTP2/DRST pin                                                    |     |
|       |             | 4.6.5  | Cautions on P10, P11, and P53 pins when power is turned on                        |     |
|       |             |        | ·                                                                                 |     |
|       |             | 4.6.6  | Hysteresis characteristics                                                        | 172 |
| СН    | ΔPTFR       | 5 BU   | S CONTROL FUNCTION                                                                | 173 |
| · · · | ~ <u></u> . | 0 20   |                                                                                   |     |
|       | 5.1         | Featur | es                                                                                | 173 |
|       | 5.2         | Bus Co | ontrol Pins                                                                       | 174 |
|       |             | 5.2.1  | Pin status when internal ROM, internal RAM, or on-chip peripheral I/O is accessed |     |
|       |             | 5.2.2  | Pin status in each operation mode                                                 |     |
|       | 5.3         | Memor  | y Block Function                                                                  |     |
|       | 5.4         |        | al Bus Interface Mode Control Function                                            |     |
|       | 5.5         |        | cess                                                                              |     |
|       |             | 5.5.1  | Number of clocks for access                                                       |     |
|       |             | 5.5.2  | Bus size setting function                                                         |     |
|       |             | 5.5.3  | Access by bus size                                                                |     |
|       | 5.6         |        | unction                                                                           |     |
|       |             | 5.6.1  | Programmable wait function                                                        |     |
|       |             | 5.6.2  | External wait function                                                            |     |
|       |             | 5.6.3  | Relationship between programmable wait and external wait                          |     |
|       |             | 5.6.4  | Programmable address wait function                                                |     |
|       | 5.7         |        | ate Insertion Function                                                            |     |
|       | 5.8         |        | old Function                                                                      |     |
|       | 5.0         | 5.8.1  | Functional outline                                                                |     |
|       |             | 5.8.2  | Bus hold procedure                                                                |     |
|       |             | 5.8.3  | Operation in power save mode                                                      |     |
|       | 5.9         |        | iority                                                                            |     |
|       | 5.10        |        | ming                                                                              |     |
|       | 5.10        | Dus II | g                                                                                 | 193 |
| СН    | APTER       | 6 CLC  | OCK GENERATION FUNCTION                                                           | 199 |
|       | 6.1         | Overvi | ew                                                                                | 199 |
|       | 6.2         |        | uration                                                                           |     |
|       | 6.3         | _      | ers                                                                               |     |
|       | 6.4         | _      | ion                                                                               |     |
|       |             | 6.4.1  | Operation of each clock                                                           |     |
|       |             |        | -r                                                                                |     |

|        | 6.4.2 Clock output function                                            | 207 |
|--------|------------------------------------------------------------------------|-----|
| 6.5    | PLL Function                                                           | 208 |
|        | 6.5.1 Overview                                                         | 208 |
|        | 6.5.2 Registers                                                        | 208 |
|        | 6.5.3 Usage                                                            |     |
| CHAPTE | R 7 16-BIT TIMER/EVENT COUNTER P (TMP)                                 | 212 |
| 7.1    | Overview                                                               | 212 |
| 7.2    | Functions                                                              | 212 |
| 7.3    | Configuration                                                          | 213 |
| 7.4    | Registers                                                              | 215 |
| 7.5    | Operation                                                              | 227 |
|        | 7.5.1 Interval timer mode (TPnMD2 to TPnMD0 bits = 000)                | 228 |
|        | 7.5.2 External event count mode (TPnMD2 to TPnMD0 bits = 001)          | 238 |
|        | 7.5.3 External trigger pulse output mode (TPnMD2 to TPnMD0 bits = 010) | 246 |
|        | 7.5.4 One-shot pulse output mode (TPnMD2 to TPnMD0 bits = 011)         | 258 |
|        | 7.5.5 PWM output mode (TPnMD2 to TPnMD0 bits = 100)                    | 265 |
|        | 7.5.6 Free-running timer mode (TPnMD2 to TPnMD0 bits = 101)            | 274 |
|        | 7.5.7 Pulse width measurement mode (TPnMD2 to TPnMD0 bits = 110)       | 291 |
|        | 7.5.8 Timer output operations                                          | 297 |
| 7.6    | Selector Function                                                      | 298 |
| 7.7    | Cautions                                                               | 300 |
| 8.1    | R 8 16-BIT TIMER/EVENT COUNTER Q (TMQ)  Overview                       | 301 |
| 8.2    | Functions                                                              |     |
| 8.3    | Configuration                                                          |     |
| 8.4    | Registers                                                              |     |
| 8.5    | Operation                                                              |     |
|        | 8.5.1 Interval timer mode (TQ0MD2 to TQ0MD0 bits = 000)                |     |
|        | 8.5.2 External event count mode (TQ0MD2 to TQ0MD0 bits = 001)          |     |
|        | 8.5.3 External trigger pulse output mode (TQ0MD2 to TQ0MD0 bits = 010) |     |
|        | 8.5.4 One-shot pulse output mode (TQ0MD2 to TQ0MD0 bits = 011)         | 353 |
|        | 8.5.5 PWM output mode (TQ0MD2 to TQ0MD0 bits = 100)                    | 362 |
|        | 8.5.6 Free-running timer mode (TQ0MD2 to TQ0MD0 bits = 101)            | 373 |
|        | 8.5.7 Pulse width measurement mode (TQ0MD2 to TQ0MD0 bits = 110)       | 393 |
|        | 8.5.8 Timer output operations                                          | 399 |
| 8.6    | Selector Function                                                      | 399 |
| 8.7    | Cautions                                                               | 400 |
| CHAPTE | R 9 16-BIT INTERVAL TIMER M (TMM)                                      | 401 |
| 9.1    | Overview                                                               |     |
| 9.2    | Configuration                                                          | 402 |
| 9.3    | Register                                                               | 403 |
| 9.4    | Operation                                                              | 404 |
|        | 9.4.1 Interval timer mode                                              | 404 |

|         | 9.4.2 Cautions                                  | 408 |
|---------|-------------------------------------------------|-----|
| CHAPTER | 10 WATCH TIMER FUNCTIONS                        | 409 |
| 10.1    | Functions                                       | 400 |
| 10.2    | Configuration                                   |     |
| 10.3    | Control Registers                               |     |
| 10.4    | Operation                                       |     |
|         | 10.4.1 Operation as watch timer                 |     |
|         | 10.4.2 Operation as interval timer              |     |
|         | 10.4.3 Cautions                                 |     |
| CHAPTER | 11 FUNCTIONS OF WATCHDOG TIMER 2                | 419 |
| 11.1    | Functions                                       | 419 |
| 11.2    | Configuration                                   | 420 |
| 11.3    | Registers                                       | 421 |
| 11.4    | Operation                                       | 423 |
| CHAPTER | 12 REAL-TIME OUTPUT FUNCTION (RTO)              | 424 |
| 12.1    | Function                                        |     |
| 12.2    | Configuration                                   |     |
| 12.3    | Registers                                       |     |
| 12.4    | Operation                                       |     |
| 12.5    | Usage                                           |     |
| 12.6    | Cautions                                        | 430 |
| CHAPTER | 13 A/D CONVERTER                                | 431 |
| 13.1    | Overview                                        | 431 |
| 13.2    | Functions                                       |     |
| 13.3    | Configuration                                   |     |
| 13.4    | Registers                                       | 435 |
| 13.5    | Operation                                       | 446 |
|         | 13.5.1 Basic operation                          | 446 |
|         | 13.5.2 Conversion operation timing              |     |
|         | 13.5.3 Trigger mode                             |     |
|         | 13.5.4 Operation mode                           |     |
|         | 13.5.5 Power-fail compare mode                  |     |
| 13.6    | Cautions                                        |     |
| 13.7    | How to Read A/D Converter Characteristics Table | 463 |
| CHAPTER | 14 D/A CONVERTER                                | 467 |
| 14.1    | Functions                                       |     |
| 14.2    | Configuration                                   |     |
| 14.3    | Registers                                       |     |
| 14.4    | Operation                                       |     |
|         | 14.4.1 Operation in normal mode                 | 470 |

|         | 14.4.2           | Operation in real-time output mode                              | 470 |
|---------|------------------|-----------------------------------------------------------------|-----|
|         | 14.4.3           | Cautions                                                        | 471 |
| CHARTER | 15 A             | SYNCHRONOUS SERIAL INTERFACE A (UARTA)                          | 470 |
| CHAPTEN | 15 A             | STNCHRONOUS SERIAL INTERFACE A (UARTA)                          | 412 |
| 15.1    | Mode             | Switching of UARTA and Other Serial Interfaces                  | 472 |
|         | 15.1.1           | CSIB4 and UARTA0 mode switching                                 | 472 |
|         | 15.1.2           | UARTA2 and I <sup>2</sup> C00 mode switching                    |     |
|         | 15.1.3           | UARTA1 and I <sup>2</sup> C02 mode switching                    |     |
| 15.2    |                  | res                                                             |     |
| 15.3    | -                | guration                                                        |     |
| 15.4    | _                | ters                                                            |     |
| 15.5    |                  | upt Request Signals                                             |     |
| 15.6    | •                | tion                                                            |     |
|         | 15.6.1           | Data format                                                     |     |
|         | 15.6.2           | SBF transmission/reception format                               |     |
|         | 15.6.3           | SBF transmission                                                |     |
|         | 15.6.4           | SBF reception                                                   |     |
|         | 15.6.5           | UART transmission                                               | _   |
|         | 15.6.6           | Continuous transmission procedure                               |     |
|         | 15.6.7<br>15.6.8 | UART reception                                                  |     |
|         | 15.6.9           | Reception errors                                                |     |
|         |                  | Parity types and operations                                     |     |
| 15.7    |                  | ated Baud Rate Generator                                        |     |
| 15.7    |                  | ons                                                             |     |
| 10.0    | oudiic           |                                                                 |     |
| CHAPTER | 16 3-            | -WIRE VARIABLE-LENGTH SERIAL I/O (CSIB)                         | 508 |
| 16.1    | Mode             | Switching of CSIB and Other Serial Interfaces                   | 508 |
| -       | 16.1.1           | CSIB4 and UARTA0 mode switching                                 |     |
|         | 16.1.2           | CSIB0 and I <sup>2</sup> C01 mode switching                     |     |
| 16.2    | Featu            | res                                                             |     |
| 16.3    |                  | guration                                                        |     |
| 16.4    | Regist           | ters                                                            | 513 |
| 16.5    | Opera            | tion                                                            | 520 |
|         | 16.5.1           | Single transfer mode (master mode, transmission/reception mode) | 520 |
|         | 16.5.2           | Single transfer mode (master mode, reception mode)              | 521 |
|         | 16.5.3           | Continuous mode (master mode, transmission/reception mode)      | 522 |
|         | 16.5.4           | Continuous mode (master mode, reception mode)                   | 523 |
|         | 16.5.5           | Continuous reception mode (error)                               | 524 |
|         | 16.5.6           | Continuous mode (slave mode, transmission/reception mode)       | 525 |
|         | 16.5.7           | Continuous mode (slave mode, reception mode)                    | 526 |
|         | 16.5.8           | Clock timing                                                    | 527 |
| 16.6    | Outpu            | ıt Pins                                                         | 529 |
| 16.7    | Opera            | tion Flow                                                       | 530 |
| 16.8    | Baud             | Rate Generator                                                  | 536 |
|         | 16.8.1           | Baud rate generation                                            | 537 |
| 16.0    | Cautio           | one                                                             | 538 |

| CHAPTER | 17 l²(                | BUS                                                                              | 539 |
|---------|-----------------------|----------------------------------------------------------------------------------|-----|
| 17.1    | Mode:                 | Switching of I <sup>2</sup> C Bus and Other Serial Interfaces                    | 539 |
|         | 17.1.1                | UARTA2 and I <sup>2</sup> C00 mode switching                                     |     |
|         | 17.1.2                | CSIB0 and I <sup>2</sup> C01 mode switching                                      |     |
|         | 17.1.3                | UARTA1 and I <sup>2</sup> C02 mode switching                                     |     |
| 17.2    | Featur                | es                                                                               |     |
| 17.3    | Config                | juration                                                                         | 543 |
| 17.4    | Regist                | ers                                                                              | 547 |
| 17.5    | I <sup>2</sup> C Bu   | s Mode Functions                                                                 | 563 |
|         | 17.5.1                | Pin configuration                                                                | 563 |
| 17.6    | I <sup>2</sup> C Bu   | s Definitions and Control Methods                                                | 564 |
|         | 17.6.1                | Start condition                                                                  | 564 |
|         | 17.6.2                | Addresses                                                                        | 565 |
|         | 17.6.3                | Transfer direction specification                                                 | 566 |
|         | 17.6.4                | ACK                                                                              | 567 |
|         | 17.6.5                | Stop condition                                                                   | 568 |
|         | 17.6.6                | Wait state                                                                       | 569 |
|         | 17.6.7                | Wait state cancellation method                                                   | 571 |
| 17.7    | I <sup>2</sup> C Inte | errupt Request Signals (INTIICn)                                                 | 572 |
|         | 17.7.1                | Master device operation                                                          | 572 |
|         | 17.7.2                | Slave device operation (when receiving slave address data (address match))       | 575 |
|         | 17.7.3                | Slave device operation (when receiving extension code)                           |     |
|         | 17.7.4                | Operation without communication                                                  |     |
|         | 17.7.5                | Arbitration loss operation (operation as slave after arbitration loss)           | 583 |
|         | 17.7.6                | Operation when arbitration loss occurs (no communication after arbitration loss) |     |
| 17.8    |                       | pt Request Signal (INTIICn) Generation Timing and Wait Control                   |     |
| 17.9    |                       | ss Match Detection Method                                                        |     |
|         |                       | Detection                                                                        |     |
|         |                       | sion Code                                                                        |     |
|         |                       | ation                                                                            |     |
|         |                       | up Function                                                                      |     |
| 17.14   |                       | unication Reservation                                                            |     |
|         |                       | When communication reservation function is enabled (IICFn.IICRSVn bit = 0)       |     |
| 4-4-    |                       | When communication reservation function is disabled (IICFn.IICRSVn bit = 1)      |     |
|         |                       | ns                                                                               |     |
| 17.16   |                       | unication Operations                                                             |     |
|         |                       | Master operation 1                                                               |     |
|         |                       | Master operation 2                                                               |     |
| 17 17   |                       | Slave operation                                                                  |     |
| 17.17   | ıımınç                | g of Data Communication                                                          |     |
| CHAPTER | 18 IE                 | Bus CONTROLLER                                                                   | 615 |
| 18.1    | Functi                | ons                                                                              | 615 |
|         | 18.1.1                | Communication protocol of IEBus                                                  |     |
|         | 18.1.2                | Determination of bus mastership (arbitration)                                    |     |
|         | 18.1.3                | Communication mode                                                               |     |
|         | 18.1.4                | Communication address                                                            |     |

|         | 18.1.5  | Broadcast communication                                              | 617 |
|---------|---------|----------------------------------------------------------------------|-----|
|         | 18.1.6  | Transfer format of IEBus                                             | 617 |
|         | 18.1.7  | Transfer data                                                        | 627 |
|         | 18.1.8  | Bit format                                                           | 629 |
| 18.2    | Config  | guration                                                             | 630 |
| 18.3    | Regist  | ters                                                                 | 632 |
| 18.4    | Interru | upt Operations of IEBus Controller                                   | 662 |
|         | 18.4.1  | Interrupt control block                                              | 662 |
|         | 18.4.2  | Example of identifying interrupt                                     | 664 |
|         | 18.4.3  | Interrupt source list                                                | 667 |
|         | 18.4.4  | Communication error source processing list                           |     |
| 18.5    | Interru | upt Request Signal Generation Timing and Main CPU Processing         | 670 |
|         | 18.5.1  | Master transmission                                                  | 670 |
|         | 18.5.2  | Master reception                                                     | 672 |
|         | 18.5.3  | Slave transmission                                                   | 674 |
|         | 18.5.4  | Slave reception                                                      | 676 |
|         | 18.5.5  | Interval of occurrence of interrupt request signal for IEBus control | 678 |
| CHAPTER | 19 C    | AN CONTROLLER                                                        | 682 |
|         |         |                                                                      |     |
| 19.1    | Overv   | iew                                                                  |     |
|         | 19.1.1  | Features                                                             |     |
|         | 19.1.2  | Overview of functions                                                |     |
|         | 19.1.3  | Configuration                                                        |     |
| 19.2    | CAN F   | Protocol                                                             |     |
|         | 19.2.1  | Frame format                                                         |     |
|         | 19.2.2  | Frame types                                                          | 686 |
|         | 19.2.3  | Data frame and remote frame                                          |     |
|         | 19.2.4  | Error frame                                                          |     |
|         | 19.2.5  | Overload frame                                                       |     |
| 19.3    | Functi  | ions                                                                 |     |
|         | 19.3.1  | Determining bus priority                                             |     |
|         | 19.3.2  | Bit stuffing                                                         | 695 |
|         | 19.3.3  | Multi masters                                                        |     |
|         | 19.3.4  | Multi cast                                                           |     |
|         | 19.3.5  | CAN sleep mode/CAN stop mode function                                |     |
|         | 19.3.6  | Error control function                                               |     |
|         | 19.3.7  | Baud rate control function                                           |     |
| 19.4    |         | ection with Target System                                            |     |
| 19.5    | Intern  | al Registers of CAN Controller                                       |     |
|         | 19.5.1  | CAN controller configuration                                         |     |
|         | 19.5.2  | Register access type                                                 |     |
|         | 19.5.3  | Register bit configuration                                           |     |
| 19.6    | •       | ters                                                                 |     |
| 19.7    |         | t/Clear Function                                                     |     |
| 19.8    | CAN     | Controller Initialization                                            |     |
|         | 19.8.1  | Initialization of CAN module                                         |     |
|         | 19.8.2  | Initialization of message buffer                                     | 76⊿ |

|         | 19.8.3 Redefinition of message buffer                                              | 764 |
|---------|------------------------------------------------------------------------------------|-----|
|         | 19.8.4 Transition from initialization mode to operation mode                       | 766 |
|         | 19.8.5 Resetting error counter C0ERC of CAN module                                 | 766 |
| 19.9    | Message Reception                                                                  | 767 |
|         | 19.9.1 Message reception                                                           | 767 |
|         | 19.9.2 Receive history list function                                               | 768 |
|         | 19.9.3 Mask function                                                               | 770 |
|         | 19.9.4 Multi buffer receive block function                                         | 772 |
|         | 19.9.5 Remote frame reception                                                      | 773 |
| 19.10   | Message Transmission                                                               |     |
|         | 19.10.1 Message transmission                                                       | 774 |
|         | 19.10.2 Transmit history list function                                             |     |
|         | 19.10.3 Automatic block transmission (ABT)                                         |     |
|         | 19.10.4 Transmission abort process                                                 |     |
|         | 19.10.5 Remote frame transmission                                                  |     |
| 19.11   | Power Saving Modes                                                                 |     |
|         | 19.11.1 CAN sleep mode                                                             |     |
|         | 19.11.2 CAN stop mode                                                              |     |
|         | 19.11.3 Example of using power saving modes                                        |     |
|         | Interrupt Function                                                                 |     |
| 19.13   | Diagnosis Functions and Special Operational Modes                                  |     |
|         | 19.13.1 Receive-only mode                                                          |     |
|         | 19.13.2 Single-shot mode                                                           |     |
| 40.44   | 19.13.3 Self-test mode                                                             |     |
| 19.14   | Time Stamp Function                                                                |     |
| 10.15   | 19.14.1 Time stamp function                                                        |     |
| 19.15   | Baud Rate Settings                                                                 |     |
|         | 19.15.1 Baud rate setting conditions                                               |     |
| 10.16   | 19.15.2 Representative examples of baud rate settings  Operation of CAN Controller |     |
| 19.16   | Operation of CAN Controller                                                        | 799 |
| CHAPTER | 20 DMA FUNCTION (DMA CONTROLLER)                                                   | 824 |
| 20.1    | Features                                                                           | 824 |
| 20.2    | Configuration                                                                      | 825 |
| 20.3    | Registers                                                                          | 826 |
| 20.4    | Transfer Targets                                                                   | 833 |
| 20.5    | Transfer Modes                                                                     | 833 |
| 20.6    | Transfer Types                                                                     | 834 |
| 20.7    | DMA Channel Priorities                                                             | 835 |
| 20.8    | Time Related to DMA Transfer                                                       | 835 |
| 20.9    | DMA Transfer Start Factors                                                         | 836 |
| 20.10   | DMA Abort Factors                                                                  | 837 |
|         | End of DMA Transfer                                                                |     |
|         | Operation Timing                                                                   |     |
| 20.13   | Cautions                                                                           | 842 |
| CHAPTER | 21 CRC FUNCTION                                                                    |     |
|         |                                                                                    |     |

|    | 21.1  | Functions                                                      | 847 |
|----|-------|----------------------------------------------------------------|-----|
|    | 21.2  | Configuration                                                  | 847 |
|    | 21.3  | Registers                                                      |     |
|    | 21.4  | Operation                                                      | 849 |
|    | 21.5  | Usage                                                          | 850 |
|    |       |                                                                |     |
| CH | APTER | 22 INTERRUPT/EXCEPTION PROCESSING FUNCTION                     | 852 |
|    | 22.1  | Features                                                       | 852 |
|    | 22.1  | Non-Maskable Interrupts                                        |     |
|    |       | 22.2.1 Operation                                               |     |
|    |       | 22.2.2 Restore                                                 |     |
|    |       | 22.2.3 NP flag                                                 |     |
|    | 22.3  | Maskable Interrupts                                            |     |
|    |       | 22.3.1 Operation                                               |     |
|    |       | 22.3.2 Restore                                                 |     |
|    |       | 22.3.3 Priorities of maskable interrupts                       |     |
|    |       | 22.3.4 Interrupt control register (xxICn)                      |     |
|    |       | 22.3.5 Interrupt mask registers 0 to 3 (IMR0 to IMR3)          |     |
|    |       | 22.3.6 In-service priority register (ISPR)                     |     |
|    |       | 22.3.7 ID flag                                                 |     |
|    |       | 22.3.8 Watchdog timer mode register 2 (WDTM2)                  |     |
|    | 22.4  | Software Exception                                             |     |
|    |       | 22.4.1 Operation                                               |     |
|    |       | 22.4.2 Restore                                                 |     |
|    |       | 22.4.3 EP flag                                                 |     |
|    | 22.5  | Exception Trap                                                 |     |
|    |       | 22.5.1 Illegal opcode definition                               |     |
|    |       | 22.5.2 Debug trap                                              |     |
|    | 22.6  | External Interrupt Request Input Pins (NMI and INTP0 to INTP7) |     |
|    | ,     | 22.6.1 Noise elimination                                       |     |
|    |       | 22.6.2 Edge detection                                          |     |
|    | 22.7  | Interrupt Acknowledge Time of CPU                              |     |
|    | 22.8  | Periods in Which Interrupts Are Not Acknowledged by CPU        |     |
|    | 22.9  | Cautions                                                       |     |
|    | ,     |                                                                |     |
| СН | APTER | 23 KEY INTERRUPT FUNCTION                                      | 888 |
|    |       |                                                                |     |
|    | 23.1  | Function                                                       | 888 |
|    | 23.2  | Register                                                       | 889 |
|    | 23.3  | Cautions                                                       | 889 |
|    |       |                                                                |     |
| CH | APTER | 24 STANDBY FUNCTION                                            | 890 |
|    | 044   | Overview                                                       | 000 |
|    | 24.1  | Overview                                                       |     |
|    | 24.2  | Registers                                                      |     |
|    | 24.3  | HALT Mode                                                      |     |
|    |       | 24.3.1 Setting and operation status                            |     |
|    |       | 24.3.2 Releasing HALT mode                                     | 895 |

|          | 24.4             | IDLE1    | Mode                                                             | 897 |
|----------|------------------|----------|------------------------------------------------------------------|-----|
|          |                  | 24.4.1   | Setting and operation status                                     | 897 |
|          |                  | 24.4.2   | Releasing IDLE1 mode                                             | 897 |
|          | 24.5             | IDLE2    | Mode                                                             | 899 |
|          |                  | 24.5.1   | Setting and operation status                                     | 899 |
|          |                  | 24.5.2   | Releasing IDLE2 mode                                             | 899 |
|          |                  | 24.5.3   | Securing setup time when releasing IDLE2 mode                    | 901 |
|          | 24.6             | STOP     | Mode                                                             | 902 |
|          |                  | 24.6.1   | Setting and operation status                                     | 902 |
|          |                  | 24.6.2   | Releasing STOP mode                                              | 902 |
|          |                  | 24.6.3   | Securing oscillation stabilization time when releasing STOP mode | 905 |
|          | 24.7             | Subclo   | ock Operation Mode                                               | 906 |
|          |                  | 24.7.1   | Setting and operation status                                     | 906 |
|          |                  | 24.7.2   | Releasing subclock operation mode                                | 906 |
|          | 24.8             | Sub-ID   | DLE Mode                                                         |     |
|          |                  | 24.8.1   | Setting and operation status                                     | 908 |
|          |                  | 24.8.2   | Releasing sub-IDLE mode                                          |     |
|          |                  |          | 3                                                                |     |
| СН       | APTER            | 25 RE    | ESET FUNCTIONS                                                   | 910 |
|          |                  |          |                                                                  |     |
|          | 25.1             | Overvi   | ew                                                               | 910 |
|          | 25.2             | •        | ers to Check Reset Source                                        |     |
|          | 25.3             | Operat   | tion                                                             | 912 |
|          |                  | 25.3.1   | Reset operation via RESET pin                                    | 912 |
|          |                  | 25.3.2   | Reset operation by watchdog timer 2                              | 914 |
|          |                  | 25.3.3   | Operation after reset release                                    | 916 |
|          |                  | 25.3.4   | Reset function operation flow                                    | 918 |
|          | 25.4             | Valid/li | nvalid of Internal RAM Data                                      | 919 |
|          |                  | 25.4.1   | RAM retention voltage detection operation                        | 920 |
|          |                  | 25.4.2   | Emulation function                                               | 921 |
|          |                  |          |                                                                  |     |
| CH       | APTER            | 26 CI    | LOCK MONITOR                                                     | 922 |
|          |                  |          |                                                                  |     |
|          | 26.1             |          | ons                                                              |     |
|          | 26.2             | •        | juration                                                         |     |
|          | 26.3             | _        | er                                                               |     |
|          | 26.4             | Operat   | tion                                                             | 924 |
| <b>~</b> | A DTED           | 07 DI    | FOUL ATOR                                                        | 007 |
| СН       | APIER            | 2/ Rt    | EGULATOR                                                         | 927 |
|          | 27.1             | Outline  | e                                                                | 927 |
|          | 27.1             |          | tion                                                             |     |
|          | 21.2             | Operai   |                                                                  | 920 |
| СН       | ΔPTFR            | 28 R(    | OM CORRECTION FUNCTION                                           | 929 |
| J. 1/    | -u 1 <b>-</b> 11 | 20 110   | O                                                                | 929 |
|          | 28.1             | Overvi   | ew                                                               | 929 |
|          | 28.2             |          | ers                                                              |     |
|          | 28.3             | •        | Correction Operation and Program Flow                            |     |
|          |                  |          | ons                                                              |     |
|          |                  |          |                                                                  |     |

| CHAPTER    | 29 FLASH MEMORY                                   | 934  |
|------------|---------------------------------------------------|------|
| 29.1       | Features                                          | 934  |
| 29.2       | Memory Configuration                              | 935  |
| 29.3       | Functional Outline                                | 936  |
| 29.4       | Rewriting by Dedicated Flash Programmer           | 938  |
|            | 29.4.1 Programming environment                    | 938  |
|            | 29.4.2 Communication mode                         | 939  |
|            | 29.4.3 Flash memory control                       | 945  |
|            | 29.4.4 Selection of communication mode            | 946  |
|            | 29.4.5 Communication commands                     | 947  |
|            | 29.4.6 Pin connection                             | 948  |
| 29.5       | Rewriting by Self Programming                     | 953  |
|            | 29.5.1 Overview                                   | 953  |
|            | 29.5.2 Features                                   | 954  |
|            | 29.5.3 Standard self programming flow             | 955  |
|            | 29.5.4 Flash functions                            | 956  |
|            | 29.5.5 Pin processing                             | 956  |
|            | 29.5.6 Internal resources used                    | 957  |
|            |                                                   |      |
| CHAPTER    | 30 ON-CHIP DEBUG FUNCTION                         | 958  |
|            |                                                   |      |
| 30.1       | Features                                          |      |
| 30.2       | Connection Circuit Example                        |      |
| 30.3       | Interface Signals                                 |      |
| 30.4       | Register                                          |      |
| 30.5       | Operation                                         |      |
| 30.6       | ROM Security Function                             |      |
|            | 30.6.1 Security ID                                |      |
|            | 30.6.2 Setting                                    |      |
| 30.7       | Cautions                                          | 967  |
| OUADTED    | Of ELECTRICAL OREGISIONS (TARGET)                 | 000  |
| CHAPTER    | 31 ELECTRICAL SPECIFICATIONS (TARGET)             | 968  |
|            |                                                   |      |
| CHAPTER    | 32 PACKAGE DRAWING                                | 1003 |
| OHAI ILII  | OZ TAORAC DIAWING                                 |      |
|            |                                                   |      |
| CHAPTER    | 33 RECOMMENDED SOLDERING CONDITIONS               | 1004 |
|            |                                                   |      |
|            |                                                   |      |
| APPENDI)   | ( A DEVELOPMENT TOOLS                             | 1005 |
| A -3       | Ooffware Backs as                                 |      |
| A.1        | Software Package                                  |      |
| A.2        | Language Processing Software                      |      |
| A.3        | Control Software                                  |      |
| <b>A.4</b> | Debugging Tools (Hardware)                        |      |
|            | A.4.1 When using in-circuit emulator IE-V850ES-G1 |      |
| <b>-</b> = | A.4.2 When using IECUBE QB-V850ESSX2              |      |
| A.5        | Debugging Tools (Software)                        | 1013 |

| A.6         | Embedded Software                       | 1014 |
|-------------|-----------------------------------------|------|
| <b>A</b> .7 | Flash Memory Writing Tools              | 1014 |
| APPENDI     | X B REGISTER INDEX                      | 1015 |
| APPENDI     | X C INSTRUCTION SET LIST                | 1027 |
| C.1         | Conventions                             | 1027 |
| C.2         | Instruction Set (in Alphabetical Order) | 1030 |

#### **CHAPTER 1 INTRODUCTION**

The V850ES/SG2 is one of the products in the NEC Electronics V850 Series of single-chip microcontrollers designed for low-power operation for real-time control applications.

This manual describes the following V850ES/SG2 products operating at 32 MHz.

μPD703262HY, 703263HY, 70F3263HY, 703272HY, 703273HY, 70F3273HY, 703282HY, 703283HY, 70F3283HY

#### 1.1 General

The V850ES/SG2 is a 32-bit single-chip microcontroller that includes the V850ES CPU core and peripheral functions such as ROM/RAM, a timer/counter, serial interfaces, an A/D converter, and a D/A converter. Some models of the V850ES/SG2 are provided with IEBus<sup>TM</sup> (Inter Equipment Bus<sup>TM</sup>) or CAN (Controller Area Network) as an automotive LAN.

In addition to high real-time response characteristics and 1-clock-pitch basic instructions, the V850ES/SG2 features multiply instructions, saturated operation instructions, bit manipulation instructions, etc., realized by a hardware multiplier, as optimum instructions for digital servo control applications. Moreover, as a real-time control system, the V850ES/SG2 enables an extremely high cost-performance for applications that require a low power consumption, such as audio and car audio.

Table 1-1 lists the products of the V850ES/SG2.

A model of the V850ES/SG2 with expanded I/O, timer/counter, and serial interface functions, V850ES/SJ2, is also available. See **Table 1-2 V850ES/SJ2 Product List**.

Table 1-1. V850ES/SG2 Product List

| Function         | RC     | OM     | RAM   | Operating                             | I <sup>2</sup> C | IEBus   | CAN     | Maskable | Interrupts | Non-maskable |
|------------------|--------|--------|-------|---------------------------------------|------------------|---------|---------|----------|------------|--------------|
|                  | Туре   | Size   | Size  | Frequency                             |                  |         |         | External | Internal   | Interrupts   |
| Part Number      |        |        |       | (MAX.)                                |                  |         |         |          |            |              |
| μPD703260        | Mask   | 256 KB | 24 KB | 20 MHz                                | None             | None    | None    | 8        | 47         | 2            |
| μPD703260Y       | ROM    |        |       |                                       | On-chip          |         |         |          |            |              |
| μPD703261        |        | 384 KB | 32 KB |                                       | None             |         |         |          |            |              |
| μPD703261Y       |        |        |       |                                       | On-chip          |         |         |          |            |              |
| μPD70F3261       | Flash  |        |       |                                       | None             |         |         |          |            |              |
| μPD70F3261Y      | memory |        |       |                                       | On-chip          |         |         |          |            |              |
| μPD703262        | Mask   | 512 KB | 40 KB |                                       | None             |         |         |          |            |              |
| μPD703262Y       | ROM    |        |       |                                       | On-chip          |         |         |          |            |              |
| μPD703262HY      |        |        |       | 32 MHz                                |                  |         |         |          | 46         |              |
| μPD703263        |        | 640 KB | 48 KB | 20 MHz                                | None             |         |         |          | 47         |              |
| $\mu$ PD703263Y  |        |        |       |                                       | On-chip          |         |         |          |            |              |
| μPD703263HY      |        |        |       | 32 MHz                                |                  |         |         |          | 46         |              |
| μPD70F3263       | Flash  |        |       | 20 MHz                                | None             |         |         |          | 47         |              |
| μPD70F3263Y      | memory |        |       |                                       | On-chip          |         |         |          |            |              |
| μPD70F3263HY     |        |        |       | 32 MHz                                |                  |         |         |          | 46         | ]            |
| μPD703270        | Mask   | 256 KB | 24 KB | 20 MHz                                | None             | On-chip |         |          | 51         | ]            |
| μPD703270Y       | ROM    |        |       |                                       | On-chip          | 1       |         |          |            |              |
| μPD703271        | 1      | 384 KB | 32 KB |                                       | None             | 1       |         |          |            |              |
| μPD703271Y       | 1      |        |       |                                       | On-chip          | 1       |         |          |            |              |
| μPD70F3271       | Flash  |        |       |                                       | None             | 1       |         |          |            |              |
| μPD70F3271Y      | memory |        |       |                                       | On-chip          |         |         |          |            |              |
| μPD703272        | Mask   | 512 KB | 40 KB |                                       | None             |         |         |          |            |              |
| μPD703272Y       | ROM    |        |       |                                       | On-chip          |         |         |          |            |              |
| μPD703272HY      | 1      |        |       | 32 MHz                                |                  |         |         |          | 50         |              |
| μPD703273        | 1      | 640 KB | 48 KB | 20 MHz                                | None             | 1       |         |          | 51         |              |
| μPD703273Y       | 1      |        |       |                                       | On-chip          | 1       |         |          |            |              |
| μPD703273HY      | 1      |        |       | 32 MHz                                |                  |         |         |          | 50         |              |
| μPD70F3273       | Flash  |        |       | 20 MHz                                | None             | 1       |         |          | 51         |              |
| μPD70F3273Y      | memory |        |       |                                       | On-chip          |         |         |          |            |              |
| μPD70F3273HY     | 1      |        |       | 32 MHz                                | 1                |         |         |          | 50         | 1            |
| μPD703280        | Mask   | 256 KB | 24 KB | 20 MHz                                | None             | None    | On-chip |          | 51         | 1            |
| μPD703280Y       | ROM    |        |       |                                       | On-chip          | 1       | •       |          |            |              |
| μPD703281        | 1      | 384 KB | 32 KB |                                       | None             | 1       |         |          |            |              |
| μPD703281Y       | 1      |        |       |                                       | On-chip          | 1       |         |          |            |              |
| μPD70F3281       | Flash  |        |       |                                       | None             | 1       |         |          |            |              |
| μPD70F3281Y      | memory |        |       |                                       | On-chip          | 1       |         |          |            |              |
| μPD703282        | Mask   | 512 KB | 40 KB |                                       | None             | 1       |         |          |            |              |
| μPD703282Y       | ROM    |        |       |                                       | On-chip          | 1       |         |          |            |              |
| μPD703282HY      | 1      |        |       | 32 MHz                                | 1                |         |         |          | 50         |              |
| μPD703283        | 1      | 640 KB | 48 KB | 20 MHz                                | None             | 1       |         |          | 51         |              |
| μPD703283Y       | 1      |        |       |                                       | On-chip          | 1       |         |          |            |              |
| μPD703283HY      | 1      |        |       | 32 MHz                                | 1                |         |         |          | 50         | 1            |
| μPD70F3283       | Flash  |        |       | 20 MHz                                | None             | 1       |         |          | 51         | 1            |
| μPD70F3283Y      | memory |        |       | , , , , , , , , , , , , , , , , , , , | On-chip          | 1       |         |          |            |              |
| μPD70F3283HY     | 1      |        |       | 32 MHz                                | 1                |         |         |          | 50         | 1            |
| r = . 3. 0=30111 | 1      |        |       |                                       | 1                | 1       |         |          |            | 1            |

**Remark** The part numbers of the V850ES/SG2 are shown as follows in this manual.

- Mask ROM version
  - μΡD703260, 703260Y, 703261, 703261Y, 703262, 703262Y, **703262HY**, 703263, 703263Y, **703263HY**, 703270, 703270Y, 703271, 703271Y, 703272, 703272Y, **703272HY**, 703273, 703273Y, **703273HY**, 703280, 703280Y, 703281Y, 703282, 703282Y, **703282HY**, 703283, 703283Y, **703283HY**
- Flash memory version  $\mu$ PD70F3261, 70F3261Y, 70F3263, 70F3263Y, **70F3263HY**, 70F3271, 70F3271Y, 70F3273, 70F3273Y, **70F3273HY**, 70F3281, 70F3281Y, 70F3283, 70F3283HY
- l²C bus version (Y version): All V850ES/SG2 products operating at 32 MHz have an on-chip l²C bus.
   μPD703260Y, 703261Y, 703262Y, 703262HY, 703263Y, 703263HY, 703270Y, 703271Y, 703272Y, 703272HY,
   703273HY, 703280Y, 703281Y, 703282Y, 703282HY, 703283Y, 7053283HY, 70F3261Y, 70F3263Y,
   70F3263HY, 70F3271Y, 70F3273HY, 70F3281Y, 70F3283Y, 70F3283HY
- General-purpose version
   μPD703260, 703260Y, 703261, 703261Y, 703262, 703262Y, 703262Y, 703263HY, 7053261Y, 70F3263Y, 70F3263Y, 70F3263HY
- IEBus controller version  $\mu$ PD703270, 703270Y, 703271, 703271Y, 703272, 703272Y, **703272HY**, 703273, 703273Y, **703273HY**, 70F3271, 70F3271Y, 70F3273Y, **70F3273HY**
- CAN controller version  $\mu$ PD703280, 703280Y, 703281, 703281Y, 703282, 703282Y, **703282HY**, 703283, 703283Y, **703283HY**, 70F3281Y, 70F3283Y, **70F3283HY**

This manual describes the products in bold and underlined.

For details on the other products, refer to the V850ES/SG2 Hardware User's Manual (U16541E).

Table 1-2. V850ES/SJ2 Product List

| Function     | RON      | 1      | RAM   | Operating        | I <sup>2</sup> C | IEBus   | CAN  | Maskable | Interrupts | Non-Maskable |
|--------------|----------|--------|-------|------------------|------------------|---------|------|----------|------------|--------------|
| Part Number  | Type     | Size   | Size  | Frequency (MAX.) |                  |         |      | External | Internal   | Interrupts   |
| μPD703264    | Mask ROM | 384 KB | 32 KB | 20 MHz           | None             | None    | None | 9        | 60         | 2            |
| μPD703264Y   |          |        |       |                  | On-chip          |         |      |          |            |              |
| μPD70F3264   | Flash    |        |       |                  | None             |         |      |          |            |              |
| μPD70F3264Y  | memory   |        |       |                  | On-chip          |         |      |          |            |              |
| μPD703265    | Mask ROM | 512 KB | 40 KB |                  | None             |         |      |          |            |              |
| μPD703265Y   |          |        |       |                  | On-chip          |         |      |          |            |              |
| μPD703265HY  |          |        |       | 32 MHz           |                  |         |      |          | 59         |              |
| μPD703266    |          | 640 KB | 48 KB | 20 MHz           | None             |         |      |          | 60         |              |
| μPD703266Y   |          |        |       |                  | On-chip          |         |      |          |            |              |
| μPD703266HY  |          |        |       | 32 MHz           |                  |         |      |          | 59         |              |
| μPD70F3266   | Flash    |        |       | 20 MHz           | None             |         |      |          | 60         |              |
| μPD70F3266Y  | memory   |        |       |                  | On-chip          |         |      |          |            |              |
| μPD70F3266HY |          |        |       | 32 MHz           |                  |         |      |          | 59         |              |
| μPD703274    | Mask ROM | 384 KB | 32 KB | 20 MHz           | None             | On-chip |      |          | 64         |              |
| μPD703274Y   |          |        |       |                  | On-chip          | ]       |      |          |            |              |
| μPD70F3274   | Flash    |        |       |                  | None             |         |      |          |            |              |
| μPD70F3274Y  | memory   |        |       |                  | On-chip          |         |      |          |            |              |
| μPD703275    | Mask ROM | 512 KB | 40 KB |                  | None             |         |      |          |            |              |
| μPD703275Y   |          |        |       |                  | On-chip          |         |      |          |            |              |
| μPD703275HY  |          |        |       | 32 MHz           |                  |         |      |          | 63         |              |
| μPD703276    |          | 640 KB | 48 KB | 20 MHz           | None             |         |      |          | 64         |              |
| μPD703276Y   |          |        |       |                  | On-chip          |         |      |          |            |              |
| μPD703276HY  |          |        |       | 32 MHz           |                  |         |      |          | 63         |              |
| μPD70F3276   | Flash    |        |       | 20 MHz           | None             |         |      |          | 64         |              |
| μPD70F3276Y  | memory   |        |       |                  | On-chip          |         |      |          |            |              |
| μPD70F3276HY |          |        |       | 32 MHz           |                  |         |      |          | 63         |              |
| μPD703284    | Mask ROM | 384 KB | 32 KB | 20 MHz           | None             | None    | 1 ch |          | 64         |              |
| μPD703284Y   |          |        |       |                  | On-chip          |         |      |          |            |              |
| μPD70F3284   | Flash    |        |       |                  | None             |         |      |          |            |              |
| μPD70F3284Y  | memory   |        |       |                  | On-chip          |         |      |          |            |              |
| μPD703285    | Mask ROM | 512 KB | 40 KB |                  | None             |         |      |          |            |              |
| μPD703285Y   |          |        |       |                  | On-chip          |         |      |          |            |              |
| μPD703285HY  |          |        |       | 32 MHz           |                  |         |      |          | 63         |              |
| μPD703286    |          | 640 KB | 48 KB | 20 MHz           | None             |         |      |          | 64         |              |
| μPD703286Y   |          |        |       |                  | On-chip          | ]       |      |          |            |              |
| μPD703286HY  |          |        |       | 32 MHz           |                  |         |      |          | 63         |              |
| μPD70F3286   | Flash    |        |       | 20 MHz           | None             |         |      |          | 64         |              |
| μPD70F3286Y  | memory   |        |       |                  | On-chip          | ]       |      |          |            |              |
| μPD70F3286HY |          |        |       | 32 MHz           |                  |         |      |          | 63         |              |
| μPD703287    | Mask ROM | 512 KB | 40 KB | 20 MHz           | None             |         | 2 ch | ]        | 68         |              |
| μPD703287Y   |          |        |       |                  | On-chip          | ]       |      |          |            |              |
| μPD703287HY  |          |        |       | 32 MHz           |                  |         |      |          | 67         |              |
| μPD703288    |          | 640 KB | 48 KB | 20 MHz           | None             | ]       |      |          | 68         |              |
| μPD703288Y   |          |        |       |                  | On-chip          | 1       |      |          |            |              |
| μPD703288HY  |          |        |       | 32 MHz           |                  |         |      |          | 67         |              |
| μPD70F3288   | Flash    |        |       | 20 MHz           | None             | 1       |      |          | 68         |              |
| μPD70F3288Y  | memory   |        |       |                  | On-chip          | 1       |      |          |            |              |
| μPD70F3286HY |          |        |       | 32 MHz           |                  |         |      |          | 67         |              |

#### 1.2 Features

O Minimum instruction execution time: 31.25 ns (operating with main clock (fxx) of 32 MHz)

O General-purpose registers: 32 bits  $\times$  32 registers

O CPU features: Signed multiplication (16  $\times$  16  $\rightarrow$  32): 1 to 2 clocks

Signed multiplication (32  $\times$  32  $\rightarrow$  64): 1 to 5 clocks

Saturated operations (overflow and underflow detection functions included)

32-bit shift instruction: 1 clock Bit manipulation instructions

Load/store instructions with long/short format

O Memory space: 64 MB of linear address space (for programs and data)

External expansion: Up to 16 MB (including 1 MB used as internal ROM/RAM)

• Internal memory: RAM: 40/48 KB (see **Table 1-1**)

Mask ROM: 512/640 KB (see **Table 1-1**)
Flash memory: 640 KB (see **Table 1-1**)

• External bus interface: Separate bus/multiplexed bus output selectable

8/16 bit data bus sizing function

Wait function

Programmable wait function
External wait function
Idle state function

Bus hold function

O Interrupts and exceptions: Non-maskable interrupts: 2 sources

Maskable interrupts: 54/58 sources (see **Table 1-1**)

Software exceptions: 32 sources Exception trap: 2 sources

O I/O lines: I/O ports: 84

O Timer function: 16-bit interval timer M (TMM): 1 channel

16-bit timer/event counter P (TMP): 6 channels16-bit timer/event counter Q (TMQ): 1 channel

Watch timer: 1 channel Watchdog timer: 1 channel

O Real-time output port: 6 bits  $\times$  1 channel

O Serial interface: Asynchronous serial interface A (UARTA)

3-wire variable-length serial interface B (CSIB)

I<sup>2</sup>C bus interface (I<sup>2</sup>C)

UARTA/CSIB: 1 channel
UARTA/I<sup>2</sup>C: 2 channels
CSIB/I<sup>2</sup>C: 1 channel
CSIB: 3 channels

O IEBus controller:
 1 channel (IEBus controller version only)
 O CAN controller:
 1 channel (CAN controller version only)

O A/D converter: 10-bit resolution: 12 channels

O DMA controller: 4 channels

O CRC function: 16-bit error detection codes are generated for data in 8-bit units

8-bit resolution: 2 channels

O On-chip debug function: JTAG interface (N-wire type) (flash memory version only)

O ROM correction: 4 correction addresses specifiable

O D/A converter:

#### **CHAPTER 1 INTRODUCTION**

O Clock generator: During main clock or subclock operation

7-level CPU clock (fxx, fxx/2, fxx/4, fxx/8, fxx/16, fxx/32, fxT)

Clock-through mode/PLL mode selectable

O Internal oscillation clock: 200 kHz (TYP.)

O Power-save functions: HALT/IDLE1/IDLE2/STOP/subclock/sub-IDLE mode

O Package: 100-pin plastic LQFP (fine pitch)  $(14 \times 14)$ 

# 1.3 Application Fields

Audio, car audio, consumer devices

# 1.4 Ordering Information

| Part Number                  | Package                                            | Internal ROM          |
|------------------------------|----------------------------------------------------|-----------------------|
| μPD703262HYGC-xxx-8EA-A      | 100-pin plastic LQFP (fine pitch) (14 $\times$ 14) | 512 KB (mask ROM)     |
| $\mu$ PD703263HYGC-xxx-8EA-A | 100-pin plastic LQFP (fine pitch) (14 $\times$ 14) | 640 KB (mask ROM)     |
| $\mu$ PD703272HYGC-xxx-8EA-A | 100-pin plastic LQFP (fine pitch) (14 $\times$ 14) | 512 KB (mask ROM)     |
| $\mu$ PD703273HYGC-xxx-8EA-A | 100-pin plastic LQFP (fine pitch) (14 $\times$ 14) | 640 KB (mask ROM)     |
| $\mu$ PD703282HYGC-xxx-8EA-A | 100-pin plastic LQFP (fine pitch) (14 $\times$ 14) | 512 KB (mask ROM)     |
| $\mu$ PD703283HYGC-xxx-8EA-A | 100-pin plastic LQFP (fine pitch) (14 $\times$ 14) | 640 KB (mask ROM)     |
| $\mu$ PD70F3263HYGC-8EA-A    | 100-pin plastic LQFP (fine pitch) (14 $\times$ 14) | 640 KB (flash memory) |
| $\mu$ PD70F3273HYGC-8EA-A    | 100-pin plastic LQFP (fine pitch) (14 $\times$ 14) | 640 KB (flash memory) |
| $\mu$ PD70F3283HYGC-8EA-A    | 100-pin plastic LQFP (fine pitch) (14 $\times$ 14) | 640 KB (flash memory) |

Remarks 1. xxx indicates ROM code suffix.

2. Products with -A at the end of the part number are lead-free products.

# 1.5 Pin Configuration (Top View)

100-pin plastic LQFP (fine pitch) ( $14 \times 14$ )

μPD703262HYGC-xxx-8EA-A μPD703272HYGC-xxx-8EA-A μPD703263HYGC-xxx-8EA-A μPD705263HYGC-8EA-A μPD70F3273HYGC-8EA-A μPD70F3273HYGC-8EA-A

μPD703282HYGC-xxx-8EA-A μPD703283HYGC-xxx-8EA-A μPD70F3283HYGC-8EA-A



#### Pin names

A0 to A21: Address bus PCM0 to PCM3: Port CM AD0 to AD15: Address/data bus PCT0, PCT1, Port CT ADTRG: A/D trigger input PCT4, PCT6: ANI0 to ANI11: Analog input PDH0 to PDH5: Port DH PDL0 to PDL15: ANO0, ANO1: Analog output Port DL RD: ASCKA0: Asynchronous serial clock Read strobe ASTB: REGC: Address strobe Regulator control AVREFO, AVREF1: Analog reference voltage RESET: Reset AVss: Analog Vss RTP00 to RTP05: Real-time output port BVDD: Power supply for bus interface RXDA0 to RXDA2: Receive data BVss: Ground for bus interface SCKB0 to SCKB4: Serial clock CLKOUT: Clock output SCL00 to SCL02: Serial clock CRXD0: CAN receive data SDA00 to SDA02: Serial data CTXD0: CAN transmit data SIB0 to SIB4: Serial input DCK: Debug clock SOB0 to SOB4: Serial output DDI: Debug data input TIP00, TIP01, DDO: Debug data output TIP10, TIP11, DMS: Debug mode select TIP20, TIP21, DRST: Debug reset TIP30, TIP31, EV<sub>DD</sub>: Power supply for port TIP40, TIP41, EVss: Ground for port TIP50, TIP51, FLMD0, FLMD1: Flash programming mode Timer input TIQ00 to TIQ03: HLDAK: Hold acknowledge TOP00, TOP01, HLDRQ: Hold request TOP10, TOP11, IC: Internally connected TOP20, TOP21, IERX0: IEBus receive data TOP30, TOP31, IETX0: IEBus transmit data TOP40, TOP41, INTP0 to INTP7: External interrupt input TOP50, TOP51, KR0 to KR7: TOQ00 to TOQ03: Key return Timer output Non-maskable interrupt request Transmit data NMI: TXDA0 to TXDA2: P02 to P06: Port 0 V<sub>DD</sub>: Power supply P10, P11: Port 1 Vss: Ground WAIT: P30 to P39: Port 3 Wait P40 to P42: Port 4 WR0: Lower byte write strobe WR1: P50 to P55: Port 5 Upper byte write strobe X1, X2: P70 to P711: Port 7 Crystal for main clock P90 to P915: Port 9 XT1, XT2: Crystal for subclock

# 1.6 Function Block Configuration

#### 1.6.1 Internal block diagram



#### 1.6.2 Internal units

# (1) CPU

The CPU uses five-stage pipeline control to enable single-clock execution of address calculations, arithmetic logic operations, data transfers, and almost all other instruction processing.

Other dedicated on-chip hardware, such as a multiplier (16 bits  $\times$  16 bits  $\rightarrow$  32 bits) and a barrel shifter (32 bits) contribute to faster complex processing.

#### (2) Bus control unit (BCU)

The BCU starts a required external bus cycle based on the physical address obtained by the CPU. When an instruction is fetched from external memory space and the CPU does not send a bus cycle start request, the BCU generates a prefetch address and prefetches the instruction code. The prefetched instruction code is stored in an instruction queue.

#### (3) ROM

This is a 640/512 KB mask ROM or flash memory mapped to addresses 0000000H to 009FFFFH/0000000H to 007FFFFH. It can be accessed from the CPU in one clock during instruction fetch.

#### (4) RAM

This is a 48/40 KB RAM mapped to addresses 3FF3000H to 3FFEFFFH/3FF5000H to 3FFEFFFH. It can be accessed from the CPU in one clock during data access.

#### (5) Interrupt controller (INTC)

This controller handles hardware interrupt requests (NMI, INTP0 to INTP7) from on-chip peripheral hardware and external hardware. Eight levels of interrupt priorities can be specified for these interrupt requests, and multiplexed servicing control can be performed.

#### (6) Clock generator (CG)

A main clock oscillator and subclock oscillator are provided and generate the main clock oscillation frequency (fx) and subclock frequency (fx), respectively. There are two modes: In the clock-through mode, fx is used as the main clock frequency (fx) as is. In the PLL mode, fx is used multiplied by 4 or 8.

The CPU clock frequency (fcpu) can be selected from among fxx, fxx/2, fxx/4, fxx/8, fxx/16, fxx/32, and fxt.

### (7) Internal oscillator

An internal oscillator is provided on chip. The oscillation frequency is 200 kHz (TYP). The internal oscillator supplies the clock for watchdog timer 2 and timer M.

# (8) Timer/counter

Six-channel 16-bit timer/event counter P (TMP), one-channel 16-bit timer/event counter Q (TMQ), and one-channel 16-bit interval timer M (TMM), are provided on chip.

### (9) Watch timer

This timer counts the reference time period (0.5 s) for counting the clock (the 32.768 kHz subclock or the 32.768 kHz clock fbrag from prescaler 3). The watch timer can also be used as an interval timer for the main clock.

#### (10) Watchdog timer 2

A watchdog timer is provided on chip to detect inadvertent program loops, system abnormalities, etc.

Either the internal oscillation clock, the main clock, or the subclock can be selected as the source clock.

Watchdog timer 2 generates a non-maskable interrupt request signal (INTWDT2) or a system reset signal (WDT2RES) after an overflow occurs.

#### (11) Serial interface

The V850ES/SG2 includes three kinds of serial interfaces: asynchronous serial interface A (UARTA), 3-wire variable-length serial interface B (CSIB), and an I<sup>2</sup>C bus interface (I<sup>2</sup>C).

In the case of UARTA, data is transferred via the TXDA0 to TXDA2 pins and RXDA0 to RXDA2 pins.

In the case of CSIB, data is transferred via the SOB0 to SOB4 pins, SIB0 to SIB4 pins, and  $\overline{\text{SCKB0}}$  to  $\overline{\text{SCKB4}}$  pins.

In the case of I<sup>2</sup>C, data is transferred via the SDA00 to SDA02 and SCL00 to SCL02 pins.

#### (12) IEBus controller

The IEBus controller is a small-scale digital data transmission system for transferring data between units.

The IEBus controller is provided only in IEBus controller versions (see Table 1-1).

#### (13) CAN controller

The CAN controller is a small-scale digital data transmission system for transferring data between units.

The CAN controller is provided only in CAN controller versions (see **Table 1-1**).

#### (14) A/D converter

This 10-bit A/D converter includes 12 analog input pins. Conversion is performed using the successive approximation method.

#### (15) D/A converter

A two-channel, 8-bit-resolution D/A converter that uses the R-2R ladder method is provided on chip.

#### (16) DMA controller

A 4-channel DMA controller is provided on chip. This controller transfers data between the internal RAM and on-chip peripheral I/O devices in response to interrupt requests sent by on-chip peripheral I/O.

#### (17) ROM correction

A ROM correction function that replaces part of a program in the mask ROM with a program in the internal RAM is provided. Up to four correction addresses can be specified.

### (18) Key interrupt function

A key interrupt request signal (INTKR) can be generated by inputting a falling edge to the key input pins (8 channels).

### (19) Real-time output function

The real-time output function transfers preset 6-bit data to output latches upon the occurrence of a timer compare register match signal.

#### (20) CRC function

A CRC operation circuit that generates 16-bit CRC (Cyclic Redundancy Check) code upon setting of 8-bit data is provided on chip.

# (21) On-chip debug function

An on-chip debug function via an N-Wire-type emulator that uses the JTAG (Joint Test Action Group) communication specifications is provided. Switching between the normal port function and on-chip debugging function is done with the control pin input level and the on-chip debug mode register (OCDM). The on-chip debug function is provided only in flash memory versions.

#### (22) Ports

The following general-purpose port functions and control pin functions are available.

| Port | I/O        | Alternate Function                                                                         |  |  |  |
|------|------------|--------------------------------------------------------------------------------------------|--|--|--|
| P0   | 5-bit I/O  | NMI, external interrupt, A/D converter trigger, debug reset                                |  |  |  |
| P1   | 2-bit I/O  | D/A converter analog output                                                                |  |  |  |
| P3   | 10-bit I/O | External interrupt, serial interface, timer I/O, CAN data I/O, IEBus data I/O              |  |  |  |
| P4   | 3-bit I/O  | Serial interface                                                                           |  |  |  |
| P5   | 6-bit I/O  | Timer I/O, real-time output, key interrupt input, serial interface                         |  |  |  |
| P7   | 12-bit I/O | A/D converter analog input                                                                 |  |  |  |
| P9   | 16-bit I/O | External address bus, serial interface, key interrupt input, timer I/O, external interrupt |  |  |  |
| PCM  | 4-bit I/O  | External control signal                                                                    |  |  |  |
| PCT  | 4-bit I/O  | External control signal                                                                    |  |  |  |
| PDH  | 6-bit I/O  | External address bus                                                                       |  |  |  |
| PDL  | 16-bit I/O | External address/data bus                                                                  |  |  |  |

# **CHAPTER 2 PIN FUNCTIONS**

#### 2.1 List of Pin Functions

The names and functions of the pins in the V850ES/SG2 are described below.

There are four types of pin I/O buffer power supplies: AVREF0, AVREF1, BVDD, and EVDD. The relationship between these power supplies and the pins is described below.

Table 2-1. Pin I/O Buffer Power Supplies

| Power Supply                                               | Corresponding Pins                 |  |
|------------------------------------------------------------|------------------------------------|--|
| AV <sub>REF0</sub>                                         | Port 7                             |  |
| AV <sub>REF1</sub>                                         | Port 1                             |  |
| BV <sub>DD</sub>                                           | Ports CM, CT, DH (bits 0 to 3), DL |  |
| EV <sub>DD</sub> RESET, ports 0, 3 to 5, 9, DH (bits 4, 5) |                                    |  |

# (1) Port pins

(1/3)

| Pin Name              | Pin No. | I/O | Function                                                                                                                            | Alternate Function                               |  |  |
|-----------------------|---------|-----|-------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|--|--|
| P02                   | 17      | I/O | Port 0                                                                                                                              | NMI                                              |  |  |
| P03                   | 18      |     |                                                                                                                                     | INTP0/ADTRG                                      |  |  |
| P04                   | 19      |     |                                                                                                                                     | INTP1                                            |  |  |
| P05 <sup>Note 1</sup> | 20      |     |                                                                                                                                     | INTP2/DRSTNote 2                                 |  |  |
| P06                   | 21      |     |                                                                                                                                     | INTP3                                            |  |  |
| P10                   | 3       | I/O | Port 1                                                                                                                              | ANO0                                             |  |  |
| P11                   | 4       |     | 2-bit I/O port Input/output can be specified in 1-bit units.                                                                        | ANO1                                             |  |  |
| P30                   | 25      | I/O | Port 3                                                                                                                              | TXDA0/SOB4                                       |  |  |
| P31                   | 26      |     | 10-bit I/O port Input/output can be specified in 1-bit units. N-ch open-drain output can be specified in 1-bit units. 5 V tolerant. | RXDA0/INTP7/SIB4                                 |  |  |
| P32                   | 27      |     |                                                                                                                                     | ASCKA0/SCKB4/TIP00/TOP00                         |  |  |
| P33                   | 28      |     |                                                                                                                                     | TIP01/TOP01                                      |  |  |
| P34                   | 29      |     |                                                                                                                                     | TIP10/TOP10                                      |  |  |
| P35                   | 30      |     |                                                                                                                                     | TIP11/TOP11                                      |  |  |
| P36                   | 31      |     |                                                                                                                                     | CTXD0 <sup>Note 3</sup> /IETX0 <sup>Note 4</sup> |  |  |
| P37                   | 32      |     |                                                                                                                                     | CRXD0 <sup>Note 3</sup> /IERX0 <sup>Note 4</sup> |  |  |
| P38                   | 35      |     |                                                                                                                                     | TXDA2/SDA00                                      |  |  |
| P39                   | 36      |     |                                                                                                                                     | RXDA2/SCL00                                      |  |  |

 $\textbf{Notes 1.} \ \ \textbf{Incorporates a pull-down resistor.} \ \ \textbf{It can be disconnected by clearing the OCDM.OCDM0 bit to 0.}$ 

- 2. Flash memory versions only
- 3. CAN controller versions only
- 4. IEBus controller versions only

(2/3)

| Pin Name | Pin No. | I/O | Function                                                                                               | Alternate Function                                 |
|----------|---------|-----|--------------------------------------------------------------------------------------------------------|----------------------------------------------------|
| P40      | 22      | I/O | Port 4                                                                                                 | SIB0/SDA01                                         |
| P41      | 23      |     | 3-bit I/O port Input/output can be specified in 1-bit units.                                           | SOB0/SCL01                                         |
| P42      | 24      |     | N-ch open-drain output can be specified in 1-bit units. 5 V tolerant.                                  | SCKB0                                              |
| P50      | 37      | I/O | Port 5                                                                                                 | TIQ01/KR0/TOQ01/RTP00                              |
| P51      | 38      |     | 6-bit I/O port                                                                                         | TIQ02/KR1/TOQ02/RTP01                              |
| P52      | 39      |     | Input/output can be specified in 1-bit units.  N-ch open-drain output can be specified in 1-bit units. | TIQ03/KR2/TOQ03/RTP02/DDI <sup>Note</sup>          |
| P53      | 40      |     | 5 V tolerant.                                                                                          | SIB2/KR3/TIQ00/TOQ00/RTP03/<br>DDO <sup>Note</sup> |
| P54      | 41      |     |                                                                                                        | SOB2/KR4/RTP04/DCK <sup>Note</sup>                 |
| P55      | 42      |     |                                                                                                        | SCKB2/KR5/RTP05/DMS <sup>Note</sup>                |
| P70      | 100     | I/O | Port 7                                                                                                 | ANI0                                               |
| P71      | 99      |     | 12-bit I/O port                                                                                        | ANI1                                               |
| P72      | 98      |     | Input/output can be specified in 1-bit units.                                                          | ANI2                                               |
| P73      | 97      |     |                                                                                                        | ANI3                                               |
| P74      | 96      |     |                                                                                                        | ANI4                                               |
| P75      | 95      |     |                                                                                                        | ANI5                                               |
| P76      | 94      |     |                                                                                                        | ANI6                                               |
| P77      | 93      |     |                                                                                                        | ANI7                                               |
| P78      | 92      |     |                                                                                                        | ANI8                                               |
| P79      | 91      |     |                                                                                                        | ANI9                                               |
| P710     | 90      |     |                                                                                                        | ANI10                                              |
| P711     | 89      |     |                                                                                                        | ANI11                                              |
| P90      | 43      | I/O | Port 9                                                                                                 | A0/KR6/TXDA1/SDA02                                 |
| P91      | 44      |     | 16-bit I/O port                                                                                        | A1/KR7/RXDA1/SCL02                                 |
| P92      | 45      |     | Input/output can be specified in 1-bit units.  N-ch open-drain output can be specified in 1-bit units. | A2/TIP41/TOP41                                     |
| P93      | 46      |     | 5 V tolerant.                                                                                          | A3/TIP40/TOP40                                     |
| P94      | 47      |     |                                                                                                        | A4/TIP31/TOP31                                     |
| P95      | 48      |     |                                                                                                        | A5/TIP30/TOP30                                     |
| P96      | 49      |     |                                                                                                        | A6/TIP21/TOP21                                     |
| P97      | 50      |     |                                                                                                        | A7/SIB1/TIP20/TOP20                                |
| P98      | 51      |     |                                                                                                        | A8/SOB1                                            |
| P99      | 52      |     |                                                                                                        | A9/SCKB1                                           |
| P910     | 53      |     |                                                                                                        | A10/SIB3                                           |
| P911     | 54      |     |                                                                                                        | A11/SOB3                                           |
| P912     | 55      |     |                                                                                                        | A12/SCKB3                                          |
| P913     | 56      |     |                                                                                                        | A13/INTP4                                          |
| P914     | 57      |     |                                                                                                        | A14/INTP5/TIP51/TOP51                              |
| P915     | 58      |     |                                                                                                        | A15/INTP6/TIP50/TOP50                              |

(3/3)

| Pin Name | Pin No. | I/O | Function                                      | Alternate Function        |
|----------|---------|-----|-----------------------------------------------|---------------------------|
| PCM0     | 61      | I/O | Port CM                                       | WAIT                      |
| PCM1     | 62      |     | 4-bit I/O port                                | CLKOUT                    |
| PCM2     | 63      |     | Input/output can be specified in 1-bit units. | HLDAK                     |
| РСМ3     | 64      |     |                                               | HLDRQ                     |
| РСТ0     | 65      | I/O | Port CT                                       | WR0                       |
| PCT1     | 66      |     | 4-bit I/O port                                | WR1                       |
| PCT4     | 67      |     | Input/output can be specified in 1-bit units. | RD                        |
| PCT6     | 68      |     |                                               | ASTB                      |
| PDH0     | 87      | I/O | Port DH                                       | A16                       |
| PDH1     | 88      |     | 6-bit I/O port                                | A17                       |
| PDH2     | 59      |     | Input/output can be specified in 1-bit units. | A18                       |
| PDH3     | 60      |     |                                               | A19                       |
| PDH4     | 6       |     |                                               | A20                       |
| PDH5     | 7       |     |                                               | A21                       |
| PDL0     | 71      | I/O | Port DL                                       | AD0                       |
| PDL1     | 72      |     | 16-bit I/O port                               | AD1                       |
| PDL2     | 73      |     | Input/output can be specified in 1-bit units. | AD2                       |
| PDL3     | 74      |     |                                               | AD3                       |
| PDL4     | 75      |     |                                               | AD4                       |
| PDL5     | 76      |     |                                               | AD5/FLMD1 <sup>Note</sup> |
| PDL6     | 77      |     |                                               | AD6                       |
| PDL7     | 78      |     |                                               | AD7                       |
| PDL8     | 79      |     |                                               | AD8                       |
| PDL9     | 80      |     |                                               | AD9                       |
| PDL10    | 81      |     |                                               | AD10                      |
| PDL11    | 82      |     |                                               | AD11                      |
| PDL12    | 83      |     |                                               | AD12                      |
| PDL13    | 84      |     |                                               | AD13                      |
| PDL14    | 85      |     |                                               | AD14                      |
| PDL15    | 86      |     |                                               | AD15                      |

# (2) Non-port pins

(1/5)

| Pin Name | Pin No. | I/O    | Function                                            | Alternate Function         |
|----------|---------|--------|-----------------------------------------------------|----------------------------|
| A0       | 43      | Output | Address bus for external memory                     | P90/KR6/TXDA1/SDA02        |
| A1       | 44      |        | (when using separate bus)                           | P91/KR7/RXDA1/SCL02        |
| A2       | 45      |        | N-ch open-drain output selectable. 5 V tolerant.    | P92/TIP41/TOP41            |
| A3       | 46      |        | o v tolorant.                                       | P93/TIP40/TOP40            |
| A4       | 47      |        |                                                     | P94/TIP31/TOP31            |
| A5       | 48      |        |                                                     | P95/TIP30/TOP30            |
| A6       | 49      |        |                                                     | P96/TIP21/TOP21            |
| A7       | 50      | ]      |                                                     | P97/SIB1/TIP20/TOP20       |
| A8       | 51      | ]      |                                                     | P98/SOB1                   |
| A9       | 52      | ]      |                                                     | P99/SCKB1                  |
| A10      | 53      | 1      |                                                     | P910/SIB3                  |
| A11      | 54      | 1      |                                                     | P911/SOB3                  |
| A12      | 55      | 1      |                                                     | P912/SCKB3                 |
| A13      | 56      |        |                                                     | P913/INTP4                 |
| A14      | 57      | 1      |                                                     | P914/INTP5/TIP51/TOP51     |
| A15      | 58      | 1      |                                                     | P915/INTP6/TIP50/TOP50     |
| A16      | 87      | Output | Address bus for external memory                     | PDH0                       |
| A17      | 88      |        |                                                     | PDH1                       |
| A18      | 59      |        |                                                     | PDH2                       |
| A19      | 60      |        |                                                     | PDH3                       |
| A20      | 6       |        |                                                     | PDH4                       |
| A21      | 7       |        |                                                     | PDH5                       |
| AD0      | 71      | I/O    | Address bus/data bus for external memory            | PDL0                       |
| AD1      | 72      |        |                                                     | PDL1                       |
| AD2      | 73      |        |                                                     | PDL2                       |
| AD3      | 74      |        |                                                     | PDL3                       |
| AD4      | 75      |        |                                                     | PDL4                       |
| AD5      | 76      | 1      |                                                     | PDL5/FLMD1 <sup>Note</sup> |
| AD6      | 77      |        |                                                     | PDL6                       |
| AD7      | 78      |        |                                                     | PDL7                       |
| AD8      | 79      |        |                                                     | PDL8                       |
| AD9      | 80      |        |                                                     | PDL9                       |
| AD10     | 81      |        |                                                     | PDL10                      |
| AD11     | 82      |        |                                                     | PDL11                      |
| AD12     | 83      |        |                                                     | PDL12                      |
| AD13     | 84      |        |                                                     | PDL13                      |
| AD14     | 85      |        |                                                     | PDL14                      |
| AD15     | 86      |        |                                                     | PDL15                      |
| ADTRG    | 18      | Input  | A/D converter external trigger input. 5 V tolerant. | P03/INTP0                  |

(2/5)

| Pin Name                 | Pin No. | I/O    | Function                                                                     | Alternate Function                 |
|--------------------------|---------|--------|------------------------------------------------------------------------------|------------------------------------|
| ANI0                     | 100     | Input  | Analog voltage input for A/D converter                                       | P70                                |
| ANI1                     | 99      |        |                                                                              | P71                                |
| ANI2                     | 98      |        |                                                                              | P72                                |
| ANI3                     | 97      |        |                                                                              | P73                                |
| ANI4                     | 96      |        |                                                                              | P74                                |
| ANI5                     | 95      |        |                                                                              | P75                                |
| ANI6                     | 94      |        |                                                                              | P76                                |
| ANI7                     | 93      |        |                                                                              | P77                                |
| ANI8                     | 92      |        |                                                                              | P78                                |
| ANI9                     | 91      |        |                                                                              | P79                                |
| ANI10                    | 90      |        |                                                                              | P710                               |
| ANI11                    | 89      |        |                                                                              | P711                               |
| ANO0                     | 3       | Output | Analog voltage output for D/A converter                                      | P10                                |
| ANO1                     | 4       |        |                                                                              | P11                                |
| ASCKA0                   | 27      | Input  | UARTA0 baud rate clock input. 5 V tolerant.                                  | P32/SCKB4/TIP00/TOP00              |
| ASTB                     | 68      | Output | Address strobe signal output for external memory                             | PCT6                               |
| AV <sub>REF0</sub>       | 1       | _      | Reference voltage input for A/D converter/positive power supply for port 7   | _                                  |
| AV <sub>REF1</sub>       | 5       |        | Reference voltage input for D/A converter/positive power supply for port 1   | _                                  |
| AVss                     | 2       | _      | Ground potential for A/D and D/A converters (same potential as Vss)          | -                                  |
| BV <sub>DD</sub>         | 70      | _      | Positive power supply pin for bus interface and alternate-<br>function ports | -                                  |
| BVss                     | 69      | _      | Ground potential for bus interface and alternate-function ports              | -                                  |
| CLKOUT                   | 62      | Output | Internal system clock output                                                 | PCM1                               |
| CRXD0 <sup>Note 1</sup>  | 32      | Input  | CAN receive data input. 5 V tolerant.                                        | P37/IERX0 <sup>Note 2</sup>        |
| CTXD0 <sup>Note 1</sup>  | 31      | Output | CAN transmit data output. N-ch open-drain output selectable. 5 V tolerant.   | P36/IETXO <sup>Note 2</sup>        |
| DCK <sup>Note 3</sup>    | 41      | Input  | Debug clock input. 5 V tolerant.                                             | P54/SOB2/KR4/RTP04                 |
| DDI <sup>Note 3</sup>    | 39      | Input  | Debug data input. 5 V tolerant.                                              | P52/TIQ03/KR2/TOQ03/RTP02          |
| DDO <sup>Note 3, 4</sup> | 40      | Output | Debug data output. N-ch open-drain output selectable. 5 V tolerant.          | P53/SIB2/KR3/TIQ00/TOQ00/<br>RTP03 |
| DMS <sup>Note 3</sup>    | 42      | Input  | Debug mode select input. 5 V tolerant.                                       | P55/SCKB2/KR5/RTP05                |
| DRST <sup>Note 3</sup>   | 20      | Input  | Debug reset input. 5 V tolerant.                                             | P05/INTP2                          |
| EV <sub>DD</sub>         | 34      | _      | Positive power supply for external (same potential as VDD)                   | -                                  |
| EVss                     | 33      | _      | Ground potential for external (same potential as Vss)                        | _                                  |
| FLMD0 <sup>Note 3</sup>  | 8       | Input  | Flash memory programming mode setting pin                                    | -                                  |
| FLMD1 <sup>Note 3</sup>  | 76      | ]      |                                                                              | PDL5/AD5                           |
| HLDAK                    | 63      | Output | Bus hold acknowledge output                                                  | PCM2                               |
| HLDRQ                    | 64      | Input  | Bus hold request input                                                       | PCM3                               |
| ICNote 5                 | 8       | _      | Internally connected                                                         | -                                  |

# Notes 1. CAN controller versions only

- 2. IEBus controller versions only
- 3. Flash memory versions only
- **4.** In the on-chip debug mode, high-level output is forcibly set.
- 5. Mask ROM versions only

(3/5)

| Pin Name                | Pin No. | I/O    | Function                                                                         | Alternate Function                                   |
|-------------------------|---------|--------|----------------------------------------------------------------------------------|------------------------------------------------------|
| IERX0 <sup>Note 1</sup> | 32      | Input  | IEBus receive data input. 5 V tolerant.                                          | P37/CRXD0 <sup>Note 2</sup>                          |
| ĪETX0 <sup>Note 1</sup> | 31      | Output | IEBus transmit data output. N-ch open-drain output selectable. 5 V tolerant.     | P36/CTXD0 <sup>Note 2</sup>                          |
| INTP0                   | 18      | Input  | External interrupt request input (maskable, analog noise                         | P03/ADTRG                                            |
| INTP1                   | 19      |        | elimination).                                                                    | P04                                                  |
| INTP2                   | 20      |        | Analog noise elimination or digital noise elimination selectable for INTP3 pin.  | P05/DRST <sup>Note 3</sup>                           |
| INTP3                   | 21      |        | 5 V tolerant.                                                                    | P06                                                  |
| INTP4                   | 56      |        |                                                                                  | P913/A13                                             |
| INTP5                   | 57      |        |                                                                                  | P914/A14/TIP51/TOP51                                 |
| INTP6                   | 58      |        |                                                                                  | P915/A15/TIP50/TOP50                                 |
| INTP7                   | 26      |        |                                                                                  | P31/RXDA0/SIB4                                       |
| KR0 <sup>Note 4</sup>   | 37      | Input  | Key interrupt input (on-chip analog noise eliminator).                           | P50/TIQ01/TOQ01/RTP00                                |
| KR1 <sup>Note 4</sup>   | 38      |        | 5 V tolerant.                                                                    | P51/TIQ02/TOQ02/RTP01                                |
| KR2 <sup>Note 4</sup>   | 39      |        |                                                                                  | P52/TIQ03/TOQ03/<br>RTP02/DDI <sup>Note 3</sup>      |
| KR3 <sup>Note 4</sup>   | 40      |        |                                                                                  | P53/SIB2/TIQ00/TOQ00/<br>RTP03/DDO <sup>Note 3</sup> |
| KR4 <sup>Note 4</sup>   | 41      |        |                                                                                  | P54/SOB2/RTP04/DCK <sup>Note 3</sup>                 |
| KR5 <sup>Note 4</sup>   | 42      |        |                                                                                  | P55/SCKB2/RTP05/DMS <sup>Note 3</sup>                |
| KR6 <sup>Note 4</sup>   | 43      |        |                                                                                  | P90/A0/TXDA1/SDA02                                   |
| KR7 <sup>Note 4</sup>   | 44      |        |                                                                                  | P91/A1/RXDA1/SCL02                                   |
| NMI <sup>Note 5</sup>   | 17      | Input  | External interrupt input (non-maskable, analog noise elimination). 5 V tolerant. | P02                                                  |
| RD                      | 67      | Output | Read strobe signal output for external memory                                    | PCT4                                                 |
| REGC                    | 10      | -      | Connection of regulator output stabilization capacitance (4.7 $\mu$ F)           | -                                                    |
| RESET                   | 14      | Input  | System reset input                                                               | -                                                    |
| RTP00                   | 37      | Output | Real-time output port.                                                           | P50/TIQ01/KR0/TOQ01                                  |
| RTP01                   | 38      |        | N-ch open-drain output selectable.                                               | P51/TIQ02/KR1/TOQ02                                  |
| RTP02                   | 39      |        | 5 V tolerant.                                                                    | P52/TIQ03/KR2/TOQ03/DDI <sup>Note 3</sup>            |
| RTP03                   | 40      |        |                                                                                  | P53/SIB2/KR3/TIQ00/TOQ00/<br>DDO <sup>Note 3</sup>   |
| RTP04                   | 41      |        |                                                                                  | P54/SOB2/KR4/DCK <sup>Note 3</sup>                   |
| RTP05                   | 42      |        |                                                                                  | P55/SCKB2/KR5/DMS <sup>Note 3</sup>                  |

# Notes 1. IEBus controller versions only

- 2. CAN controller versions only
- 3. Flash memory versions only
- 4. Pull this pin up externally.
- **5.** The NMI pin and P02 pin are an alternate-function pin. This pin functions as the P02 pin after if has been reset. To enable the NMI pin, set the PMC0.PMC02 bit to 1. The initial setting of the NMI pin is "No edge detected". Select the NMI pin valid edge using INTF0 and INTR0 registers.

(4/5)

| Pin Name | Pin No. | I/O    | Function                                                                                      | Alternate Function                                |
|----------|---------|--------|-----------------------------------------------------------------------------------------------|---------------------------------------------------|
| RXDA0    | 26      | Input  | Serial receive data input (UARTA0 to UARTA2)                                                  | P31/INTP7/SIB4                                    |
| RXDA1    | 44      |        | 5 V tolerant.                                                                                 | P91/A1/KR7/SCL02                                  |
| RXDA2    | 36      |        |                                                                                               | P39/SCL00                                         |
| SCKB0    | 24      | I/O    | Serial clock I/O (CSIB0 to CSIB4)                                                             | P42                                               |
| SCKB1    | 52      |        | N-ch open-drain output selectable.                                                            | P99/A9                                            |
| SCKB2    | 42      |        | 5 V tolerant.                                                                                 | P55/KR5/RTP05/DMS <sup>Note</sup>                 |
| SCKB3    | 55      |        |                                                                                               | P912/A12                                          |
| SCKB4    | 27      |        |                                                                                               | P32/ASCKA0/TIP00/TOP00                            |
| SCL00    | 36      | I/O    | Serial clock I/O (I <sup>2</sup> C00 to I <sup>2</sup> C02)                                   | P39/RXDA2                                         |
| SCL01    | 23      |        | N-ch open-drain output selectable.                                                            | P41/SOB0                                          |
| SCL02    | 44      |        | 5 V tolerant.                                                                                 | P91/A1/KR7/RXDA1                                  |
| SDA00    | 35      | I/O    | Serial transmit/receive data I/O (I <sup>2</sup> C00 to I <sup>2</sup> C02)                   | P38/TXDA2                                         |
| SDA01    | 22      |        | N-ch open-drain output selectable.                                                            | P40/SIB0                                          |
| SDA02    | 43      |        | 5 V tolerant.                                                                                 | P90/A0/KR6/TXDA1                                  |
| SIB0     | 22      | Input  | Serial receive data input (CSIB0 to CSIB4)                                                    | P40/SDA01                                         |
| SIB1     | 50      |        | 5 V tolerant.                                                                                 | P97/A7/TIP20/TOP20                                |
| SIB2     | 40      |        |                                                                                               | P53/KR3/TIQ00/TOQ00/<br>RTP03/DDO <sup>Note</sup> |
| SIB3     | 53      |        |                                                                                               | P910/A10                                          |
| SIB4     | 26      |        |                                                                                               | P31/RXDA0/INTP7                                   |
| SOB0     | 23      | Output | Serial transmit data output (CSIB0 to CSIB4)                                                  | P41/SCL01                                         |
| SOB1     | 51      |        | N-ch open-drain output selectable.                                                            | P98/A8                                            |
| SOB2     | 41      |        | 5 V tolerant.                                                                                 | P54/KR4/RTP04/DCK <sup>Note</sup>                 |
| SOB3     | 54      |        |                                                                                               | P911/A11                                          |
| SOB4     | 25      |        |                                                                                               | P30/TXDA0                                         |
| TIP00    | 27      | Input  | External event count input/capture trigger input/external trigger input (TMP0). 5 V tolerant. | P32/ASCKA0/SCKB4/TOP00                            |
| TIP01    | 28      |        | Capture trigger input (TMP0). 5 V tolerant.                                                   | P33/TOP01                                         |
| TIP10    | 29      |        | External event count input/capture trigger input/external trigger input (TMP1). 5 V tolerant. | P34/TOP10                                         |
| TIP11    | 30      |        | Capture trigger input (TMP1). 5 V tolerant.                                                   | P35/TOP11                                         |
| TIP20    | 50      |        | External event count input/capture trigger input/external trigger input (TMP2). 5 V tolerant. | P97/A7/SIB1/TOP20                                 |
| TIP21    | 49      | 1      | Capture trigger input (TMP2). 5 V tolerant.                                                   | P96/A6/TOP21                                      |
| TIP30    | 48      |        | External event count input/capture trigger input/external trigger input (TMP3). 5 V tolerant. | P95/A5/TOP30                                      |
| TIP31    | 47      | 1      | Capture trigger input (TMP3). 5 V tolerant.                                                   | P94/A4/TOP31                                      |
| TIP40    | 46      |        | External event count input/capture trigger input/external trigger input (TMP4). 5 V tolerant. | P93/A3/TOP40                                      |
| TIP41    | 45      | 1      | Capture trigger input (TMP4). 5 V tolerant.                                                   | P92/A2/TOP41                                      |
| TIP50    | 58      | -      | External event count input/capture trigger input/external trigger input (TMP5). 5 V tolerant. | P915/A15/INTP6/TOP50                              |
| TIP51    | 57      | 1      | Capture trigger input (TMP5). 5 V tolerant.                                                   | P914/A14/INTP5/TOP51                              |

(5/5)

| Pin Name        | Pin No. | I/O    | Function                                                                                      | Alternate Function                               |
|-----------------|---------|--------|-----------------------------------------------------------------------------------------------|--------------------------------------------------|
| TIQ00           | 40      | Input  | External event count input/capture trigger input/external trigger input (TMQ0). 5 V tolerant. | P53/SIB2/KR3/TOQ00/RTP03<br>/DDO <sup>Note</sup> |
| TIQ01           | 37      |        | Capture trigger input (TMQ0). 5 V tolerant.                                                   | P50/KR0/TOQ01/RTP00                              |
| TIQ02           | 38      |        |                                                                                               | P51/KR1/TOQ02/RTP01                              |
| TIQ03           | 39      |        |                                                                                               | P52/KR2/TOQ03/RTP02/<br>DDI <sup>Note</sup>      |
| TOP00           | 27      | Output | Timer output (TMP0)                                                                           | P32/ASCKA0/SCKB4/TIP00                           |
| TOP01           | 28      |        | N-ch open-drain output selectable. 5 V tolerant.                                              | P33/TIP01                                        |
| TOP10           | 29      |        | Timer output (TMP1)                                                                           | P34/TIP10                                        |
| TOP11           | 30      |        | N-ch open-drain output selectable. 5 V tolerant.                                              | P35/TIP11                                        |
| TOP20           | 50      |        | Timer output (TMP2)                                                                           | P97/A7/SIB1/TIP20                                |
| TOP21           | 49      |        | N-ch open-drain output selectable. 5 V tolerant.                                              | P96/A6/TIP21                                     |
| TOP30           | 48      |        | Timer output (TMP3)                                                                           | P95/A5/TIP30                                     |
| TOP31           | 47      |        | N-ch open-drain output selectable. 5 V tolerant.                                              | P94/A4/TIP31                                     |
| TOP40           | 46      |        | Timer output (TMP4)                                                                           | P93/A3/TIP40                                     |
| TOP41           | 45      |        | N-ch open-drain output selectable. 5 V tolerant.                                              | P92/A2/TIP41                                     |
| TOP50           | 58      |        | Timer output (TMP5)                                                                           | P915/A15/INTP6/TIP50                             |
| TOP51           | 57      |        | N-ch open-drain output selectable. 5 V tolerant.                                              | P914/A14/INTP5/TIP51                             |
| TOQ00           | 40      | Output | Timer output (TMQ0) N-ch open-drain output selectable. 5 V tolerant.                          | P53/SIB2/KR3/TIQ00/RTP03/<br>DDO <sup>Note</sup> |
| TOQ01           | 37      |        |                                                                                               | P50/TIQ01/KR0/RTP00                              |
| TOQ02           | 38      |        |                                                                                               | P51/TIQ02/KR1/RTP01                              |
| TOQ03           | 39      |        |                                                                                               | P52/TIQ03/KR2/RTP02/DDI <sup>Note</sup>          |
| TXDA0           | 25      | Output | Serial transmit data output (UARTA0 to UARTA2)                                                | P30/SOB4                                         |
| TXDA1           | 43      |        | N-ch open-drain output selectable.                                                            | P90/A0/KR6/SDA02                                 |
| TXDA2           | 35      |        | 5 V tolerant.                                                                                 | P38/SDA00                                        |
| V <sub>DD</sub> | 9       | _      | Positive power supply pin for internal                                                        | -                                                |
| Vss             | 11      | _      | Ground potential for internal                                                                 |                                                  |
| WAIT            | 61      | Input  | External wait input                                                                           | PCM0                                             |
| WR0             | 65      | Output | Write strobe for external memory (lower 8 bits)                                               | РСТ0                                             |
| WR1             | 66      |        | Write strove for external memory (higher 8 bits)                                              | PCT1                                             |
| X1              | 12      | Input  | Connection of resonator for main clock                                                        | -                                                |
| X2              | 13      |        |                                                                                               |                                                  |
| XT1             | 15      | Input  | Connection of resonator for subclock                                                          | _                                                |
| XT2             | 16      |        |                                                                                               | -                                                |

#### 2.2 Pin States

The operation states of pins in the various modes are described below.

**Table 2-2. Pin Operation States in Various Modes** 

| Pin Name                  | When Power<br>Is Turned<br>On <sup>Note 1</sup> | During Reset<br>(Except When<br>Power Is<br>Turned On) | HALT Mode <sup>Note 2</sup>      | IDLE1, IDLE2,<br>Sub-IDLE<br>Mode <sup>Note 2</sup> | STOP<br>Mode <sup>Note 2</sup> | Idle<br>State <sup>Note 3</sup> | Bus Hold  |
|---------------------------|-------------------------------------------------|--------------------------------------------------------|----------------------------------|-----------------------------------------------------|--------------------------------|---------------------------------|-----------|
| P05/DRSTNote 4            | Pulled down                                     | Pulled down <sup>Note 5</sup>                          | Held                             | Held                                                | Held                           | Held                            | Held      |
| P10/ANO0,<br>P11/ANO1     | Undefined                                       | Hi-Z                                                   | Held                             | Held                                                | Hi-Z                           | Held                            | Held      |
| P53/DDO <sup>Note 4</sup> |                                                 | Hi-Z <sup>Note 6</sup>                                 | Held                             | Held                                                | Held                           | Held                            | Held      |
| AD0 to AD15               | Hi-Z <sup>Note 7</sup>                          | Hi-Z <sup>Note 7</sup>                                 | Notes 8, 9                       | Hi-Z                                                | Hi-Z                           | Held                            | Hi-Z      |
| A0 to A15                 |                                                 |                                                        | Undefined <sup>Notes 8, 10</sup> |                                                     |                                |                                 |           |
| A16 to A21                |                                                 |                                                        | Undefined <sup>Note 8</sup>      |                                                     |                                |                                 |           |
| WAIT                      |                                                 |                                                        | _                                | -                                                   | -                              | -                               | _         |
| CLKOUT                    |                                                 |                                                        | Operating                        | L                                                   | L                              | Operating                       | Operating |
| WR0, WR1                  |                                                 |                                                        | H <sup>Note 8</sup>              | Н                                                   | Н                              | Н                               | Hi-Z      |
| RD                        |                                                 |                                                        |                                  |                                                     |                                |                                 |           |
| ASTB                      |                                                 |                                                        |                                  |                                                     |                                |                                 |           |
| HLDAK                     |                                                 |                                                        | Operating <sup>Note 8</sup>      |                                                     |                                |                                 | L         |
| HLDRQ                     |                                                 |                                                        |                                  | -                                                   | _                              | _                               | Operating |
| Other port pins           | Hi-Z                                            | Hi-Z                                                   | Held                             | Held                                                | Held                           | Held                            | Held      |

- **Notes 1.** Duration until 1 ms elapses after the supply voltage reaches the operating supply voltage range (lower limit) when the power is turned on.
  - 2. Operates while an alternate function is operating.
  - 3. In separate bus mode, the state of the pins in the idle state inserted after the T2 state is shown. In multiplexed bus mode, the state of the pins in the idle state inserted after the T3 state is shown.
  - 4. Flash memory version only
  - **5.** Pulled down during external reset. During internal reset by the watchdog timer, clock monitor, etc., the state of this pin differs according to the OCDM.OCDM0 bit setting.
  - **6.** DDO output is specified in the on-chip debug mode.
  - **7.** The bus control pins function alternately as port pins, so they are initialized to the input mode (port mode).
  - 8. Operates even in the HALT mode, during DMA operation.
  - **9.** In separate bus mode: Hi-Z

In multiplexed bus mode: Undefined

10. In separate bus mode

Remark Hi-Z: High impedance

Held: The state during the immediately preceding external bus cycle is held.

- L: Low-level output
- H: High-level output
- -: Input without sampling (not acknowledged)

# 2.3 Pin I/O Circuit Types, I/O Buffer Power Supplies, and Connection of Unused Pins

(1/3)

| Pin         | Alternate Function                               | Pin No. | I/O Circuit Type | Recommended Connection                                                                                                                                     |
|-------------|--------------------------------------------------|---------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P02         | NMI                                              | 17      | 10-D             | Input: Independently connect to EVDD or                                                                                                                    |
| P03         | INTP0/ADTRG                                      | 18      |                  | EVss via a resistor.                                                                                                                                       |
| P04         | INTP1                                            | 19      |                  | Output: Leave open.                                                                                                                                        |
| P05         | INTP2/DRSTNote 1                                 | 20      | 10-N             | Input: Independently connect to EVss via a resistor. Fixing to VDD level is prohibited. Output: Leave open. Internally pull-down after reset by RESET pin. |
| P06         | INTP3                                            | 21      | 10-D             | Input: Independently connect to EV <sub>DD</sub> or EV <sub>SS</sub> via a resistor. Output: Leave open.                                                   |
| P10, P11    | ANO0, ANO1                                       | 3, 4    | 12-D             | Input: Independently connect to AVREF1 or AVss via a resistor.  Output: Leave open.                                                                        |
| P30         | TXDA0/SOB4                                       | 25      | 10-G             | Input: Independently connect to EVDD or                                                                                                                    |
| P31         | RXDA0/INTP7/SIB4                                 | 26      | 10-D             | EVss via a resistor.                                                                                                                                       |
| P32         | ASCKA0/SCKB4/TIP00                               | 27      |                  | Output: Leave open.                                                                                                                                        |
| P33         | TIP01/TOP01                                      | 28      |                  |                                                                                                                                                            |
| P34         | TIP10/TOP10                                      | 29      |                  |                                                                                                                                                            |
| P35         | TIP11/TOP11                                      | 30      |                  |                                                                                                                                                            |
| P36         | CTXD0 <sup>Note 2</sup> /IETX0 <sup>Note 3</sup> | 31      | 10-G             |                                                                                                                                                            |
| P37         | CRXD0 <sup>Note 2</sup> /IERX0 <sup>Note 3</sup> | 32      | 10-D             |                                                                                                                                                            |
| P38         | TXDA2/SDA00                                      | 35      |                  |                                                                                                                                                            |
| P39         | RXDA2/SCL00                                      | 36      |                  |                                                                                                                                                            |
| P40         | SIB0/SDA01                                       | 22      |                  |                                                                                                                                                            |
| P41         | SOB0/SCL01                                       | 23      |                  |                                                                                                                                                            |
| P42         | SCKB0                                            | 24      |                  |                                                                                                                                                            |
| P50         | TIQ01/KR0/TOQ01/RTP00                            | 37      |                  |                                                                                                                                                            |
| P51         | TIQ02/KR1/TOQ02/RTP01                            | 38      |                  |                                                                                                                                                            |
| P52         | TIQ03/KR2/TOQ03/RTP02/DDI <sup>Note 1</sup>      | 39      |                  |                                                                                                                                                            |
| P53         | SIB2/KR3/TIQ00/TOQ00/RTP03/DDO <sup>Note 1</sup> | 40      |                  |                                                                                                                                                            |
| P54         | SOB2/KR4/RTP04/DCK <sup>Note 1</sup>             | 41      |                  |                                                                                                                                                            |
| P55         | SCKB2/KR5/RTP05/DMS <sup>Note 1</sup>            | 42      |                  |                                                                                                                                                            |
| P70 to P711 | ANI0 to ANI11                                    | 100-89  | 11-G             | Input: Independently connect to AVREFO or AVss via a resistor.  Output: Leave open.                                                                        |

- 2. CAN controller versions only
- 3. IEBus controller versions only

(2/3)

| Pin                | Alternate Function        | Pin No. | I/O Circuit Type | Recommended Connection                                               |
|--------------------|---------------------------|---------|------------------|----------------------------------------------------------------------|
| P90                | A0/KR6/TXDA1/SDA02        | 43      | 10-D             | Input: Independently connect to EV <sub>DD</sub> or EV <sub>SS</sub> |
| P91                | A1/KR7/RXDA1/SCL02        | 44      |                  | via a resistor.                                                      |
| P92                | A2/TIP41/TOP41            | 45      |                  | Output: Leave open.                                                  |
| P93                | A3/TIP40/TOP40            | 46      |                  |                                                                      |
| P94                | A4/TIP31/TOP31            | 47      |                  |                                                                      |
| P95                | A5/TIP30/TOP30            | 48      |                  |                                                                      |
| P96                | A6/TIP21/TOP21            | 49      |                  |                                                                      |
| P97                | A7/SIB1/TIP20/TOP20       | 50      |                  |                                                                      |
| P98                | A8/SOB1                   | 51      | 10-G             |                                                                      |
| P99                | A9/SCKB1                  | 52      | 10-D             |                                                                      |
| P910               | A10/SIB3                  | 53      |                  |                                                                      |
| P911               | A11/SOB3                  | 54      | 10-G             |                                                                      |
| P912               | A12/SCKB3                 | 55      | 10-D             |                                                                      |
| P913               | A13/INTP4                 | 56      | ]                |                                                                      |
| P914               | A14/INTP5/TIP51/TOP51     | 57      | ]                |                                                                      |
| P915               | A15/INTP6/TIP50/TOP50     | 58      |                  |                                                                      |
| PCM0               | WAIT                      | 61      | 5                | Input: Independently connect to BVpp or BVss                         |
| PCM1               | CLKOUT                    | 62      |                  | via a resistor.                                                      |
| PCM2               | HLDAK                     | 63      |                  | Output: Leave open.                                                  |
| РСМ3               | HLDRQ                     | 64      |                  |                                                                      |
| PCT0, PCT1         | WRO, WR1                  | 65, 66  |                  |                                                                      |
| PCT4               | RD                        | 67      |                  |                                                                      |
| PCT6               | ASTB                      | 68      | ]                |                                                                      |
| PDH0 to            | A16 to A19                | 87, 88  |                  |                                                                      |
| PDH3               |                           | 59, 60  |                  |                                                                      |
| PDH4,              | A20, A21                  | 6, 7    |                  | Input: Independently connect to EV <sub>DD</sub> or EVss             |
| PDH5               |                           |         |                  | via a resistor. Output: Leave open.                                  |
| PDL0 to            | AD0 to AD4                | 71-75   | _                | Input: Independently connect to BVpp or BVss                         |
| PDL4               |                           |         |                  | via a resistor.                                                      |
| PDL5               | AD5/FLMD1 <sup>Note</sup> | 76      |                  | Output: Leave open.                                                  |
| PDL6 to            | AD6 to AD15               | 77-86   |                  |                                                                      |
| PDL15              |                           |         |                  |                                                                      |
| AV <sub>REF0</sub> | _                         | 1       |                  | Directly connect to V <sub>DD</sub> and always supply power.         |
| AV <sub>REF1</sub> | _                         | 5       | -                | Directly connect to VDD and always supply power.                     |
| AVss               | _                         | 2       | -                | Directly connect to Vss and always supply power.                     |
| BV <sub>DD</sub>   | _                         | 70      | -                | Directly connect to V <sub>DD</sub> and always supply power.         |
| BVss               | -                         | 69      | -                | Directly connect to Vss and always supply power.                     |
| EV <sub>DD</sub>   | -                         | 34      | -                | -                                                                    |
| EVss               |                           | 33      | _                |                                                                      |

(3/3)

| Pin                     | Alternate Function | Pin No. | I/O Circuit Type | Recommended Connection                                                          |
|-------------------------|--------------------|---------|------------------|---------------------------------------------------------------------------------|
| FLMD0 <sup>Note 1</sup> | -                  | 8       | -                | Directly connect to Vss in a mode other than the flash memory programming mode. |
| IC <sup>Note 2</sup>    | -                  | 8       | -                | Directly connect to Vss.                                                        |
| REGC                    | -                  | 10      | _                | Connect regulator output stabilization capacitance.                             |
| RESET                   | -                  | 14      | 2                | _                                                                               |
| V <sub>DD</sub>         | -                  | 9       | -                | _                                                                               |
| Vss                     | -                  | 11      | -                | _                                                                               |
| X1                      | _                  | 12      | _                | _                                                                               |
| X2                      | _                  | 13      | _                | _                                                                               |
| XT1                     | -                  | 15      | 16               | Connect to Vss.                                                                 |
| XT2                     | <del>-</del>       | 16      | 16               | Leave open.                                                                     |

Notes 1. Flash memory versions only

2. Mask ROM versions only

Figure 2-1. Pin I/O Circuits



Note Hysteresis characteristics are not available in port mode.

# 2.4 Cautions

When the power is turned on, the following pins may output an undefined level temporarily even during reset.

- P10/ANO0 pin
- P11/ANO1 pin
- P53/SIB2/KR3/TIQ00/TOQ00/RTP03/DDO<sup>Note</sup> pin

**Note** The DDO pin is provided only in the flash memory version.

# **CHAPTER 3 CPU FUNCTION**

The CPU of the V850ES/SG2 is based on RISC architecture and executes almost all instructions with one clock by using a 5-stage pipeline.

# 3.1 Features

NOT1TST1

| O Minimum instruction execution time: 3 |                                               |                                | 31.25 ns (at 32       | MHz operation)                        |  |  |
|-----------------------------------------|-----------------------------------------------|--------------------------------|-----------------------|---------------------------------------|--|--|
|                                         |                                               | 3                              | $30.5~\mu$ s (with su | ubclock (fxr) = 32.768 kHz operation) |  |  |
| 0                                       | Memory space                                  | Program (physical a            | ddress) space:        | 64 MB linear                          |  |  |
|                                         |                                               | Data (logical addres           | s) space:             | 4 GB linear                           |  |  |
| 0                                       | General-purpose                               | e registers: 32 bits $	imes$ 3 | 32 registers          |                                       |  |  |
| 0                                       | Internal 32-bit ar                            | chitecture                     |                       |                                       |  |  |
| 0                                       | 5-stage pipeline                              | control                        |                       |                                       |  |  |
| 0                                       | Multiplication/div                            | ision instruction              |                       |                                       |  |  |
| 0                                       | Saturation opera                              | tion instruction               |                       |                                       |  |  |
| 0                                       | 32-bit shift instru                           | ction: 1 clock                 |                       |                                       |  |  |
| 0                                       | Load/store instruction with long/short format |                                |                       |                                       |  |  |
| 0                                       | Four types of bit manipulation instructions   |                                |                       |                                       |  |  |
|                                         | • SET1                                        |                                |                       |                                       |  |  |
|                                         | • CLR1                                        |                                |                       |                                       |  |  |

# 3.2 CPU Register Set

The registers of the V850ES/SG2 can be classified into two types: general-purpose program registers and dedicated system registers. All the registers are 32 bits wide.

For details, refer to the V850ES Architecture User's Manual.

#### (1) Program register set (2) System register set 0 EIPC (Interrupt status saving register) (Zero register) r0 r1 (Assembler-reserved register) **EIPSW** (Interrupt status saving register) r2 r3 (Stack pointer (SP)) FEPC (NMI status saving register) (Global pointer (GP)) r4 FEPSW (NMI status saving register) r5 (Text pointer (TP)) r6 ECR (Interrupt source register) r7 r8 PSW (Program status word) r9 r10 CTPC (CALLT execution status saving register) r11 CTPSW (CALLT execution status saving register) r12 r13 DBPC (Exception/debug trap status saving register) r14 DBPSW (Exception/debug trap status saving register) r15 r16 r17 **CTBP** (CALLT base pointer) r18 r19 r20 r22 r23 r24 r25 r26 r27 r28 r29 (Element pointer (EP)) r30 (Link pointer (LP)) r31 PC (Program counter)

#### 3.2.1 Program register set

The program registers include general-purpose registers and a program counter.

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

Thirty-two general-purpose registers, r0 to r31, are available. Any of these registers can be used to store a data variable or an address variable.

However, r0 and r30 are implicitly used by instructions and care must be exercised when these registers are used. r0 always holds 0 and is used for an operation that uses 0 or addressing of offset 0. r30 is used by the SLD and SST instructions as a base pointer when these instructions access the memory. r1, r3 to r5, and r31 are implicitly used by the assembler and C compiler. When using these registers, save their contents for protection, and then restore the contents after using the registers. r2 is sometimes used by the real-time OS. If the real-time OS does not use r2, it can be used as a register for variables.

Name Usage Operation r0 Always holds 0. Zero register r1 Assembler-reserved register Used as working register to create 32-bit immediate data r2 Register for address/data variable (if real-time OS does not use r2) r3 Stack pointer Used to create a stack frame when a function is called r4 Global pointer Used to access a global variable in the data area r5 Text pointer Used as register that indicates the beginning of a text area (area where program codes are located) r6 to r29 Register for address/data variable r30 Element pointer Used as base pointer to access memory Link pointer Used when the compiler calls a function r31 PC Program counter Holds the instruction address during program execution

**Table 3-1. Program Registers** 

**Remark** For further details on the r1, r3 to r5, and r31 that are used in the assembler and C compiler, refer to the CA850 (C Compiler Package) Assembly Language User's Manual.

### (2) Program counter (PC)

The program counter holds the instruction address during program execution. The lower 32 bits of this register are valid. Bits 31 to 26 are fixed to 0. A carry from bit 25 to 26 is ignored even if it occurs.

Bit 0 is fixed to 0. This means that execution cannot branch to an odd address.



### 3.2.2 System register set

The system registers control the status of the CPU and hold interrupt information.

These registers can be read or written by using system register load/store instructions (LDSR and STSR), using the system register numbers listed below.

Table 3-2. System Register Numbers

| System             | System Register Name                                                                                 | Operand S        | pecification     |
|--------------------|------------------------------------------------------------------------------------------------------|------------------|------------------|
| Register<br>Number |                                                                                                      | LDSR Instruction | STSR Instruction |
| 0                  | Interrupt status saving register (EIPC) <sup>Note 1</sup>                                            | √                | √                |
| 1                  | Interrupt status saving register (EIPSW) <sup>Note 1</sup>                                           | √                | √                |
| 2                  | NMI status saving register (FEPC) <sup>Note 1</sup>                                                  | √                | √                |
| 3                  | NMI status saving register (FEPSW) <sup>Note 1</sup>                                                 | √                | √                |
| 4                  | Interrupt source register (ECR)                                                                      | ×                | √                |
| 5                  | Program status word (PSW)                                                                            | √                | √                |
| 6 to 15            | Reserved for future function expansion (operation is not guaranteed if these registers are accessed) | ×                | ×                |
| 16                 | CALLT execution status saving register (CTPC)                                                        | √                | √                |
| 17                 | CALLT execution status saving register (CTPSW)                                                       | √                | √                |
| 18                 | Exception/debug trap status saving register (DBPC)                                                   | √Note 2          | √Note 2          |
| 19                 | Exception/debug trap status saving register (DBPSW)                                                  | √Note 2          | √Note 2          |
| 20                 | CALLT base pointer (CTBP)                                                                            | √                | √                |
| 21 to 31           | Reserved for future function expansion (operation is not guaranteed if these registers are accessed) | ×                | ×                |

- **Notes 1.** Because only one set of these registers is available, the contents of these registers must be saved by program if multiple interrupts are enabled.
  - 2. These registers can be accessed only during the interval between the execution of the DBTRAP instruction or illegal opcode execution and DBRET instruction.

Caution Even if EIPC or FEPC, or bit 0 of CTPC is set to 1 by the LDSR instruction, bit 0 is ignored when execution is returned to the main routine by the RETI instruction after interrupt servicing (this is because bit 0 of the PC is fixed to 0). Set an even value to EIPC, FEPC, and CTPC (bit 0 = 0).

**Remark**  $\sqrt{\cdot}$ : Can be accessed

×: Access prohibited

### (1) Interrupt status saving registers (EIPC and EIPSW)

EIPC and EIPSW are used to save the status when an interrupt occurs.

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

The address of the instruction next to the instruction under execution, except some instructions (see 22.8 Periods in Which Interrupts Are Not Acknowledged by CPU), is saved to EIPC when a software exception or a maskable interrupt occurs.

The current contents of the PSW are saved to EIPSW.

Because only one set of interrupt status saving registers is available, the contents of these registers must be saved by program when multiple interrupts are enabled.

Bits 31 to 26 of EIPC and bits 31 to 8 of EIPSW are reserved for future function expansion (these bits are always fixed to 0).

The value of EIPC is restored to the PC and the value of EIPSW to the PSW by the RETI instruction.



### (2) NMI status saving registers (FEPC and FEPSW)

FEPC and FEPSW are used to save the status when a non-maskable interrupt (NMI) occurs.

If an NMI occurs, the contents of the program counter (PC) are saved to FEPC, and those of the program status word (PSW) are saved to FEPSW.

The address of the instruction next to the one of the instruction under execution, except some instructions, is saved to FEPC when an NMI occurs.

The current contents of the PSW are saved to FEPSW.

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

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

The value of FEPC is restored to the PC and the value of FEPSW to the PSW by the RETI instruction.



### (3) Interrupt source register (ECR)

The interrupt source register (ECR) holds the source of an exception or interrupt if an exception or interrupt occurs. This register holds the exception code of each interrupt source. Because this register is a read-only register, data cannot be written to this register using the LDSR instruction.



# (4) Program status word (PSW)

The program status word (PSW) is a collection of flags that indicate the status of the program (result of instruction execution) and the status of the CPU.

If the contents of a bit of this register are changed by using the LDSR instruction, the new contents are validated immediately after completion of LDSR instruction execution. However if the ID flag is set to 1, interrupt requests will not be acknowledged while the LDSR instruction is being executed.

Bits 31 to 8 of this register are reserved for future function expansion (these bits are fixed to 0).

(1/2)



| Bit position | Flag name           | Meaning                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 to 8      | RFU                 | Reserved field. Fixed to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7            | NP                  | Indicates that a non-maskable interrupt (NMI) is being serviced. This bit is set to 1 when an NMI request is acknowledged, disabling multiple interrupts.  0: NMI is not being serviced.  1: NMI is being serviced.                                                                                                                                                                                                                                                          |
| 6            | EP                  | Indicates that an exception is being processed. This bit is set to 1 when an exception occurs. Even if this bit is set, interrupt requests are acknowledged.  0: Exception is not being processed.  1: Exception is being processed.                                                                                                                                                                                                                                         |
| 5            | ID                  | Indicates whether a maskable interrupt can be acknowledged.  0: Interrupt enabled  1: Interrupt disabled                                                                                                                                                                                                                                                                                                                                                                     |
| 4            | SAT <sup>Note</sup> | Indicates that the result of a saturation operation has overflowed and is saturated. Because this is a cumulative flag, it is set to 1 when the result of a saturation operation instruction is saturated, and is not cleared to 0 even if the subsequent operation result is not saturated. Use the LDSR instruction to clear this bit. This flag is neither set to 1 nor cleared to 0 by execution of an arithmetic operation instruction.  0: Not saturated  1: Saturated |
| 3            | CY                  | Indicates whether a carry or a borrow occurs as a result of an operation.  0: Carry or borrow does not occur.  1: Carry or borrow occurs.                                                                                                                                                                                                                                                                                                                                    |
| 2            | OV <sup>Note</sup>  | Indicates whether an overflow occurs during operation.  0: Overflow does not occur.  1: Overflow occurs.                                                                                                                                                                                                                                                                                                                                                                     |
| 1            | S <sup>Note</sup>   | Indicates whether the result of an operation is negative.  0: The result is positive or 0.  1: The result is negative.                                                                                                                                                                                                                                                                                                                                                       |
| 0            | Z                   | Indicates whether the result of an operation is 0.  0: The result is not 0.  1: The result is 0.                                                                                                                                                                                                                                                                                                                                                                             |

**Remark** Also read **Note** on the next page.

(2/2)

**Note** The result of the operation that has performed saturation processing is determined by the contents of the OV and S flags. The SAT flag is set to 1 only when the OV flag is set to 1 when a saturation operation is performed.

| Status of operation result               |                  | Result of operation of |   |                         |
|------------------------------------------|------------------|------------------------|---|-------------------------|
|                                          | SAT              | OV                     | S | saturation processing   |
| Maximum positive value is exceeded       | 1                | 1                      | 0 | 7FFFFFFH                |
| Maximum negative value is exceeded       | 1                | 1                      | 1 | 80000000H               |
| Positive (maximum value is not exceeded) | Holds value      | 0                      | 0 | Operation result itself |
| Negative (maximum value is not exceeded) | before operation |                        | 1 |                         |

## (5) CALLT execution status saving registers (CTPC and CTPSW)

CTPC and CTPSW are CALLT execution status saving registers.

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

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

The current contents of the PSW are saved to CTPSW.

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



### (6) Exception/debug trap status saving registers (DBPC and DBPSW)

DBPC and DBPSW are exception/debug trap status registers.

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

The contents to be saved to DBPC are the address of the instruction next to the one that is being executed when an exception trap or debug trap occurs.

The current contents of the PSW are saved to DBPSW.

This register can be read or written only during the interval between the execution of the DBTRAP instruction or illegal opcode and DBRET instruction execution.

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

The value of DBPC is restored to the PC and the value of DBPSW to the PSW by the DBRET instruction.



### (7) CALLT base pointer (CTBP)

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

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



# 3.3 Operation Modes

The V850ES/SG2 has the following operation modes.

#### (1) Normal operation mode

In this mode, each pin related to the bus interface is set to the port mode after system reset has been released. Execution branches to the reset entry address of the internal ROM, and then instruction processing is started.

### (2) Flash memory programming mode

In this mode, the internal flash memory can be programmed by using a flash programmer.

The following products are on-chip flash memory versions of the V850ES/SG2.

• μPD70F3263HY, 70F3273HY, 70F3283HY

# (3) On-chip debug mode

The V850ES/SG2 is provided with an on-chip debug function that employs the JTAG (Joint Test Action Group) communication specifications and that is executed via an N-Wire emulator.

The on-chip debug function is provided only in the flash memory versions.

For details, see CHAPTER 30 ON-CHIP DEBUG FUNCTION.

## 3.3.1 Specifying operation mode

Specify the operation mode by using the FLMD0 and FLMD1 pins.

In the normal mode, make sure that a low level is input to the FLMD0/IC when reset is released.

In the flash memory programming mode, a high level is input to the FLMD0 pin from the flash programmer if a flash programmer is connected, but it must be input from an external circuit in the self-programming mode.

| Operation When F | Reset Is Released | Operation Mode After Reset    |
|------------------|-------------------|-------------------------------|
| FLMD0            | FLMD1             |                               |
| L                | ×                 | Normal operation mode         |
| H L              |                   | Flash memory programming mode |
| Н                | Н                 | Setting prohibited            |

Remark L: Low-level input

H: High-level input

×: Don't care

# 3.4 Address Space

# 3.4.1 CPU address space

For addressing instruction addresses, up to 64 MB of external memory area, internal ROM area, and internal RAM area in an area of up to 16 MB of linear address space (program space) is supported. Up to 4 GB of linear address space (data space) is supported for operand addressing (data access). In the 4 GB address space, it seems that there are sixty-four 64 MB physical address spaces. This means that the same 64 MB physical address space is accessed, regardless of the values of bits 31 to 26.



Figure 3-1. Image on Address Space

### 3.4.2 Wraparound of CPU address space

# (1) Program space

Of the 32 bits of the PC (program counter), the higher 6 bits are fixed to 0 and only the lower 26 bits are valid. The higher 6 bits ignore a carry or borrow from bit 25 to 26 during branch address calculation.

Therefore, the highest address of the program space, 03FFFFFH, and the lowest address, 00000000H, are contiguous addresses. That the highest address and the lowest address of the program space are contiguous in this way is called wraparound.

Caution Because the 4 KB area of addresses 03FFF000H to 03FFFFFH is an on-chip peripheral I/O area, instructions cannot be fetched from this area. Therefore, do not execute an operation in which the result of a branch address calculation affects this area.



# (2) Data space

The result of an operand address calculation operation that exceeds 32 bits is ignored.

Therefore, the highest address of the data space, FFFFFFFH, and the lowest address, 00000000H, are contiguous, and wraparound occurs at the boundary of these addresses.



#### 3.4.3 Memory map

The areas shown below are reserved in the V850ES/SG2.

03FFFFFFH 03FFFFFFH On-chip peripheral I/O area (4 KB) 03FFF000H (80 KB) 03FFEFFFH 03FEC000H 03FEBFFFH Internal RAM area (60 KB) 03FF0000H 03FEFFFFH Use prohibited Use prohibitedNote 1 03FEF000H 03FEEFFFH Programmable peripheral I/O area<sup>Note 2</sup> or use prohibited<sup>Note 3</sup> 01000000H 03FEC000H 00FFFFFFH External memory area (14 MB) 001FFFFFH External memory area (1 MB) 00100000H00200000H 001FFFFFH 000FFFFFH Internal ROM area Note 4 (2 MB) (1 MB) 0000000H 0000000H

Figure 3-2. Data Memory Map (Physical Addresses)

- **Notes 1.** Use of addresses 03FEF000H to 03FEFFFFH is prohibited because these addresses are in the same area as the on-chip peripheral I/O area.
  - 2. Only the programmable peripheral I/O area can be viewed in the 4 GB address space as the image in 256 MB unit.
  - **3.** Addresses 03FEC000H to 03FECBFFH are allocated to addresses 03FEC000H to 03FEFFFH of the CAN controller version as a programmable peripheral I/O area. Use of these addresses in a version without a CAN controller is prohibited.
  - **4.** Fetch access and read access to addresses 00000000H to 000FFFFH is made to the internal ROM area. However, data write access to these addresses is made to the external memory area.

Figure 3-3. Program Memory Map

| 03FFFFFH<br>03FFF000H<br>03FFEFFFH                          | Use prohibited (program fetch prohibited area)                |  |
|-------------------------------------------------------------|---------------------------------------------------------------|--|
|                                                             | Internal RAM area (60 KB)                                     |  |
| 03FF0000H<br>03FEFFFFH<br>01000000H                         | Use prohibited (program fetch prohibited area)                |  |
| 00FFFFFH                                                    |                                                               |  |
|                                                             | External memory area<br>(14 MB)                               |  |
| 00200000H<br>001FFFFH<br>00100000H<br>000FFFFH<br>00000000H | External memory area<br>(1 MB)<br>Internal ROM area<br>(1 MB) |  |

#### 3.4.4 Areas

# (1) Internal ROM area

Up to 1 MB is reserved as an internal ROM area.

# (a) Internal ROM (512 KB)

512 KB mask ROM is allocated to addresses 00000000H to 0007FFFFH in the following versions. Accessing addresses 00080000H to 000FFFFFH is prohibited.

• μPD703262HY, 703272HY, 703282HY

Figure 3-4. Internal ROM Area (512 KB)



# (b) Internal ROM (640 KB)

640 KB mask ROM or flash memory is allocated to addresses 00000000H to 0009FFFFH in the following versions.

Accessing addresses 000A0000H to 000FFFFFH is prohibited.

•  $\mu$ PD703263HY, 703273HY, 703283HY, 70F3263HY, 70F3273HY, 70F3283HY

Figure 3-5. Internal ROM Area (640 KB)



### (2) Internal RAM area

Up to 60 KB are reserved as the internal RAM area.

#### (a) Internal RAM (40 KB)

40 KB RAM is allocated to addresses 03FF5000H to 03FFEFFFH of the following versions. Accessing addresses 03FF0000H to 03FF4FFFH is prohibited.

• μPD703262HY, 703272HY, 703282HY

Figure 3-6. Internal RAM Area (40 KB)



# (b) Internal RAM area (48 KB)

48 KB RAM is allocated to addresses 03FF3000H to 03FFEFFFH of the following versions. Accessing addresses 03FF0000H to 03FF2FFFH is prohibited.

• μPD703263HY, 703273HY, 703283HY, 70F3263HY, 70F3273HY, 70F3283HY

Figure 3-7. Internal RAM Area (48 KB)



### (3) On-chip peripheral I/O area

4 KB of addresses 03FFF000H to 03FFFFFFH are reserved as the on-chip peripheral I/O area.

Figure 3-8. On-Chip Peripheral I/O Area



Peripheral I/O registers that have functions to specify the operation mode for and monitor the status of the on-chip peripheral I/O are mapped to the on-chip peripheral I/O area. Program cannot be fetched from this area.

- Cautions 1. When a register is accessed in word units, a word area is accessed twice in halfword units in the order of lower area and higher area, with the lower 2 bits of the address ignored.
  - 2. If a register that can be accessed in byte units is accessed in halfword units, the higher 8 bits are undefined when the register is read, and data is written to the lower 8 bits.
  - 3. Addresses not defined as registers are reserved for future expansion. The operation is undefined and not guaranteed when these addresses are accessed.

### (4) Programmable peripheral I/O area

- Cautions 1. The programmable peripheral I/O area exists only in the CAN controller versions. This area cannot be used with products that are not equipped with the CAN controller.
  - 2. Only the programmable peripheral I/O area is seen as images of 256 MB each in the 4 GB address space.

12 KB of addresses 03FEC000H to 03FEEFFFH are reserved as the programmable peripheral I/O area.

Figure 3-9. Programmable Peripheral I/O Area



## (5) External memory area

15 MB (00100000H to 00FFFFFFH) are allocated as the external memory area. For details, see **CHAPTER 5 BUS CONTROL FUNCTION**.

Caution The V850ES/SG2 has 22 address pins (A0 to A21), so the external memory area appears as a repeated 4 MB image. When 22 address pins are used, it is necessary that EVDD = BVDD = VDD.

#### 3.4.5 Recommended use of address space

The architecture of the V850ES/SG2 requires that a register that serves as a pointer be secured for address generation when operand data in the data space is accessed. The address stored in this pointer ±32 KB can be directly accessed by an instruction for operand data. Because the number of general-purpose registers that can be used as a pointer is limited, however, by keeping the performance from dropping during address calculation when a pointer value is changed, as many general-purpose registers as possible can be secured for variables, and the program size can be reduced.

#### (1) Program space

Of the 32 bits of the PC (program counter), the higher 6 bits are fixed to 0, and only the lower 26 bits are valid. Regarding the program space, therefore, a 64 MB space of contiguous addresses starting from 00000000H unconditionally corresponds to the memory map.

To use the internal RAM area as the program space, access the following addresses.

Caution If a branch instruction is at the upper limit of the internal RAM area, a prefetch operation (invalid fetch) straddling the on-chip peripheral I/O area does not occur.

| RAM Size | Access Address         |
|----------|------------------------|
| 48 KB    | 03FF3000H to 03FFEFFFH |
| 40 KB    | 03FF5000H to 03FFEFFFH |

## (2) Data space

With the V850ES/SG2, it seems that there are sixty-four 64 MB address spaces on the 4 GB CPU address space. Therefore, the least significant bit (bit 25) of a 26-bit address is sign-extended to 32 bits and allocated as an address.

### (a) Application example of wraparound

If R = r0 (zero register) is specified for the LD/ST disp16 [R] instruction, a range of addresses 00000000H  $\pm 32$  KB can be addressed by sign-extended disp16. All the resources, including the internal hardware, can be addressed by one pointer.

The zero register (r0) is a register fixed to 0 by hardware, and practically eliminates the need for registers dedicated to pointers.





Figure 3-10. Recommended Memory Map

**Note** In the CAN controller version, the data space of addresses 03FEC000H to 03FEEFFFH is assigned as the programmable peripheral I/O area. Only the programmable peripheral I/O area is seen as images of 256 MB each in the 4 GB address space.

**Remarks 1.** indicates the recommended area.

**2.** This figure is the recommended memory map of the  $\mu$ PD703263HY.

# 3.4.6 Peripheral I/O registers

(1/11)

| Address   | Function Register Name                      | Symbol                | R/W | Manipulata |           | le Bits  | Default Value           |
|-----------|---------------------------------------------|-----------------------|-----|------------|-----------|----------|-------------------------|
|           |                                             |                       |     | 1          | 8         | 16       |                         |
| FFFFF004H | Port DL register                            | PDL                   | R/W |            |           | <b>V</b> | 0000H <sup>Note 1</sup> |
| FFFF004H  | Port DL register L                          | PDLL                  |     | √          | √         |          | 00H <sup>Note 1</sup>   |
| FFFFF005H | Port DL register H                          | PDLH                  |     | √          |           |          | 00H <sup>Note 1</sup>   |
| FFFFF006H | Port DH register                            | PDH                   |     | √          |           |          | 00H <sup>Note 1</sup>   |
| FFFF00AH  | Port CT register                            | PCT                   |     | √          | $\sqrt{}$ |          | 00H <sup>Note 1</sup>   |
| FFFFF00CH | Port CM register                            | PCM                   |     | √          |           |          | 00H <sup>Note 1</sup>   |
| FFFFF024H | Port DL mode register                       | PMDL                  |     |            |           | <b>V</b> | FFFFH                   |
| FFFFF024H | Port DL mode register L                     | PMDLL                 |     | √          |           |          | FFH                     |
| FFFFF025H | Port DL mode register H                     | PMDLH                 |     | √          |           |          | FFH                     |
| FFFFF026H | Port DH mode register                       | PMDH                  |     | √          | √         |          | FFH                     |
| FFFFF02AH | Port CT mode register                       | PMCT                  |     | √          | $\sqrt{}$ |          | FFH                     |
| FFFFF02CH | Port CM mode register                       | PMCM                  |     | √          | $\sqrt{}$ |          | FFH                     |
| FFFFF044H | Port DL mode control register               | PMCDL                 |     |            |           | √        | 0000H                   |
| FFFFF044H | Port DL mode control register L             | PMCDLL                |     | √          | √         |          | 00H                     |
| FFFFF045H | Port DL mode control register H             | PMCDLH                |     | √          | √         |          | 00H                     |
| FFFFF046H | Port DH mode control register               | PMCDH                 |     | √          | $\sqrt{}$ |          | 00H                     |
| FFFFF04AH | Port CT mode control register               | PMCCT                 |     | √          | √         |          | 00H                     |
| FFFFF04CH | Port CM mode control register               | PMCCM                 |     | √          | √         |          | 00H                     |
| FFFFF064H | Peripheral I/O area select control register | BPC <sup>Note 2</sup> |     |            |           | √        | 0000H                   |
| FFFFF066H | Bus size configuration register             | BSC                   |     |            |           | √        | 5555H                   |
| FFFFF06EH | System wait control register                | VSWC                  |     |            | √         |          | 77H                     |
| FFFFF080H | DMA source address register 0L              | DSA0L                 |     |            |           | √        | Undefined               |
| FFFFF082H | DMA source address register 0H              | DSA0H                 |     |            |           | √        | Undefined               |
| FFFFF084H | DMA destination address register 0L         | DDA0L                 |     |            |           | <b>V</b> | Undefined               |
| FFFFF086H | DMA destination address register 0H         | DDA0H                 |     |            |           | <b>V</b> | Undefined               |
| FFFFF088H | DMA source address register 1L              | DSA1L                 |     |            |           | √        | Undefined               |
| FFFF08AH  | DMA source address register 1H              | DSA1H                 |     |            |           | <b>V</b> | Undefined               |
| FFFFF08CH | DMA destination address register 1L         | DDA1L                 |     |            |           | <b>V</b> | Undefined               |
| FFFFF08EH | DMA destination address register 1H         | DDA1H                 |     |            |           | <b>V</b> | Undefined               |
| FFFFF090H | DMA source address register 2L              | DSA2L                 |     |            |           | <b>V</b> | Undefined               |
| FFFFF092H | DMA source address register 2H              | DSA2H                 |     |            |           | √        | Undefined               |
| FFFFF094H | DMA destination address register 2L         | DDA2L                 |     |            |           | <b>V</b> | Undefined               |
| FFFFF096H | DMA destination address register 2H         | DDA2H                 |     |            |           | <b>V</b> | Undefined               |
| FFFFF098H | DMA source address register 3L              | DSA3L                 |     |            |           | √        | Undefined               |
| FFFF09AH  | DMA source address register 3H              | DSA3H                 |     |            |           | <b>√</b> | Undefined               |
| FFFFF09CH | DMA destination address register 3L         | DDA3L                 |     |            |           | √        | Undefined               |
| FFFFF09EH | DMA destination address register 3H         | DDA3H                 |     |            |           | <b>V</b> | Undefined               |
| FFFFF0C0H | DMA transfer count register 0               | DBC0                  |     |            |           | <b>V</b> | Undefined               |
| FFFF0C2H  | DMA transfer count register 1               | DBC1                  |     |            |           | √        | Undefined               |
| FFFFF0C4H | DMA transfer count register 2               | DBC2                  |     |            |           | <b>V</b> | Undefined               |

**Notes 1.** The output latch is 00H or 0000H. When these registers are in the input mode, the pin statuses are read.

2. CAN controller versions only

(2/11)

|           | T                                 |          |     | 1            |           |    | (2/11         |
|-----------|-----------------------------------|----------|-----|--------------|-----------|----|---------------|
| Address   | Function Register Name            | Symbol   | R/W | Manip        | ulatab    | l  | Default Value |
|           |                                   |          |     | 1            | 8         | 16 |               |
| FFFFF0C6H | DMA transfer count register 3     | DBC3     | R/W |              |           | √, | Undefined     |
| FFFFF0D0H | DMA addressing control register 0 | DADC0    | 4   | -            |           | √, | 0000H         |
| FFFFF0D2H | DMA addressing control register 1 | DADC1    | 1   |              |           | √, | 0000H         |
| FFFFF0D4H | DMA addressing control register 2 | DADC2    | 1   |              |           | √. | 0000H         |
| FFFFF0D6H | DMA addressing control register 3 | DADC3    | _   |              |           | √  | 0000H         |
| FFFF0E0H  | DMA channel control register 0    | DCHC0    |     | √            | √         |    | 00H           |
| FFFFF0E2H | DMA channel control register 1    | DCHC1    |     |              | √         |    | 00H           |
| FFFFF0E4H | DMA channel control register 2    | DCHC2    | 1   |              | √         |    | 00H           |
| FFFFF0E6H | DMA channel control register 3    | DCHC3    |     |              | √         |    | 00H           |
| FFFFF100H | Interrupt mask register 0         | IMR0     |     |              |           | √  | FFFFH         |
| FFFFF100H | Interrupt mask register 0L        | IMR0L    |     | $\sqrt{}$    | √         |    | FFH           |
| FFFFF101H | Interrupt mask register 0H        | IMR0H    |     | $\sqrt{}$    | √         |    | FFH           |
| FFFFF102H | Interrupt mask register 1         | IMR1     |     |              |           | √  | FFFFH         |
| FFFFF102H | Interrupt mask register 1L        | IMR1L    |     | $\checkmark$ | √         |    | FFH           |
| FFFFF103H | Interrupt mask register 1H        | IMR1H    |     | $\sqrt{}$    | $\sqrt{}$ |    | FFH           |
| FFFF104H  | Interrupt mask register 2         | IMR2     |     |              |           | √  | FFFFH         |
| FFFFF104H | Interrupt mask register 2L        | IMR2L    |     | $\sqrt{}$    | $\sqrt{}$ |    | FFH           |
| FFFFF105H | Interrupt mask register 2H        | IMR2H    |     | $\sqrt{}$    | √         |    | FFH           |
| FFFFF106H | Interrupt mask register 3         | IMR3     |     |              |           | √  | FFFFH         |
| FFFFF106H | Interrupt mask register 3L        | IMR3L    |     | $\sqrt{}$    | √         |    | FFH           |
| FFFFF107H | Interrupt mask register 3H        | IMR3H    |     | $\checkmark$ | √         |    | FFH           |
| FFFFF112H | Interrupt control register        | PIC0     |     | √            | √         |    | 47H           |
| FFFFF114H | Interrupt control register        | PIC1     |     | $\sqrt{}$    | √         |    | 47H           |
| FFFFF116H | Interrupt control register        | PIC2     |     | $\sqrt{}$    | √         |    | 47H           |
| FFFFF118H | Interrupt control register        | PIC3     |     | $\sqrt{}$    | √         |    | 47H           |
| FFFFF11AH | Interrupt control register        | PIC4     |     | $\sqrt{}$    | √         |    | 47H           |
| FFFFF11CH | Interrupt control register        | PIC5     |     | $\checkmark$ | √         |    | 47H           |
| FFFFF11EH | Interrupt control register        | PIC6     |     | √            | √         |    | 47H           |
| FFFFF120H | Interrupt control register        | PIC7     |     | √            | √         |    | 47H           |
| FFFFF122H | Interrupt control register        | TQ00VIC  |     | √            | √         |    | 47H           |
| FFFFF124H | Interrupt control register        | TQ0CCIC0 |     | √            | √         |    | 47H           |
| FFFFF126H | Interrupt control register        | TQ0CCIC1 |     | $\sqrt{}$    | √         |    | 47H           |
| FFFFF128H | Interrupt control register        | TQ0CCIC2 |     | $\sqrt{}$    | √         |    | 47H           |
| FFFFF12AH | Interrupt control register        | TQ0CCIC3 |     | √            | √         |    | 47H           |
| FFFFF12CH | Interrupt control register        | TP00VIC  |     | √            | √         |    | 47H           |
| FFFFF12EH | Interrupt control register        | TP0CCIC0 |     | √            | √         |    | 47H           |
| FFFFF130H | Interrupt control register        | TP0CCIC1 | 1   | √            | √         |    | 47H           |
| FFFFF132H | Interrupt control register        | TP10VIC  | 1   | √            | √         |    | 47H           |
| FFFFF134H | Interrupt control register        | TP1CCIC0 | 1   | √            | √         |    | 47H           |
| FFFFF136H | Interrupt control register        | TP1CCIC1 | 1   | √            | √         |    | 47H           |
| FFFFF138H | Interrupt control register        | TP2OVIC  | 1   |              | <b>√</b>  |    | 47H           |
| FFFFF13AH | Interrupt control register        | TP2CCIC0 | 1   | <b>√</b>     | √         |    | 47H           |
| FFFFF13CH | Interrupt control register        | TP2CCIC1 | 1   | <b>√</b>     | √         |    | 47H           |

(3/11)

| Address   | Function Register Name     | Symbol                                                | R/W | Manipulatable Bits |          | le Bits | Default Value |
|-----------|----------------------------|-------------------------------------------------------|-----|--------------------|----------|---------|---------------|
|           |                            | ,                                                     |     | 1                  | 8        | 16      |               |
| FFFFF13EH | Interrupt control register | TP3OVIC                                               | R/W | √                  | V        |         | 47H           |
| FFFFF140H | Interrupt control register | TP3CCIC0                                              |     | √                  | √        |         | 47H           |
| FFFFF142H | Interrupt control register | TP3CCIC1                                              |     | √                  | √        |         | 47H           |
| FFFFF144H | Interrupt control register | TP40VIC                                               |     | √                  | √        |         | 47H           |
| FFFFF146H | Interrupt control register | TP4CCIC0                                              |     | √                  | √        |         | 47H           |
| FFFFF148H | Interrupt control register | TP4CCIC1                                              |     | √                  | √        |         | 47H           |
| FFFFF14AH | Interrupt control register | TP5OVIC                                               |     | √                  | √        |         | 47H           |
| FFFFF14CH | Interrupt control register | TP5CCIC0                                              |     | √                  | √        |         | 47H           |
| FFFFF14EH | Interrupt control register | TP5CCIC1                                              |     | √                  | √        |         | 47H           |
| FFFFF150H | Interrupt control register | TM0EQIC0                                              |     | √                  | √        |         | 47H           |
| FFFFF152H | Interrupt control register | CB0RIC/IICIC1                                         |     | √                  | √        |         | 47H           |
| FFFFF154H | Interrupt control register | CB0TIC                                                |     | √                  | √        |         | 47H           |
| FFFFF156H | Interrupt control register | CB1RIC                                                |     | √                  | √        |         | 47H           |
| FFFFF158H | Interrupt control register | CB1TIC                                                |     | √                  | √        |         | 47H           |
| FFFFF15AH | Interrupt control register | CB2RIC                                                |     | √                  | √        |         | 47H           |
| FFFFF15CH | Interrupt control register | CB2TIC                                                |     | √                  | √        |         | 47H           |
| FFFFF15EH | Interrupt control register | CB3RIC                                                |     | √                  | √        |         | 47H           |
| FFFFF160H | Interrupt control register | CB3TIC                                                |     | √                  | √        |         | 47H           |
| FFFFF162H | Interrupt control register | UA0RIC/CB4RIC                                         |     | √                  | √        |         | 47H           |
| FFFFF164H | Interrupt control register | UA0TIC/CB4TIC                                         |     | √                  | √        |         | 47H           |
| FFFFF166H | Interrupt control register | UA1RIC/IICIC2                                         |     | √                  | √        |         | 47H           |
| FFFFF168H | Interrupt control register | UA1TIC                                                |     | √                  | √        |         | 47H           |
| FFFFF16AH | Interrupt control register | UA2RIC/IICIC0                                         |     | √                  | √        |         | 47H           |
| FFFFF16CH | Interrupt control register | UA2TIC                                                |     | √                  | √        |         | 47H           |
| FFFFF16EH | Interrupt control register | ADIC                                                  |     | √                  | √        |         | 47H           |
| FFFFF170H | Interrupt control register | DMAIC0                                                |     | √                  | √        |         | 47H           |
| FFFFF172H | Interrupt control register | DMAIC1                                                |     | √                  | √        |         | 47H           |
| FFFFF174H | Interrupt control register | DMAIC2                                                |     | $\sqrt{}$          | √        |         | 47H           |
| FFFFF176H | Interrupt control register | DMAIC3                                                |     | $\sqrt{}$          | √        |         | 47H           |
| FFFFF178H | Interrupt control register | KRIC                                                  |     | $\sqrt{}$          | √        |         | 47H           |
| FFFFF17AH | Interrupt control register | WTIIC                                                 |     | $\sqrt{}$          | √        |         | 47H           |
| FFFFF17CH | Interrupt control register | WTIC                                                  |     | $\sqrt{}$          | <b>√</b> |         | 47H           |
| FFFFF17EH | Interrupt control register | ERRIC0 <sup>Note 1</sup> / ERRIC <sup>Note 2</sup>    |     | <b>V</b>           | √        |         | 47H           |
| FFFFF180H | Interrupt control register | WUPIC0 <sup>Note 1</sup> /<br>STAIC <sup>Note 2</sup> |     | √                  | <b>V</b> |         | 47H           |
| FFFFF182H | Interrupt control register | RECICO <sup>Note 1</sup> / IEIC1 <sup>Note 2</sup>    |     | √                  | <b>V</b> |         | 47H           |
| FFFFF184H | Interrupt control register | TRXIC0 <sup>Note 1</sup> / IEIC2 <sup>Note 2</sup>    |     | √                  | <b>V</b> |         | 47H           |

Notes 1. CAN controller versions only

2. IEBus controller versions only

(4/11)

| Address   | Function Register Name                            | Symbol    | R/W | Manip    | Manipulatable Bits |          | (4/11<br>Default Value |
|-----------|---------------------------------------------------|-----------|-----|----------|--------------------|----------|------------------------|
|           | -                                                 |           |     | 1        | 8                  | 16       |                        |
| FFFFF1FAH | In-service priority register                      | ISPR      | R   | √        | <b>√</b>           |          | 00H                    |
| FFFFF1FCH | Command register                                  | PRCMD     | W   |          | V                  |          | Undefined              |
| FFFFF1FEH | Power save control register                       | PSC       | R/W | <b>V</b> | <b>√</b>           |          | 00H                    |
| FFFFF200H | A/D converter mode register 0                     | ADA0M0    |     | √        | √                  |          | 00H                    |
| FFFFF201H | A/D converter mode register 1                     | ADA0M1    |     | √        | √                  |          | 00H                    |
| FFFFF202H | A/D converter channel specification register      | ADA0S     |     | √        | √                  |          | 00H                    |
| FFFFF203H | A/D converter mode register 2                     | ADA0M2    |     | √        | √                  |          | 00H                    |
| FFFFF204H | Power-fail compare mode register                  | ADA0PFM   |     | √        | <b>V</b>           |          | 00H                    |
| FFFFF205H | Power-fail compare threshold value register       | ADA0PFT   |     | √        | <b>√</b>           |          | 00H                    |
| FFFFF210H | A/D conversion result register 0                  | ADA0CR0   | R   |          |                    | <b>V</b> | Undefined              |
| FFFFF211H | A/D conversion result register 0H                 | ADA0CR0H  |     |          | $\sqrt{}$          |          | Undefined              |
| FFFFF212H | A/D conversion result register 1                  | ADA0CR1   |     |          |                    | √        | Undefined              |
| FFFFF213H | A/D conversion result register 1H                 | ADA0CR1H  |     |          | <b>V</b>           |          | Undefined              |
| FFFFF214H | A/D conversion result register 2                  | ADA0CR2   |     |          |                    | √        | Undefined              |
| FFFFF215H | A/D conversion result register 2H                 | ADA0CR2H  |     |          | √                  |          | Undefined              |
| FFFFF216H | A/D conversion result register 3                  | ADA0CR3   |     |          |                    | √        | Undefined              |
| FFFFF217H | A/D conversion result register 3H                 | ADA0CR3H  |     |          | √                  |          | Undefined              |
| FFFFF218H | A/D conversion result register 4                  | ADA0CR4   |     |          |                    | √        | Undefined              |
| FFFFF219H | A/D conversion result register 4H                 | ADA0CR4H  |     |          | √                  |          | Undefined              |
| FFFF21AH  | A/D conversion result register 5                  | ADA0CR5   |     |          |                    | √        | Undefined              |
| FFFFF21BH | A/D conversion result register 5H                 | ADA0CR5H  |     |          | √                  |          | Undefined              |
| FFFFF21CH | A/D conversion result register 6                  | ADA0CR6   |     |          |                    | √        | Undefined              |
| FFFFF21DH | A/D conversion result register 6H                 | ADA0CR6H  |     |          | √                  |          | Undefined              |
| FFFFF21EH | A/D conversion result register 7                  | ADA0CR7   |     |          |                    | √        | Undefined              |
| FFFFF21FH | A/D conversion result register 7H                 | ADA0CR7H  |     |          | <b>√</b>           |          | Undefined              |
| FFFFF220H | A/D conversion result register 8                  | ADA0CR8   |     |          |                    | √        | Undefined              |
| FFFFF221H | A/D conversion result register 8H                 | ADA0CR8H  |     |          | <b>√</b>           |          | Undefined              |
| FFFFF222H | A/D conversion result register 9                  | ADA0CR9   |     |          |                    | √        | Undefined              |
| FFFFF223H | A/D conversion result register 9H                 | ADA0CR9H  |     |          | <b>√</b>           |          | Undefined              |
| FFFFF224H | A/D conversion result register 10                 | ADA0CR10  |     |          |                    | √        | Undefined              |
| FFFFF225H | A/D conversion result register 10H                | ADA0CR10H |     |          | <b>√</b>           |          | Undefined              |
| FFFFF226H | A/D conversion result register 11                 | ADA0CR11  |     |          |                    | √        | Undefined              |
| FFFFF227H | A/D conversion result register 11H                | ADA0CR11H |     |          | $\sqrt{}$          |          | Undefined              |
| FFFFF280H | D/A converter conversion value setting register 0 | DA0CS0    | R/W |          | <b>√</b>           |          | 00H                    |
| FFFFF281H | D/A converter conversion value setting register 1 | DA0CS1    |     |          | <b>√</b>           |          | 00H                    |
| FFFFF282H | D/A converter mode register                       | DA0M      |     | √        | <b>√</b>           |          | 00H                    |
| FFFFF300H | Key return mode register                          | KRM       |     | √        | <b>√</b>           |          | 00H                    |
| FFFFF308H | Selector operation control register               | SELCNT0   | 1   | √        | √                  |          | 00H                    |
| FFFFF310H | CRC input register                                | CRCIN     | 1   |          | √                  |          | 00H                    |
| FFFFF312H | CRC data register                                 | CRCD      | 7   |          |                    | <b>√</b> | 0000H                  |
| FFFFF318H | Noise elimination control register                | NFC       | 7   |          | √                  |          | 00H                    |
| FFFFF320H | BRG1 prescaler mode register                      | PRSM1     | 1   | √        | √                  |          | 00H                    |
| FFFFF321H | BRG1 prescaler compare register                   | PRSCM1    | 7   |          | √                  |          | 00H                    |

(5/11)

| Address   | Function Register Name               | Symbol                  | R/W | Manip    | oulatab   | le Bits  | Default Value           |
|-----------|--------------------------------------|-------------------------|-----|----------|-----------|----------|-------------------------|
|           | , and an angle of the same           | ,,,,,,,,,,              |     | 1        | 8         | 16       |                         |
| FFFFF324H | BRG2 prescaler mode register         | PRSM2                   | R/W | √        | √         |          | 00H                     |
| FFFFF325H | BRG2 prescaler compare register      | PRSCM2                  |     | <u> </u> | √         |          | 00H                     |
| FFFFF328H | BRG3 prescaler mode register         | PRSM3                   |     |          | √         |          | 00H                     |
| FFFFF329H | BRG3 prescaler compare register      | PRSCM3                  |     |          | √         |          | 00H                     |
| FFFFF340H | IIC division clock select register   | OCKS0                   | 1   |          | <b>√</b>  |          | 00H                     |
| FFFFF344H | IIC division clock select register   | OCKS1                   |     |          | √         |          | 00H                     |
| FFFFF348H | IEBus clock select register          | OCKS2 <sup>Note 1</sup> | 1   |          | <b>√</b>  |          | 00H                     |
| FFFFF360H | IEBus control register               | BCR <sup>Note 1</sup>   | 1   | √        | <b>V</b>  |          | 00H                     |
| FFFFF361H | IEBus power save register            | PSR <sup>Note 1</sup>   | 1   | √        | <b>√</b>  |          | 00H                     |
| FFFFF362H | IEBus slave status register          | SSR <sup>Note 1</sup>   | R   | <b>√</b> | <b>V</b>  |          | 81H                     |
| FFFFF363H | IEBus unit status register           | USR <sup>Note 1</sup>   |     | <b>√</b> | <b>√</b>  |          | 00H                     |
| FFFFF364H | IEBus interrupt status register      | ISR <sup>Note 1</sup>   | R/W | √        | <b>√</b>  |          | 00H                     |
| FFFFF365H | IEBus error status register          | ESR <sup>Note 1</sup>   |     | √        | √         |          | 00H                     |
| FFFFF366H | IEBus unit address register          | UAR <sup>Note 1</sup>   |     |          |           | V        | 0000H                   |
| FFFFF368H | IEBus slave address register         | SAR <sup>Note 1</sup>   |     |          |           | √        | 0000H                   |
| FFFFF36AH | IEBus partner address register       | PAR <sup>Note 1</sup>   | R   |          |           | √        | 0000H                   |
| FFFFF36CH | IEBus receive slave address register | RSA <sup>Note 1</sup>   |     |          |           | √<br>√   | 0000H                   |
| FFFFF36EH | IEBus control data register          | CDR <sup>Note 1</sup>   | R/W |          | <b>√</b>  |          | 00H                     |
| FFFFF36FH | IEBus telegraph length register      | DLR <sup>Note 1</sup>   |     |          | √         |          | 01H                     |
| FFFFF370H | IEBus data register                  | DR <sup>Note 1</sup>    | 1   |          | <b>√</b>  |          | 00H                     |
| FFFFF371H | IEBus field status register          | FSR <sup>Note 2</sup>   | R   |          | <b>V</b>  |          | 00H                     |
| FFFFF372H | IEBus success count register         | SCR <sup>Note 1</sup>   | 1   |          | <b>V</b>  |          | 01H                     |
| FFFFF373H | IEBus communication count register   | CCR <sup>Note 1</sup>   |     |          | <b>√</b>  |          | 20H                     |
| FFFFF400H | Port 0 register                      | P0                      | R/W | √        | <b>√</b>  |          | 00H <sup>Note 2</sup>   |
| FFFFF402H | Port 1 register                      | P1                      |     | <b>√</b> | <b>√</b>  |          | 00H <sup>Note 2</sup>   |
| FFFFF406H | Port 3 register                      | P3                      |     |          |           | √        | 0000H <sup>Note 2</sup> |
| FFFFF406H | Port 3 register L                    | P3L                     |     | <b>√</b> | <b>V</b>  |          | 00H <sup>Note 2</sup>   |
| FFFFF407H | Port 3 register H                    | РЗН                     |     |          | <b>√</b>  |          | 00H <sup>Note 2</sup>   |
| FFFFF408H | Port 4 register                      | P4                      |     |          | <b>√</b>  |          | 00H <sup>Note 2</sup>   |
| FFFFF40AH | Port 5 register                      | P5                      |     | √        | √         |          | 00H <sup>Note 2</sup>   |
| FFFFF40EH | Port 7 register L                    | P7L                     |     |          | <b>√</b>  |          | 00H <sup>Note 2</sup>   |
| FFFFF40FH | Port 7 register H                    | P7H                     |     | √        | √         |          | 00H <sup>Note 2</sup>   |
| FFFFF412H | Port 9 register                      | P9                      |     |          |           | √        | 0000H <sup>Note 2</sup> |
| FFFFF412H | Port 9 register L                    | P9L                     | 1   | <b>√</b> | <b>√</b>  |          | 00H <sup>Note 2</sup>   |
| FFFFF413H | Port 9 register H                    | Р9Н                     | 1   |          | $\sqrt{}$ |          | 00H <sup>Note 2</sup>   |
| FFFFF420H | Port 0 mode register                 | PM0                     | 1   | <b>√</b> | <b>√</b>  |          | FFH                     |
| FFFFF422H | Port 1 mode register                 | PM1                     | 1   | <b>√</b> | <b>V</b>  |          | FFH                     |
| FFFFF426H | Port 3 mode register                 | PM3                     | 1   |          |           | <b>√</b> | FFFFH                   |
| FFFFF426H | Port 3 mode register L               | PM3L                    | 1   | √        | <b>√</b>  |          | FFH                     |
| FFFFF427H | Port 3 mode register H               | PM3H                    | 1   | \<br>√   | \<br>√    |          | FFH                     |
| FFFFF428H | Port 4 mode register                 | PM4                     | 1   | \<br>√   | <b>√</b>  |          | FFH                     |

# Notes 1. IEBus controller versions only

2. The output latch is 00H or 0000H. When these registers are input, the pin statuses are read.

(6/11)

| Address   | Function Register Name             | Symbol  | R/W    | Manipulatable Bits |           | (6/11<br>Default Value |               |
|-----------|------------------------------------|---------|--------|--------------------|-----------|------------------------|---------------|
| Addiess   | r unction register wante           | Symbol  | 11/ ۷۷ | 1                  | 8         | 16                     | Delault value |
| FFFFF42AH | Port 5 mode register               | PM5     | R/W    | √                  | √         | 10                     | FFH           |
| FFFFF42EH | Port 7 mode register L             | PM7L    | 1      | ·<br>√             | ·<br>√    |                        | FFH           |
| FFFFF42FH | Port 7 mode register H             | PM7H    | 1      | · √                | √         |                        | FFH           |
| FFFFF432H | Port 9 mode register               | PM9     | 1      |                    | ·         | V                      | FFFFH         |
| FFFFF432H | Port 9 mode register L             | PM9L    |        | <b>√</b>           | √         |                        | FFH           |
| FFFFF433H | Port 9 mode register H             | РМ9Н    |        | √                  | √         |                        | FFH           |
| FFFFF440H | Port 0 mode control register       | PMC0    |        | V                  | √         |                        | 00H           |
| FFFFF446H | Port 3 mode control register       | PMC3    | 1      |                    |           | √                      | 0000H         |
| FFFFF446H | Port 3 mode control register L     | PMC3L   |        | √                  | √         |                        | 00H           |
| FFFFF447H | Port 3 mode control register H     | РМС3Н   |        | V                  | √         |                        | 00H           |
| FFFFF448H | Port 4 mode control register       | PMC4    |        | √                  | √         |                        | 00H           |
| FFFFF44AH | Port 5 mode control register       | PMC5    |        | √                  | √         |                        | 00H           |
| FFFFF452H | Port 9 mode control register       | PMC9    |        |                    |           | √                      | 0000H         |
| FFFFF452H | Port 9 mode control register L     | PMC9L   |        | V                  | √         |                        | 00H           |
| FFFFF453H | Port 9 mode control register H     | PMC9H   |        | V                  | √         |                        | 00H           |
| FFFFF460H | Port 0 function control register   | PFC0    |        | V                  | √         |                        | 00H           |
| FFFFF466H | Port 3 function control register   | PFC3    |        |                    |           | √                      | 0000H         |
| FFFFF466H | Port 3 function control register L | PFC3L   |        |                    | √         |                        | 00H           |
| FFFFF467H | Port 3 function control register H | PFC3H   |        |                    | √         |                        | 00H           |
| FFFFF468H | Port 4 function control register   | PFC4    |        |                    | √         |                        | 00H           |
| FFFFF46AH | Port 5 function control register   | PFC5    |        |                    | √         |                        | 00H           |
| FFFFF472H | Port 9 function control register   | PFC9    |        |                    |           | √                      | 0000H         |
| FFFFF472H | Port 9 function control register L | PFC9L   |        | √                  | √         |                        | 00H           |
| FFFFF473H | Port 9 function control register H | PFC9H   |        | $\sqrt{}$          | √         |                        | 00H           |
| FFFFF484H | Data wait control register 0       | DWC0    |        |                    |           | √                      | 7777H         |
| FFFFF488H | Address wait control register      | AWC     |        |                    |           | √                      | FFFFH         |
| FFFFF48AH | Bus cycle control register         | BCC     |        |                    |           | $\sqrt{}$              | AAAAH         |
| FFFF540H  | TMQ0 control register 0            | TQ0CTL0 |        |                    | $\sqrt{}$ |                        | 00H           |
| FFFFF541H | TMQ0 control register 1            | TQ0CTL1 |        |                    | $\sqrt{}$ |                        | 00H           |
| FFFFF542H | TMQ0 I/O control register 0        | TQ0IOC0 |        |                    | $\sqrt{}$ |                        | 00H           |
| FFFFF543H | TMQ0 I/O control register 1        | TQ0IOC1 |        |                    | $\sqrt{}$ |                        | 00H           |
| FFFF544H  | TMQ0 I/O control register 2        | TQ0IOC2 |        |                    | $\sqrt{}$ |                        | 00H           |
| FFFFF545H | TMQ0 option register 0             | TQ0OPT0 |        | $\sqrt{}$          | √         |                        | 00H           |
| FFFFF546H | TMQ0 capture/compare register 0    | TQ0CCR0 |        |                    |           | √                      | 0000H         |
| FFFFF548H | TMQ0 capture/compare register 1    | TQ0CCR1 |        |                    |           | √                      | 0000H         |
| FFFF54AH  | TMQ0 capture/compare register 2    | TQ0CCR2 |        |                    |           | √                      | 0000H         |
| FFFFF54CH | TMQ0 capture/compare register 3    | TQ0CCR3 |        |                    |           | √                      | 0000H         |
| FFFFF54EH | TMQ0 counter read buffer register  | TQ0CNT  | R      |                    |           | √                      | 0000H         |
| FFFFF590H | TMP0 control register 0            | TP0CTL0 | R/W    | $\sqrt{}$          | √         |                        | 00H           |
| FFFFF591H | TMP0 control register 1            | TP0CTL1 | 1      |                    | √         |                        | 00H           |
| FFFFF592H | TMP0I/O control register 0         | TP0IOC0 |        |                    | $\sqrt{}$ |                        | 00H           |
| FFFFF593H | TMP0I/O control register 1         | TP0IOC1 |        |                    | √         |                        | 00H           |
| FFFFF594H | TMP0I/O control register 2         | TP0IOC2 |        | $\sqrt{}$          | $\sqrt{}$ |                        | 00H           |

(7/11)

| Address   | Function Register Name            | Symbol  | R/W      | Manin    | Manipulatable Bits |          | (7/11) Default Value |
|-----------|-----------------------------------|---------|----------|----------|--------------------|----------|----------------------|
| Addiess   | T undion riegister Name           | Cymbol  | 11/44    | 1        | 8 16               |          | Delault value        |
| FFFFF595H | TMP0 option register 0            | TP0OPT0 | R/W      | √        | √                  | 10       | 00H                  |
| FFFFF596H | TMP0 capture/compare register 0   | TP0CCR0 | 1        |          | ,                  | <b>√</b> | 0000H                |
| FFFFF598H | TMP0 capture/compare register 1   | TP0CCR1 | 1        |          |                    | ,<br>√   | 0000H                |
| FFFFF59AH | TMP0 counter read buffer register | TPOCNT  | R        |          |                    | ·<br>√   | 0000H                |
| FFFFF5A0H | TMP1 control register 0           | TP1CTL0 | R/W      | √        | √                  | · ·      | 00H                  |
| FFFFF5A1H | TMP1 control register 1           | TP1CTL1 | 1        | \<br>√   | · √                |          | 00H                  |
| FFFFF5A2H | TMP1I/O control register 0        | TP1IOC0 |          | √        | · √                |          | 00H                  |
| FFFFF5A3H | TMP1I/O control register 1        | TP1IOC1 |          | \<br>√   | · √                |          | 00H                  |
| FFFFF5A4H | TMP1I/O control register 2        | TP1IOC2 | -        | \<br>√   | ·<br>√             |          | 00H                  |
| FFFFF5A5H | TMP1 option register 0            | TP1OPT0 | -        | 1        | ·<br>√             |          | 00H                  |
| FFFFF5A6H | TMP1 capture/compare register 0   | TP1CCR0 | -        |          | ,                  | <b>√</b> | 0000H                |
| FFFFF5A8H | TMP1 capture/compare register 1   | TP1CCR1 | -        |          |                    | ,<br>√   | 0000H                |
| FFFFF5AAH | TMP1 counter read buffer register | TP1CNT  | R        |          |                    | ,<br>√   | 0000H                |
| FFFFF5B0H | TMP2 control register 0           | TP2CTL0 | R/W      | √        | <b>√</b>           |          | 00H                  |
| FFFFF5B1H | TMP2 control register 1           | TP2CTL1 | 1        | \\       | <b>√</b>           |          | 00H                  |
| FFFFF5B2H | TMP2I/O control register 0        | TP2IOC0 | -        | 1        | \<br>√             |          | 00H                  |
| FFFFF5B3H | TMP2I/O control register 1        | TP2IOC1 | -        | \\       | \<br>√             |          | 00H                  |
| FFFFF5B4H | TMP2I/O control register 2        | TP2IOC2 | -        | \\       | √                  |          | 00H                  |
| FFFFF5B5H | TMP2 option register 0            | TP2OPT0 | 1        | <b>√</b> | <b>√</b>           |          | 00H                  |
| FFFFF5B6H | TMP2 capture/compare register 0   | TP2CCR0 | 1        |          | ,                  | √        | 0000H                |
| FFFFF5B8H | TMP2 capture/compare register 1   | TP2CCR1 | 1        |          |                    | √<br>√   | 0000H                |
| FFFFF5BAH | TMP2 counter read buffer register | TP2CNT  | R        |          |                    | √ √      | 0000H                |
| FFFFF5C0H | TMP3 control register 0           | TP3CTL0 | R/W      | √        | <b>√</b>           | · ·      | 00H                  |
| FFFFF5C1H | TMP3 control register 1           | TP3CTL1 | - 11,777 | <b>√</b> | <b>√</b>           |          | 00H                  |
| FFFFF5C2H | TMP3I/O control register 0        | TP3IOC0 | -        | <b>√</b> | \<br>√             |          | 00H                  |
| FFFFF5C3H | TMP3I/O control register 1        | TP3IOC1 | -        | \\       | \<br>√             |          | 00H                  |
| FFFFF5C4H | TMP3I/O control register 2        | TP3IOC2 | -        | \\       | \<br>√             |          | 00H                  |
| FFFFF5C5H | TMP3 option register 0            | TP3OPT0 | -        | √<br>√   | \<br>√             |          | 00H                  |
| FFFFF5C6H | TMP3 capture/compare register 0   | TP3CCR0 | -        | ,        | '                  | <b>√</b> | 0000H                |
| FFFFF5C8H | TMP3 capture/compare register 1   | TP3CCR1 | -        |          |                    | ,<br>√   | 0000H                |
| FFFFF5CAH | TMP3 counter read buffer register | TP3CNT  | R        |          |                    | ,<br>√   | 0000H                |
| FFFFF5D0H | TMP4 control register 0           | TP4CTL0 | R/W      | √        | <b>√</b>           | · ·      | 00H                  |
| FFFFF5D1H | TMP4 control register 1           | TP4CTL1 | 1        | √        | · √                |          | 00H                  |
| FFFFF5D2H | TMP4I/O control register 0        | TP4IOC0 |          | \<br>√   | · √                |          | 00H                  |
| FFFFF5D3H | TMP4I/O control register 1        | TP4IOC1 |          | √        | · √                |          | 00H                  |
| FFFFF5D4H | TMP4I/O control register 2        | TP4IOC2 |          | √        | · √                |          | 00H                  |
| FFFFF5D5H | TMP4 option register 0            | TP4OPT0 |          | \<br>√   | · √                |          | 00H                  |
| FFFFF5D6H | TMP4 capture/compare register 0   | TP4CCR0 | -        |          | ,                  | √        | 0000H                |
| FFFFF5D8H | TMP4 capture/compare register 1   | TP4CCR1 | 1        |          |                    | √ √      | 0000H                |
| FFFFF5DAH | TMP4 counter read buffer register | TP4CNT  | R        |          |                    | √ √      | 0000H                |
| FFFFF5E0H | TMP5 control register 0           | TP5CTL0 | R/W      | √        | √                  | <u>'</u> | 00H                  |
| FFFFF5E1H | TMP5 control register 1           | TP5CTL1 | - ""     | <b>√</b> | \<br>√             |          | 00H                  |
| FFFFF5E2H | TMP5I/O control register 0        | TP5IOC0 | 1        | <b>√</b> | √<br>√             |          | 00H                  |
| FFFFF5E3H | TMP5I/O control register 1        | TP5IOC0 | 1        | √<br>√   | √<br>√             |          | 00H                  |
| TETESESE  | Tivii 370 control register 1      | 153001  |          | ٧        | V                  | <u> </u> | 0011                 |

(8/11)

| FFFF5E5H         TM           FFFF5E6H         TM           FFFF5E8H         TM           FFFF5EAH         TM           FFFF680H         Wa           FFFF690H         TM           FFFF694H         TM           FFFF6C0H         Os           FFFFF6C1H         PL           FFFFF6D1H         Wa         | Function Register Name  MP5I/O control register 2  MP5 option register 0  MP5 capture/compare register 0  MP5 capture/compare register 1  MP5 counter read buffer register  atch timer operation mode register  MM0 control register 0  MM0 compare register 0  scillation stabilization time select register  atchdog timer mode register 2  atchdog timer enable register  sal-time output buffer register 0L | Symbol  TP5IOC2 TP5OPT0 TP5CCR0 TP5CCR1 TP5CNT WTM TM0CTL0 TM0CMP0 OSTS PLLS WDTM2 | R/W R/W R | 1 \( \sqrt{1} \) | 8 \( \sqrt{1} \) | 16               | 32       | Default<br>Value<br>00H<br>00H<br>0000H<br>0000H<br>000H<br>00H |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-----------|------------------|------------------|------------------|----------|-----------------------------------------------------------------|
| FFFF5E5H TM FFFF5E6H TM FFFFF5E8H TM FFFFF680H Wa FFFFF690H TM FFFFF694H TM FFFFF6C0H Os FFFFF6C1H PL FFFFF6D1H Wa                                                                                                                                                                                          | MP5 option register 0 MP5 capture/compare register 0 MP5 capture/compare register 1 MP5 counter read buffer register atch timer operation mode register MM0 control register 0 MM0 compare register 0 scillation stabilization time select register atchdog timer mode register 2 atchdog timer enable register                                                                                                 | TP5OPT0 TP5CCR0 TP5CCR1 TP5CNT WTM TM0CTL0 TM0CMP0 OSTS PLLS                       | R         | √<br>√           | \[ \sqrt{1} \]   | \<br>\<br>\<br>\ | 32       | 00H<br>0000H<br>0000H<br>0000H<br>00H                           |
| FFFFF5E5H         TM           FFFFF5E6H         TM           FFFFF5E8H         TM           FFFFF5EAH         TM           FFFFF680H         Wa           FFFFF690H         TM           FFFFF694H         TM           FFFFF6C0H         Os           FFFFF6C1H         PL           FFFFF6D1H         Wa | MP5 option register 0 MP5 capture/compare register 0 MP5 capture/compare register 1 MP5 counter read buffer register atch timer operation mode register MM0 control register 0 MM0 compare register 0 scillation stabilization time select register atchdog timer mode register 2 atchdog timer enable register                                                                                                 | TP5OPT0 TP5CCR0 TP5CCR1 TP5CNT WTM TM0CTL0 TM0CMP0 OSTS PLLS                       | R         | √<br>√           | √<br>√<br>√      | √<br>√           |          | 00H<br>0000H<br>0000H<br>0000H<br>00H                           |
| FFFF5E6H         TM           FFFF5E8H         TM           FFFFF5EAH         TM           FFFFF680H         Wa           FFFFF690H         TM           FFFFF694H         TM           FFFFF6C0H         Os           FFFFF6C1H         PLI           FFFFF6D0H         Wa           FFFFF6D1H         Wa  | MP5 capture/compare register 0 MP5 capture/compare register 1 MP5 counter read buffer register atch timer operation mode register MM0 control register 0 MM0 compare register 0 scillation stabilization time select register atchdog timer mode register 2 atchdog timer enable register                                                                                                                       | TP5CCR0 TP5CCR1 TP5CNT WTM TM0CTL0 TM0CMP0 OSTS PLLS                               |           | <b>√</b>         | √<br>√           | √<br>√           |          | 0000H<br>0000H<br>0000H<br>00H                                  |
| FFFFF5E8H         TM           FFFFF5EAH         TM           FFFFF680H         Wa           FFFFF690H         TM           FFFFF694H         TM           FFFFF6C0H         Os           FFFFF6C1H         PL           FFFFF6D0H         Wa           FFFFF6D1H         Wa                                | MP5 capture/compare register 1 MP5 counter read buffer register atch timer operation mode register MM0 control register 0 MM0 compare register 0 scillation stabilization time select register L lockup time specification register atchdog timer mode register 2 atchdog timer enable register                                                                                                                 | TP5CCR1 TP5CNT WTM TM0CTL0 TM0CMP0 OSTS PLLS                                       |           |                  | √                | √<br>√           |          | 0000H<br>0000H<br>00H                                           |
| FFFFF6D1H  FFFFF6BAH  FFFFF690H  TM  FFFFF694H  FFFFF6C0H  FFFFF6C1H  FFFFF6D1H  Wa                                                                                                                                                                                                                         | MP5 counter read buffer register atch timer operation mode register MM0 control register 0 MM0 compare register 0 scillation stabilization time select register L lockup time specification register atchdog timer mode register 2 atchdog timer enable register                                                                                                                                                | TP5CNT WTM TM0CTL0 TM0CMP0 OSTS PLLS                                               |           |                  | √                | √                |          | 0000H<br>00H<br>00H                                             |
| FFFFF680H         Wa           FFFFF690H         TM           FFFFF694H         TM           FFFFF6C0H         Os           FFFFF6C1H         PLI           FFFFF6D0H         Wa           FFFFF6D1H         Wa                                                                                             | atch timer operation mode register  MM0 control register 0  MM0 compare register 0  scillation stabilization time select register  L lockup time specification register  atchdog timer mode register 2  atchdog timer enable register                                                                                                                                                                           | WTM TM0CTL0 TM0CMP0 OSTS PLLS                                                      |           |                  | √                |                  |          | 00H<br>00H                                                      |
| FFFFF690H TM FFFFF694H TM FFFFF6C0H Os FFFFF6C1H PLI FFFFF6D0H Wa FFFFF6D1H Wa                                                                                                                                                                                                                              | MM0 control register 0  MM0 compare register 0  scillation stabilization time select register  L lockup time specification register atchdog timer mode register 2  atchdog timer enable register                                                                                                                                                                                                                | TMOCTLO TMOCMPO OSTS PLLS                                                          | ri/ VV    |                  | √                | √                |          | 00H                                                             |
| FFFF694H TM FFFFF6C0H Os FFFFF6C1H PLI FFFFF6D0H Wa FFFFF6D1H Wa                                                                                                                                                                                                                                            | MM0 compare register 0 scillation stabilization time select register L lockup time specification register atchdog timer mode register 2 atchdog timer enable register                                                                                                                                                                                                                                           | TM0CMP0 OSTS PLLS                                                                  |           | V                |                  | <b>√</b>         |          | <u> </u>                                                        |
| FFFFF6C0H Os<br>FFFFF6C1H PLI<br>FFFFF6D0H Wa<br>FFFFF6D1H Wa                                                                                                                                                                                                                                               | scillation stabilization time select register  L lockup time specification register atchdog timer mode register 2 atchdog timer enable register                                                                                                                                                                                                                                                                 | OSTS<br>PLLS                                                                       |           |                  | √                | V                |          |                                                                 |
| FFFFF6C1H PLI<br>FFFFF6D0H Wa<br>FFFFF6D1H Wa                                                                                                                                                                                                                                                               | L lockup time specification register atchdog timer mode register 2 atchdog timer enable register                                                                                                                                                                                                                                                                                                                | PLLS                                                                               |           |                  | ٧                |                  |          | 0000H                                                           |
| FFFF6D0H Wa                                                                                                                                                                                                                                                                                                 | atchdog timer mode register 2<br>atchdog timer enable register                                                                                                                                                                                                                                                                                                                                                  |                                                                                    |           |                  | V                |                  |          | 06H                                                             |
| FFFF6D1H Wa                                                                                                                                                                                                                                                                                                 | atchdog timer enable register                                                                                                                                                                                                                                                                                                                                                                                   | WDTM2                                                                              |           |                  |                  |                  |          | 03H                                                             |
|                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                    |           |                  | 1                |                  |          | 67H                                                             |
| LEEEEEVEUH IDV                                                                                                                                                                                                                                                                                              | sal timo autaut buffor register ()                                                                                                                                                                                                                                                                                                                                                                              | WDTE                                                                               |           | ,                | √                |                  |          | 9AH                                                             |
|                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                 | RTBL0                                                                              |           | √                | √                |                  |          | 00H                                                             |
|                                                                                                                                                                                                                                                                                                             | eal-time output buffer register 0H                                                                                                                                                                                                                                                                                                                                                                              | RTBH0                                                                              |           | √                | √                |                  |          | 00H                                                             |
|                                                                                                                                                                                                                                                                                                             | eal-time output port mode register 0                                                                                                                                                                                                                                                                                                                                                                            | RTPM0                                                                              |           | √                | √                |                  |          | 00H                                                             |
| <del> </del>                                                                                                                                                                                                                                                                                                | eal-time output port control register 0                                                                                                                                                                                                                                                                                                                                                                         | RTPC0                                                                              |           | √                | √                |                  |          | 00H                                                             |
|                                                                                                                                                                                                                                                                                                             | ort 3 function control expansion register L                                                                                                                                                                                                                                                                                                                                                                     | PFCE3L                                                                             |           | √                | √                |                  |          | 00H                                                             |
| FFFFF70AH Poi                                                                                                                                                                                                                                                                                               | ort 5 function control expansion register                                                                                                                                                                                                                                                                                                                                                                       | PFCE5                                                                              |           | √                | √                |                  |          | 00H                                                             |
| FFFFF712H Poi                                                                                                                                                                                                                                                                                               | ort 9 function control expansion register                                                                                                                                                                                                                                                                                                                                                                       | PFCE9                                                                              |           |                  |                  | V                |          | 0000H                                                           |
| FFFFF712H Poi                                                                                                                                                                                                                                                                                               | ort 9 function control expansion register L                                                                                                                                                                                                                                                                                                                                                                     | PFCE9L                                                                             |           |                  | V                |                  |          | 00H                                                             |
| FFFFF713H Poi                                                                                                                                                                                                                                                                                               | ort 9 function control expansion register H                                                                                                                                                                                                                                                                                                                                                                     | PFCE9H                                                                             |           |                  | √                |                  |          | 00H                                                             |
| FFFFF802H Sys                                                                                                                                                                                                                                                                                               | rstem status register                                                                                                                                                                                                                                                                                                                                                                                           | SYS                                                                                |           | $\sqrt{}$        | √                |                  |          | 00H                                                             |
| FFFFF80CH Inte                                                                                                                                                                                                                                                                                              | ernal oscillation mode register                                                                                                                                                                                                                                                                                                                                                                                 | RCM                                                                                |           | $\sqrt{}$        | √                |                  |          | 00H                                                             |
| FFFFF810H DM                                                                                                                                                                                                                                                                                                | MA trigger factor register 0                                                                                                                                                                                                                                                                                                                                                                                    | DTFR0                                                                              |           | $\sqrt{}$        | √                |                  |          | 00H                                                             |
| FFFFF812H DM                                                                                                                                                                                                                                                                                                | MA trigger factor register 1                                                                                                                                                                                                                                                                                                                                                                                    | DTFR1                                                                              |           | $\sqrt{}$        | √                |                  |          | 00H                                                             |
| FFFFF814H DM                                                                                                                                                                                                                                                                                                | MA trigger factor register 2                                                                                                                                                                                                                                                                                                                                                                                    | DTFR2                                                                              |           | $\sqrt{}$        | √                |                  |          | 00H                                                             |
| FFFFF816H DM                                                                                                                                                                                                                                                                                                | MA trigger factor register 3                                                                                                                                                                                                                                                                                                                                                                                    | DTFR3                                                                              |           | $\sqrt{}$        | $\sqrt{}$        |                  |          | 00H                                                             |
| FFFFF820H Pov                                                                                                                                                                                                                                                                                               | wer save mode register                                                                                                                                                                                                                                                                                                                                                                                          | PSMR                                                                               |           | $\checkmark$     | $\sqrt{}$        |                  |          | 00H                                                             |
| FFFFF822H Clo                                                                                                                                                                                                                                                                                               | ock control register                                                                                                                                                                                                                                                                                                                                                                                            | CKC                                                                                |           | $\sqrt{}$        | √                |                  |          | 0AH                                                             |
| FFFFF824H Loc                                                                                                                                                                                                                                                                                               | ck register                                                                                                                                                                                                                                                                                                                                                                                                     | LOCKR                                                                              | R         | $\sqrt{}$        | √                |                  |          | 00H                                                             |
| FFFFF828H Pro                                                                                                                                                                                                                                                                                               | ocessor clock control register                                                                                                                                                                                                                                                                                                                                                                                  | PCC                                                                                | R/W       |                  | √                |                  |          | 03H                                                             |
| FFFFF82CH PLI                                                                                                                                                                                                                                                                                               | L control register                                                                                                                                                                                                                                                                                                                                                                                              | PLLCTL                                                                             |           | $\sqrt{}$        | √                |                  |          | 01H                                                             |
| FFFFF82EH CP                                                                                                                                                                                                                                                                                                | PU operation clock status register                                                                                                                                                                                                                                                                                                                                                                              | CCLS                                                                               | R         | <b>√</b>         | √                |                  |          | 00H                                                             |
| FFFFF840H Co                                                                                                                                                                                                                                                                                                | prrection address register 0                                                                                                                                                                                                                                                                                                                                                                                    | CORAD0                                                                             | R/W       |                  |                  |                  | <b>√</b> | 00000000Н                                                       |
| FFFFF840H Co                                                                                                                                                                                                                                                                                                | prrection address register 0L                                                                                                                                                                                                                                                                                                                                                                                   | CORAD0L                                                                            |           |                  |                  | <b>√</b>         |          | 0000H                                                           |
| FFFFF842H Co                                                                                                                                                                                                                                                                                                | prrection address register 0H                                                                                                                                                                                                                                                                                                                                                                                   | CORAD0H                                                                            |           |                  |                  | <b>V</b>         |          | 0000H                                                           |
|                                                                                                                                                                                                                                                                                                             | prrection address register 1                                                                                                                                                                                                                                                                                                                                                                                    | CORAD1                                                                             |           |                  |                  |                  | √        | 00000000Н                                                       |
|                                                                                                                                                                                                                                                                                                             | prrection address register 1L                                                                                                                                                                                                                                                                                                                                                                                   | CORAD1L                                                                            |           |                  |                  | V                |          | 0000H                                                           |
| l l                                                                                                                                                                                                                                                                                                         | prection address register 1H                                                                                                                                                                                                                                                                                                                                                                                    | CORAD1H                                                                            |           |                  |                  | √                |          | 0000H                                                           |
| <u> </u>                                                                                                                                                                                                                                                                                                    | prection address register 2                                                                                                                                                                                                                                                                                                                                                                                     | CORAD2                                                                             |           |                  |                  | Ť                | √        | 00000000H                                                       |
|                                                                                                                                                                                                                                                                                                             | prrection address register 2L                                                                                                                                                                                                                                                                                                                                                                                   | CORAD2L                                                                            |           |                  |                  | 1                |          | 0000H                                                           |
| <u> </u>                                                                                                                                                                                                                                                                                                    | prection address register 2H                                                                                                                                                                                                                                                                                                                                                                                    | CORAD2H                                                                            |           |                  |                  | 1                |          | 0000H                                                           |

(9/11)

| Address   | Function Register Name                                    | Symbol                | R/W | Ma       | ninula    | table  | Rits | Default   |
|-----------|-----------------------------------------------------------|-----------------------|-----|----------|-----------|--------|------|-----------|
| , taarooo | T another register reality                                | - Cymbol              |     | 1        | 8         | 16     | 32   | Value     |
| FFFFF84CH | Correction address register 3                             | CORAD3                | R/W |          |           |        | √    | 00000000H |
| FFFFF84CH | Correction address register 3L                            | CORAD3L               |     |          |           | V      |      | 0000H     |
| FFFFF84EH | Correction address register 3H                            | CORAD3H               |     |          |           | ·<br>√ |      | 0000H     |
| FFFFF870H | Clock monitor mode register                               | CLM                   |     | V        | √         |        |      | 00H       |
| FFFFF880H | Correction control register                               | CORCN                 |     | √        | √         |        |      | 00H       |
| FFFFF888H | Reset source flag register                                | RESF                  |     | <b>√</b> | √         |        |      | 00H       |
| FFFFF892H | Internal RAM data status register                         | RAMS                  |     | V        | √         |        |      | 01H       |
| FFFFF8B0H | Prescaler mode register                                   | PRSM0                 |     | √        | √         |        |      | 00H       |
| FFFFF8B1H | Prescaler compare register                                | PRSCM0                |     |          | √         |        |      | 00H       |
| FFFFF9FCH | On-chip debug mode register                               | OCDM                  |     | V        | √         |        |      | 01H       |
| FFFFF9FEH | Peripheral emulation register 1                           | PEMU1 <sup>Note</sup> |     | V        | √         |        |      | 00H       |
| FFFFFA00H | UARTA0 control register 0                                 | UA0CTL0               |     | <b>V</b> | √         |        |      | 10H       |
| FFFFFA01H | UARTA0 control register 1                                 | UA0CTL1               |     |          | √         |        |      | 00H       |
| FFFFFA02H | UARTA0 control register 2                                 | UA0CTL2               |     |          | √         |        |      | FFH       |
| FFFFFA03H | UARTA0 option control register 0                          | UA0OPT0               |     | <b>V</b> | √         |        |      | 14H       |
| FFFFFA04H | UARTA0 status register                                    | UA0STR                |     | <b>V</b> | √         |        |      | 00H       |
| FFFFFA06H | UARTA0 receive data register                              | UA0RX                 | R   |          | √         |        |      | FFH       |
| FFFFFA07H | UARTA0 transmit data register                             | UA0TX                 | R/W |          | √         |        |      | FFH       |
| FFFFFA10H | UARTA1 control register 0                                 | UA1CTL0               |     | V        | √         |        |      | 10H       |
| FFFFFA11H | UARTA1 control register 1                                 | UA1CTL1               |     |          | √         |        |      | 00H       |
| FFFFFA12H | UARTA1 control register 2                                 | UA1CTL2               |     |          | √         |        |      | FFH       |
| FFFFFA13H | UARTA1 option control register 0                          | UA1OPT0               |     | <b>√</b> | √         |        |      | 14H       |
| FFFFFA14H | UARTA1 status register                                    | UA1STR                |     | 1        | √         |        |      | 00H       |
| FFFFFA16H | UARTA1 receive data register                              | UA1RX                 | R   |          | √         |        |      | FFH       |
| FFFFFA17H | UARTA1 transmit data register                             | UA1TX                 | R/W |          | V         |        |      | FFH       |
| FFFFFA20H | UARTA2 control register 0                                 | UA2CTL0               |     | V        | V         |        |      | 10H       |
| FFFFFA21H | UARTA2 control register 1                                 | UA2CTL1               |     |          | V         |        |      | 00H       |
| FFFFFA22H | UARTA2 control register 2                                 | UA2CTL2               |     |          | √         |        |      | FFH       |
| FFFFFA23H | UARTA2 option control register 0                          | UA2OPT0               |     | V        | V         |        |      | 14H       |
| FFFFFA24H | UARTA2 status register                                    | UA2STR                |     | √        | √         |        |      | 00H       |
| FFFFFA26H | UARTA2 receive data register                              | UA2RX                 | R   |          | √         |        |      | FFH       |
| FFFFFA27H | UARTA2 transmit data register                             | UA2TX                 | R/W |          | √         |        |      | FFH       |
| FFFFC00H  | External interrupt falling edge specification register 0  | INTF0                 |     | √        | √         |        |      | 00H       |
| FFFFC06H  | External interrupt falling edge specification register 3  | INTF3                 |     | √        | √         |        |      | 00H       |
| FFFFFC13H | External interrupt falling edge specification register 9H | INTF9H                |     | √        | $\sqrt{}$ |        |      | 00H       |
| FFFFC20H  | External interrupt rising edge specification register 0   | INTR0                 |     | 1        | √         |        |      | 00H       |
| FFFFC26H  | External interrupt rising edge specification register 3   | INTR3                 |     | √        | $\sqrt{}$ |        |      | 00H       |
| FFFFC33H  | External interrupt rising edge specification register 9H  | INTR9H                | 1   | 1        | √         |        |      | 00H       |
| FFFFC60H  | Port 0 function control register                          | PF0                   |     | 1        | √         |        |      | 00H       |
| FFFFC66H  | Port 3 function control register                          | PF3                   |     |          |           | √      |      | 0000H     |
| FFFFC66H  | Port 3 function control register L                        | PF3L                  |     | V        | V         |        |      | 00H       |
| FFFFC67H  | Port 3 function control register H                        | PF3H                  |     | 1        | 1         |        |      | 00H       |

Note Only during emulation

(10/11)

| Address   | Function Register Name             | Symbol  | R/W | Manip    | Manipulatable Bits |          | (10/11<br>Default Value |
|-----------|------------------------------------|---------|-----|----------|--------------------|----------|-------------------------|
|           | _                                  |         |     | 1 8 16   |                    |          |                         |
| FFFFC68H  | Port 4 function control register   | PF4     | R/W | V        | √                  |          | 00H                     |
| FFFFC6AH  | Port 5 function control register   | PF5     |     | √        | √                  |          | 00H                     |
| FFFFC72H  | Port 9 function control register   | PF9     |     |          |                    | √        | 0000H                   |
| FFFFC72H  | Port 9 function control register L | PF9L    |     | √        | √                  |          | 00H                     |
| FFFFC73H  | Port function 9 control register H | PF9H    |     | √        | √                  |          | 00H                     |
| FFFFFD00H | CSIB0 control register 0           | CB0CTL0 |     | V        | √                  |          | 01H                     |
| FFFFD01H  | CSIB0 control register 1           | CB0CTL1 |     | V        | √                  |          | 00H                     |
| FFFFD02H  | CSIB0 control register 2           | CB0CTL2 |     |          | √                  |          | 00H                     |
| FFFFD03H  | CSIB0 status register              | CB0STR  |     | √        | √                  |          | 00H                     |
| FFFFD04H  | CSIB0 receive data register        | CB0RX   | R   |          |                    | V        | 0000H                   |
| FFFFD04H  | CSIB0 receive data register L      | CB0RXL  |     |          | √                  |          | 00H                     |
| FFFFFD06H | CSIB0 transmit data register       | CB0TX   | R/W |          |                    | V        | 0000H                   |
| FFFFD06H  | CSIB0 transmit data register L     | CB0TXL  |     |          | √                  |          | 00H                     |
| FFFFFD10H | CSIB1 control register 0           | CB1CTL0 |     | √        | √                  |          | 01H                     |
| FFFFFD11H | CSIB1 control register 1           | CB1CTL1 |     | V        | √                  |          | 00H                     |
| FFFFD12H  | CSIB1 control register 2           | CB1CTL2 |     |          | √                  |          | 00H                     |
| FFFFFD13H | CSIB1 status register              | CB1STR  |     | √        | √                  |          | 00H                     |
| FFFFD14H  | CSIB1 receive data register        | CB1RX   | R   |          |                    | √        | 0000H                   |
| FFFFD14H  | CSIB1 receive data register L      | CB1RXL  |     |          | √                  |          | 00H                     |
| FFFFD16H  | CSIB1 transmit data register       | CB1TX   | R/W |          |                    | <b>√</b> | 0000H                   |
| FFFFD16H  | CSIB1 transmit data register L     | CB1TXL  |     |          | √                  |          | 00H                     |
| FFFFD20H  | CSIB2 control register 0           | CB2CTL0 |     | √        | √                  |          | 01H                     |
| FFFFFD21H | CSIB2 control register 1           | CB2CTL1 |     | √        | √                  |          | 00H                     |
| FFFFD22H  | CSIB2 control register 2           | CB2CTL2 |     |          | √                  |          | 00H                     |
| FFFFD23H  | CSIB2 status register              | CB2STR  |     | √        | √                  |          | 00H                     |
| FFFFD24H  | CSIB2 receive data register        | CB2RX   | R   |          |                    | <b>√</b> | 0000H                   |
| FFFFD24H  | CSIB2 receive data register L      | CB2RXL  |     |          | √                  |          | 00H                     |
| FFFFD26H  | CSIB2 transmit data register       | CB2TX   | R/W |          |                    | <b>√</b> | 0000H                   |
| FFFFD26H  | CSIB2 transmit data register L     | CB2TXL  |     |          | √                  |          | 00H                     |
| FFFFD30H  | CSIB3 control register 0           | CB3CTL0 |     | √        | √                  |          | 01H                     |
| FFFFD31H  | CSIB3 control register 1           | CB3CTL1 |     | √        | √                  |          | 00H                     |
| FFFFD32H  | CSIB3 control register 2           | CB3CTL2 |     |          | √                  |          | 00H                     |
| FFFFD33H  | CSIB3 status register              | CB3STR  |     | √        | √                  |          | 00H                     |
| FFFFD34H  | CSIB3 receive data register        | CB3RX   | R   |          |                    | √        | 0000H                   |
| FFFFD34H  | CSIB3 receive data register L      | CB3RXL  |     |          | √                  |          | 00H                     |
| FFFFD36H  | CSIB3 transmit data register       | СВЗТХ   | R/W |          |                    | <b>V</b> | 0000H                   |
| FFFFD36H  | CSIB3 transmit data register L     | CB3TXL  |     |          | √                  |          | 00H                     |
| FFFFFD40H | CSIB4 control register 0           | CB4CTL0 | 1   | √        | √                  |          | 01H                     |
| FFFFFD41H | CSIB4 control register 1           | CB4CTL1 | 1   | √        | √                  |          | 00H                     |
| FFFFFD42H | CSIB4 control register 2           | CB4CTL2 | 1   |          | √                  |          | 00H                     |
| FFFFFD43H | CSIB4 status register              | CB4STR  | 1   | <b>√</b> | · √                |          | 00H                     |
| FFFFFD44H | CSIB4 receive data register        | CB4RX   | R   | † ·      |                    | V        | 0000H                   |
| FFFFFD44H | CSIB4 receive data register L      | CB4RXL  | 1   |          | √                  | Ė        | 00H                     |

(11/11)

| Address   | Function Register Name                       | Symbol | R/W | Manip     | ulatab   | le Bits  | Default Value |
|-----------|----------------------------------------------|--------|-----|-----------|----------|----------|---------------|
|           |                                              |        |     | 1         | 8        | 16       |               |
| FFFFFD46H | CSIB4 transmit data register                 | CB4TX  | R/W |           |          | <b>√</b> | 0000H         |
| FFFFD46H  | CSIB4 transmit data register L               | CB4TXL |     |           | √        |          | 00H           |
| FFFFFD80H | IIC shift register 0                         | IIC0   |     |           | <b>√</b> |          | 00H           |
| FFFFD82H  | IIC control register 0                       | IICC0  |     | √         | √        |          | 00H           |
| FFFFD83H  | Slave address register 0                     | SVA0   |     |           | <b>√</b> |          | 00H           |
| FFFFFD84H | IIC clock select register 0                  | IICCL0 |     |           | <b>√</b> |          | 00H           |
| FFFFFD85H | IIC function expansion register 0            | IICX0  |     |           | <b>√</b> |          | 00H           |
| FFFFFD86H | IIC status register 0                        | IICS0  | R   | $\sqrt{}$ | <b>√</b> |          | 00H           |
| FFFFFD8AH | IIC flag register 0                          | IICF0  | R/W | $\sqrt{}$ | <b>√</b> |          | 00H           |
| FFFFFD90H | IIC shift register 1                         | IIC1   |     |           | √        |          | 00H           |
| FFFFFD92H | IIC control register 1                       | IICC1  |     | $\sqrt{}$ | √        |          | 00H           |
| FFFFFD93H | Slave address register 1                     | SVA1   |     |           | √        |          | 00H           |
| FFFFFD94H | IIC clock select register 1                  | IICCL1 |     |           | <b>√</b> |          | 00H           |
| FFFFFD95H | IIC function expansion register 1            | IICX1  |     | √         | √        |          | 00H           |
| FFFFFD96H | IIC status register 1                        | IICS1  | R   | $\sqrt{}$ | √        |          | 00H           |
| FFFFFD9AH | IIC flag register 1                          | IICF1  | R/W | $\sqrt{}$ | √        |          | 00H           |
| FFFFDA0H  | IIC shift register 2                         | IIC2   |     |           | √        |          | 00H           |
| FFFFDA2H  | IIC control register 2                       | IICC2  |     | √         | √        |          | 00H           |
| FFFFDA3H  | IIC slave address register 2                 | SVA2   |     |           | √        |          | 00H           |
| FFFFDA4H  | IIC clock select register 2                  | IICCL2 |     | $\sqrt{}$ | √        |          | 00H           |
| FFFFDA5H  | IIC function expansion register 2            | IICX2  |     | √         | <b>√</b> |          | 00H           |
| FFFFDA6H  | IIC status register 2                        | IICS2  | R   | √         | <b>√</b> |          | 00H           |
| FFFFDAAH  | IIC flag register 2                          | IICF2  | R/W | √         | <b>√</b> |          | 00H           |
| FFFFFDBEH | External bus interface mode control register | EXIMC  |     |           | <b>√</b> |          | 00H           |

## 3.4.7 Programmable peripheral I/O registers

The BPC register is used for programmable peripheral I/O register area selection.

## (1) Peripheral I/O area select control register (BPC)

The BPC register can be read or written in 16-bit units.

Reset input clears this register to 0000H.



Caution When setting the PA15 bit to 1, be sure to set the BPC register to 8FFBH. When clearing the PA15 bit to 0, be sure to set the BPC register to 0000H.

For a list of the programmable peripheral I/O register areas, see Table 19-16 Register Access Types.

### 3.4.8 Special registers

Special registers are registers that are protected from being written with illegal data due to a program hang-up. V850ES/SG2 has the following seven special registers.

- Power save control register (PSC)
- Clock control register (CKC)
- Processor clock control register (PCC)
- Clock monitor mode register (CLM)
- Reset source flag register (RESF)
- Internal RAM data status register (RAMS)
- On-chip debug mode register (OCDM)

In addition, the PRCDM register is provided to protect against a write access to the special registers so that the application system does not inadvertently stop due to a program hang-up. A write access to the special registers is made in a specific sequence, and an illegal store operation is reported to the SYS register.

#### (1) Setting data to special registers

Set data to the special registers in the following sequence.

- <1> Disable DMA operation.
- <2> Prepare data to be set to the special register in a general-purpose register.
- <3> Write the data prepared in <2> to the PRCMD register.
- <4> Write the setting data to the special register (by using the following instructions).
  - Store instruction (ST/SST instruction)
  - Bit manipulation instruction (SET1/CLR1/NOT1 instruction)

```
(<5> to <9> Insert NOP instructions (5 instructions).) Note
```

<10> Enable DMA operation if necessary.

[Example] With PSC register (setting standby mode)

```
ST.B r11, PSMR[r0]; Set PSMR register (setting IDLE1, IDLE2, and STOP modes).
<1>CLR1 0, DCHCn[r0]
                             ; Disable DMA operation. n = 0 to 3
<2>MOV0x02, r10
<3>ST.B r10, PRCMD[r0]; Write PRCMD register.
<4>ST.B r10, PSC[r0]
                             ; Set PSC register.
<5>NOP^{Note}
                             ; Dummy instruction
<6>NOP<sup>Note</sup>
                             ; Dummy instruction
<7>NOP<sup>Note</sup>
                              ; Dummy instruction
< 8 > NOP^{Note}
                              ; Dummy instruction
<9>NOP<sup>Note</sup>
                              ; Dummy instruction
<10>SET1 0, DCHCn[r0]
                            ; Enable DMA operation. n = 0 to 3
(next instruction)
```

There is no special sequence to read a special register.

**Note** Five NOP instructions or more must be inserted immediately after setting the IDLE1 mode, IDLE2 mode, or STOP mode (by setting the PSC.STP bit to 1).

- Cautions 1. When a store instruction is executed to store data in the command register, interrupts are not acknowledged. This is because it is assumed that steps <3> and <4> above are performed by successive store instructions. If another instruction is placed between <3> and <4>, and if an interrupt is acknowledged by that instruction, the above sequence may not be established, causing malfunction.
  - Although dummy data is written to the PRCMD register, use the same general-purpose register used to set the special register (<4> in Example) to write data to the PRCMD register (<3> in Example). The same applies when a general-purpose register is used for addressing.

## (2) Command register (PRCMD)

The PRCMD register is an 8-bit register that protects the registers that may seriously affect the application system from being written, so that the system does not inadvertently stop due to a program hang-up. The first write access to a special register is valid after data has been written in advance to the PRCMD register. In this way, the value of the special register can be rewritten only in a specific sequence, so as to protect the register from an illegal write access.

The PRCMD register is write-only, in 8-bit units (undefined data is read when this register is read).



### (3) System status register (SYS)

Status flags that indicate the operation status of the overall system are allocated to this register.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.



The PRERR flag operates under the following conditions.

## (a) Set condition (PRERR flag = 1)

- (i) When data is written to a special register without writing anything to the PRCMD register (when <4> is executed without executing <3> in 3.4.8 (1) Setting data to special registers)
- (ii) When data is written to an on-chip peripheral I/O register other than a special register (including execution of a bit manipulation instruction) after writing data to the PRCMD register (if <3> in 3.4.8 (1) Setting data to special registers is not the setting of a special register)

**Remark** Even if an on-chip peripheral I/O register is read (except by a bit manipulation instruction) between an operation to write the PRCMD register and an operation to write a special register, the PRERR flag is not set, and the set data can be written to the special register.

### (b) Clear condition (PRERR flag = 0)

- (i) When 0 is written to the PRERR flag
- (ii) When the system is reset
- Cautions 1. If 0 is written to the PRERR bit of the SYS register, which is not a special register, immediately after a write access to the PRCMD register, the PRERR bit is cleared to 0 (the write access takes precedence).
  - 2. If data is written to the PRCMD register, which is not a special register, immediately after a write access to the PRCMD register, the PRERR bit is set to 1.

#### 3.4.9 Cautions

### (1) Registers to be set first

Be sure to set the following registers first when using the V850ES/SG2.

- System wait control register (VSWC)
- On-chip debug mode register (OCDM)
- Watchdog timer mode register 2 (WDTM2)

After setting the VSWC, OCDM, and WDTM2 registers, set the other registers as necessary.

When using the external bus, set each pin to the alternate-function bus control pin mode by using the portrelated registers after setting the above registers.

## (a) System wait control register (VSWC)

The VSWC register controls wait of bus access to the on-chip peripheral I/O registers.

Three clocks are required to access an on-chip peripheral I/O register (without a wait cycle). The V850ES/SG2 requires wait cycles according to the operating frequency. Set the following value to the VSWC register in accordance with the frequency used.

The VSWC register can be read or written in 8-bit units (address: FFFF66EH, default value: 77H).

| Operating Frequency (fclк) | Set Value of VSWC | Number of Waits |
|----------------------------|-------------------|-----------------|
| 32 kHz ≤ fclk < 16.6 MHz   | 00H               | 0 (no waits)    |
| 16.6 MHz ≤ fclk < 25 MHz   | 01H               | 1               |
| 25 MHz ≤ fclk ≤ 32 MHz     | 11H               | 2               |

#### (b) On-chip debug mode register (OCDM)

For details, see CHAPTER 30 ON-CHIP DEBUG FUNCTION.

### (c) Watchdog timer mode register 2 (WDTM2)

The WDTM2 register sets the overflow time and the operation clock of the watchdog timer 2.

The watchdog timer 2 automatically starts in the reset mode after reset is released. Write the WDTM2 register to activate this operation.

For details, see CHAPTER 11 FUNCTIONS OF WATCHDOG TIMER 2.

### (2) Accessing specific on-chip peripheral I/O registers

This product has two types of internal system buses.

One is a CPU bus and the other is a peripheral bus that interfaces with low-speed peripheral hardware.

The clock of the CPU bus and the clock of the peripheral bus are asynchronous. If an access to the CPU and an access to the peripheral hardware conflict, therefore, unexpected illegal data may be transferred. If there is a possibility of a conflict, the number of cycles for accessing the CPU changes when the peripheral hardware is accessed, so that correct data is transferred. As a result, the CPU does not start processing of the next instruction but enters the wait status. If this wait status occurs, the number of clocks required to execute an instruction increases by the number of wait clocks shown below.

This must be taken into consideration if real-time processing is required.

When specific on-chip peripheral I/O registers are accessed, more wait states may be required in addition to the wait states set by the VSWC register.

The access conditions and how to calculate the number of wait states to be inserted (number of CPU clocks) at this time are shown below.

(1/2)

| Peripheral Function                      | Register Name         | Access                       | k                                                                      |
|------------------------------------------|-----------------------|------------------------------|------------------------------------------------------------------------|
| 16-bit timer/event counter P (TMP)       | TPnCNT                | Read                         | 1 or 2                                                                 |
| (n = 0 to 5)                             | TPnCCR0, TPnCCR1      | Write                        | <ul><li>1st access: No wait</li><li>Continuous write: 3 or 4</li></ul> |
|                                          |                       | Read                         | 1 or 2                                                                 |
| 16-bit timer/event counter Q (TMQ)       | TQ0CNT                | Read                         | 1 or 2                                                                 |
|                                          | TQ0CCR0 to TQ0CCR3    | Write                        | <ul><li>1st access: No wait</li><li>Continuous write: 3 or 4</li></ul> |
|                                          |                       | Read                         | 1 or 2                                                                 |
| Watchdog timer 2 (WDT2)                  | WDTM2                 | Write (when WDT2 operating)  | 3                                                                      |
| Real-time output function (RTO)          | RTBL0                 | Write (RTPC0.RTPOE0 bit = 0) | 1                                                                      |
|                                          | RTBH0                 | Write (RTPC0.RTPOE0 bit = 0) | 1                                                                      |
| A/D converter                            | ADA0M0                | Read                         | 1 or 2                                                                 |
|                                          | ADA0CR0 to ADA0CR11   | Read                         | 1 or 2                                                                 |
|                                          | ADA0CR0H to ADA0CR11H | Read                         | 1 or 2                                                                 |
| I <sup>2</sup> C00 to I <sup>2</sup> C02 | IICS0 to IICS2        | Read                         | 1                                                                      |

(2/2)

| Peripheral Function                         | Register Name                                                                                                           | Access           | k                                                                                                                      |
|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------|
| CAN controller<br>(m = 0 to 31, a = 1 to 4) | COGMCTRL, COGMCS, COGMABT, COGMABTD, COMASKAL, COMASKAH, COCTRL, COLEC, COINFO, COERC, COIE, COINTS, COBRP, COBTR, COTS | Read/write       | $ (fxx/fcanmod + 1)/(2 + j) (MIN.)^{Note} $ $ (2 \times fxx/fcanmod + 1)/(2 + j) (MAX.)^{Note} $                       |
|                                             | CORGPT,<br>COTGPT                                                                                                       | Write            | $(fxx/f_{CANMOD} + 1)/(2 + j) (MIN.)^{Note}$<br>$(2 \times fxx/f_{CANMOD} + 1)/(2 + j) (MAX.)^{Note}$                  |
|                                             |                                                                                                                         | Read             | $(3 \times fxx/f_{CANMODE} + 1)/(2 + j) (MIN.)^{Note} $<br>$(4 \times fxx/f_{CANMODE} + 1)/(2 + j) (MAX.)^{Note}$      |
|                                             | COLIPT,<br>COLOPT                                                                                                       | Read             | $(3 \times f_{XX}/f_{CANMODE} + 1)/(2 + j) (MIN.)^{Note}$<br>$(4 \times f_{XX}/f_{CANMODE} + 1)/(2 + j) (MAX.)^{Note}$ |
|                                             | C0MDATA01m, C0MDATA0m,<br>C0MDATA1m, C0MDATA23m,                                                                        | Write (8 bits)   | $(4 \times f_{XX}/f_{CANMODE} + 1)/(2 + j) (MIN.)^{Note}$<br>$(5 \times f_{XX}/f_{CANMODE} + 1)/(2 + j) (MAX.)^{Note}$ |
|                                             | COMDATA2m, COMDATA3m,<br>COMDATA45m, COMDATA4m,                                                                         | Write (16 bits)  | $(2 \times f_{XX}/f_{CANMODE} + 1)/(2 + j) (MIN.)^{Note}$<br>$(3 \times f_{XX}/f_{CANMODE} + 1)/(2 + j) (MAX.)^{Note}$ |
|                                             | COMDATA5m, COMDATA67m, COMDATA6m, COMDATA7m, COMDLCm, COMCONFm, COMIDLm, COMIDHm, COMCTRLm                              | Read (8/16 bits) | $(3 \times fxx/f_{CANMODE} + 1)/(2 + j) (MIN.)^{Note}$<br>$(4 \times fxx/f_{CANMODE} + 1)/(2 + j) (MAX.)^{Note}$       |
| CRC                                         | CRCD                                                                                                                    | Write            | 1                                                                                                                      |

Number of clocks necessary for access =  $3 + i + j + (2 + j) \times k$ 

**Note** Digits below the decimal point are rounded up.

Caution Accessing the above registers is prohibited in the following statuses. If a wait cycle is generated, it can only be cleared by a reset.

- When the CPU operates with the subclock and the main clock oscillation is stopped
- When the CPU operates with the internal oscillation clock

**Remark** fxx: Main clock frequency = fxx fcanmod: CAN module system clock

TCANNIOD. OAN MODULE SYSTEM CLOCK

i: Values (0) of higher 4 bits of VSWC registerj: Values (0 or 1) of lower 4 bits of VSWC register

### (3) System reserved area

In the V850ES/SG2, 0000007AH to 0000007FH is a system reserved area for function expansion, and therefore it is recommended that this area not be used.

However, in the case of the special version of the following products, be sure to set 00H to 0000007AH.

- μPD70F3261, 70F3261Y, 70F3271, 70F3271Y, 70F3281, 70F3281Y: Ver. 1.0
- $\mu$ PD70F3263, 70F3263Y, **70F3263HY**, 70F3273, 70F3273Y, **70F3273HY**, 70F3283, 70F3283Y, **70F3283HY**: No applicable versions
- **Remarks 1.** With products other than the above (including all the products listed in this manual), operations are not affected even if 00H is set to 0000007AH.
  - 2. Check the product version by the number that follows DS, ES, or CS on the third line of the package stamp. If the generic name is stamped (V850ES/SG2, etc.), the above restriction does not apply.

For enquiries, contact an NEC Electronics sales representative.



Note For the security ID, see 30.6.1 Security ID.

Caution When the data in the flash memory has been deleted, all the bits are cleared to 1.

### (4) Restriction on conflict between sld instruction and interrupt request

## (a) Description

If a conflict occurs between the decode operation of an instruction in <2> immediately before the sld instruction following an instruction in <1> and an interrupt request before the instruction in <1> is complete, the execution result of the instruction in <1> may not be stored in a register.

#### Instruction <1>

Id instruction: Id.b, Id.h, Id.w, Id.bu, Id.hu
sld instruction: sld.b, sld.h, sld.w, sld.bu, sld.hu

• Multiplication instruction: mul, mulh, mulhi, mulu

#### Instruction <2>

| , reg2 |
|--------|
| g2     |
| g2     |
| reg2   |
| g2     |
|        |

#### <Example>

| <i>&gt;</i> | ld.w | [r11], r10 | If the decode operation of the mov instruction <ii> immediately before the sld</ii>     |
|-------------|------|------------|-----------------------------------------------------------------------------------------|
|             |      | •          | instruction <iii> and an interrupt request conflict before execution of the Id</iii>    |
|             |      | •          | instruction <i> is complete, the execution result of instruction <i> may not be</i></i> |
|             |      |            | stored in a register.                                                                   |

<ii> mov r10, r28 <iii> sld.w 0x28, r10

#### (b) Countermeasure

### <1> When compiler (CA850) is used

Use CA850 Ver. 2.61 or later because generation of the corresponding instruction sequence can be automatically suppressed.

### <2> For assembler

When executing the sld instruction immediately after instruction <ii>, avoid the above operation using either of the following methods.

- Insert a nop instruction immediately before the sld instruction.
- Do not use the same register as the sld instruction destination register in the above instruction <ii>executed immediately before the sld instruction.

## **CHAPTER 4 PORT FUNCTIONS**

### 4.1 Features

- O I/O ports: 84
  - 5 V tolerant/N-ch open-drain output selectable: 40 (ports 0, 3 to 5, 9)
- O Input/output specifiable in 1-bit units

## 4.2 Basic Port Configuration

The V850ES/SG2 features a total of 84 I/O ports consisting of ports 0, 1, 3 to 5, 7, 9, CM, CT, DH, and DL. The port configuration is shown below.



Figure 4-1. Port Configuration Diagram

Table 4-1. I/O Buffer Power Supplies for Pins

| Power Supply       | Corresponding Pins                        |
|--------------------|-------------------------------------------|
| AV <sub>REF0</sub> | Port 7                                    |
| AV <sub>REF1</sub> | Port 1                                    |
| BV <sub>DD</sub>   | Ports CM, CT, DH (bits 0 to 3), DL        |
| EV <sub>DD</sub>   | RESET, ports 0, 3 to 5, 9, DH (bits 4, 5) |

# 4.3 Port Configuration

**Table 4-2. Port Configuration** 

| Item             | Configuration                                                                                                                                                                                                                                                                                                           |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Control register | Port n mode register (PMn: n = 0, 1, 3 to 5, 7, 9, CM, CT, DH, DL)  Port n mode control register (PMCn: n = 0, 3 to 5, 9, CM, CT, DH, DL)  Port n function control register (PFCn: n = 0, 3 to 5, 9)  Port n function control expansion register (PFCEn: n = 3, 5, 9)  Port n function register (PFn: n = 0, 3 to 5, 9) |
| Ports            | 1/O: 84                                                                                                                                                                                                                                                                                                                 |

### (1) Port n register (Pn)

Data is input from or output to an external device by writing or reading the Pn register.

The Pn register consists of a port latch that holds output data, and a circuit that reads the status of pins.

Each bit of the Pn register corresponds to one pin of port n, and can be read or written in 1-bit units.



Data is written to or read from the Pn register as follows, regardless of the setting of the PMCn register.

Table 4-3. Writing/Reading Pn Register

| Setting of PMn Register   | Writing to Pn Register                                                                                                                         | Reading from Pn Register               |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|
| Output mode<br>(PMnm = 0) | Data is written to the output latch <sup>Note</sup> .  In the port mode (PMCn = 0), the contents of the output latch are output from the pins. | The value of the output latch is read. |
| Input mode<br>(PMnm = 1)  | Data is written to the output latch.  The pin status is not affected <sup>Note</sup> .                                                         | The pin status is read.                |

**Note** The value written to the output latch is retained until a new value is written to the output latch.

# (2) Port n mode register (PMn)

The PMn register specifies the input or output mode of the corresponding port pin.

Each bit of this register corresponds to one pin of port n, and the input or output mode can be specified in 1-bit units.



### (3) Port n mode control register (PMCn)

The PMCn register specifies the port mode or alternate function.

Each bit of this register corresponds to one pin of port n, and the mode of the port can be specified in 1-bit units.



### (4) Port n function control register (PFCn)

The PFCn register specifies the alternate function of a port pin to be used if the pin has two alternate functions. Each bit of this register corresponds to one pin of port n, and the alternate function of a port pin can be specified in 1-bit units.



## (5) Port n function control expansion register (PFCEn)

The PFCEn register specifies the alternate function of a port pin to be used if the pin has three or more alternate functions.

Each bit of this register corresponds to one pin of port n, and the alternate function of a port pin can be specified in 1-bit units.



## (6) Port n function register (PFn)

The PFn register specifies normal output or N-ch open-drain output.

Each bit of this register corresponds to one pin of port n, and the output mode of the port pin can be specified in 1-bit units.



| PFnm <sup>Note</sup> | Control of normal output/N-ch open-drain output |  |  |
|----------------------|-------------------------------------------------|--|--|
| 0                    | Normal output (CMOS output)                     |  |  |
| 1                    | N-ch open-drain output                          |  |  |

**Note** The PFnm bit of the PFn register is valid only when the PMnm bit of the PMn register is 0 (when the output mode is specified) in port mode (PMCnm bit = 0). When the PMnm bit is 1 (when the input mode is specified), the set value of the PFn register is invalid.

## (7) Port setting

Set a port as illustrated below.

Figure 4-2. Setting of Each Register and Pin Function



- <2> Set the PFCn register.
- <3> Set the INTRn or INTFn register (to specify an external interrupt pin).

If the PMCn register is set first, an unintended function may be set while the PFCn and PFCEn registers are being set.

### 4.3.1 Port 0

Port 0 is a 5-bit port for which I/O settings can be controlled in 1-bit units.

Port 0 includes the following alternate-function pins.

**Table 4-4. Port 0 Alternate-Function Pins** 

| Pin Name | Pin No. | Alternate-Function Pin Name | I/O   | Remark                               | Block Type |
|----------|---------|-----------------------------|-------|--------------------------------------|------------|
| P02      | 17      | NMI                         | Input | Selectable as N-ch open-drain output | L-1        |
| P03      | 18      | INTP0/ADTRG                 | Input |                                      | N-1        |
| P04      | 19      | INTP1                       | Input |                                      | L-1        |
| P05      | 20      | INTP2/DRST <sup>Note</sup>  | Input |                                      | AA-1       |
| P06      | 21      | INTP3                       | Input |                                      | L-1        |

**Note** The DRST pin is for on-chip debugging (flash memory version only).

If on-chip debugging is not used, fix the P05/INTP2/ $\overline{DRST}$  pin to low level between when the reset signal of the  $\overline{RESET}$  pin is released and when the OCDM.OCDM0 bit is cleared (0). Although the mask ROM versions do not support the on-chip debug mode, handle the P05/INTP2 pin the same as in flash memory versions.

For details, see 4.6.3 Cautions on on-chip debug pins.

Caution The P02 to P06 pins have hysteresis characteristics in the input mode of the alternate function, but do not have hysteresis characteristics in the port mode.

## (1) Port 0 register (P0)



## (2) Port 0 mode register (PM0)

| After res | et: FFH | R/W       | Address: F | FFFF420H | 1            |           |   |   |
|-----------|---------|-----------|------------|----------|--------------|-----------|---|---|
|           | 7       | 6         | 5          | 4        | 3            | 2         | 1 | 0 |
| PM0       | 1       | PM06      | PM05       | PM04     | PM03         | PM02      | 1 | 1 |
|           |         |           |            |          |              |           |   |   |
|           | PM0n    |           |            | I/O mode | e control (n | = 2 to 6) |   |   |
|           | 0       | Output me | ode        |          |              |           |   |   |
|           | 1       | Input mod | le         |          |              |           |   |   |
|           |         | '         |            |          |              |           |   |   |

# (3) Port 0 mode control register (PMC0)



Caution The P05/INTP2/DRST pin becomes the DRST pin regardless of the value of the PMC05 bit when the OCDM.OCDM0 bit = 1.

## (4) Port 0 function control register (PFC0)



| PFC03 | Specification of P03 pin alternate function |
|-------|---------------------------------------------|
| 0     | INTP0 input                                 |
| 1     | ADTRG input                                 |

## (5) Port 0 function register (PF0)



 7
 6
 5
 4
 3
 2
 1
 0

 PF0
 0
 PF06
 PF05
 PF04
 PF03
 PF02
 0
 0

|   | PF0n | Control of normal output or N-ch open-drain output (n = 2 to 6) |
|---|------|-----------------------------------------------------------------|
| ſ | 0    | Normal output (CMOS output)                                     |
| Γ | 1    | N-ch open drain output                                          |

Caution To pull up an output pin at a voltage of EV<sub>DD</sub> or higher, be sure to set the corresponding PF0n bit to 1.

#### 4.3.2 Port 1

Port 1 is a 2-bit port for which I/O settings can be controlled in 1-bit units.

Port 1 includes the following alternate-function pins.

Table 4-5. Port 1 Alternate-Function Pins

| Pin Name | Pin No. | Alternate-Function Pin Name | I/O    | Remark | Block Type |
|----------|---------|-----------------------------|--------|--------|------------|
| P10      | 3       | ANO0                        | Output | _      | A-2        |
| P11      | 4       | ANO1                        | Output | -      | A-2        |

Caution When the power is turned on, the P10 and P11 pins may output an undefined level temporarily even during reset.

## (1) Port 1 register (P1)



Caution Do not read/write the P1 register during D/A conversion (see 14.4.3 Cautions).

## (2) Port 1 mode register (PM1)



Cautions 1. When using P1n as the alternate function (ANOn pin output), set the PM1n bit to 1.

When using one of the P10 and P11 pins as an I/O port and the other as a D/A output pin, do so in an application where the port I/O level does not change during D/A output.

### 4.3.3 Port 3

Port 3 is a 10-bit port for which I/O settings can be controlled in 1-bit units.

Port 3 includes the following alternate-function pins.

Table 4-6. Port 3 Alternate-Function Pins

| Pin Name | Pin No. | Alternate-Function Pin Name                      | I/O    | Remark                               | Block Type |
|----------|---------|--------------------------------------------------|--------|--------------------------------------|------------|
| P30      | 25      | TXDA0/SOB4                                       | Output | Selectable as N-ch open-drain output | G-3        |
| P31      | 26      | RXDA0/INTP7/SIB4                                 | Input  |                                      | N-3        |
| P32      | 27      | ASCKA0/SCKB4/TIP00/TOP00                         | I/O    |                                      | U-1        |
| P33      | 28      | TIP01/TOP01                                      | I/O    |                                      | G-1        |
| P34      | 29      | TIP10/TOP10                                      | I/O    |                                      | G-1        |
| P35      | 30      | TIP11/TOP11                                      | I/O    |                                      | G-1        |
| P36      | 31      | CTXD0 <sup>Note 1</sup> /IETX0 <sup>Note 2</sup> | Output |                                      | G-3        |
| P37      | 32      | CRXD0 <sup>Note 1</sup> /IERX0 <sup>Note 2</sup> | Input  |                                      | G-4        |
| P38      | 35      | TXDA2/SDA00                                      | I/O    |                                      | G-12       |
| P39      | 36      | RXDA2/SCL00                                      | I/O    |                                      | G-6        |

Notes 1. CAN controller version only

2. IEBus controller version only

Caution The P31 to P35 and P37 to P39 pins have hysteresis characteristics in the input mode of the alternate-function pin, but do not have the hysteresis characteristics in the port mode.

## (1) Port 3 register (P3)



| P3n | Output data control (in output mode) (n = 0 to 9) |
|-----|---------------------------------------------------|
| 0   | Outputs 0                                         |
| 1   | Outputs 1                                         |

Remarks 1. The P3 register can be read or written in 16-bit units.

However, when using the higher 8 bits of the P3 register as the P3H register and the lower 8 bits as the P3L register, P3 can be read or written in 8-bit or 1-bit units.

2. To read/write bits 8 to 15 of the P3 register in 8-bit or 1-bit units, specify them as bits 0 to 7 of the P3H register.

## (2) Port 3 mode register (PM3)

| After reset: FFFFH |                      | Address:                         |                                                |                                                                     | , PM3H FF                                                                     | FFF427H                                                                                                      |                                                                                                                          |
|--------------------|----------------------|----------------------------------|------------------------------------------------|---------------------------------------------------------------------|-------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| 15                 | 14                   | 13                               | 12                                             | 11                                                                  | 10                                                                            | 9                                                                                                            | 8                                                                                                                        |
| 1                  | 1                    | 1                                | 1                                              | 1                                                                   | 1                                                                             | PM39                                                                                                         | PM38                                                                                                                     |
| 7                  | 6                    | 5                                | 4                                              | 3                                                                   | 2                                                                             | 1                                                                                                            | 0                                                                                                                        |
| PM37               | PM36                 | PM35                             | PM34                                           | PM33                                                                | PM32                                                                          | PM31                                                                                                         | PM30                                                                                                                     |
|                    |                      |                                  |                                                |                                                                     |                                                                               |                                                                                                              | -                                                                                                                        |
| PM3n               |                      |                                  |                                                | e control (n                                                        | = 0 to 9)                                                                     |                                                                                                              |                                                                                                                          |
|                    | 15<br>1<br>7<br>PM37 | 15 14<br>1 1<br>7 6<br>PM37 PM36 | 15 14 13<br>1 1 1 1<br>7 6 5<br>PM37 PM36 PM35 | PM3L FI<br>15 14 13 12<br>1 1 1 1<br>7 6 5 4<br>PM37 PM36 PM35 PM34 | PM3L FFFF426H, 15 14 13 12 11  1 1 1 1 1  7 6 5 4 3  PM37 PM36 PM35 PM34 PM33 | PM3L FFFF426H, PM3H FF<br>15 14 13 12 11 10<br>1 1 1 1 1 1 1<br>7 6 5 4 3 2<br>PM37 PM36 PM35 PM34 PM33 PM32 | PM3L FFFF426H, PM3H FFFFF427H 15 14 13 12 11 10 9  1 1 1 1 1 1 1 PM39  7 6 5 4 3 2 1  PM37 PM36 PM35 PM34 PM33 PM32 PM31 |

| PM3n | I/O mode control (n = 0 to 9) |
|------|-------------------------------|
| 0    | Output mode                   |
| 1    | Input mode                    |

**Remarks 1.** The PM3 register can be read or written in 16-bit units.

However, when using the higher 8 bits of the PM3 register as the PM3H register and the lower 8 bits as the PM3L register, PM3 can be read or written in 8-bit or 1-bit units.

2. To read/write bits 8 to 15 of the PM3 register in 8-bit or 1-bit units, specify them as bits 0 to 7 of the PM3H register.

## (3) Port 3 mode control register (PMC3)

(1/2)

| After re     | set: 0000H | R/W                                           | Address              |       | FFFF446H, |       | FFFFF447I | Н     |
|--------------|------------|-----------------------------------------------|----------------------|-------|-----------|-------|-----------|-------|
|              | 15         | 14                                            | 13                   | 12    | 11        | 10    | 9         | 8     |
| PMC3 (PMC3H) | 0          | 0                                             | 0                    | 0     | 0         | 0     | PMC39     | PMC38 |
|              | 7          | 6                                             | 5                    | 4     | 3         | 2     | 1         | 0     |
| (PMC3L)      | PMC37      | PMC36                                         | PMC35                | PMC34 | PMC33     | PMC32 | PMC31     | PMC30 |
|              | PMC39      | PMC39 Specification of P39 pin operation mode |                      |       |           |       |           |       |
|              | 0          | I/O port                                      |                      |       |           |       |           |       |
|              | 1          | RXDA2 in                                      | put/SCL00            | I/O   |           |       |           |       |
|              | PMC38      | PMC38 Specification of P38 pin operation mode |                      |       |           |       |           |       |
|              | 0          | I/O port                                      |                      |       |           |       |           |       |
|              | 1          | TXDA2 ou                                      | DA2 output/SDA00 I/O |       |           |       |           |       |

(2/2)

| PMC37 | Specification of P37 pin operation mode |
|-------|-----------------------------------------|
| 0     | I/O port                                |
| 1     | CRXD0 input/IERX0 input                 |

| PMC36 | Specification of P36 pin operation mode |
|-------|-----------------------------------------|
| 0     | I/O port                                |
| 1     | CTXD0 output/IETX0 output               |

| PMC35 | Specification of P35 pin operation mode |
|-------|-----------------------------------------|
| 0     | I/O port                                |
| 1     | TIP11 input/TOP11 output                |

| PMC34 | Specification of P34 pin operation mode |
|-------|-----------------------------------------|
| 0     | I/O port                                |
| 1     | TIP10 input/TOP10 output                |

| PMC33 | Specification of P33 pin operation mode |
|-------|-----------------------------------------|
| 0     | I/O port                                |
| 1     | TIP01 input/TOP01 output                |

| PMC32 | Specification of P32 pin operation mode         |
|-------|-------------------------------------------------|
| 0     | I/O port                                        |
| 1     | ASCKA0 input/SCKB4 I/O/TIP00 input/TOP00 output |

| PMC31 | Specification of P31 pin operation mode |  |  |  |  |  |
|-------|-----------------------------------------|--|--|--|--|--|
| 0     | I/O port                                |  |  |  |  |  |
| 1     | RXDA0 input/SIB4 input/INTP7 input      |  |  |  |  |  |

| PMC30 | Specification of P30 pin operation mode |
|-------|-----------------------------------------|
| 0     | I/O port                                |
| 1     | TXDA0 output/SOB4 output                |

## **Remarks 1.** The PMC3 register can be read or written in 16-bit units.

However, when using the higher 8 bits of the PMC3 register as the PMC3H register and the lower 8 bits as the PMC3L register, PMC3 can be read or written in 8-bit or 1-bit units.

2. To read/write bits 8 to 15 of the PMC3 register in 8-bit or 1-bit units, specify them as bits 0 to 7 of the PMC3H register.

## (4) Port 3 function control register (PFC3)

| After reset: 0000H |       | R/W   | Address | lress: PFC3 FFFFF466H,<br>PFC3L FFFFF466H, PFC3L FFFFF467H |       |       |       |       |
|--------------------|-------|-------|---------|------------------------------------------------------------|-------|-------|-------|-------|
|                    | 15    | 14    | 13      | 12                                                         | 11    | 10    | 9     | 8     |
| PFC3 (PFC3H)       | 0     | 0     | 0       | 0                                                          | 0     | 0     | PFC39 | PFC38 |
|                    | 7     | 6     | 5       | 4                                                          | 3     | 2     | 1     | 0     |
| (PFC3L)            | PFC37 | PFC36 | PFC35   | PFC34                                                      | PFC33 | PFC32 | PFC31 | PFC30 |

Remarks 1. For details of alternate function specification, see 4.3.3 (6) Port 3 alternate function specifications.

- 2. The PFC3 register can be read or written in 16-bit units.
  However, when using the higher 8 bits of the PFC3 register as the PFC3H register and the lower 8 bits as the PFC3L register, PFC3 can be read or written in 8-bit and 1-bit units.
- **3.** To read/write bits 8 to 15 of the PFC3 register in 8-bit or 1-bit units, specify them as bits 0 to 7 of the PFC3H register.

### (5) Port 3 function control expansion register L (PFCE3L)



Remark For details of alternate function specification, see 4.3.3 (6) Port 3 alternate function specifications.

### (6) Port 3 alternate function specifications

| PFC39 | Specification of P39 pin alternate function |  |  |  |  |
|-------|---------------------------------------------|--|--|--|--|
| 0     | RXDA2 input                                 |  |  |  |  |
| 1     | SCL00 input                                 |  |  |  |  |

| PFC38 | Specification of P38 pin alternate function |  |  |  |  |  |
|-------|---------------------------------------------|--|--|--|--|--|
| 0     | TXDA2 output                                |  |  |  |  |  |
| 1     | SDA00 I/O                                   |  |  |  |  |  |

| PFC37 | Specification of P37 pin alternate function |  |  |  |  |  |
|-------|---------------------------------------------|--|--|--|--|--|
| 0     | CRXD0 input                                 |  |  |  |  |  |
| 1     | IERX0 input                                 |  |  |  |  |  |

| PFC36 | Specification of P36 pin alternate function |  |  |  |  |  |
|-------|---------------------------------------------|--|--|--|--|--|
| 0     | CTXD0 output                                |  |  |  |  |  |
| 1     | IETX0 output                                |  |  |  |  |  |

| PFC35 | Specification of P35 pin alternate function |  |  |  |  |
|-------|---------------------------------------------|--|--|--|--|
| 0     | TIP11 input                                 |  |  |  |  |
| 1     | TOP11 output                                |  |  |  |  |

| PFC34 | Specification of P34 pin alternate function |  |  |  |  |  |
|-------|---------------------------------------------|--|--|--|--|--|
| 0     | TIP10 input                                 |  |  |  |  |  |
| 1     | TOP10 output                                |  |  |  |  |  |

| PFC33 | Specification of P33 pin alternate function |  |  |  |  |
|-------|---------------------------------------------|--|--|--|--|
| 0     | TIP01 input                                 |  |  |  |  |
| 1     | TOP01 output                                |  |  |  |  |

| PFCE32 | PFC32 | Specification of P32 pin alternate function |
|--------|-------|---------------------------------------------|
| 0      | 0     | ASCKA0 input                                |
| 0      | 1     | SCKB4 I/O                                   |
| 1      | 0     | TIP00 input                                 |
| 1      | 1     | TOP00 output                                |

| PFC31 | Specification of P31 pin alternate function |  |  |  |
|-------|---------------------------------------------|--|--|--|
| 0     | XDA0 input/INTP7 <sup>Note</sup> input      |  |  |  |
| 1     | SIB4 input                                  |  |  |  |

| PFC30 | Specification of P30 pin alternate function |  |  |  |  |
|-------|---------------------------------------------|--|--|--|--|
| 0     | TXDA0 output                                |  |  |  |  |
| 1     | SOB4 output                                 |  |  |  |  |

Note The INTP7 pin and RXDA0 pin are alternate-function pins. When using the pin as the RXDA0 pin, disable edge detection for the INTP7 alternate-function pin. (Clear the INTF3.INTF31 bit and the INTR3.INTR31 bit to 0.) When using the pin as the INTP7 pin, stop UARTA0 reception. (Clear the UA0CTL0.UA0RXE bit to 0.)

## (7) Port 3 function register (PF3)

| After reset: 0000H |      | R/W  | Address | : PF3 FFFI<br>PF3L FFI | FFC66H,<br>FFFC66H, | PF3H FFFI | FC67H |      |
|--------------------|------|------|---------|------------------------|---------------------|-----------|-------|------|
|                    | 15   | 14   | 13      | 12                     | 11                  | 10        | 9     | 8    |
| PF3 (PF3H)         | 0    | 0    | 0       | 0                      | 0                   | 0         | PF39  | PF38 |
|                    | 7    | 6    | 5       | 4                      | 3                   | 2         | 1     | 0    |
| (PF3L)             | PF37 | PF36 | PF35    | PF34                   | PF33                | PF32      | PF31  | PF30 |

| PF3n | Control of normal output or N-ch open-drain output (n = 0 to 9) |
|------|-----------------------------------------------------------------|
| 0    | Normal output (CMOS output)                                     |
| 1    | N-ch open-drain output                                          |

Caution To pull up an output pin at a voltage of EV<sub>DD</sub> or higher, be sure to set the corresponding PF3n bit to 1.

- Remarks 1. The PF3 register can be read or written in 16-bit units.

  However, when using the higher 8 bits of the PF3 register as the PF3H register and the lower 8 bits as the PF3L register, PF3 can be read or written in 8-bit or 1-bit units.
  - 2. To read/write bits 8 to 15 of the PF3 register in 8-bit or 1-bit units, specify them as bits 0 to 7 of the PF3H register.

## 4.3.4 Port 4

Port 4 is a 3-bit port that controls I/O in 1-bit units.

Port 4 includes the following alternate-function pins.

**Table 4-7. Port 4 Alternate-Function Pins** 

| Pin Name | Pin No. | Alternate-Function Pin Name | I/O | Remark                               | Block Type |
|----------|---------|-----------------------------|-----|--------------------------------------|------------|
| P40      | 22      | SIB0/SDA01                  | I/O | Selectable as N-ch open-drain output | G-6        |
| P41      | 23      | SOB0/SCL01                  | I/O |                                      | G-12       |
| P42      | 24      | SCKB0                       | I/O |                                      | E-3        |

Caution The P40 to P42 pins have hysteresis characteristics in the input mode of the alternate-function pin, but do not have the hysteresis characteristics in the port mode.

## (1) Port 4 register (P4)



## (2) Port 4 mode register (PM4)



# (3) Port 4 mode control register (PMC4)

| After re | set: 00H | R/W                                     | Address: F | FFFF448H |   |       |       |       |  |  |
|----------|----------|-----------------------------------------|------------|----------|---|-------|-------|-------|--|--|
|          | 7        | 6                                       | 5          | 4        | 3 | 2     | 1     | 0     |  |  |
| PMC4     | 0        | 0                                       | 0          | 0        | 0 | PMC42 | PMC41 | PMC40 |  |  |
|          |          | 1                                       |            |          |   |       |       |       |  |  |
|          | PMC42    | Specification of P42 pin operation mode |            |          |   |       |       |       |  |  |
|          | 0        | I/O port                                |            |          |   |       |       |       |  |  |
|          | 1        | SCKB0 I/O                               |            |          |   |       |       |       |  |  |
|          | PMC41    | Specification of P41 pin operation mode |            |          |   |       |       |       |  |  |
|          | 0        | I/O port                                |            |          |   |       |       |       |  |  |
|          | 1        | SOB0 output/SCL01 I/O                   |            |          |   |       |       |       |  |  |
|          | PMC40    | Specification of P40 pin operation mode |            |          |   |       |       |       |  |  |
|          | 0        | I/O port                                |            |          |   |       |       |       |  |  |
|          | 1        | SIB0 input/SDA01 I/O                    |            |          |   |       |       |       |  |  |

# (4) Port 4 function control register (PFC4)



## (5) Port 4 function register (PF4)



| PF4n | Control of normal output or N-ch open-drain output ( $n = 0$ to 2) |  |  |  |  |
|------|--------------------------------------------------------------------|--|--|--|--|
| 0    | Normal output (CMOS output)                                        |  |  |  |  |
| 1    | N-ch open-drain output                                             |  |  |  |  |

Caution To pull up an output pin at a voltage of EV<sub>DD</sub> or higher, be sure to set the corresponding PF4n bit to 1.

#### 4.3.5 Port 5

Port 5 is a 6-bit port that controls I/O in 1-bit units.

Port 5 includes the following alternate-function pins.

Table 4-8. Port 5 Alternate-Function Pins

| Pin Name | Pin No. | Alternate-Function Pin Name                    | I/O | Remark                               | Block Type |
|----------|---------|------------------------------------------------|-----|--------------------------------------|------------|
| P50      | 37      | TIQ01/KR0/TOQ01/RTP00                          | I/O | Selectable as N-ch open-drain output | U-5        |
| P51      | 38      | TIQ02/KR1/TOQ02/RTP01                          | I/O |                                      | U-5        |
| P52      | 39      | TIQ03/KR2/TOQ03/RTP02/DDI <sup>Note</sup>      | I/O |                                      | U-6        |
| P53      | 40      | SIB2/KR3/TIQ00/TOQ00/RTP03/DDO <sup>Note</sup> | I/O |                                      | U-7        |
| P54      | 41      | SOB2/KR4/RTP04/DCK <sup>Note</sup>             | I/O |                                      | U-8        |
| P55      | 42      | SCKB2/KR5/RTP05/DMS <sup>Note</sup>            | I/O |                                      | U-9        |

Note The DDI, DDO, DCK, and DMS pins are for on-chip debugging (flash memory version only).

If on-chip debugging is not used, fix the P05/INTP2/ $\overline{DRST}$  pin to low level between when the reset signal of the  $\overline{RESET}$  pin is released and when the OCDM.OCDM0 bit is cleared (0). Although the mask ROM versions do not support the on-chip debug mode, handle the P05/INTP2 pin the same as the flash memory versions.

For details, see 4.6.3 Cautions on on-chip debug pins.

- Cautions 1. When the power is turned on, the P53 pin may output undefined level temporarily even during reset.
  - 2. The P50 to P55 pins have hysteresis characteristics in the input mode of the alternate function, but do not have hysteresis characteristics in the port mode.

### (1) Port 5 register (P5)



# (2) Port 5 mode register (PM5)

| After res | set: FFH | R/W      | Address: F | FFFF42AI | +            |           |      |      |
|-----------|----------|----------|------------|----------|--------------|-----------|------|------|
|           | 7        | 6        | 5          | 4        | 3            | 2         | 1    | 0    |
| PM5       | 1        | 1        | PM55       | PM54     | PM53         | PM52      | PM51 | PM50 |
|           |          |          |            |          |              |           |      |      |
|           | PM5n     |          |            | I/O mode | e control (n | = 0 to 5) |      |      |
|           | 0        | Output n | node       |          |              |           |      |      |
|           | 1        | Input mo | de         |          |              |           |      |      |
|           |          |          |            |          |              |           |      |      |

# (3) Port 5 mode control register (PMC5)

| After re | set: 00H | R/W                                     | Address: F   | FFFF44AI       | 4            |            |            |       |
|----------|----------|-----------------------------------------|--------------|----------------|--------------|------------|------------|-------|
|          | 7        | 6                                       | 5            | 4              | 3            | 2          | 1          | 0     |
| PMC5     | 0        | 0                                       | PMC55        | PMC54          | PMC53        | PMC52      | PMC51      | PMC50 |
|          | PMC55    |                                         | Spe          | ecification o  | of P55 pin o | peration m | node       |       |
|          | 0        | I/O port                                |              |                |              |            |            |       |
|          | 1        | SCKB2 I/                                | O/KR5 inpu   | t/RTP05 o      | utput        |            |            |       |
|          | PMC54    |                                         | Spe          | ecification o  | of P54 pin o | peration m | node       |       |
|          | 0        | I/O port                                |              |                |              |            |            |       |
|          | 1        | SOB2 ou                                 | tput/KR4 inp | out/RTP04      | output       |            |            |       |
|          | PMC53    |                                         | Spe          | cification o   | of P53 pin o | peration m | node       |       |
|          | 0        | I/O port                                |              |                |              |            |            |       |
|          | 1        | SIB2 inpu                               | ut/KR3 input | /TIQ00 inp     | out/TOQ00    | output/RTF | P03 output |       |
|          | PMC52    | Specification of P52 pin operation mode |              |                |              |            |            |       |
|          | 0        | I/O port                                |              |                |              |            |            |       |
|          | 1        | TIQ03 inp                               | out/KR2 inp  | ut/TOQ03       | output/RTP   | 02 output  |            |       |
|          | PMC51    |                                         | Spe          | cification o   | of P51 pin o | peration m | node       |       |
|          | 0        | I/O port                                |              |                |              |            |            |       |
|          | 1        | TIQ02 inp                               | out/KR1 inpo | ut/TOQ02       | output/RTP   | 01 output  |            |       |
|          | PMC50    |                                         | Spe          | ecification of | of P50 pin o | peration m | node       |       |
|          | 0        | I/O port                                |              |                |              |            |            |       |
|          | 1        | TIQ01 inp                               | out/KR0 inp  | ut/TOQ01       | output/RTP   | 00 output  |            |       |

## (4) Port 5 function control register (PFC5)



Remark For details of alternate function specification, see 4.3.5 (6) Port 5 alternate function specifications.

### (5) Port 5 function control expansion register (PFCE5)



Remark For details of alternate function specification, see 4.3.5 (6) Port 5 alternate function specifications.

### (6) Port 5 alternate function specifications

| PFCE55 | PFC55 | Specification of P55 pin alternate function |
|--------|-------|---------------------------------------------|
| 0      | 0     | SCKB2 I/O                                   |
| 0      | 1     | KR5 input                                   |
| 1      | 0     | Setting prohibited                          |
| 1      | 1     | RTP05 output                                |

| PFCE54 | PFC54 | Specification of P54 pin alternate function |
|--------|-------|---------------------------------------------|
| 0      | 0     | SOB2 output                                 |
| 0      | 1     | KR4 input                                   |
| 1      | 0     | Setting prohibited                          |
| 1      | 1     | RTP04 output                                |

| PFCE53 | PFC53 | Specification of P53 pin alternate function |
|--------|-------|---------------------------------------------|
| 0      | 0     | SIB2 input                                  |
| 0      | 1     | TIQ00 input/KR3 <sup>Note</sup> input       |
| 1      | 0     | TOQ00 output                                |
| 1      | 1     | RTP03 output                                |

| PFCE52 | PFC52 | Specification of P52 pin alternate function |
|--------|-------|---------------------------------------------|
| 0      | 0     | Setting prohibited                          |
| 0      | 1     | TIQ03 input/KR2 <sup>Note</sup> input       |
| 1      | 0     | TOQ03 input                                 |
| 1      | 1     | RTP02 output                                |

| PFCE51 | PFC51 | Specification of P51 pin alternate function |
|--------|-------|---------------------------------------------|
| 0      | 0     | Setting prohibited                          |
| 0      | 1     | TIQ02 input/KR1 <sup>Note</sup> input       |
| 1      | 0     | TOQ02 output                                |
| 1      | 1     | RTP01 output                                |

| PFCE50 | PFC50 | Specification of P50 pin alternate function |
|--------|-------|---------------------------------------------|
| 0      | 0     | Setting prohibited                          |
| 0      | 1     | TIQ01 input/KR0 <sup>Note</sup> input       |
| 1      | 0     | TOQ01 output                                |
| 1      | 1     | RTP00 output                                |

Note The KRn pin and TIQ0m pin are alternate-function pins. When using the pin as the TIQ0m pin, disable KRn pin key return detection, which is the alternate function. (Clear the KRM.KRMn bit to 0.) Also, when using the pin as the KRn pin, disable TIQ0m pin edge detection, which is the alternate function (n = 0 to 3, m = 0 to 3).

| Pin Name  | Use as TIQ0m Pin | Use as KRn Pin                                                                                                                |
|-----------|------------------|-------------------------------------------------------------------------------------------------------------------------------|
| KR0/TIQ01 | KRM.KRM0 bit = 0 | TQ0IOC1. TQ0TIG2, TQ0IOC1. TQ0TIG3 bits = 0                                                                                   |
| KR1/TIQ02 | KRM.KRM1 bit = 0 | TQ0IOC1.TQ0TIG4, TQ0IOC1.TQ0TIG5 bits = 0                                                                                     |
| KR2/TIQ03 | KRM.KRM2 bit = 0 | TQ0IOC1.TQ0TIG6, TQ0IOC1.TQ0TIG7 bits = 0                                                                                     |
| KR3/TIQ00 | KRM.KRM3 bit = 0 | TQ0IOC1.TQ0TIG0, TQ0IOC1.TQ0TIG1 bits = 0 TQ0IOC2.TQ0EES0, TQ0IOC2.TQ0EES1 bits = 0 TQ0IOC2.TQ0ETS0, TQ0IOC2.TQ0ETS1 bits = 0 |

## (7) Port 5 function register (PF5)

After reset: 00H R/W Address: FFFFC6AH 5 4 3 2 0 PF5 0 0 PF55 PF54 PF53 PF52 PF51 PF50

|   | PF5n | Control of normal output or N-ch open-drain output ( $n = 0$ to 5) |  |  |  |  |
|---|------|--------------------------------------------------------------------|--|--|--|--|
| ſ | 0    | Normal output (CMOS output)                                        |  |  |  |  |
|   | 1    | N-ch open-drain output                                             |  |  |  |  |

Caution To pull up an output pin at a voltage of EV<sub>DD</sub> or higher, be sure to set the corresponding PF5n bit to 1.

### 4.3.6 Port 7

Port 7 is a 12-bit port for which I/O settings can be controlled in 1-bit units.

Port 7 includes the following alternate-function pins.

Table 4-9. Port 7 Alternate-Function Pins

| Pin Name | Pin No. | Alternate-Function Pin Name | I/O   | Remark | Block Type |
|----------|---------|-----------------------------|-------|--------|------------|
| P70      | 100     | ANI0                        | Input | =      | A-1        |
| P71      | 99      | ANI1                        | Input |        | A-1        |
| P72      | 98      | ANI2                        | Input |        | A-1        |
| P73      | 97      | ANI3                        | Input |        | A-1        |
| P74      | 96      | ANI4                        | Input |        | A-1        |
| P77      | 95      | ANI5                        | Input |        | A-1        |
| P76      | 94      | ANI6                        | Input |        | A-1        |
| P77      | 93      | ANI7                        | Input |        | A-1        |
| P78      | 92      | ANI8                        | Input |        | A-1        |
| P79      | 91      | ANI9                        | Input |        | A-1        |
| P710     | 90      | ANI10                       | Input |        | A-1        |
| P711     | 89      | ANI11                       | Input |        | A-1        |

### (1) Port 7 register H, port 7 register L (P7H, P7L)

After reset: 00H (output latch) R/W Address: P7L FFFFF40EH, P7H FFFFF40FH 5 3 2 0 P7H 0 0 0 0 P711 P710 P79 P78 5 2 0 P74 P7L P77 P76 P75 P73 P72 P71 P70

| P7n | Output data control (in output mode) (n = 0 to 11) |  |  |
|-----|----------------------------------------------------|--|--|
| 0   | Outputs 0                                          |  |  |
| 1   | Outputs 1                                          |  |  |

Caution Do not read/write the P7H and P7L registers during A/D conversion (see 13.6 (4) Alternate I/O).

**Remark** These registers cannot be accessed in 16-bit units as the P7 register. They can be read or written in 8-bit or 1-bit units as the P7H and P7L registers.

## (2) Port 7 mode register H, port 7 mode register L (PM7H, PM7L)

| After reset: FFH R/W |      | R/W  | Address: PM7L FFFFF42EH, PM7H FFFFF42FH |      |       |       |      |      |  |
|----------------------|------|------|-----------------------------------------|------|-------|-------|------|------|--|
|                      | 7    | 6    | 5                                       | 4    | 3     | 2     | 1    | 0    |  |
| РМ7Н                 | 1    | 1    | 1                                       | 1    | PM711 | PM710 | PM79 | PM78 |  |
|                      | 7    | 6    | 5                                       | 4    | 3     | 2     | 1    | 0    |  |
| PM7L                 | PM77 | PM76 | PM75                                    | PM74 | PM73  | PM72  | PM71 | PM70 |  |

| PM7n | I/O mode control (n = 0 to 11) |  |  |
|------|--------------------------------|--|--|
| 0    | Output mode                    |  |  |
| 1    | Input mode                     |  |  |

Caution When using the P7n pin as its alternate function (ANIn pin), set the PM7n bit to 1.

**Remark** These registers cannot be accessed in 16-bit units as the PM7 register. They can be read or written in 8-bit or 1-bit units as the PM7H and PM7L registers.

### 4.3.7 Port 9

Port 9 is a 16-bit port for which I/O settings can be controlled in 1-bit units.

Port 9 includes the following alternate-function pins.

Table 4-10. Port 9 Alternate-Function Pins

| Pin Name | Pin No. | Alternate-Function Pin Name | I/O    | Remark                               | Block Type |
|----------|---------|-----------------------------|--------|--------------------------------------|------------|
| P90      | 43      | A0/KR6/TXDA1/SDA02          | I/O    | Selectable as N-ch open-drain output | U-10       |
| P91      | 44      | A1/KR7/RXDA1/SCL02          | I/O    |                                      | U-11       |
| P92      | 45      | A2/TIP41/TOP41              | I/O    |                                      | U-12       |
| P93      | 46      | A3/TIP40/TOP40              | I/O    |                                      | U-12       |
| P94      | 47      | A4/TIP31/TOP31              | I/O    |                                      | U-12       |
| P95      | 48      | A5/TIP30/TOP30              | I/O    |                                      | U-12       |
| P96      | 49      | A6/TIP21/TOP21              | I/O    |                                      | U-13       |
| P97      | 50      | A7/SIB1/TIP20/TOP20         | I/O    |                                      | U-14       |
| P98      | 51      | A8/SOB1                     | Output |                                      | G-3        |
| P99      | 52      | A9/SCKB1                    | I/O    |                                      | G-5        |
| P910     | 53      | A10/SIB3                    | I/O    |                                      | G-2        |
| P911     | 54      | A11/SOB3                    | Output |                                      | G-3        |
| P912     | 55      | A12/SCKB3                   | I/O    |                                      | G-5        |
| P913     | 56      | A13/INTP4                   | I/O    |                                      | N-2        |
| P914     | 57      | A14/INTP5/TIP51/TOP51       | I/O    |                                      | U-15       |
| P915     | 58      | A15/INTP6/TIP50/TOP50       | I/O    |                                      | U-15       |

Caution The P90 to P97, P99, P910, and P912 to P915 pins have hysteresis characteristics in the input mode of the alternate-function pin, but do not have the hysteresis characteristics in the port mode.

### (1) Port 9 register (P9)

After reset: 0000H (output latch) R/W Address: P9 FFFFF412H, P9L FFFFF412H, P9H FFFFF413H 15 14 13 12 11 10 9 8 P9 (P9H) P915 P914 P98 P913 P912 P911 P910 P99 7 6 5 4 3 2 1 0 (P9L) P97 P96 P95 P94 P93 P92 P91 P90

| P9n | Output data control (in output mode) (n = 0 to 15) |
|-----|----------------------------------------------------|
| 0   | Outputs 0                                          |
| 1   | Outputs 1                                          |

**Remarks 1.** The P9 register can be read or written in 16-bit units.

However, when using the higher 8 bits of the P9 register as the P9H register and the lower 8 bits as the P9L register, P9 can be read or written in 8-bit or 1-bit units.

2. To read/write bits 8 to 15 of the P9 register in 8-bit or 1-bit units, specify them as bits 0 to 7 of the P9H register.

#### (2) Port 9 mode register (PM9)

After reset: FFFFH R/W Address: PM9 FFFFF432H, PM9L FFFFF432H, PM9H FFFFF433H 15 14 13 11 9 8 PM9 (PM9H) PM915 PM914 PM913 PM912 PM911 PM910 PM99 **PM98** 5 2 0 7 6 4 3 1 (PM9L) PM97 PM96 PM95 PM94 PM93 PM92 PM91 PM90

| PM9n | I/O mode control (n = 0 to 15) |  |  |  |
|------|--------------------------------|--|--|--|
| 0    | Output mode                    |  |  |  |
| 1    | Input mode                     |  |  |  |

**Remarks 1.** The PM9 register can be read or written in 16-bit units.

However, when using the higher 8 bits of the PM9 register as the PM9H register and the lower 8 bits as the PM9L register, PM9 can be read or written in 8-bit and 1-bit units.

2. To read/write bits 8 to 15 of the PM9 register in 8-bit or 1-bit units, specify them as bits 0 to 7 of the PM9H register.

## (3) Port 9 mode control register (PMC9)

(1/2)

| After res    | After reset: 0000H |            |             |               | R/W Address: PMC9 FFFF452H,<br>PMC9L FFFFF452H, PMC9H FFFFF453H |             |       |       |  |
|--------------|--------------------|------------|-------------|---------------|-----------------------------------------------------------------|-------------|-------|-------|--|
|              | 15                 |            | 13          | 12            | 11                                                              | 10          | 9     | 8     |  |
| PMC9 (PMC9H) | PMC915             | PMC914     | PMC913      | PMC912        | PMC911                                                          | PMC910      | PMC99 | PMC98 |  |
|              | 7                  | 6          | 5           | 4             | 3                                                               | 2           | 1     | 0     |  |
| (PMC9L)      | PMC97              | PMC96      | PMC95       | PMC94         | PMC93                                                           | PMC92       | PMC91 | PMC90 |  |
|              |                    |            |             |               |                                                                 |             |       |       |  |
|              | PMC915             |            | Spe         | cification of | P915 pin                                                        | operation n | node  |       |  |
|              | 0                  | I/O port   |             |               |                                                                 |             |       |       |  |
|              | 1                  | A15 outpu  | t/INTP6 inp | out/TIP50 in  | nput/TOP5                                                       | 0 output    |       |       |  |
|              | PMC914             |            | Spe         | cification of | P914 pin o                                                      | operation m | node  |       |  |
|              | 0                  | I/O port   |             |               |                                                                 |             |       |       |  |
|              | 1                  | A14 outpu  | t/INTP5 inp | out/TIP51 in  | nput/TOP5                                                       | 1 output    |       |       |  |
|              | PMC913             |            | Spec        | cification of | P913 pin o                                                      | operation m | node  |       |  |
|              | 0                  | I/O port   |             |               |                                                                 |             |       |       |  |
|              | 1                  | A13 outpu  | t/INTP4 inp | out           |                                                                 |             |       |       |  |
|              | PMC912             |            | Spe         | cification of | P912 pin o                                                      | operation n | node  |       |  |
|              | 0                  | I/O port   |             |               |                                                                 |             |       |       |  |
|              | 1                  | A12 outpu  | t/SCKB3 I/  | 0             |                                                                 |             |       |       |  |
|              | PMC911             |            | Spec        | cification of | P911 pin o                                                      | operation m | node  |       |  |
|              | 0                  | I/O port   |             |               |                                                                 |             |       |       |  |
|              | 1                  | A11 outpu  | t/SOB3 out  | tput          |                                                                 |             |       |       |  |
|              | PMC910             |            | Spec        | cification of | P910 pin o                                                      | operation m | node  |       |  |
|              | 0                  | I/O port   |             |               |                                                                 |             |       |       |  |
|              | 1                  | A10 outpu  | t/SIB3 inpu | ıt            |                                                                 |             |       |       |  |
|              | PMC99              |            | Spe         | cification o  | f P99 pin o                                                     | peration m  | ode   |       |  |
|              | 0                  | I/O port   |             |               |                                                                 |             |       |       |  |
|              | 1                  | A9 output/ | SCKB1 I/C   | )             |                                                                 |             |       |       |  |

**Remarks 1.** The PMC9 register can be read or written in 16-bit units.

However, when using the higher 8 bits of the PMC9 register as the PMC9H register and the lower 8 bits as the PMC9L register, PMC9 can be read or written in 8-bit or 1-bit units.

2. To read/write bits 8 to 15 of the PMC9 register in 8-bit or 1-bit units, specify them as bits 0 to 7 of the PMC9H register.

(2/2)

| PMC98 | Specification of P98 pin operation mode       |
|-------|-----------------------------------------------|
| 0     | I/O port                                      |
| 1     | A8 output/SOB1 output                         |
| PMC97 | Specification of P97 pin operation mode       |
| 0     | I/O port                                      |
| 1     | A7 output/SIB1 input/TIP20 input/TOP20 output |
| PMC96 | Specification of P96 pin operation mode       |
| 0     | I/O port                                      |
| 1     | A6 output/TIP21 input/TOP21 output            |
| PMC95 | Specification of P95 pin operation mode       |
| 0     | I/O port                                      |
| 1     | A5 output/TIP30 input/TOP30 output            |
| PMC94 | Specification of P94 pin operation mode       |
| 0     | I/O port                                      |
| 1     | A4 output/TIP31 input/TOP31 output            |
| PMC93 | Specification of P93 pin operation mode       |
| 0     | I/O port                                      |
| 1     | A3 output/TIP40 input/TOP40 output            |
| PMC92 | Specification of P92 pin operation mode       |
| 0     | I/O port                                      |
| 1     | A2 output/TIP41 input/TOP41 output            |
| PMC91 | Specification of P91 pin operation mode       |
| 0     | I/O port                                      |
| 1     | A1 output/KR7 input/RXDA1 input/SCL02 I/O     |
| PMC90 | Specification of P90 pin operation mode       |
| 0     | I/O port                                      |
| 1     | A0 output/KR6 input/TXDA1 output/SDA02 I/O    |

Caution Only when using the A0 to A15 pins as the alternate functions of the P90 to P915 pins, set all 16 bits of the PMC9 register to FFFFH at once.

#### (4) Port 9 function control register (PFC9)

Caution When performing separate address bus output (A0 to A15), set the PMC9 register to FFFFH for all 16 bits at once after clearing the PFC9 register to 0000H.

R/W After reset: 0000H Address: PFC9 FFFF472H, PFC9L FFFFF472H, PFC9H FFFFF473H 13 8 PFC9 (PFC9H) PFC915 PFC914 PFC913 PFC912 PFC911 PFC910 PFC99 PFC98 6 3 2 Ω (PFC9L) PFC97 PFC96 PFC95 PFC94 PFC93 PFC92 PFC91 PFC90

- Remarks 1. For details of alternate function specification, see 4.3.7 (6) Port 9 alternate function specifications.
  - 2. The PFC9 register can be read or written in 16-bit units. However, when using the higher 8 bits of the PFC9 register as the PFC9H register and the lower 8 bits as the PFC9L register, PFC9 can be read or written in 8-bit or 1-bit units.
  - **3.** To read/write bits 8 to 15 of the PFC9 register in 8-bit or 1-bit units, specify them as bits 0 to 7 of the PFC9H register.

#### (5) Port 9 function control expansion register (PFCE9)

After reset: 0000H R/W Address: PFCE9 FFFF712H, PFCE9L FFFFF712H. PFCE9H FFFFF713H 14 13 12 11 10 8 PFCE9 (PFCE9H) PFCE915 PFCE914 0 0 0 0 0 0 3 0 (PFCE9L) PFCE97 PFCE96 PFCE95 PFCE94 PFCE93 PFCE92 PFCE91 PFCE90

- Remarks 1. For details of alternate function specification, see 4.3.7 (6) Port 9 alternate function specifications.
  - 2. The PFCE9 register can be read or written in 16-bit units. However, when using the higher 8 bits of the PFCE9 register as the PFCE9H register and the lower 8 bits as the PFCE9L register, PFCE9 can be read or written in 8-bit or 1-bit units.
  - **3.** To read/write bits 8 to 15 of the PFCE9 register in 8-bit or 1-bit units, specify them as bits 0 to 7 of the PFCE9H register.

## (6) Port 9 alternate function specifications

| PFCE915 | PFC915 | Specification of P915 pin alternate function |
|---------|--------|----------------------------------------------|
| 0       | 0      | A15 output                                   |
| 0       | 1      | INTP6 input                                  |
| 1       | 0      | TIP50 input                                  |
| 1       | 1      | TOP50 output                                 |

| PFCE914 | PFC914 | Specification of P914 pin alternate function |
|---------|--------|----------------------------------------------|
| 0       | 0      | A14 output                                   |
| 0       | 1      | INTP5 input                                  |
| 1       | 0      | TIP51 input                                  |
| 1       | 1      | TOP51 output                                 |

| PFC913 | Specification of P913 pin alternate function |
|--------|----------------------------------------------|
| 0      | A13 output                                   |
| 1      | INTP4 input                                  |

|   | PFC912 | Specification of P912 pin alternate function |
|---|--------|----------------------------------------------|
| Ī | 0      | A12 output                                   |
| Ī | 1      | SCKB3 I/O                                    |

| PFC911 | Specification of P911 pin alternate function |
|--------|----------------------------------------------|
| 0      | A11 output                                   |
| 1      | SOB3 output                                  |

| PFC910 Specification of P910 pin alternate function |            |
|-----------------------------------------------------|------------|
| 0                                                   | A10 output |
| 1                                                   | SIB3 input |

| PFC99 | Specification of P99 pin alternate function |
|-------|---------------------------------------------|
| 0     | A9 output                                   |
| 1     | SCKB1 I/O                                   |

| PFC98 | Specification of P98 pin alternate function |
|-------|---------------------------------------------|
| 0     | A8 output                                   |
| 1     | SOB1 output                                 |

| PFCE97 | PFC97 | Specification of P97 pin alternate function |
|--------|-------|---------------------------------------------|
| 0      | 0     | A7 output                                   |
| 0      | 1     | SIB1 input                                  |
| 1      | 0     | TIP20 input                                 |
| 1      | 1     | TOP20 output                                |

| PFCE96 | PFC96 | Specification of P96 pin alternate function |
|--------|-------|---------------------------------------------|
| 0      | 0     | A6 output                                   |
| 0      | 1     | Setting prohibited                          |
| 1      | 0     | TIP21 input                                 |
| 1      | 1     | TOP21 output                                |

| PFCE95 | PFC95 | Specification of P95 pin alternate function |
|--------|-------|---------------------------------------------|
| 0      | 0     | A5 output                                   |
| 0      | 1     | TIP30 input                                 |
| 1      | 0     | TOP30 output                                |
| 1      | 1     | Setting prohibited                          |

| PFCE94 | PFC94 | Specification of P94 pin alternate function |
|--------|-------|---------------------------------------------|
| 0      | 0     | A4 output                                   |
| 0      | 1     | TIP31 input                                 |
| 1      | 0     | TOP31 output                                |
| 1      | 1     | Setting prohibited                          |

| PFCE93 | PFC93 | Specification of P93 pin alternate function |
|--------|-------|---------------------------------------------|
| 0      | 0     | A3 output                                   |
| 0      | 1     | TIP40 input                                 |
| 1      | 0     | TOP40 output                                |
| 1      | 1     | Setting prohibited                          |

| PFCE92 | PFC92 | Specification of P92 pin alternate function |
|--------|-------|---------------------------------------------|
| 0      | 0     | A2 output                                   |
| 0      | 1     | TIP41 input                                 |
| 1      | 0     | TOP41 output                                |
| 1      | 1     | Setting prohibited                          |

| PFCE91 | PFC91 | Specification of P91 pin alternate function |
|--------|-------|---------------------------------------------|
| 0      | 0     | A1 output                                   |
| 0      | 1     | KR7 input                                   |
| 1      | 0     | RXDA1 input/KR7 input <sup>Note</sup>       |
| 1      | 1     | SCL02 I/O                                   |

| PFCE90 | PFC90 | Specification of P90 pin alternate function |
|--------|-------|---------------------------------------------|
| 0      | 0     | A0 output                                   |
| 0      | 1     | KR6 input                                   |
| 1      | 0     | TXDA1 output                                |
| 1      | 1     | SDA02 I/O                                   |

**Note** The RXDA1 and KR7 pins must not be used at the same time. When using the RXDA1 pin, do not use the KR7 pin. When using the KR7 pin, do not use the RXDA1 pin (it is recommended to set the PFC91 bit to 1 and clear the PFCE91 bit to 0).

## (7) Port 9 function register (PF9)



| PF9n | Control of normal output or N-ch open-drain output (n = 0 to 15) |
|------|------------------------------------------------------------------|
| 0    | Normal output (CMOS output)                                      |
| 1    | N-ch open-drain output                                           |

Caution To pull up an output pin at a voltage of EV<sub>DD</sub> or higher, be sure to set the corresponding PF9n bit to 1.

- Remarks 1. The PF9 register can be read or written in 16-bit units.

  However, when using the higher 8 bits of the PF9 register as the PF9H register and the lower 8 bits as the PF9L register, PF9 can be read or written in 8-bit or 1-bit units.
  - 2. To read/write bits 8 to 15 of the PF9 register in 8-bit or 1-bit units, specify them as bits 0 to 7 of the PF9H register.

### 4.3.8 Port CM

Port CM is a 4-bit port for which I/O settings can be controlled in 1-bit units.

Port CM includes the following alternate-function pins.

**Table 4-11. Port CM Alternate-Function Pins** 

| Pin Name | Pin No. | Alternate-Function Pin Name | I/O    | Remark | Block Type |
|----------|---------|-----------------------------|--------|--------|------------|
| РСМ0     | 61      | WAIT                        | Input  | -      | D-1        |
| PCM1     | 62      | CLKOUT                      | Output |        | D-2        |
| PCM2     | 63      | HLDAK                       | Output |        | D-2        |
| РСМ3     | 64      | HLDRQ                       | Input  |        | D-1        |

## (1) Port CM register (PCM)



## (2) Port CM mode register (PMCM)



# (3) Port CM mode control register (PMCCM)

| After re | set: 00H | R/W       | Address: F | FFFF04C      | СН          |             |        |        |
|----------|----------|-----------|------------|--------------|-------------|-------------|--------|--------|
|          | 7        | 6         | 5          | 4            | 3           | 2           | 1      | 0      |
| PMCCM    | 0        | 0         | 0          | 0            | РМССМ3      | PMCCM2      | PMCCM1 | РМССМ0 |
|          | РМССМ3   |           | Spec       | cification o | of PCM3 pin | operation r | node   |        |
|          | 0        | I/O port  |            |              |             |             |        |        |
|          | 1        | HLDRQ in  | put        |              |             |             |        |        |
|          | PMCCM2   |           | Spec       | cification o | of PCM2 pin | operation r | node   |        |
|          | 0        | I/O port  |            |              |             |             |        |        |
|          | 1        | HLDAK ou  | utput      |              |             |             |        |        |
|          | PMCCM1   |           | Spec       | cification o | of PCM1 pin | operation r | node   |        |
|          | 0        | I/O port  |            |              |             |             |        |        |
|          | 1        | CLKOUT    | output     |              |             |             |        |        |
|          | РМССМ0   |           | Spec       | cification o | of PCM0 pin | operation r | node   |        |
|          | 0        | I/O port  |            |              |             |             |        |        |
|          | 1        | WAIT inpu | ut         |              |             |             |        |        |

### 4.3.9 Port CT

Port CT is a 4-bit port for which I/O settings can be controlled in 1-bit units.

Port CT includes the following alternate-function pins.

Table 4-12. Port CT Alternate-Function Pins

| Pin Name | Pin No. | Alternate-Function Pin Name | I/O    | Remark | Block Type |
|----------|---------|-----------------------------|--------|--------|------------|
| РСТ0     | 65      | WR0                         | Output | _      | D-2        |
| PCT1     | 66      | WR1                         | Output |        | D-2        |
| PCT4     | 67      | RD                          | Output |        | D-2        |
| PCT6     | 68      | ASTB                        | Output |        | D-2        |

## (1) Port CT register (PCT)



## (2) Port CT mode register (PMCT)



# (3) Port CT mode control register (PMCCT)

| After res | set: 00H | R/W A      | ddress:                                  | FFFFF04AH      |          |           |        |        |
|-----------|----------|------------|------------------------------------------|----------------|----------|-----------|--------|--------|
|           | 7        | 6          | 5                                        | 4              | 3        | 2         | 1      | 0      |
| PMCCT     | 0        | РМССТ6     | 0                                        | PMCCT4         | 0        | 0         | PMCCT1 | РМССТ0 |
|           | PMCCT6   | 1/0        | Spe                                      | ecification of | PCT6 pin | operation | n mode |        |
|           | 0        | I/O port   |                                          |                |          |           |        |        |
|           | 1        | ASTB outpo |                                          |                |          |           |        |        |
|           | PMCCT4   |            | Specification of PCT4 pin operation mode |                |          |           |        |        |
|           | 0        | I/O port   |                                          |                |          |           |        |        |
|           | 1        | RD output  |                                          |                |          |           |        |        |
|           | PMCCT1   |            | Spe                                      | ecification of | PCT1 pin | operation | n mode |        |
|           | 0        | I/O port   |                                          |                |          |           |        |        |
|           | 1        | WR1 outpu  | t                                        |                |          |           |        |        |
|           | РМССТ0   |            | Spe                                      | ecification of | PCT0 pin | operation | n mode |        |
|           | 0        | I/O port   |                                          |                |          |           |        |        |
|           | 1        | WR0 outpu  | t                                        |                |          |           |        |        |

### 4.3.10 Port DH

Port DH is a 6-bit port for which I/O settings can be controlled in 1-bit units.

Port DH includes the following alternate-function pins.

Table 4-13. Port DH Alternate-Function Pins

| Pin Name | Pin No. | Alternate-Function Pin Name | I/O    | Remark | Block Type |
|----------|---------|-----------------------------|--------|--------|------------|
| PDH0     | 87      | A16                         | Output | _      | D-2        |
| PDH1     | 88      | A17                         | Output |        | D-2        |
| PDH2     | 59      | A18                         | Output |        | D-2        |
| PDH3     | 60      | A19                         | Output |        | D-2        |
| PDH4     | 6       | A20                         | Output |        | D-2        |
| PDH5     | 7       | A21                         | Output |        | D-2        |

### (1) Port DH register (PDH)



### (2) Port DH mode register (PMDH)



# (3) Port DH mode control register (PMCDH)

| After res | et: 00H | R/W      | Address: F   | FFFF046H    | I           |           |                |        |
|-----------|---------|----------|--------------|-------------|-------------|-----------|----------------|--------|
|           | 7       | 6        | 5            | 4           | 3           | 2         | 1              | 0      |
| PMCDH     | 0       | 0        | PMCDH5       | PMCDH4      | PMCDH3      | PMCDH2    | PMCDH1         | PMCDH0 |
|           |         |          |              |             |             |           |                |        |
|           | PMCDHn  |          | Specificati  | on of PDHr  | n pin opera | tion mode | (n = 0  to  5) |        |
|           | 0       | I/O port |              |             |             |           |                |        |
|           | 1       | Am outpu | t (address l | ous output) | (m = 16 to  | 21)       |                |        |

#### 4.3.11 Port DL

Port DL is a 16-bit port for which I/O settings can be controlled in 1-bit units.

Port DL includes the following alternate-function pins.

Table 4-14. Port DL Alternate-Function Pins

| Pin Name | Pin No. | Alternate-Function Pin Name | I/O | Remark | Block Type |
|----------|---------|-----------------------------|-----|--------|------------|
| PDL0     | 71      | AD0                         | I/O | _      | D-3        |
| PDL1     | 72      | AD1                         | I/O |        | D-3        |
| PDL2     | 73      | AD2                         | I/O |        | D-3        |
| PDL3     | 74      | AD3                         | I/O |        | D-3        |
| PDL4     | 75      | AD4                         | I/O |        | D-3        |
| PDL5     | 76      | AD5/FLMD1 <sup>Note</sup>   | I/O |        | D-3        |
| PDL6     | 77      | AD6                         | I/O |        | D-3        |
| PDL7     | 78      | AD7                         | I/O |        | D-3        |
| PDL8     | 79      | AD8                         | I/O |        | D-3        |
| PDL9     | 80      | AD9                         | I/O |        | D-3        |
| PDL10    | 81      | AD10                        | I/O |        | D-3        |
| PDL11    | 82      | AD11                        | I/O |        | D-3        |
| PDL12    | 83      | AD12                        | I/O |        | D-3        |
| PDL13    | 84      | AD13                        | I/O |        | D-3        |
| PDL14    | 85      | AD14                        | I/O |        | D-3        |
| PDL15    | 86      | AD15                        | I/O |        | D-3        |

**Note** Since this pin is set in the flash memory programming mode, it does not need to be manipulated with the port control register. For details, see **CHAPTER 29 FLASH MEMORY**.

### (1) Port DL register (PDL)



Remarks 1. The PDL register can be read or written in 16-bit units.

However, when using the higher 8 bits of the PDL register as the PDLH register and the lower 8 bits as the PDLL register, PDL can be read or written in 8-bit or 1-bit units.

2. To read/write bits 8 to 15 of the PDL register in 8-bit or 1-bit units, specify them as bits 0 to 7 of the PDLH register.

#### (2) Port DL mode register (PMDL)



**Remarks 1.** The PMDL register can be read or written in 16-bit units.

However, when using the higher 8 bits of the PMDL register as the PMDLH register and the

lower 8 bits as the PMDLL register, PMDL can be read or written in 8-bit or 1-bit units.

2. To read/write bits 8 to 15 of the PMDL register in 8-bit or 1-bit units, specify them as bits 0 to 7 of the PMDLH register.

#### (3) Port DL mode control register (PMCDL)



Caution When the SMSEL bit of the EXIMC register = 1 (separate mode) and the BS30 to BS00 bits of the BSC register = 0 (8-bit bus width), do not specify the AD8 to AD15 pins.

Remarks 1. The PMCDL register can be read or written in 16-bit units.

However, when using the higher 8 bits of the PMCDL register as the PMCDLH register and the lower 8 bits as the PMCDLL register, PMCDL can be read or written in 8-bit or 1-bit units.

2. To read/write bits 8 to 15 of the PMCDL register in 8-bit or 1-bit units, specify them as bits 0 to 7 of the PMCDLH register.

# 4.4 Block Diagrams

Figure 4-3. Block Diagram of Type A-1





Figure 4-4. Block Diagram of Type A-2



Figure 4-5. Block Diagram of Type D-1



Figure 4-6. Block Diagram of Type D-2



Figure 4-7. Block Diagram of Type D-3



Figure 4-8. Block Diagram of Type E-3



Figure 4-9. Block Diagram of Type G-1



Figure 4-10. Block Diagram of Type G-2



Figure 4-11. Block Diagram of Type G-3



Figure 4-12. Block Diagram of Type G-4



Figure 4-13. Block Diagram of Type G-5

WRPF PFmn WRPFC PFCmn  $WR_{\text{PMC}}$ PMCmn Internal bus WRPM **PMmn**  $\mathsf{EV}_\mathsf{DD}$ Output signal when alternate function is used Selector WRPORT O Pmn Pmn 7/7 Selector  $\text{EV}_{\text{SS}}$ Selector Address Note RD Input signal 1 when alternate function is used Selector Input signal 2 when alternate function is used **Note** Hysteresis characteristics are not available in port mode.

Figure 4-14. Block Diagram of Type G-6



Figure 4-15. Block Diagram of Type G-12

 $WR_{\text{PF}}$ PFmn WRINTR INTRmn<sup>Note 1</sup> WRINTF INTFmn<sup>Note 1</sup> WRPMC PMCmn Internal bus WRPM PMmn  $\text{EV}_{\text{DD}}$ WRPORT Pmn O Pmn N-ch Selector EVss Selector Note 2 Address RD Input signal 1 when Noise elimination Edge detection alternate function is used Notes 1. See 22.6 External Interrupt Request Input Pins (NMI and INTP0 to INTP7). 2. Hysteresis characteristics are not available in port mode.

Figure 4-16. Block Diagram of Type L-1

WRPF PFmn WRINTR INTRmn<sup>Note 1</sup> WRINTF INTFmn<sup>Note 1</sup> WRPFC PFCmn Internal bus WRPMC PMCmn  $WR_{PM}$ PMmn  $\mathsf{EV}_\mathsf{DD}$ WRPORT Pmn O Pmn ⊢N-ch 7/7 Selector EVss Note 2 Address RD Input signal 1 when Edge detection Noise elimination alternate function is used Selector Input signal 2 when alternate function is used Notes 1. See 22.6 External Interrupt Request Input Pins (NMI and INTP0 to INTP7). 2. Hysteresis characteristics are not available in port mode.

Figure 4-17. Block Diagram of Type N-1

WRPF PFmn WRINTR INTRmn<sup>Note 1</sup> WRINTE INTFmn<sup>Note 1</sup> WRPFC **PFCmn WR**PMC Internal bus **PMCmn**  $WR_{\text{PM}}$ PMmn Output signal when alternate function is used  $\mathsf{EV}_\mathsf{DD}$ WRPORT Selector Pmn O Pmn Selector EVss Selector Note 2 Address RD Input signal when Noise elimination Edge detection alternate function is used Notes 1. See 22.6 External Interrupt Request Input Pins (NMI and INTP0 to INTP7). 2. Hysteresis characteristics are not available in port mode.

Figure 4-18. Block Diagram of Type N-2



Figure 4-19. Block Diagram of Type N-3

WRPF Output enable signal when alternate function is used PFCEmn WRPFC PFCmn WRPMC Internal bus PMCmn WRPM PMmn Output signal 1 when Selector alternate function is used  $\text{EV}_{\text{DD}}$ Output signal 2 when alternate function is used O Pmn Selector EVss Note Address RD Input signal 1 when alternate function is used Selector Input signal 2 when alternate function is used Input signal 3 when alternate function is used **Note** Hysteresis characteristics are not available in port mode.

Figure 4-20. Block Diagram of Type U-1



Figure 4-21. Block Diagram of Type U-5

WRPF PFmn WRосомо OCDM0 WRPFCE PFCEmn  $WR_{\text{PFC}}$ **PFCmn** WRPMC PMCmn Internal bus WRPM PMmn Output signal 1 when alternate function is used Selector EVDD Output signal 2 when alternate function is used WRPORT - Pmn Pmn 7/7 EVss Selector Selector Note Address Input signal 1-1 when RD alternate function is used Input signal 1-2 when Noise elimination alternate function is used Input signal when on-chip debugging **Note** Hysteresis characteristics are not available in port mode.

Figure 4-22. Block Diagram of Type U-6

WRPF PFmn WRосомо OCDM0 WRPFCE PFCEmn  $WR_{\text{PFC}}$ PFCmn WRPMC Internal bus PMCmn  $WR_{PM}$ PMmn Output signal 1 when alternate function is used Selector Output signal 2 when alternate function is used Selector  $\text{EV}_{\text{DD}}$ Output signal when on-chip debugging P-ch WRPORT - ○ Pmn Pmn EVss Selector Note Address RD Input signal 1 when alternate function is used Input signal 2-1 when alternate function is used Input signal 2-2 when alternate function is used Noise elimination **Note** Hysteresis characteristics are not available in port mode.

Figure 4-23. Block Diagram of Type U-7

WRPF PFmn WRосомо OCDM0 WRPFCE PFCEmn WRPFC PFCmn WRPMC Internal bus PMCmn WRPM PMmn Output signal 1 when alternate function is used Selector EVDD Output signal 2 when alternate function is used - P-ch WRPORT - ○ Pmn Pmn → N-ch 7/7 EVss Selector Note Address Input signal when alternate function is used Noise elimination RD Input signal when on-chip debugging **Note** Hysteresis characteristics are not available in port mode.

Figure 4-24. Block Diagram of Type U-8

 $WR_{\text{PF}}$ PFmn WRосомо OCDM0 Output enable signal when alternate function is used WRPFCE PFCEmn WRPFC PFCmn WRPMC Internal bus PMCmn WRPM PMmn Output signal 1 when alternate function is used Selector  $\text{EV}_{\text{DD}}$ Output signal 2 when alternate function is used Selector WRPORT P-ch - Pmn Pmn N-ch EVss Selector Note Address RD Input signal 1 when alternate function is used Input signal 2 when Noise elimination alternate function is used Input signal when on-chip debugging **Note** Hysteresis characteristics are not available in port mode.

Figure 4-25. Block Diagram of Type U-9

WRPF PFmn WRPFCE **PFCEmn**  $WR_{\text{PFC}}$ **PFCmn**  $WR_{PMC}$ **PMCmn** Internal bus  $WR_{\text{PM}}$ PMmn Output signal 1 when alternate function is used Selector Output signal 2 when alternate function is used  $\mathsf{EV}_\mathsf{DD}$ Output signal 3 when alternate function is used Selector WRPORT - ⊕ Pmn Pmn 7// Selector EVss Address Note RD Input signal 1 when Noise elimination Selector alternate function is used Input signal 2 when alternate function is used **Note** Hysteresis characteristics are not available in port mode.

Figure 4-26. Block Diagram of Type U-10

WRPF PFmn  $WR_{\text{PFCE}}$ **PFCEmn**  $WR_{\text{PFC}}$ **PFCmn** WRPMC **PMCmn** Internal bus  $WR_{PM}$ **PMmn** Output signal 1 when alternate function is used Selector  $\text{EV}_{\text{DD}}$ Output signal 2 when alternate function is used Selector WRPORT - ⊕ Pmn Pmn Selector  $\mathsf{EV}\mathsf{ss}$ Selector Address Note RD Input signal 1 when Noise elimination alternate function is used Selector Input signal 2 when alternate function is used Input signal 3 when alternate function is used Note Hysteresis characteristics are not available in port mode.

Figure 4-27. Block Diagram of Type U-11



Figure 4-28. Block Diagram of Type U-12



Figure 4-29. Block Diagram of Type U-13



Figure 4-30. Block Diagram of Type U-14



Figure 4-31. Block Diagram of Type U-15



Figure 4-32. Block Diagram of Type AA-1

# 4.5 Port Register Settings When Alternate Function Is Used

Table 4-15 shows the port register settings when each port is used for an alternate function. When using a port pin as an alternate-function pin, refer to the description of each pin.

Table 4-15. Using Port Pin as Alternate-Function Pin (1/7)

| Pin Name | Alternate Function     |        | Pnx Bit of                 | PMnx Bit of                 | PMCnx Bit of                 | PFCEnx Bit of  | PFCnx Bit of              | Other Bits       |
|----------|------------------------|--------|----------------------------|-----------------------------|------------------------------|----------------|---------------------------|------------------|
|          | Name                   | I/O    | Pn Register                | PMn Register                | PMCn Register                | PFCEn Register | PFCn Register             | (Registers)      |
| P02      | NMI                    | Input  | P02 = Setting not required | PM02 = Setting not required | PMC02 = 1                    | _              | -                         |                  |
| P03      | INTP0                  | Input  | P03 = Setting not required | PM03 = Setting not required | PMC03 = 1                    | -              | PFC03 = 0                 |                  |
|          | ADTRG                  | Input  | P03 = Setting not required | PM03 = Setting not required | PMC03 = 1                    | _              | PFC03 = 1                 |                  |
| P04      | INTP1                  | Input  | P04 = Setting not required | PM04 = Setting not required | PMC04 = 1                    | -              | -                         |                  |
| P05      | INTP2                  | Input  | P05 = Setting not required | PM05 = Setting not required | PMC05 = 1                    | -              | -                         |                  |
|          | DRST <sup>Note 1</sup> | Input  | P05 = Setting not required | PM05 = Setting not required | PMC05 = Setting not required | -              | -                         | OCDM0 (OCDM) = 1 |
| P06      | INTP3                  | Input  | P06 = Setting not required | PM06 = Setting not required | PMC06 = 1                    | -              | -                         |                  |
| P10      | ANO0                   | Output | P10 = Setting not required | PM10 = 1                    | -                            | -              | -                         |                  |
| P11      | ANO1                   | Output | P11 = Setting not required | PM11 = 1                    | -                            | -              | -                         |                  |
| P30      | TXDA0                  | Output | P30 = Setting not required | PM30 = Setting not required | PMC30 = 1                    | -              | PFC30 = 0                 |                  |
|          | SOB4                   | Output | P30 = Setting not required | PM30 = Setting not required | PMC30 = 1                    | _              | PFC30 = 1                 |                  |
| P31      | RXDA0                  | Input  | P31 = Setting not required | PM31 = Setting not required | PMC31 = 1                    | _              | <b>Note 2</b> , PFC31 = 0 |                  |
|          | INTP7                  | Input  | P31 = Setting not required | PM31 = Setting not required | PMC31 = 1                    | -              | <b>Note 2</b> , PFC31 = 0 |                  |
|          | SIB4                   | Input  | P31 = Setting not required | PM31 = Setting not required | PMC31 = 1                    | -              | PFC31 = 1                 |                  |
| P32      | ASCKA0                 | Input  | P32 = Setting not required | PM32 = Setting not required | PMC32 = 1                    | PFCE32 = 0     | PFC32 = 0                 |                  |
|          | SCKB4                  | I/O    | P32 = Setting not required | PM32 = Setting not required | PMC32 = 1                    | PFCE32 = 0     | PFC32 = 1                 |                  |
|          | TIP00                  | Input  | P32 = Setting not required | PM32 = Setting not required | PMC32 = 1                    | PFCE32 = 1     | PFC32 = 0                 |                  |
|          | TOP00                  | Output | P32 = Setting not required | PM32 = Setting not required | PMC32 = 1                    | PFCE32 = 1     | PFC32 = 1                 |                  |
| P33      | TIP01                  | Input  | P33 = Setting not required | PM33 = Setting not required | PMC33 = 1                    | _              | PFC33 = 0                 |                  |
|          | TOP01                  | Output | P33 = Setting not required | PM33 = Setting not required | PMC33 = 1                    | _              | PFC33 = 1                 |                  |
| P34      | TIP10                  | Input  | P34 = Setting not required | PM34 = Setting not required | PMC34 = 1                    | _              | PFC34 = 0                 |                  |
|          | TOP10                  | Output | P34 = Setting not required | PM34 = Setting not required | PMC34 = 1                    | _              | PFC34 = 1                 |                  |
| P35      | TIP11                  | Input  | P35 = Setting not required | PM35 = Setting not required | PMC35 = 1                    | -              | PFC35 = 0                 |                  |
|          | TOP11                  | Output | P35 = Setting not required | PM35 = Setting not required | PMC35 = 1                    | -              | PFC35 = 1                 |                  |

CHAPTER 4 PORT FUNCTIONS

Notes 1. Flash memory versions only

2. The INTP7 pin and RXDA0 pin are alternate-function pins. When using the pin as the RXDA0 pin, disable edge detection for the alternate-function INTP7 pin (clear the INTF3.INTF31 bit and INTR3.INTR31 bit to 0). When using the pin as the INTP7 pin, stop the UARTA0 reception operation (clear the UA0CTL0.UA0RXE bit to 0).

Caution When using one of the P10 and P11 pins as an I/O port and the other as a D/A output pin (ANO0, ANO1), do so in an application where the port I/O level does not change during D/A output.

Preliminary User's Manual U17644EJ1V0UD

Table 4-15. Using Port Pin as Alternate-Function Pin (2/7)

| Pin Name | Alternate               | Function | Pnx Bit of                 | PMnx Bit of                 | PMCnx Bit of  | PFCEnx Bit of  | PFCnx Bit of  | Other Bits                     |
|----------|-------------------------|----------|----------------------------|-----------------------------|---------------|----------------|---------------|--------------------------------|
|          | Name                    | I/O      | Pn Register                | PMn Register                | PMCn Register | PFCEn Register | PFCn Register | (Registers)                    |
| P36      | CTXD0 <sup>Note 1</sup> | Output   | P36 = Setting not required | PM36 = Setting not required | PMC36 = 1     | _              | PFC36 = 0     |                                |
|          | IETX0Note 2             | Output   | P36 = Setting not required | PM36 = Setting not required | PMC36 = 1     | _              | PFC36 = 1     |                                |
| P37      | CRXD0 <sup>Note 1</sup> | Input    | P37 = Setting not required | PM37 = Setting not required | PMC37 = 1     | _              | PFC37 = 0     |                                |
|          | IERX0 <sup>Note 2</sup> | Input    | P37 = Setting not required | PM37 = Setting not required | PMC37 = 1     | _              | PFC37 = 1     |                                |
| P38      | TXDA2                   | Output   | P38 = Setting not required | PM38 = Setting not required | PMC38 = 1     | _              | PFC38 = 0     |                                |
|          | SDA00                   | I/O      | P38 = Setting not required | PM38 = Setting not required | PMC38 = 1     | _              | PFC38 = 1     |                                |
| P39      | RXDA2                   | Input    | P39 = Setting not required | PM39 = Setting not required | PMC39 = 1     | _              | PFC39 = 0     |                                |
|          | SCL00                   | I/O      | P39 = Setting not required | PM39 = Setting not required | PMC39 = 1     | _              | PFC39 = 1     |                                |
| P40      | SIB0                    | Input    | P40 = Setting not required | PM40 = Setting not required | PMC40 = 1     | _              | PFC40 = 0     |                                |
|          | SDA01                   | I/O      | P40 = Setting not required | PM40 = Setting not required | PMC40 = 1     | _              | PFC40 = 1     |                                |
| P41      | SOB0                    | Output   | P41 = Setting not required | PM41 = Setting not required | PMC41 = 1     | -              | PFC41 = 0     |                                |
|          | SCL01                   | I/O      | P41 = Setting not required | PM41 = Setting not required | PMC41 = 1     | _              | PFC41 = 1     |                                |
| P42      | SCKB0                   | I/O      | P42 = Setting not required | PM42 = Setting not required | PMC42 = 1     | -              | -             |                                |
| P50      | TIQ01                   | Input    | P50 = Setting not required | PM50 = Setting not required | PMC50 = 1     | PFCE50 = 0     | PFC50 = 1     | KRM0 (KRM) = 0                 |
|          | KR0                     | Input    | P50 = Setting not required | PM50 = Setting not required | PMC50 = 1     | PFCE50 = 0     | PFC50 = 1     | TQ0TIG2, TQ0TIG3 (TQ0IOC1) = 0 |
|          | TOQ01                   | Output   | P50 = Setting not required | PM50 = Setting not required | PMC50 = 1     | PFCE50 = 1     | PFC50 = 0     |                                |
|          | RTP00                   | Output   | P50 = Setting not required | PM50 = Setting not required | PMC50 = 1     | PFCE50 = 1     | PFC50 = 1     |                                |
| P51      | TIQ02                   | Input    | P51 = Setting not required | PM51 = Setting not required | PMC51 = 1     | PFCE51 = 0     | PFC51 = 1     | KRM1 (KRM) = 0                 |
|          | KR1                     | Input    | P51 = Setting not required | PM51 = Setting not required | PMC51 = 1     | PFCE51 = 0     | PFC51 = 1     | TQ0TIG4, TQ0TIG5 (TQ0IOC1) = 0 |
|          | TOQ02                   | Output   | P51 = Setting not required | PM51 = Setting not required | PMC51 = 1     | PFCE51 = 1     | PFC51 = 0     |                                |
|          | RTP01                   | Output   | P51 = Setting not required | PM51 = Setting not required | PMC51 = 1     | PFCE51 = 1     | PFC51 = 1     |                                |

Notes 1. CAN controller versions only

2. IEBus controller versions only

Table 4-15. Using Port Pin as Alternate-Function Pin (3/7)

| Pin Name | Alternate           | Function | Pnx Bit of                 | PMnx Bit of                 | PMCnx Bit of                 | PFCEnx Bit of                 | PFCnx Bit of                 | Other Bits                      |
|----------|---------------------|----------|----------------------------|-----------------------------|------------------------------|-------------------------------|------------------------------|---------------------------------|
|          | Name                | I/O      | Pn Register                | PMn Register                | PMCn Register                | PFCEn Register                | PFCn Register                | (Registers)                     |
| P52      | TIQ03               | Input    | P52 = Setting not required | PM52 = Setting not required | PMC52 = 1                    | PFCE52 = 0                    | PFC52 = 1                    | KRM2 (KRM) = 0                  |
|          | KR2                 | Input    | P52 = Setting not required | PM52 = Setting not required | PMC52 = 1                    | PFCE52 = 0                    | PFC52 = 1                    | TQ0TIG6, TQ0TIG7 (TQ0I0C1) = 0  |
|          | TOQ03               | Output   | P52 = Setting not required | PM52 = Setting not required | PMC52 = 1                    | PFCE52 = 1                    | PFC52 = 0                    |                                 |
|          | RTP02               | Output   | P52 = Setting not required | PM52 = Setting not required | PMC52 = 1                    | PFCE52 = 1                    | PFC52 = 1                    |                                 |
|          | DDI <sup>Note</sup> | Input    | P52 = Setting not required | PM52 = Setting not required | PMC52 = Setting not required | PFCE52 = Setting not required | PFC52 = Setting not required | OCDM0 (OCDM) = 1                |
| P53      | SIB2                | Input    | P53 = Setting not required | PM53 = Setting not required | PMC53 = 1                    | PFCE53 = 0                    | PFC53 = 0                    |                                 |
|          | TIQ00               | Input    | P53 = Setting not required | PM53 = Setting not required | PMC53 = 1                    | PFCE53 = 0                    | PFC53 = 1                    | KRM3 (KRM) = 0                  |
|          | KR3                 | Input    | P53 = Setting not required | PM53 = Setting not required | PMC53 = 1                    | PFCE53 = 0                    | PFC53 = 1                    | TQ0TIG0, TQ0TIG1 (TQ0IOC1) = 0, |
|          |                     |          |                            |                             |                              |                               |                              | TQ0EES0, TQ0EES1 (TQ0IOC2) = 0, |
|          |                     |          |                            |                             |                              |                               |                              | TQ0ETS0, TQ0ETS1 (TQ0IOC2) = 0  |
|          | TOQ00               | Input    | P53 = Setting not required | PM53 = Setting not required | PMC53 = 1                    | PFCE53 = 1                    | PFC53 = 0                    |                                 |
|          | RTP03               | Output   | P53 = Setting not required | PM53 = Setting not required | PMC53 = 1                    | PFCE53 = 1                    | PFC53 = 1                    |                                 |
|          | DDO <sup>Note</sup> | Output   | P53 = Setting not required | PM53 = Setting not required | PMC53 = Setting not required | PFCE53 = Setting not required | PFC53 = Setting not required | OCDM0 (OCDM) = 1                |
| P54      | SOB2                | Output   | P54 = Setting not required | PM54 = Setting not required | PMC54 = 1                    | PFCE54 = 0                    | PFC54 = 0                    |                                 |
|          | KR4                 | Input    | P54 = Setting not required | PM54 = Setting not required | PMC54 = 1                    | PFCE54 = 0                    | PFC54 = 1                    |                                 |
|          | RTP04               | Output   | P54 = Setting not required | PM54 = Setting not required | PMC54 = 1                    | PFCE54 = 1                    | PFC54 = 1                    |                                 |
|          | DCK <sup>Note</sup> | Input    | P54 = Setting not required | PM54 = Setting not required | PMC54 = Setting not required | PFCE54 = Setting not required | PFC54 = Setting not required | OCDM0 (OCDM) = 1                |
| P55      | SCKB2               | I/O      | P55 = Setting not required | PM55 = Setting not required | PMC55 = 1                    | PFCE55 = 0                    | PFC55 = 0                    |                                 |
|          | KR5                 | Input    | P55 = Setting not required | PM55 = Setting not required | PMC55 = 1                    | PFCE55 = 0                    | PFC55 = 1                    |                                 |
|          | RTP05               | Output   | P55 = Setting not required | PM55 = Setting not required | PMC55 = 1                    | PFCE55 = 1                    | PFC55 = 1                    |                                 |
|          | DMS <sup>Note</sup> | Input    | P55 = Setting not required | PM55 = Setting not required | PMC55 = Setting not required | PFCE55 = Setting not required | PFC55 = Setting not required | OCDM0 (OCDM) = 1                |

CHAPTER 4 PORT FUNCTIONS

Note Flash memory versions only

Preliminary User's Manual U17644EJ1V0UD

Table 4-15. Using Port Pin as Alternate-Function Pin (4/7)

| Pin Name | Alternate                   | Function | Pnx Bit of                  | PMnx Bit of                 | PMCnx Bit of  | PFCEnx Bit of  | PFCnx Bit of  | Other Bits  |
|----------|-----------------------------|----------|-----------------------------|-----------------------------|---------------|----------------|---------------|-------------|
|          | Name                        | I/O      | Pn Register                 | PMn Register                | PMCn Register | PFCEn Register | PFCn Register | (Registers) |
| P70      | ANI0                        | Input    | P70 = Setting not required  | PM70 = 1                    | -             | -              | -             |             |
| P71      | ANI1                        | Input    | P71 = Setting not required  | PM71 = 1                    | -             | _              | _             |             |
| P72      | ANI2                        | Input    | P72 = Setting not required  | PM72 = 1                    | _             | -              | _             |             |
| P73      | ANI3                        | Input    | P73 = Setting not required  | PM73 = 1                    | -             | -              | -             |             |
| P74      | ANI4                        | Input    | P74 = Setting not required  | PM74 = 1                    | -             | _              | -             |             |
| P75      | ANI5                        | Input    | P75 = Setting not required  | PM75 = 1                    | -             | -              | -             |             |
| P76      | ANI6                        | Input    | P76 = Setting not required  | PM76 = 1                    | _             | _              | -             |             |
| P77      | ANI7                        | Input    | P77 = Setting not required  | PM77 = 1                    | -             | -              | -             |             |
| P78      | ANI8                        | Input    | P78 = Setting not required  | PM78 = 1                    | _             | -              | -             |             |
| P79      | ANI9                        | Input    | P79 = Setting not required  | PM79 = 1                    | _             | _              | -             |             |
| P710     | ANI10                       | Input    | P710 = Setting not required | PM710 = 1                   | _             | _              | _             |             |
| P711     | ANI11                       | Input    | P711 = Setting not required | PM711 = 1                   | -             | _              | _             |             |
| P90      | A0                          | Output   | P90 = Setting not required  | PM90 = Setting not required | PMC90 = 1     | PFCE90 = 0     | PFC90 = 0     | Note 1      |
|          | KR6                         | Input    | P90 = Setting not required  | PM90 = Setting not required | PMC90 = 1     | PFCE90 = 0     | PFC90 = 1     |             |
|          | TXDA1                       | Output   | P90 = Setting not required  | PM90 = Setting not required | PMC90 = 1     | PFCE90 = 1     | PFC90 = 0     |             |
|          | SDA02                       | I/O      | P90 = Setting not required  | PM90 = Setting not required | PMC90 = 1     | PFCE90 = 1     | PFC90 = 1     |             |
| P91      | A1                          | Output   | P91 = Setting not required  | PM91 = Setting not required | PMC91 = 1     | PFCE91 = 0     | PFC91 = 0     | Note 1      |
|          | KR7                         | Input    | P91 = Setting not required  | PM91 = Setting not required | PMC91 = 1     | PFCE91 = 0     | PFC91 = 1     |             |
|          | RXDA1/KR7 <sup>Note 2</sup> | Input    | P91 = Setting not required  | PM91 = Setting not required | PMC91 = 1     | PFCE91 = 1     | PFC91 = 0     |             |
|          | SCL02                       | I/O      | P91 = Setting not required  | PM91 = Setting not required | PMC91 = 1     | PFCE91 = 1     | PFC91 = 1     |             |

Notes 1. When setting pins A0 to A15 as the alternate function, set all 16 bits of the PMC9 register to FFFFH at once.

2. The RXDA1 and KR7 pins must not be used at the same time. When using the RXDA1 pin, do not use the KR7 pin. When using the KR7 pin, do not use the RXDA1 pin (it is recommended to set the PFC91 bit to 1 and clear the PFCE91 bit to 0).

Table 4-15. Using Port Pin as Alternate-Function Pin (5/7)

| Pin Name | Alternat | e Function | Pnx Bit of                 | PMnx Bit of                 | PMCnx Bit of  | PFCEnx Bit of  | PFCnx Bit of  | Other Bits  |
|----------|----------|------------|----------------------------|-----------------------------|---------------|----------------|---------------|-------------|
|          | Name     | I/O        | Pn Register                | PMn Register                | PMCn Register | PFCEn Register | PFCn Register | (Registers) |
| P92      | A2       | Output     | P92 = Setting not required | PM92 = Setting not required | PMC92 = 1     | PFCE92 = 0     | PFC92 = 0     | Note        |
|          | TIP41    | Input      | P92 = Setting not required | PM92 = Setting not required | PMC92 = 1     | PFCE92 = 0     | PFC92 = 1     |             |
|          | TOP41    | Output     | P92 = Setting not required | PM92 = Setting not required | PMC92 = 1     | PFCE92 = 1     | PFC92 = 0     |             |
| P93      | А3       | Output     | P93 = Setting not required | PM93 = Setting not required | PMC93 = 1     | PFCE93 = 0     | PFC93 = 0     | Note        |
|          | TIP40    | Input      | P93 = Setting not required | PM93 = Setting not required | PMC93 = 1     | PFCE93 = 0     | PFC93 = 1     |             |
|          | TOP40    | Output     | P93 = Setting not required | PM93 = Setting not required | PMC93 = 1     | PFCE93 = 1     | PFC93 = 0     |             |
| P94      | A4       | Output     | P94 = Setting not required | PM94 = Setting not required | PMC94 = 1     | PFCE94 = 0     | PFC94 = 0     | Note        |
|          | TIP31    | Input      | P94 = Setting not required | PM94 = Setting not required | PMC94 = 1     | PFCE94 = 0     | PFC94 = 1     |             |
|          | TOP31    | Output     | P94 = Setting not required | PM94 = Setting not required | PMC94 = 1     | PFCE94 = 1     | PFC94 = 0     |             |
| P95      | A5       | Output     | P95 = Setting not required | PM95 = Setting not required | PMC95 = 1     | PFCE95 = 0     | PFC95 = 0     | Note        |
|          | TIP30    | Input      | P95 = Setting not required | PM95 = Setting not required | PMC95 = 1     | PFCE95 = 0     | PFC95 = 1     |             |
|          | TOP30    | Output     | P95 = Setting not required | PM95 = Setting not required | PMC95 = 1     | PFCE95 = 1     | PFC95 = 0     |             |
| P96      | A6       | Output     | P96 = Setting not required | PM96 = Setting not required | PMC96 = 1     | PFCE96 = 0     | PFC96 = 0     | Note        |
|          | TIP21    | Input      | P96 = Setting not required | PM96 = Setting not required | PMC96 = 1     | PFCE96 = 1     | PFC96 = 0     |             |
|          | TOP21    | Output     | P96 = Setting not required | PM96 = Setting not required | PMC96 = 1     | PFCE96 = 1     | PFC96 = 1     |             |
| P97      | A7       | Output     | P97 = Setting not required | PM97 = Setting not required | PMC97 = 1     | PFCE97 = 0     | PFC97 = 0     | Note        |
|          | SIB1     | Input      | P97 = Setting not required | PM97 = Setting not required | PMC97 = 1     | PFCE97 = 0     | PFC97 = 1     |             |
|          | TIP20    | Input      | P97 = Setting not required | PM97 = Setting not required | PMC97 = 1     | PFCE97 = 1     | PFC97 = 0     |             |
|          | TOP20    | Output     | P97 = Setting not required | PM97 = Setting not required | PMC97 = 1     | PFCE97 = 1     | PFC97 = 1     |             |
| P98      | A8       | Output     | P98 = Setting not required | PM98 = Setting not required | PMC98 = 1     | _              | PFC98 = 0     | Note        |
|          | SOB1     | Output     | P98 = Setting not required | PM98 = Setting not required | PMC98 = 1     | _              | PFC98 = 1     |             |
| P99      | A9       | Output     | P99 = Setting not required | PM99 = Setting not required | PMC99 = 1     | _              | PFC99 = 0     | Note        |
|          | SCKB1    | I/O        | P99 = Setting not required | PM99 = Setting not required | PMC99 = 1     | _              | PFC99 = 1     |             |

**Note** When setting pins A0 to A15 as the alternate function, set all 16 bits of the PMC9 register to FFFFH at once.

Preliminary User's Manual U17644EJ1V0UD

Table 4-15. Using Port Pin as Alternate-Function Pin (6/7)

| Pin Name | Alternate Function |        | Pnx Bit of                  | PMnx Bit of                  | PMCnx Bit of  | PFCEnx Bit of  | PFCnx Bit of  | Other Bits  |
|----------|--------------------|--------|-----------------------------|------------------------------|---------------|----------------|---------------|-------------|
|          | Name               | I/O    | Pn Register                 | PMn Register                 | PMCn Register | PFCEn Register | PFCn Register | (Registers) |
| P910     | A10                | Output | P910 = Setting not required | PM910 = Setting not required | PMC910 = 1    | _              | PFC910 = 0    | Note        |
|          | SIB3               | Input  | P910 = Setting not required | PM910 = Setting not required | PMC910 = 1    | _              | PFC910 = 1    |             |
| P911     | A11                | Output | P911 = Setting not required | PM911 = Setting not required | PMC911 = 1    | _              | PFC911 = 0    | Note        |
|          | SOB3               | Output | P911 = Setting not required | PM911 = Setting not required | PMC911 = 1    | -              | PFC911 = 1    |             |
| P912     | A12                | Output | P912 = Setting not required | PM912 = Setting not required | PMC912 = 1    | -              | PFC912 = 0    | Note        |
|          | SCKB3              | I/O    | P912 = Setting not required | PM912 = Setting not required | PMC912 = 1    | -              | PFC912 = 1    |             |
| P913     | A13                | Output | P913 = Setting not required | PM913 = Setting not required | PMC913 = 1    | _              | PFC913 = 0    | Note        |
|          | INTP4              | Input  | P913 = Setting not required | PM913 = Setting not required | PMC913 = 1    | -              | PFC913 = 1    |             |
| P914     | A14                | Output | P914 = Setting not required | PM914 = Setting not required | PMC914 = 1    | PFCE914 = 0    | PFC914 = 0    | Note        |
|          | INTP5              | Input  | P914 = Setting not required | PM914 = Setting not required | PMC914 = 1    | PFCE914 = 0    | PFC914 = 1    |             |
|          | TIP51              | Input  | P914 = Setting not required | PM914 = Setting not required | PMC914 = 1    | PFCE914 = 1    | PFC914 = 0    |             |
|          | TOP51              | Output | P914 = Setting not required | PM914 = Setting not required | PMC914 = 1    | PFCE914 = 1    | PFC914 = 1    |             |
| P915     | A15                | Output | P915 = Setting not required | PM915 = Setting not required | PMC915 = 1    | PFCE915 = 0    | PFC915 = 0    | Note        |
|          | INTP6              | Input  | P915 = Setting not required | PM915 = Setting not required | PMC915 = 1    | PFCE915 = 0    | PFC915 = 1    |             |
|          | TIP50              | Input  | P915 = Setting not required | PM915 = Setting not required | PMC915 = 1    | PFCE915 = 1    | PFC915 = 0    |             |
|          | TOP50              | Output | P915 = Setting not required | PM915 = Setting not required | PMC915 = 1    | PFCE915 = 1    | PFC915 = 1    |             |
| PCM0     | WAIT               | Input  | PCM0 = Setting not required | PMCM0 = Setting not required | PMCCM0 = 1    | -              | -             |             |
| PCM1     | CLKOUT             | Output | PCM1 = Setting not required | PMCM1 = Setting not required | PMCCM1 = 1    | -              | -             |             |
| PCM2     | HLDAK              | Output | PCM2 = Setting not required | PMCM2 = Setting not required | PMCCM2 = 1    | -              | -             |             |
| РСМ3     | HLDRQ              | Input  | PCM3 = Setting not required | PMCM3 = Setting not required | PMCCM3 = 1    | -              | -             |             |
| PCT0     | WR0                | Output | PCT0 = Setting not required | PMCT0 = Setting not required | PMCCT0 = 1    | -              | -             |             |
| PCT1     | WR1                | Output | PCT1 = Setting not required | PMCT1 = Setting not required | PMCCT1 = 1    | -              | -             |             |
| PCT4     | RD                 | Output | PCT4 = Setting not required | PMCT4 = Setting not required | PMCCT4 = 1    | -              | -             |             |
| PCT6     | ASTB               | Output | PCT6 = Setting not required | PMCT6 = Setting not required | PMCCT6 = 1    | _              | _             |             |

Note When not using the pins as the INTP4 to INTP6 pins, disable edge detection (clear the INTF9n bit of the INTF9H register and INTR9n bit of the INTR9H register to 0 (n = 13 to 15)).

Preliminary User's Manual U17644EJ1V0UD

Table 4-15. Using Port Pin as Alternate-Function Pin (7/7)

| Pin Name | Alternate             | Function | Pnx Bit of                   | PMnx Bit of                   | PMCnx Bit of                  | PFCEnx Bit of  | PFCnx Bit of  | Other Bits  |
|----------|-----------------------|----------|------------------------------|-------------------------------|-------------------------------|----------------|---------------|-------------|
|          | Name                  | I/O      | Pn Register                  | PMn Register                  | PMCn Register                 | PFCEn Register | PFCn Register | (Registers) |
| PDH0     | A16                   | Output   | PDH0 = Setting not required  | PMDH0 = Setting not required  | PMCDH0 = 1                    | _              | _             |             |
| PDH1     | A17                   | Output   | PDH1 = Setting not required  | PMDH1 = Setting not required  | PMCDH1 = 1                    | _              | 1             |             |
| PDH2     | A18                   | Output   | PDH2 = Setting not required  | PMDH2 = Setting not required  | PMCDH2 = 1                    | _              | _             |             |
| PDH3     | A19                   | Output   | PDH3 = Setting not required  | PMDH3 = Setting not required  | PMCDH3 = 1                    | -              | -             |             |
| PDH4     | A20                   | Output   | PDH4 = Setting not required  | PMDH4 = Setting not required  | PMCDH4 = 1                    | -              | -             |             |
| PDH5     | A21                   | Output   | PDH5 = Setting not required  | PMDH5 = Setting not required  | PMCDH5 = 1                    | -              | -             |             |
| PDL0     | AD0                   | I/O      | PDL0 = Setting not required  | PMDL0 = Setting not required  | PMCDL0 = 1                    | _              | -             |             |
| PDL1     | AD1                   | I/O      | PDL1 = Setting not required  | PMDL1 = Setting not required  | PMCDL1 = 1                    | -              | _             |             |
| PDL2     | AD2                   | I/O      | PDL2 = Setting not required  | PMDL2 = Setting not required  | PMCDL2 = 1                    | _              | _             |             |
| PDL3     | AD3                   | I/O      | PDL3 = Setting not required  | PMDL3 = Setting not required  | PMCDL3 = 1                    | -              | -             |             |
| PDL4     | AD4                   | I/O      | PDL4 = Setting not required  | PMDL4 = Setting not required  | PMCDL4 = 1                    | -              | -             |             |
| PDL5     | AD5                   | I/O      | PDL5 = Setting not required  | PMDL5 = Setting not required  | PMCDL5 = 1                    | -              | -             |             |
|          | FLMD1 <sup>Note</sup> | Input    | PDL5 = Setting not required  | PMDL5 = Setting not required  | PMCDL5 = Setting not required | _              | -             |             |
| PDL6     | AD6                   | I/O      | PDL6 = Setting not required  | PMDL6 = Setting not required  | PMCDL6 = 1                    | -              | -             |             |
| PDL7     | AD7                   | I/O      | PDL7 = Setting not required  | PMDL7 = Setting not required  | PMCDL7 = 1                    | -              | -             |             |
| PDL8     | AD8                   | I/O      | PDL8 = Setting not required  | PMDL8 = Setting not required  | PMCDL8 = 1                    | -              | _             |             |
| PDL9     | AD9                   | I/O      | PDL9 = Setting not required  | PMDL9 = Setting not required  | PMCDL9 = 1                    | _              | _             |             |
| PDL10    | AD10                  | I/O      | PDL10 = Setting not required | PMDL10 = Setting not required | PMCDL10 = 1                   | _              | _             |             |
| PDL11    | AD11                  | I/O      | PDL11 = Setting not required | PMDL11 = Setting not required | PMCDL11 = 1                   | _              | _             |             |
| PDL12    | AD12                  | I/O      | PDL12 = Setting not required | PMDL12 = Setting not required | PMCDL12 = 1                   | _              | _             |             |
| PDL13    | AD13                  | I/O      | PDL13 = Setting not required | PMDL13 = Setting not required | PMCDL13 = 1                   | -              | -             |             |
| PDL14    | AD14                  | I/O      | PDL14 = Setting not required | PMDL14 = Setting not required | PMCDL14 = 1                   | -              | -             |             |
| PDL15    | AD15                  | I/O      | PDL15 = Setting not required | PMDL15 = Setting not required | PMCDL15 = 1                   | -              | -             |             |

CHAPTER 4 PORT FUNCTIONS

Note Since this pin is set in the flash memory programming mode, it does not need to be manipulated using the port control register. For details, see **CHAPTER**29 FLASH MEMORY.

#### 4.6 Cautions

### 4.6.1 Cautions on setting port pins

(1) In the V850ES/SG2, the general-purpose port function and several peripheral function I/O pin share a pin. To switch between the general-purpose port (port mode) and the peripheral function I/O pin (alternate-function mode), set by the PMCn register. In regards to this register setting sequence, note with caution the following.

### (a) Cautions on switching from port mode to alternate-function mode

To switch from the port mode to alternate-function mode in the following order.

<1> Set the PFn register<sup>Note</sup>: N-ch open-drain setting
<2> Set the PFCn and PFCEn registers: Alternate-function selection
<3> Set the corresponding bit of the PMCn register to 1: Switch to alternate-function mode

If the PMCn register is set first, note with caution that, at that moment or depending on the change of the pin states in accordance with the setting of the PFn, PFCn, and PFCEn registers, unexpected operations may occur.

A concrete example is shown as Example below.

Note N-ch open-drain output pin only

Caution Regardless of the port mode/alternate-function mode, the Pn register is read and written as follows.

- Pn register read: Read the port output latch value (when PMn.PMnm bit = 0), or read the pin states (PMn.PMnm bit = 1).
- Pn register write: Write to the port output latch

## [Example] SCL01 pin setting example

The SCL01 pin is used alternately with the P41/SOB0 pin. Select the valid pin functions with the PMC4, PFC4, and PF4 registers.

| PMC41 Bit | PFC41 Bit  | PF41 Bit | Valid Pin Functions                               |
|-----------|------------|----------|---------------------------------------------------|
| 0         | don't care | 1        | P41 (in output port mode, N-ch open-drain output) |
| 1         | 0          | 1        | SOB0 output (N-ch open-drain output)              |
|           | 1          | 1        | SCL01 I/O (N-ch open-drain output)                |

The order of setting in which malfunction may occur on switching from the P41 pin to the SCL01 pin are shown below.

| Setting Order | Setting Contents                                                    | Pin States        | Pin Level                                             |
|---------------|---------------------------------------------------------------------|-------------------|-------------------------------------------------------|
| <1>           | Initial value<br>(PMC41 bit = 0,<br>PFC41 bit = 0,<br>PF41 bit = 0) | Port mode (input) | Hi-Z                                                  |
| <2>           | PMC41 bit ← 1                                                       | SOB0 output       | Low level (high level depending on the CSIB0 setting) |
| <3>           | PFC41 bit ← 1                                                       | SCL01 I/O         | High level (CMOS output)                              |
| <4>           | PF41 bit ← 1                                                        | SCL01 I/O         | Hi-Z (N-ch open-drain output)                         |

In <2>, I<sup>2</sup>C communication may be affected since the alternate-function SOB0 output is output to the pin. In the CMOS output period of <2> or <3>, unnecessary current may be generated.

## (b) Cautions on alternate-function mode (input)

The input signal to the alternate-function block is low level when the PMCn.PMCnm bit is 0 due to the AND output of the PMCn register set value and the pin level. Thus, depending on the port setting and alternate-function operation enable timing, unexpected operations may occur. Therefore, switch between the port mode and alternate-function mode in the following sequence.

- To switch from port mode to alternate-function mode (input)
   Set the pins to the alternate-function mode using the PMCn register and then enable the alternate-function operation.
- To switch from alternate-function mode (input) to port mode
   Stop the alternate-function operation and then switch the pins to the port mode.

The concrete examples are shown as Example 1 and Example 2.

## [Example 1] Switch from general-purpose port (P02) to external interrupt pin (NMI)

When the P02/NMI pin is pulled up as shown in Figure 4-33 and the rising edge is specified in the NMI pin edge detection setting, even though high level is input continuously to the NMI pin during switching from the P02 pin to the an NMI pin (PMC02 bit =  $0 \rightarrow 1$ ), this is detected as a rising edge as if the low level changed to high level, and an NMI interrupt occurs. To avoid it, set the NMI pin's valid edge after switching from the P02 pin to the NMI pin.



Figure 4-33. Example of Switching from P02 to NMI (Incorrect)

[Example 2] Switch from external pin (NMI) to general-purpose port (P02)

When the P02/NMI pin is pulled up as shown in Figure 4-34 and the falling edge is specified in the NMI pin edge detection setting, even though high level is input continuously to the NMI pin at switching from the NMI pin to the P02 pin (PMC02 bit =  $1 \rightarrow 0$ ), this is detected as falling edge as if high level changed to low level, and NMI interrupt occurs.

To avoid this, set the NMI pin edge detection as "No edge detected" before switching to the P02 pin.



Figure 4-34. Example of Switching from NMI to P02 (Incorrect)

(2) In port mode, the PFn.PFnm bit is valid only in the output mode (PMn.PMnm bit = 0). In the input mode (PMnm bit = 1), the value of the PFnm bit is not reflected in the buffer.

### 4.6.2 Cautions on bit manipulation instruction for port n register (Pn)

When a 1-bit manipulation instruction is executed on a port that provides both input and output functions, the value of the output latch of an input port that is not subject to manipulation may be written in addition to the targeted bit.

Therefore, it is recommended to rewrite the output latch when switching a port from input mode to output mode.

#### <Example>

When P90 pin is an output port, P91 to P97 pins are input ports (all pin statuses are high level), and the value of the port latch is 00H, if the output of P90 pin is changed from low level to high level via a bit manipulation instruction, the value of the port latch is FFH.

Explanation: The targets of writing to and reading from the Pn register of a port whose PMnm bit is 1 are the output latch and pin status, respectively.

A bit manipulation instruction is executed in the following order in the V850ES/SG2.

- <1> The Pn register is read in 8-bit units.
- <2> The targeted one bit is manipulated.
- <3> The Pn register is written in 8-bit units.

In step <1>, the value of the output latch (0) of P90 pin, which is an output port, is read, while the pin statuses of P91 to P97 pins, which are input ports, are read. If the pin statuses of P91 to P97 pins are high level at this time, the read value is FEH.

The value is changed to FFH by the manipulation in <2>.

FFH is written to the output latch by the manipulation in <3>.

Bit manipulation instruction P90 P90 (set1 0, P9L[r0]) Low-level output High-level output is executed for P90 bit. P91 to P97 P91 to P97 Pin status: High level Pin status: High level Port 9L latch Port 9L latch 0 0 1 1 0 0 0 0 0 0 1 1 1 Bit manipulation instruction for P90 bit <1> P9L register is read in 8-bit units. • In the case of P90, an output port, the value of the port latch (0) is read. • In the case of P91 to P97, input ports, the pin status (1) is read. <2> Set (1) P90 bit. <3> Write the results of <2> to the output latch of P9L register in 8-bit units.

Figure 4-35. Bit Manipulation Instruction (P90 Pin)

### 4.6.3 Cautions on on-chip debug pins

The  $\overline{\text{DRST}}$ , DCK, DMS, DDI, and DDO pins are on-chip debug pins (these pins are available only in the flash-memory versions).

After reset by the  $\overline{\text{RESET}}$  pin, the P05/INTP2/ $\overline{\text{DRST}}$  pin is initialized to function as an on-chip debug pin ( $\overline{\text{DRST}}$ ). If a high level is input to the  $\overline{\text{DRST}}$  pin at this time, the on-chip debug mode is set, and the DCK, DMS, DDI, and DDO pins can be used.

The following action must be taken if on-chip debugging is not used.

• Clear the OCDM0 bit of the OCDM register (special register) (0)

At this time, fix the P05/INTP2/DRST pin to low level from when reset by the RESET pin is released until the above action is taken.

If a high level is input to the DRST pin before the above action is taken, it may cause a malfunction (CPU deadlock). Handle the P05 pin with the utmost care.

Caution After reset by the WDT2RES signal or clock monitor (CLM), the P05/INTP2/DRST pin is not initialized to function as an on-chip debug pin (DRST). The OCDM register holds the current value.

## 4.6.4 Cautions on P05/INTP2/DRST pin

The P05/INTP2/ $\overline{DRST}$  pin has an internal pull-down resistor (30 k $\Omega$  TYP.). After a reset by the  $\overline{RESET}$  pin, a pull-down resistor is connected. The pull-down resistor is disconnected when the OCDM0 bit is cleared (0).

#### 4.6.5 Cautions on P10, P11, and P53 pins when power is turned on

When the power is turned on, the following pins may output an undefined level temporarily even during reset.

- P10/ANO0 pin
- P11/ANO1 pin
- P53/SIB2/KR3/TIQ00/TOQ00/RTP03/DDO<sup>Note</sup> pin

**Note** The DDO pin is provided only in the flash memory version.

#### 4.6.6 Hysteresis characteristics

In port mode, the following port pins do not have hysteresis characteristics.

P02 to P06

P31 to P35, P37 to P39

P40 to P42

P50 to P55

P90 to P97, P99, P910, P912 to P915

## **CHAPTER 5 BUS CONTROL FUNCTION**

The V850ES/SG2 is provided with an external bus interface function by which external memories such as ROM and RAM, and I/O can be connected.

## 5.1 Features

| $\bigcirc$ Output is selectable from a multiplexed bus with a minimum of 3 bus cycles and a separate bus with a minimum |
|-------------------------------------------------------------------------------------------------------------------------|
| of 2 bus cycles.                                                                                                        |
| ○ 8-bit/16-bit data bus selectable                                                                                      |

- O Wait function
  - Programmable wait function of up to 7 states
  - External wait function using WAIT pin
- O Idle state function
- O Bus hold function
- O Up to 4 MB of physical memory connectable (of which 1 MB is internal ROM space)
- The bus can be controlled at a voltage that is different from the operating voltage when  $BV_{DD} \le EV_{DD} = V_{DD}$ . However, in separate bus mode or when the A20 and A21 pins are used, set  $BV_{DD} = EV_{DD} = V_{DD}$ .

### 5.2 Bus Control Pins

The pins used to connect an external device are listed in the table below.

Table 5-1. Bus Control Pins (Multiplexed Bus)

| Bus Control Pin | Alternate-Function Pin | I/O    | Function              |
|-----------------|------------------------|--------|-----------------------|
| AD0 to AD15     | PDL0 to PDL15          | I/O    | Address/data bus      |
| A16 to A21      | PDH0 to PDH5           | Output | Address bus           |
| WAIT            | РСМ0                   | Input  | External wait control |
| CLKOUT          | PCM1                   | Output | Internal system clock |
| WR0, WR1        | PCT0, PCT1             | Output | Write strobe signal   |
| RD              | PCT4                   | Output | Read strobe signal    |
| ASTB            | PCT6                   | Output | Address strobe signal |
| HLDRQ           | РСМ3                   | Input  | Bus hold control      |
| HLDAK           | PCM2                   | Output |                       |

Table 5-2. External Control Pins (Separate Bus)

| Bus Control Pin | Alternate-Function Pin | I/O    | Function              |
|-----------------|------------------------|--------|-----------------------|
| AD0 to AD15     | PDL0 to PDL15          | I/O    | Data bus              |
| A0 to A15       | P90 to P915            | Output | Address bus           |
| A16 to A21      | PDH0 to PDH5           | Output | Address bus           |
| WAIT            | PCM0                   | Input  | External wait control |
| CLKOUT          | PCM1                   | Output | Internal system clock |
| WR0, WR1        | PCT0, PCT1             | Output | Write strobe signal   |
| RD              | PCT4                   | Output | Read strobe signal    |
| HLDRQ           | PCM3                   | Input  | Bus hold control      |
| HLDAK           | PCM2                   | Output |                       |

## 5.2.1 Pin status when internal ROM, internal RAM, or on-chip peripheral I/O is accessed

When the internal ROM, internal RAM, or on-chip peripheral I/O are accessed, the status of each pin is as follows.

Table 5-3. Pin Statuses When Internal ROM, Internal RAM, or On-Chip Peripheral I/O Is Accessed

| Separate Bus Mode       |           | Multiplexed Bus Mode           |           |  |
|-------------------------|-----------|--------------------------------|-----------|--|
| Address bus (A21 to A0) | Undefined | Address bus (A21 to A16)       | Undefined |  |
| Data bus (AD15 to AD0)  | Hi-Z      | Address/data bus (AD15 to AD0) | Undefined |  |
| Control signal          | Inactive  | Control signal                 | Inactive  |  |

Caution When a write access is performed to the internal ROM area, address, data, and control signals are activated in the same way as access to the external memory area.

## 5.2.2 Pin status in each operation mode

For the pin status of the V850ES/SG2 in each operation mode, see 2.2 Pin Status.

## 5.3 Memory Block Function

The 16 MB external memory space is divided into memory blocks of (lower) 2 MB, 2 MB, 4 MB, and 8 MB. The programmable wait function and bus cycle operation mode for each of these blocks can be independently controlled in one-block units.



Figure 5-1. Data Memory Map: Physical Address

- **Notes 1.** Use of addresses 03FEF000H to 03FEFFFFH is prohibited because these addresses are in the same area as the on-chip peripheral I/O area.
  - 2. Only the programmable peripheral I/O area is seen as images of 256 MB each in the 4 GB address space.
  - **3.** Addresses 03FEC000H to 03FECBFFH are allocated to addresses 03FEC000H to 03FEFFFH of the CAN controller version as a programmable peripheral I/O area. Use of these addresses in a version without a CAN controller is prohibited.
  - **4.** This area is an external memory area in the case of a data write access.

## 5.4 External Bus Interface Mode Control Function

The V850ES/SG2 has the following two external bus interface modes.

- Multiplexed bus mode
- · Separate bus mode

These two modes can be selected by using the EXIMC register.

## (1) External bus interface mode control register (EXIMC)

The EXIMC register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

| After res | set: 00H | R/W | Address: FFFFFBEH |   | 4 |   |   |       |
|-----------|----------|-----|-------------------|---|---|---|---|-------|
|           | 7        | 6   | 5                 | 4 | 3 | 2 | 1 | 0     |
| EXIMC     | 0        | 0   | 0                 | 0 | 0 | 0 | 0 | SMSEL |

| SMSEL | Mode selection       |  |
|-------|----------------------|--|
| 0     | Multiplexed bus mode |  |
| 1     | Separate bus mode    |  |

Caution Set the EXIMC register from the internal ROM or internal RAM area before making an external access.

After setting the EXIMC register, be sure to insert a NOP instruction.

#### 5.5 Bus Access

#### 5.5.1 Number of clocks for access

The following table shows the number of basic clocks required for accessing each resource.

| Area (Bus Width) Bus Cycle Type   | Internal ROM (32 Bits) | Internal RAM (32 Bits) | External Memory (16 Bits) |
|-----------------------------------|------------------------|------------------------|---------------------------|
| Instruction fetch (normal access) | 1                      | 1 Note 1               | 3 + n <sup>Note 2</sup>   |
| Instruction fetch (branch)        | 2                      | 2 <sup>Note 1</sup>    | 3 + n <sup>Note 2</sup>   |
| Operand data access               | 3                      | 1                      | 3 + n <sup>Note 2</sup>   |

Notes 1. Increases by 1 if a conflict with a data access occurs.

2. 2 + n clocks (n: Number of wait states) when the separate bus mode is selected.

Remark Unit: Clocks/access

#### 5.5.2 Bus size setting function

Each external memory area selected by memory block n can be set by using the BSC register. However, the bus size can be set to 8 bits and 16 bits only.

The external memory area of the V850ES/SG2 is selected by memory blocks 0 to 3.

## (1) Bus size configuration register (BSC)

The BSC register can be read or written in 16-bit units.

Reset input sets this register to 5555H.

Caution Write to the BSC register after reset, and then do not change the set values. Also, do not access an external memory area until the initial settings of the BSC register are complete.



Caution Be sure to set bits 14, 12, 10, and 8 to 1, and clear bits 15, 13, 11, 9, 7, 5, 3, and 1 to 0.

#### 5.5.3 Access by bus size

The V850ES/SG2 accesses the on-chip peripheral I/O and external memory in 8-bit, 16-bit, or 32-bit units. The bus size is as follows.

- The bus size of the on-chip peripheral I/O is fixed to 16 bits.
- The bus size of the external memory is selectable from 8 bits or 16 bits (by using the BSC register).

The operation when each of the above is accessed is described below. All data is accessed starting from the lower side.

The V850ES/SG2 supports only the little-endian format.

Figure 5-2. Little-Endian Address in Word



#### (1) Data space

The V850ES/SG2 has an address misalign function.

With this function, data can be placed at all addresses, regardless of the format of the data (word data or halfword data). However, if the word data or halfword data is not aligned at the boundary, a bus cycle is generated at least twice, causing the bus efficiency to drop.

## (a) Halfword-length data access

A byte-length bus cycle is generated twice if the least significant bit of the address is 1.

#### (b) Word-length data access

- (i) A byte-length bus cycle, halfword-length bus cycle, and byte-length bus cycle are generated in that order if the least significant bit of the address is 1.
- (ii) A halfword-length bus cycle is generated twice if the lower 2 bits of the address are 10.

# (2) Byte access (8 bits)

# (a) 16-bit data bus width



# (b) 8-bit data bus width



# (3) Halfword access (16 bits)

# (a) With 16-bit data bus width



## (b) 8-bit data bus width



# (4) Word access (32 bits)

# (a) 16-bit data bus width (1/2)



# (a) 16-bit data bus width (2/2)



# (b) 8-bit data bus width (1/2)



## (b) 8-bit data bus width (2/2)



### 5.6 Wait Function

## 5.6.1 Programmable wait function

### (1) Data wait control register 0 (DWC0)

To realize interfacing with a low-speed memory or I/O, up to seven data wait states can be inserted in the bus cycle that is executed for each memory block space.

The number of wait states can be programmed by using the DWC0 register. Immediately after system reset, 7 data wait states are inserted for all the blocks.

The DWC0 register can be read or written in 16-bit units.

Reset input sets this register to 7777H.

- Cautions 1. The internal ROM and internal RAM areas are not subject to programmable wait, and are always accessed without a wait state. The on-chip peripheral I/O area is also not subject to programmable wait, and only wait control from each peripheral function is performed.
  - Write to the DWC0 register after reset, and then do not change the set values. Also, do not access an external memory area until the initial settings of the DWC0 register are complete.
  - 3. When the V850ES/SG2 is used in separate bus mode and operated at fxx > 20 MHz, be sure to insert one or more wait.



Caution Be sure to clear bits 15, 11, 7, and 3 to 0.

### 5.6.2 External wait function

To synchronize an extremely slow external memory, I/O, or asynchronous system, any number of wait states can be inserted in the bus cycle by using the external wait pin (WAIT).

When the PCM0 pin is set to alternate function, the external wait function is enabled.

Access to each area of the internal ROM, internal RAM, and on-chip peripheral I/O is not subject to control by the external wait function, in the same manner as the programmable wait function.

The WAIT signal can be input asynchronously to CLKOUT, and is sampled at the falling edge of the clock in the T2 and TW states of the bus cycle in the multiplexed bus mode. In the separate bus mode, it is sampled at the rising edge of the clock immediately after the T1 and TW states of the bus cycle. If the setup/hold time of the sampling timing is not satisfied, a wait state is inserted in the next state, or not inserted at all.

# 5.6.3 Relationship between programmable wait and external wait

Wait cycles are inserted as the result of an OR operation between the wait cycles specified by the set value of the programmable wait and the wait cycles controlled by the  $\overline{\text{WAIT}}$  pin.



For example, if the timing of the programmable wait and the  $\overline{\text{WAIT}}$  pin signal is as illustrated below, three wait states will be inserted in the bus cycle.



Figure 5-3. Inserting Wait Example

### 5.6.4 Programmable address wait function

Address-setup or address-hold waits to be inserted in each bus cycle can be set by using the AWC register. Address wait insertion is set for each memory block area (memory blocks 0 to 3).

If an address setup wait is inserted, it seems that the high-clock period of the T1 state is extended by 1 clock. If an address hold wait is inserted, it seems that the low-clock period of the T1 state is extended by 1 clock.

### (1) Address wait control register (AWC)

The AWC register can be read or written in 16-bit units.

Reset input sets this register to FFFFH.

- Cautions 1. Address setup wait and address hold wait cycles are not inserted when the internal ROM area, internal RAM area, and on-chip peripheral I/O areas are accessed.
  - Write to the AWC register after reset, and then do not change the set values. Also, do not access an external memory area until the initial settings of the AWC register are complete.
  - 3. When the V850ES/SG2 is operated at fxx > 20 MHz, be sure to insert the address-hold wait and the address-setup wait.



### 5.7 Idle State Insertion Function

To facilitate interfacing with low-speed memories, one idle state (TI) can be inserted after the T3 state in the bus cycle that is executed for each space selected by the memory block in the multiplex address/data bus mode. In the separate bus mode, one idle state (TI) can be inserted after the T2 state. By inserting an idle state, the data output float delay time of the memory can be secured during read access (an idle state cannot be inserted during write access).

Whether the idle state is to be inserted can be programmed by using the BCC register.

An idle state is inserted for all the areas immediately after system reset.

### (1) Bus cycle control register (BCC)

The BCC register can be read or written in 16-bit units.

Reset input sets this register to AAAAH.

- Cautions 1. The internal ROM, internal RAM, and on-chip peripheral I/O areas are not subject to idle state insertion.
  - 2. Write to the BCC register after reset, and then do not change the set values. Also, do not access an external memory area until the initial settings of the BCC register are complete.



### 5.8 Bus Hold Function

### 5.8.1 Functional outline

The HLDRQ and HLDAK functions are valid if the PCM2 and PCM3 pins are set to alternate function.

When the HLDRQ pin is asserted (low level), indicating that another bus master has requested bus mastership, the external address/data bus goes into a high-impedance state and is released (bus hold status). If the request for the bus mastership is cleared and the HLDRQ pin is deasserted (high level), driving these pins is started again.

During the bus hold period, execution of the program in the internal ROM and internal RAM is continued until an on-chip peripheral I/O register or the external memory is accessed.

The bus hold status is indicated by assertion of the HLDAK pin (low level). The bus hold function enables the configuration of multi-processor type systems in which two or more bus masters exist.

Note that the bus hold request is not acknowledged during a multiple-access cycle initiated by the bus sizing function or a bit manipulation instruction.

| Status                                                   | Data Bus<br>Width | Access Type                    | Timing at Which Bus Hold Request Is Not Acknowledged |
|----------------------------------------------------------|-------------------|--------------------------------|------------------------------------------------------|
| CPU bus lock                                             | 16 bits           | Word access to even address    | Between first and second access                      |
|                                                          |                   | Word access to odd address     | Between first and second access                      |
|                                                          |                   |                                | Between second and third access                      |
|                                                          |                   | Halfword access to odd address | Between first and second access                      |
|                                                          | 8 bits            | Word access                    | Between first and second access                      |
|                                                          |                   |                                | Between second and third access                      |
|                                                          |                   |                                | Between third and fourth access                      |
|                                                          |                   | Halfword access                | Between first and second access                      |
| Read-modify-write access of bit manipulation instruction | _                 | -                              | Between read access and write access                 |

### 5.8.2 Bus hold procedure

The bus hold status transition procedure is shown below.



## 5.8.3 Operation in power save mode

Because the internal system clock is stopped in the STOP, IDLE1, and IDLE2 modes, the bus hold status is not entered even if the  $\overline{\text{HLDRQ}}$  pin is asserted.

In the HALT mode, the  $\overline{\text{HLDAK}}$  pin is asserted as soon as the  $\overline{\text{HLDRQ}}$  pin has been asserted, and the bus hold status is entered. When the  $\overline{\text{HLDRQ}}$  pin is later deasserted, the  $\overline{\text{HLDAK}}$  pin is also deasserted, and the bus hold status is cleared.

# 5.9 Bus Priority

Bus hold, instruction fetch (branch), instruction fetch (successive), operand data accesses, and DMA transfer are executed in the external bus cycle.

Bus hold has the highest priority, followed by DMA transfer, operand data access, instruction fetch (branch), and instruction fetch (successive).

An instruction fetch may be inserted between the read access and write access in a read-modify-write access.

If an instruction is executed for two or more accesses, an instruction fetch and bus hold are not inserted between accesses due to bus size limitations.

Table 5-4. Bus Priority

| Priority | External Bus Cycle             | Bus Master      |  |
|----------|--------------------------------|-----------------|--|
| High     | Bus hold                       | External device |  |
| ĺ        | DMA transfer                   | DMAC            |  |
|          | Operand data access            | CPU             |  |
| <b>,</b> | Instruction fetch (branch)     | CPU             |  |
| Low      | Instruction fetch (successive) | CPU             |  |

# 5.10 Bus Timing

Figure 5-4. Multiplexed Bus Read Timing (Bus Size: 16 Bits, 16-Bit Access)



Figure 5-5. Multiplexed Bus Read Timing (Bus Size: 8 Bits)





Figure 5-6. Multiplexed Bus Write Timing (Bus Size: 16 Bits, 16-Bit Access)







Figure 5-8. Multiplexed Bus Hold Timing (Bus Size: 16 Bits, 16-Bit Access)



Figure 5-9. Separate Bus Read Timing (Bus Size: 16 Bits, 16-Bit Access)







Figure 5-11. Separate Bus Write Timing (Bus Size: 16 Bits, 16-Bit Access)





T2 T2 CLKOUT HLDRQ HLDAK A21 to A0 À1 Undefined Undefined AD7 to AD0 D1 D2 D3 WR1, WR0 11 Note This idle state (TI) does not depend on the BCC register settings. **Remark** The broken lines indicate high impedance.

Figure 5-13. Separate Bus Hold Timing (Bus Size: 8 Bits, Write)





## **CHAPTER 6 CLOCK GENERATION FUNCTION**

### 6.1 Overview

The following clock generation functions are available.

- O Main clock oscillator
  - In clock-through mode

fx = 2.5 to 8 MHz (fxx = 2.5 to 8 MHz)

• In PLL mode

 $fx = 2.5 \text{ to } 5 \text{ MHz} (\times 4: fxx = 10 \text{ to } 20 \text{ MHz})$ 

 $fx = 2.5 \text{ to } 4 \text{ MHz} (\times 8: 20 \text{ to } 32 \text{ MHz})$ 

- O Subclock oscillator
  - 32.768 kHz
- O Multiply (×4/×8) function by PLL (Phase Locked Loop)
  - Clock-through mode/PLL mode selectable
- O Internal oscillator
  - fr = 200 kHz (TYP.)
- O Internal system clock generation
  - 7 steps (fxx, fxx/2, fxx/4, fxx/8, fxx/16, fxx/32, fxT)
- O Peripheral clock generation
- O Clock output function

Remark fx: Main clock oscillation frequency

fxx: Main clock frequency

fa: Internal oscillation clock frequency

fxT: Subclock frequency

## 6.2 Configuration

Figure 6-1. Clock Generator



### (1) Main clock oscillator

The main resonator oscillates the following frequencies (fx).

In clock-through mode

fx = 2.5 to 8 MHz

In PLL mode

 $fx = 2.5 \text{ to } 5 \text{ MHz } (\times 4)$ 

 $fx = 2.5 \text{ to } 4 \text{ MHz } (\times 8)$ 

### (2) Subclock oscillator

The sub-resonator oscillates a frequency of 32.768 kHz (fxT).

### (3) Main clock oscillator stop control

This circuit generates a control signal that stops oscillation of the main clock oscillator.

Oscillation of the main clock oscillator is stopped in the STOP mode or when the PCC.MCK bit = 1 (valid only when the PCC.CLS bit = 1).

### (4) Internal oscillator

Oscillates a frequency (fR) of 200 kHz (TYP.).

### (5) Prescaler 1

This prescaler generates the clock (fxx to fxx/1,024) to be supplied to the following on-chip peripheral functions: TMP0 to TMP5, TMQ0, TMM0, CSIB0 to CSIB4, UARTA0 to UARTA2, I<sup>2</sup>C00 to I<sup>2</sup>C02, ADC, WDT2, CAN0<sup>Note 1</sup> and IEBus<sup>Note 2</sup>

### Notes 1. CAN controller version only

2. IEBus version only

### (6) Prescaler 2

This circuit divides the main clock (fxx).

The clock generated by prescaler 2 (fxx to fxx/32) is supplied to the selector that generates the CPU clock (fcpu) and internal system clock (fclk).

fclk is the clock supplied to the INTC, ROM correction, ROM, and RAM blocks, and can be output from the CLKOUT pin.

## (7) Prescaler 3

This circuit divides the clock generated by the main clock oscillator (fx) to a specific frequency (32.768 kHz) and supplies that clock to the watch timer block.

For details, see CHAPTER 10 WATCH TIMER FUNCTIONS.

## (8) PLL

This circuit multiplies the clock generated by the main clock oscillator (fx) by 4 or 8.

It operates in two modes: clock-through mode in which fx is output as is, and PLL mode in which a multiplied clock is output. These modes can be selected by using the PLLCTL.SELPLL bit.

Whether the clock is multiplied by 4 or 8 is selected by the CKC.CKDIV0 bit, and PLL is started or stopped by the PLLCTL.PLLON bit.

# 6.3 Registers

# (1) Processor clock control register (PCC)

The PCC register is a special register. Data can be written to this register only in combination of specific sequences (see **3.4.8 Special registers**).

This register can be read or written in 8-bit or 1-bit units.

Reset input sets this register to 03H.

After reset: 03H R/W Address: FFFFF828H

PCC

| 7   | <6> | 5    | <4>                 | <3> | 2   | 1   | 0   |
|-----|-----|------|---------------------|-----|-----|-----|-----|
| FRC | MCK | MFRC | CLS <sup>Note</sup> | СКЗ | CK2 | CK1 | CK0 |

| FRC | Use of subclock on-chip feedback resistor |
|-----|-------------------------------------------|
| 0   | Used                                      |
| 1   | Not used                                  |

| MCK | Main clock oscillator control |  |  |  |  |
|-----|-------------------------------|--|--|--|--|
| 0   | Oscillation enabled           |  |  |  |  |
| 1   | Oscillation stopped           |  |  |  |  |

- Even if the MCK bit is set (1) while the system is operating with the main clock as the CPU clock, the operation of the main clock does not stop. It stops after the CPU clock has been changed to the subclock.
- Before setting the MCK bit from 0 to 1, stop the on-chip peripheral functions operating with the main clock.
- When the main clock is stopped and the device is operating with the subclock, clear (0) the MCK bit and secure the oscillation stabilization time by software before switching the CPU clock to the main clock or operating the on-chip peripheral functions.

| MFRC | Use of main clock on-chip feedback resistor |
|------|---------------------------------------------|
| 0    | Used                                        |
| 1    | Not used                                    |

| CLS <sup>Note</sup> | Status of CPU clock (fcpu) |
|---------------------|----------------------------|
| 0                   | Main clock operation       |
| 1                   | Subclock operation         |

| CK3 | CK2 | CK1 | CK0 | Clock selection (fclk/fcpu) |
|-----|-----|-----|-----|-----------------------------|
| 0   | 0   | 0   | 0   | fxx                         |
| 0   | 0   | 0   | 1   | fxx/2                       |
| 0   | 0   | 1   | 0   | fxx/4                       |
| 0   | 0   | 1   | 1   | fxx/8                       |
| 0   | 1   | 0   | 0   | fxx/16                      |
| 0   | 1   | 0   | 1   | fxx/32                      |
| 0   | 1   | 1   | ×   | Setting prohibited          |
| 1   | ×   | ×   | ×   | fхт                         |

Note The CLS bit is a read-only bit.

Cautions 1. Do not change the CPU clock (by using the CK3 to CK0 bits) while CLKOUT is being output.

2. Use a bit manipulation instruction to manipulate the CK3 bit. When using an 8-bit manipulation instruction, do not change the set values of the CK2 to CK0 bits.

Remark ×: don't care

(a) Example of setting main clock operation → subclock operation

<1> CK3 bit  $\leftarrow$  1: Use of a bit manipulation instruction is recommended. Do not change the CK2 to CK0 bits.

<2> Subclock operation: Read the CLS bit to check if subclock operation has started. It takes the following time after the CK3 bit is set until subclock operation is started.

Max.: 1/fxT (1/subclock frequency)

<3> MCK bit  $\leftarrow$  1: Set the MCK bit to 1 only when stopping the main clock.

- Cautions 1. When stopping the main clock, stop the PLL. Also stop the operations of the on-chip peripheral functions operating with the main clock.
  - 2. If the following conditions are not satisfied, change the CK2 to CK0 bits so that the conditions are satisfied, then change to the subclock operation mode.

Internal system clock (fclk) > Subclock (fxt: 32.768 kHz) × 4

Remark Internal system clock (fcLK): Clock generated from the main clock (fxx) by setting bits CK2 to CK0

# [Description example]

```
_DMA_DISABLE:
                                          -- DMA operation disabled. n = 0 to 3
     clrl
                  0, DCHCn[r0]
<1> _SET_SUB_RUN :
     st.b
                  r0, PRCMD[r0]
                                          -- CK3 bit ← 1
     set1
                  3, PCC[r0]
<2> _CHECK_CLS :
     tst1
                  4, PCC[r0]
                                          -- Wait until subclock operation starts.
                  _CHECK_CLS
     bz.
<3> _STOP_MAIN_CLOCK :
     st.b
                  r0, PRCMD[r0]
                  6, PCC[r0]
                                          -- MCK bit \leftarrow 1, main clock is stopped.
     set1
     _DMA_ENABLE:
                                          -- DMA operation enabled. n = 0 to 3
     setl
                  0, DCHCn[r0]
```

**Remark** The description above is simply an example. Note that in <2> above, the CLS bit is read in a closed loop.

### (b) Example of setting subclock operation → main clock operation

<1> MCK bit ← 1: Main clock starts oscillating

<2> Insert waits by the program and wait until the oscillation stabilization time of the main clock elapses.

<3> CK3 bit  $\leftarrow$  1: Use of a bit manipulation instruction is recommended. Do not change the

CK2 to CK0 bits.

<4> Main clock operation: It takes the following time after the CK3 bit is set until main clock operation

is started.

Max.: 1/fxT (1/subclock frequency)

Therefore, insert one NOP instruction immediately after setting the CK3 bit

to 0 or read the CLS bit to check if main clock operation has started.

Caution Enable operation of the on-chip peripheral functions operating with the main clock only after the oscillation of the main clock stabilizes. If their operations are enabled before the lapse of the oscillation stabilization time, a malfunction may occur.

### [Description example]

```
_DMA_DISABLE:
     clrl
                  0, DCHCn[r0]
                                                    -- DMA operation disabled. n = 0 to 3
<1> _START_MAIN_OSC :
     st.b
                                                    -- Release of protection of special registers
                  r0, PRCMD[r0]
                                                    -- Main clock starts oscillating.
     clr1
                  6, PCC[r0]
<2> movea
                  0x55, r0, r11
                                                    -- Wait for oscillation stabilization time.
     _WAIT_OST :
    nop
    nop
    nop
     addi
                  -1, r11, r11
     cmp
                  r0, r11
    bne
                            _WAIT_OST
<3> st.b
                  r0, PRCMD[r0]
                                                    -- CK3 ← 0
     clr1
                  3, PCC[r0]
<4> _CHECK_CLS :
                  4, PCC[r0]
                                                    -- Wait until main clock operation starts.
     tst1
                  _CHECK_CLS
     bnz
     DMA ENABLE:
                                                    -- DMA operation enabled. n = 0 to 3
                  0, DCHCn[r0]
     setl
```

**Remark** The description above is simply an example. Note that in <4> above, the CLS bit is read in a closed loop.

### (2) Internal oscillation mode register (RCM)

The RCM register is an 8-bit register that sets the operation mode of the internal oscillator.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.



| RSTOP | Oscillation/stop of internal oscillator |
|-------|-----------------------------------------|
| 0     | Internal oscillator oscillating         |
| 1     | Internal oscillator stopped             |

- Cautions 1. The internal oscillator cannot be stopped while the CPU is operating on the internal oscillation clock (CCLS.CCLSF bit = 1). Do not set the RSTOP bit to 1.
  - 2. The internal oscillator oscillates if the CCLS.CCLSF bit is set to 1 (when WDT overflow occurs during oscillation stabilization) even when the RSTOP bit is set to 1. At this time, the RSTOP bit remains being set to 1.

# (3) CPU operation clock status register (CCLS)

The CCLS register indicates the status of the CPU operation clock.

This register is read-only, in 8-bit or 1-bit units.

Reset input clears this register to 00H.



| CCLSF | CPU operation clock status                                 |
|-------|------------------------------------------------------------|
| 0     | Operating on main clock (fx) or subclock (fxт).            |
| 1     | Operating on internal oscillation clock (f <sub>R</sub> ). |

**Note** If WDT overflow occurs during oscillation stabilization after a reset is released, the CCLSF bit is set to 1 and the reset value is 01H.

## 6.4 Operation

## 6.4.1 Operation of each clock

The following table shows the operation status of each clock.

Table 6-1. Operation Status of Each Clock

| Register Setting and                | PCC Register    |                                             |              |                         |                             |                  |                             |                  |                  |
|-------------------------------------|-----------------|---------------------------------------------|--------------|-------------------------|-----------------------------|------------------|-----------------------------|------------------|------------------|
| Operation Status                    |                 | CLK Bi                                      | t = 0, MCK   | Bit = 0                 | CLS Bit = 1,<br>MCK Bit = 0 |                  | CLS Bit = 1,<br>MCK Bit = 1 |                  |                  |
| Target Clock                        | During<br>Reset | During Oscillation Stabilization Time Count | HALT<br>Mode | IDLE1,<br>IDLE2<br>Mode | STOP<br>Mode                | Subclock<br>Mode | Sub-IDLE<br>Mode            | Subclock<br>Mode | Sub-IDLE<br>Mode |
| Main clock oscillator (fx)          | ×               | O                                           | 0            | 0                       | ×                           | 0                | 0                           | ×                | ×                |
| Subclock oscillator (fxr)           | 0               | 0                                           | 0            | 0                       | 0                           | 0                | 0                           | 0                | 0                |
| CPU clock (fcpu)                    | ×               | ×                                           | ×            | ×                       | ×                           | 0                | ×                           | 0                | ×                |
| Internal system clock (fclk)        | ×               | ×                                           | 0            | ×                       | ×                           | 0                | ×                           | 0                | ×                |
| Main clock (in PLL mode, fxx)       | ×               | O <sup>Note</sup>                           | 0            | ×                       | ×                           | 0                | 0                           | ×                | ×                |
| Peripheral clock (fxx to fxx/1,024) | ×               | ×                                           | 0            | ×                       | ×                           | 0                | ×                           | ×                | ×                |
| WT clock (main)                     | ×               | 0                                           | 0            | 0                       | ×                           | 0                | 0                           | ×                | ×                |
| WT clock (sub)                      | 0               | 0                                           | 0            | 0                       | 0                           | 0                | 0                           | 0                | 0                |
| WDT2 clock (internal oscillation)   | ×               | 0                                           | 0            | 0                       | 0                           | 0                | 0                           | 0                | 0                |
| WDT2 clock (main)                   | ×               | ×                                           | 0            | ×                       | ×                           | 0                | ×                           | ×                | ×                |
| WDT2 clock (sub)                    | 0               | 0                                           | 0            | 0                       | 0                           | 0                | 0                           | 0                | 0                |

Note Lockup time

Remark O: Operable

×: Stopped

# 6.4.2 Clock output function

The clock output function is used to output the internal system clock (fcLk) from the CLKOUT pin.

The internal system clock (fclk) is selected by using the PCC.CK3 to PCC.CK0 bits.

The CLKOUT pin functions alternately as the PCM1 pin and functions as a clock output pin if so specified by the control register of port CM.

The status of the CLKOUT pin is the same as the internal system clock in Table 6-1 and the pin can output the clock when it is in the operable status. It outputs a low level in the stopped status. However, the CLKOUT pin is in the port mode (PCM1 pin: input mode) after reset and until it is set in the output mode. Therefore, the status of the pin is Hi-Z.

### 6.5 PLL Function

### 6.5.1 Overview

In the V850ES/SG2, an operating clock that is 4 or 8 times higher than the oscillation frequency output by the PLL function or the clock-through mode can be selected as the operating clock of the CPU and on-chip peripheral functions.

When PLL function is used ( $\times$ 4): Input clock = 2.5 to 5 MHz (output: 10 to 20 MHz) When PLL function is used ( $\times$ 8): Input clock = 2.5 to 4 MHz (output: 20 to 32 MHz) Clock-through mode: Input clock = 2.5 to 8 MHz (output: 2.5 to 8 MHz)

## 6.5.2 Registers

## (1) PLL control register (PLLCTL)

The PLLCTL register is an 8-bit register that controls the PLL function.

This register can be read or written in 8-bit or 1-bit units.

Reset input sets this register to 01H.

| After reset: 01H R/W |   |   | Address: | FFFFF820 | СН |   |        |       |
|----------------------|---|---|----------|----------|----|---|--------|-------|
|                      | 7 | 6 | 5        | 4        | 3  | 2 | <1>    | <0>   |
| PLLCTL               | 0 | 0 | 0        | 0        | 0  | 0 | SELPLL | PLLON |

| PLLON | PLL operation stop register                                                                       |
|-------|---------------------------------------------------------------------------------------------------|
| 0     | PLL stopped                                                                                       |
| 1     | PLL operating (After PLL operation starts, a lockup time is required for frequency stabilization) |

| SELPLL | CPU operation clock selection register |  |
|--------|----------------------------------------|--|
| 0      | Clock-through mode                     |  |
| 1      | PLL mode                               |  |

- Cautions 1. When the PLLON bit is cleared to 0, the SELPLL bit is automatically cleared to 0 (clock-through mode).
  - 2. The SELPLL bit can be set to 1 only when the PLL clock frequency is stabilized. If not (unlocked), "0" is written to the SELPLL bit if data is written to it.

### (2) Clock control register (CKC)

The CKC register is a special register. Data can be written to this register only in a combination of specific sequence (see **3.4.8 Special registers**).

The CKC register controls the internal system clock in the PLL mode.

This register can be read or written in 8-bit or 1-bit units.

Reset input sets this register to 0AH.



| CKDIV0 | Internal system clock (fxx) in PLL mode      |  |
|--------|----------------------------------------------|--|
| 0      | $fxx = 4 \times fx$ ( $fx = 2.5$ to 5.0 MHz) |  |
| 1      | $fxx = 8 \times fx$ ( $fx = 2.5$ to 4.0 MHz) |  |

Cautions 1. The PLL mode cannot be used at fx = 5.0 to 8.0 MHz.

- 2. Before changing the multiplication factor between 4 and 8 by using the CKC register, set the clock-through mode and stop the PLL.
- 3. Be sure to set bits 3 and 1 to 1 and clear bits 7 to 4 and 2 to 0.

**Remark** Both the CPU clock and peripheral clock are divided by the CKC register, but only the CPU clock is divided by the PCC register.

### (3) Lock register (LOCKR)

Phase lock occurs at a given frequency following power application or immediately after the STOP mode is released, and the time required for stabilization is the lockup time (frequency stabilization time). This state until stabilization is called the lockup status, and the stabilized state is called the locked status.

The LOCKR register includes a LOCK bit that reflects the PLL frequency stabilization status.

This register is read-only, in 8-bit or 1-bit units.

Reset input clears this register to 00H.

| After reset: 00H |      | R A                   | ddress: FF | FFF824H |   |   |   |      |
|------------------|------|-----------------------|------------|---------|---|---|---|------|
|                  | 7    | 6                     | 5          | 4       | 3 | 2 | 1 | <0>  |
| LOCKR            | 0    | 0                     | 0          | 0       | 0 | 0 | 0 | LOCK |
|                  |      |                       |            |         |   |   |   |      |
|                  | LOCK | PLL lock status check |            |         |   |   |   |      |
|                  | 0    | Locked st             | atus       |         |   |   |   |      |
|                  | 1    | Unlocked              | status     |         |   |   |   |      |

Caution The LOCK register does not reflect the lock status of the PLL in real time. The set/clear conditions are as follows.

## [Set conditions]

- Upon system reset<sup>Note</sup>
- In IDLE2 or STOP mode
- Upon setting of PLL stop (clearing of PLLCTL.PLLON bit to 0)
- Upon stopping main clock and using CPU with subclock (setting of PCC.CK3 bit to 1 and setting of PCC.MCK bit to 1)

**Note** This register is set to 01H by reset and cleared to 00H after the reset has been released and the oscillation stabilization time has elapsed.

### [Clear conditions]

- Upon overflow of oscillation stabilization time following reset release (OSTS register default time (see 24.2 (3) Oscillation stabilization time select register (OSTS)))
- Upon oscillation stabilization timer overflow (time set by OSTS register) following STOP mode release, when the STOP mode was set in the PLL operating status
- Upon PLL lockup time timer overflow (time set by PLLS register) when the PLLCTL.PLLON bit is changed from 0 to 1
- After the setup time inserted upon release of the IDLE2 mode is released (time set by the OSTS register) when the IDLE2 mode is set during PLL operation.

### (4) PLL lockup time specification register (PLLS)

The PLLS register is an 8-bit register used to select the PLL lockup time when the PLLCTL.PLLON bit is changed from 0 to 1.

This register can be read or written in 8-bit units.

Reset input sets this register to 03H.



| PLLS1 | PLLS0 | Selection of PLL lockup time        |
|-------|-------|-------------------------------------|
| 0     | 0     | 2 <sup>10</sup> /fx                 |
| 0     | 1     | 2 <sup>11</sup> fx                  |
| 1     | 0     | 2 <sup>12</sup> /fx                 |
| 1     | 1     | 2 <sup>13</sup> /fx (default value) |

Cautions 1. Set so that the lockup time is 800  $\mu$ s or longer.

2. Do not change the PLLS register setting during the lockup period.

### 6.5.3 Usage

### (1) When PLL is used

- After the reset signal has been released, the PLL operates (PLLCTL.PLLON bit = 1), but because the default
  mode is the clock-through mode (PLLCTL.SELPLL bit = 0), select the PLL mode (SELPLL bit = 1).
- To enable PLL operation, first set the PLLON bit to 1, and then set the SELPLL bit to 1 after the LOCKR.LOCK bit = 0. To stop the PLL, first select the clock-through mode (SELPLL bit = 0), wait for 8 clocks or more, and then stop the PLL (PLLON bit = 0).
- The PLL stops during transition to IDLE2 or STOP mode regardless of the setting and is restored from IDLE2 or STOP mode to the status before transition. The time required for restoration is as follows.

### (a) To set the IDLE2/STOP mode in clock through mode

- STOP mode: Set the OSTS register so that the oscillation stabilization time is 1 ms (MIN.) or more.
- IDLE2 mode: Set the OSTS register so that the setup time is 350  $\mu$ s (MIN.) or more.

### (b) To set IDLE2/STOP mode in PLL operation mode

- STOP mode: Set the OSTS register so that the oscillation stabilization time is 1 ms (MIN.) or more.
- IDLE2 mode: Set the OSTS register so that the setup time is 800  $\mu$ s (MIN.) or more.

When shifting to the IDLE1 mode, the PLL does not stop. Stop the PLL if necessary.

### (2) When PLL is not used

• The clock-through mode (SELPLL bit = 0) is selected after the reset signal has been released, but the PLL is operating (PLLON bit = 1) and must therefore be stopped (PLLON bit = 0).

# CHAPTER 7 16-BIT TIMER/EVENT COUNTER P (TMP)

Timer P (TMP) is a 16-bit timer/event counter.

The V850ES/SG2 has six timer/event counter channels, TMP0 to TMP5.

## 7.1 Overview

An outline of TMPn is shown below.

| Clock selection:                                   | 8 ways |
|----------------------------------------------------|--------|
| Capture/trigger input pins:                        | 2      |
| External event count input pins:                   | 1      |
| External trigger input pins:                       | 1      |
| Timer/counters:                                    | 1      |
| Capture/compare registers:                         | 2      |
| • Capture/compare match interrupt request signals: | 2      |
| Timer output pins:                                 | 2      |

**Remark** n = 0 to 5

# 7.2 Functions

TMPn has the following functions.

- Interval timer
- External event counter
- External trigger pulse output
- · One-shot pulse output
- PWM output
- Free-running timer
- Pulse width measurement

**Remark** n = 0 to 5

## 7.3 Configuration

TMPn includes the following hardware.

Table 7-1. Configuration of TMPn

| Item                                | Configuration                                                                                                                            |
|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Timer register                      | 16-bit counter                                                                                                                           |
| Registers                           | TMPn capture/compare registers 0, 1 (TPnCCR0, TPnCCR1) TMPn counter read buffer register (TPnCNT) CCR0, CCR1 buffer registers            |
| Timer inputs                        | 2 (TIPn0 <sup>Note 1</sup> , TIPn1 pins)                                                                                                 |
| Timer outputs                       | 2 (TOPn0, TOPn1 pins)                                                                                                                    |
| Control registers <sup>Note 2</sup> | TMPn control registers 0, 1 (TPnCTL0, TPnCTL1)  TMPn I/O control registers 0 to 2 (TPnIOC0 to TPnIOC2)  TMPn option register 0 (TPnOPT0) |

- **Notes 1.** The TIPn0 pin functions alternately as a capture trigger input signal, external event count input signal, and external trigger input signal.
  - 2. When using the functions of the TIPn0, TIPn1, TOPn0, and TOPn1 pins, see **Table 4-15 Using Port Pin as Alternate-Function Pin**.

**Remark** n = 0 to 5

Figure 7-1. Block Diagram of TMPn



### (1) 16-bit counter

This 16-bit counter can count internal clocks or external events.

The count value of this counter can be read by using the TPnCNT register.

When the TPnCTL0.TPnCE bit = 0, the value of the 16-bit counter is FFFFH. If the TPnCNT register is read at this time, 0000H is read.

Reset input clears the TPnCE bit to 0. Therefore, the 16-bit counter is set to FFFFH.

### (2) CCR0 buffer register

This is a 16-bit compare register that compares the count value of the 16-bit counter.

When the TPnCCR0 register is used as a compare register, the value written to the TPnCCR0 register is transferred to the CCR0 buffer register. When the count value of the 16-bit counter matches the value of the CCR0 buffer register, a compare match interrupt request signal (INTTPnCC0) is generated.

The CCR0 buffer register cannot be read or written directly.

The CCR0 buffer register is cleared to 0000H after reset, as the TPnCCR0 register is cleared to 0000H.

# (3) CCR1 buffer register

This is a 16-bit compare register that compares the count value of the 16-bit counter.

When the TPnCCR1 register is used as a compare register, the value written to the TPnCCR1 register is transferred to the CCR1 buffer register. When the count value of the 16-bit counter matches the value of the CCR1 buffer register, a compare match interrupt request signal (INTTPnCC1) is generated.

The CCR1 buffer register cannot be read or written directly.

The CCR1 buffer register is cleared to 0000H after reset, as the TPnCCR1 register is cleared to 0000H.

#### (4) Edge detector

This circuit detects the valid edges input to the TIPn0 and TIPn1 pins. No edge, rising edge, falling edge, or both the rising and falling edges can be selected as the valid edge by using the TPnIOC1 and TPnIOC2 registers.

### (5) Output controller

This circuit controls the output of the TOPn0 and TOPn1 pins. The output controller is controlled by the TPnIOC0 register.

### (6) Selector

This selector selects the count clock for the 16-bit counter. Eight types of internal clocks or an external event can be selected as the count clock.

## 7.4 Registers

The registers that control TMPn are as follows.

- TMPn control register 0 (TPnCTL0)
- TMPn control register 1 (TPnCTL1)
- TMPn I/O control register 0 (TPnIOC0)
- TMPn I/O control register 1 (TPnIOC1)
- TMPn I/O control register 2 (TPnIOC2)
- TMPn option register 0 (TPnOPT0)
- TMPn capture/compare register 0 (TPnCCR0)
- TMPn capture/compare register 1 (TPnCCR1)
- TMPn counter read buffer register (TPnCNT)
- Remarks 1. When using the functions of the TIPn0, TIPn1,TOPn0, and TOPn1 pins, see Table 4-15 Using Port Pin as Alternate-Function Pin.
  - **2.** n = 0 to 5

#### (1) TMPn control register 0 (TPnCTL0)

The TPnCTL0 register is an 8-bit register that controls the operation of TMPn.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

The same value can always be written to the TPnCTL0 register by software.

After reset: 00H R/W Address: TP0CTL0 FFFFF590H, TP1CTL0 FFFF5A0H,

TP2CTL0 FFFF5B0H, TP3CTL0 FFFF5C0H,

TP4CTL0 FFFFF5D0H, TP5CTL0 FFFFF5E0H

TPnCTL0 (n = 0 to 5)

| <7>   | 6 | 5 | 4 | 3 | 2       | 1       | 0       |
|-------|---|---|---|---|---------|---------|---------|
| TPnCE | 0 | 0 | 0 | 0 | TPnCKS2 | TPnCKS1 | TPnCKS0 |

| TPnCE | TMPn operation control                                                |
|-------|-----------------------------------------------------------------------|
| 0     | TMPn operation disabled (TMPn reset asynchronously <sup>Note</sup> ). |
| 1     | TMPn operation enabled. TMPn operation started.                       |

| TPnCKS2 | TPnCKS1 | TPnCKS0 | Internal count clock selection |             |  |
|---------|---------|---------|--------------------------------|-------------|--|
|         |         |         | n = 0, 2, 4                    | n = 1, 3, 5 |  |
| 0       | 0       | 0       | fxx                            |             |  |
| 0       | 0       | 1       | fxx/2                          |             |  |
| 0       | 1       | 0       | fxx/4                          |             |  |
| 0       | 1       | 1       | fxx/8                          |             |  |
| 1       | 0       | 0       | fxx/16                         |             |  |
| 1       | 0       | 1       | fxx/32                         |             |  |
| 1       | 1       | 0       | fxx/64                         | fxx/256     |  |
| 1       | 1       | 1       | fxx/128                        | fxx/512     |  |

Note TPn0PT0.TPnOVF bit, 16-bit counter, timer output (TOPn0, TOPn1 pins)

- Cautions 1. Set the TPnCKS2 to TPnCKS0 bits when the TPnCE bit = 0.

  When the value of the TPnCE bit is changed from 0 to 1, the TPnCKS2 to TPnCKS0 bits can be set simultaneously.
  - 2. Be sure to clear bits 3 to 6 to 0.

Remark fxx: Main clock frequency

## (2) TMPn control register 1 (TPnCTL1)

The TPnCTL1 register is an 8-bit register that controls the operation of TMPn.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

After reset: 00H R/W Address: TP0CTL1 FFFF591H, TP1CTL1 FFFF5A1H,

TP2CTL1 FFFF5B1H, TP3CTL1 FFFF5C1H,

TP4CTL1 FFFF5D1H, TP5CTL1 FFFF5E1H

TPnCTL1 (n = 0 to 5)

| 7 | <6>    | <5>    | 4 | 3 | 2      | 1      | 0      |
|---|--------|--------|---|---|--------|--------|--------|
| 0 | TPnEST | TPnEEE | 0 | 0 | TPnMD2 | TPnMD1 | TPnMD0 |

| TPnEST | Software trigger control                                                                                                                                                                                                                                                           |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | <del>-</del>                                                                                                                                                                                                                                                                       |
| 1      | Generate a valid signal for external trigger input.  In one-shot pulse output mode: A one-shot pulse is output with writing  1 to the TPnEST bit as the trigger.  In external trigger pulse output mode: A PWM waveform is output with writing 1 to the TPnEST bit as the trigger. |

| TPnEEE | Count clock selection                                                                                                                     |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | Disable operation with external event count input. (Perform counting with the count clock selected by the TPnCTL0.TPnCK0 to TPnCK2 bits.) |
| 1      | Enable operation with external event count input. (Perform counting at the valid edge of the external event count input signal.)          |

The TPnEEE bit selects whether counting is performed with the internal count clock or the valid edge of the external event count input.

| TPnMD2 | TPnMD1 | TPnMD0 | Timer mode selection               |
|--------|--------|--------|------------------------------------|
| 0      | 0      | 0      | Interval timer mode                |
| 0      | 0      | 1      | External event count mode          |
| 0      | 1      | 0      | External trigger pulse output mode |
| 0      | 1      | 1      | One-shot pulse output mode         |
| 1      | 0      | 0      | PWM output mode                    |
| 1      | 0      | 1      | Free-running timer mode            |
| 1      | 1      | 0      | Pulse width measurement mode       |
| 1      | 1      | 1      | Setting prohibited                 |

- Cautions 1. The TPnEST bit is valid only in the external trigger pulse output mode or the one-shot pulse output mode. In any other mode, writing 1 to this bit is ignored.
  - 2. External event count input is selected in the external event count mode regardless of the value of the TPnEEE bit.
  - 3. Set the TPnEEE and TPnMD2 to TPnMD0 bits when the TPnCTL0.TPnCE bit = 0. (The same value can be written when the TPnCE bit = 1.) The operation is not guaranteed when rewriting is performed with the TPnCE bit = 1. If rewriting was mistakenly performed, clear the TPnCE bit to 0 and then set the bits again.
  - 4. Be sure to clear bits 3, 4, and 7 to 0.

#### (3) TMPn I/O control register 0 (TPnIOC0)

The TPnIOC0 register is an 8-bit register that controls the timer output (TOPn0, TOPn1 pins).

This register can be read or written in 8-bit or 1-bit units.

6

0

Reset input clears this register to 00H.

After reset: 00H R/W Address: TP0IOC0 FFFFF592H, TP1IOC0 FFFF5A2H,

TP2IOC0 FFFFF5B2H, TP3IOC0 FFFFF5C2H,

TP4IOC0 FFFFF5D2H, TP5IOC0 FFFFF5E2H

11 41000 11111 30211, 11 31000 11111 302

4

0

5

TPnIOC0 (n = 0 to 5)

| TPnOL1 | TOPn1 pin output level setting      |
|--------|-------------------------------------|
| 0      | TOPn1 pin output inversion disabled |
| 1      | TOPn1 pin output inversion enabled  |

3

<2>

1

TPnOL1 TPnOE1 TPnOL0 TPnOE0

<0>

| TPnOE1 | TOPn1 pin output setting                                                                                                                             |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | Timer output disabled  • When TPnOL1 bit = 0: Low level is output from the TOPn1 pin  • When TPnOL1 bit = 1: High level is output from the TOPn1 pin |
| 1      | Timer output enabled (a square wave is output from the TOPn1 pin).                                                                                   |

| TPnOL0 | TOPn0 pin output level setting      |
|--------|-------------------------------------|
| 0      | TOPn0 pin output inversion disabled |
| 1      | TOPn0 pin output inversion enabled  |

| TPnOE0 | TOPn0 pin output setting                                                                                                                             |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | Timer output disabled  • When TPnOL0 bit = 0: Low level is output from the TOPn0 pin  • When TPnOL0 bit = 1: High level is output from the TOPn0 pin |
| 1      | Timer output enabled (a square wave is output from the TOPn0 pin).                                                                                   |

- Cautions 1. Rewrite the TPnOL1, TPnOE1, TPnOL0, and TPnOE0 bits when the TPnCTL0.TPnCE bit = 0. (The same value can be written when the TPnCE bit = 1.) If rewriting was mistakenly performed, clear the TPnCE bit to 0 and then set the bits again.
  - 2. Even if the TPnOLm bit is manipulated when the TPnCE and TPnOEm bits are 0, the TOPnm pin output level varies (m = 0, 1).

## (4) TMPn I/O control register 1 (TPnIOC1)

The TPnIOC1 register is an 8-bit register that controls the valid edge of the capture trigger input signals (TIPn0, TIPn1 pins).

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

After reset: 00H R/W Address: TP0IOC1 FFFFF593H, TP1IOC1 FFFFF5A3H, TP2IOC1 FFFF5B3H, TP3IOC1 FFFF5C3H, TP4IOC1 FFFFF5D3H, TP5IOC1 FFFFF5E3H 6 5 3 2 1 0 TPnIOC1 0 0 0 TPnIS3 TPnIS2 TPnIS1 TPnIS0

(n = 0 to 5)

| TPnIS3 | TPnIS2 | Capture trigger input signal (TIPn1 pin) valid edge setting |
|--------|--------|-------------------------------------------------------------|
| 0      | 0      | No edge detection (capture operation invalid)               |
| 0      | 1      | Detection of rising edge                                    |
| 1      | 0      | Detection of falling edge                                   |
| 1      | 1      | Detection of both edges                                     |

| TPnIS1 | TPnIS0 | Capture trigger input signal (TIPn0 pin) valid edge setting |
|--------|--------|-------------------------------------------------------------|
| 0      | 0      | No edge detection (capture operation invalid)               |
| 0      | 1      | Detection of rising edge                                    |
| 1      | 0      | Detection of falling edge                                   |
| 1      | 1      | Detection of both edges                                     |

- Cautions 1. Rewrite the TPnIS3 to TPnIS0 bits when the TPnCTL0.TPnCE bit = 0. (The same value can be written when the TPnCE bit = 1.) If rewriting was mistakenly performed, clear the TPnCE bit to 0 and then set the bits again.
  - 2. The TPnIS3 to TPnIS0 bits are valid only in the free-running timer mode and the pulse width measurement mode. In all other modes, a capture operation is not possible.

#### (5) TMPn I/O control register 2 (TPnIOC2)

The TPnIOC2 register is an 8-bit register that controls the valid edge of the external event count input signal (TIPn0 pin) and external trigger input signal (TIPn0 pin).

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

After reset: 00H R/W Address: TP0IOC2 FFFFF594H, TP1IOC2 FFFF5A4H,

TP2IOC2 FFFFF5B4H, TP3IOC2 FFFFF5C4H,

TP4IOC2 FFFFF5D4H, TP5IOC2 FFFFF5E4H

7 6 5 4 3 2 1 0

PnIOC2 0 0 0 TPnEES1 TPnEES0 TPnETS1 TPnETS0

TPnIOC2 (n = 0 to 5)

| TPnEES1 | TPnEES0 | External event count input signal (TIPn0 pin) valid edge setting |
|---------|---------|------------------------------------------------------------------|
| 0       | 0       | No edge detection (external event count invalid)                 |
| 0       | 1       | Detection of rising edge                                         |
| 1       | 0       | Detection of falling edge                                        |
| 1       | 1       | Detection of both edges                                          |

| TPnETS1 | TPnETS0 | External trigger input signal (TIPn0 pin) valid edge setting |
|---------|---------|--------------------------------------------------------------|
| 0       | 0       | No edge detection (external trigger invalid)                 |
| 0       | 1       | Detection of rising edge                                     |
| 1       | 0       | Detection of falling edge                                    |
| 1       | 1       | Detection of both edges                                      |

- Cautions 1. Rewrite the TPnEES1, TPnEES0, TPnETS1, and TPnETS0 bits when the TPnCTL0.TPnCE bit = 0. (The same value can be written when the TPnCE bit = 1.) If rewriting was mistakenly performed, clear the TPnCE bit to 0 and then set the bits again.
  - 2. The TPnEES1 and TPnEES0 bits are valid only when the TPnCTL1.TPnEEE bit = 1 or when the external event count mode (TPnCTL1.TPnMD2 to TPnCTL1.TPnMD0 bits = 001) has been set.
  - 3. The TPnETS1 and TPnETS0 bits are valid only when the external trigger pulse output mode (TPnCTL1.TPnMD2 to TPnCTL1.TPnMD0 bits = 010) or the one-shot pulse output mode (TPnCTL1.TPnMD2 to TPnCTL1.TPnMD0 = 011) is set.

#### (6) TMPn option register 0 (TPnOPT0)

The TPnOPT0 register is an 8-bit register used to set the capture/compare operation and detect an overflow. This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

After reset: 00H R/W Address: TP0OPT0 FFFF595H, TP1OPT0 FFFF5A5H,

TP2OPT0 FFFF5B5H, TP3OPT0 FFFF5C5H,

TP4OPT0 FFFFF5D5H, TP5OPT0 FFFFF5E5H

TPnOPT0 (n = 0 to 5)

| 7 | 6 | 5       | 4       | 3 | 2 | 1 | <0>    |
|---|---|---------|---------|---|---|---|--------|
| 0 | 0 | TPnCCS1 | TPnCCS0 | 0 | 0 | 0 | TPnOVF |

| TPnCCS1                                                               | TPnCCR1 register capture/compare selection |  |  |
|-----------------------------------------------------------------------|--------------------------------------------|--|--|
| 0                                                                     | Compare register selected                  |  |  |
| 1 Capture register selected                                           |                                            |  |  |
| The TPnCCS1 bit setting is valid only in the free-running timer mode. |                                            |  |  |

| TPnCCS0                                                               | TPnCCR0 register capture/compare selection |  |  |
|-----------------------------------------------------------------------|--------------------------------------------|--|--|
| 0                                                                     | Compare register selected                  |  |  |
| 1                                                                     | Capture register selected                  |  |  |
| The TPnCCS0 bit setting is valid only in the free-running timer mode. |                                            |  |  |

| TPnOVF    | TMPn overflow detection flag                  |
|-----------|-----------------------------------------------|
| Set (1)   | Overflow occurred                             |
| Reset (0) | TPnOVF bit 0 written or TPnCTL0.TPnCE bit = 0 |

- The TPnOVF bit is reset when the 16-bit counter count value overflows from FFFFH to 0000H in the free-running timer mode or the pulse width measurement mode.
- An interrupt request signal (INTTPnOV) is generated at the same time that the TPnOVF bit is set to 1. The INTTPnOV signal is not generated in modes other than the free-running timer mode and the pulse width measurement mode.
- The TPnOVF bit is not cleared even when the TPnOVF bit or the TPnOPT0 register are read when the TPnOVF bit = 1.
- The TPnOVF bit can be both read and written, but the TPnOVF bit cannot be set to 1 by software. Writing 1 has no influence on the operation of TMPn.
- Cautions 1. Rewrite the TPnCCS1 and TPnCCS0 bits when the TPnCE bit = 0. (The same value can be written when the TPnCE bit = 1.) If rewriting was mistakenly performed, clear the TPnCE bit to 0 and then set the bits again.
  - 2. Be sure to clear bits 1 to 3, 6, and 7 to 0.

#### (7) TMPn capture/compare register 0 (TPnCCR0)

The TPnCCR0 register can be used as a capture register or a compare register depending on the mode.

This register can be used as a capture register or a compare register only in the free-running timer mode, depending on the setting of the TPnOPT0.TPnCCS0 bit. In the pulse width measurement mode, the TPnCCR0 register can be used only as a capture register. In any other mode, this register can be used only as a compare register.

The TPnCCR0 register can be read or written during operation.

This register can be read or written in 16-bit units.

Reset input clears this register to 0000H.

# Caution Accessing the TPnCCR0 register is prohibited in the following statuses. For details, see 3.4.9

- (2) Accessing specific on-chip peripheral I/O registers.
- When the CPU operates with the subclock and the main clock oscillation is stopped
- When the CPU operates with the internal oscillation clock



#### (a) Function as compare register

The TPnCCR0 register can be rewritten even when the TPnCTL0.TPnCE bit = 1.

The set value of the TPnCCR0 register is transferred to the CCR0 buffer register. When the value of the 16-bit counter matches the value of the CCR0 buffer register, a compare match interrupt request signal (INTTPnCC0) is generated. If TOPn0 pin output is enabled at this time, the output of the TOPn0 pin is inverted.

When the TPnCCR0 register is used as a cycle register in the interval timer mode, external event count mode, external trigger pulse output mode, one-shot pulse output mode, or PWM output mode, the value of the 16-bit counter is cleared (0000H) if its count value matches the value of the CCR0 buffer register.

#### (b) Function as capture register

When the TPnCCR0 register is used as a capture register in the free-running timer mode, the count value of the 16-bit counter is stored in the TPnCCR0 register if the valid edge of the capture trigger input pin (TIPn0 pin) is detected. In the pulse-width measurement mode, the count value of the 16-bit counter is stored in the TPnCCR0 register and the 16-bit counter is cleared (0000H) if the valid edge of the capture trigger input pin (TIPn0) is detected.

Even if the capture operation and reading the TPnCCR0 register conflict, the correct value of the TPnCCR0 register can be read.

The following table shows the functions of the capture/compare register in each mode, and how to write data to the compare register.

Table 7-2. Function of Capture/Compare Register in Each Mode and How to Write Compare Register

| Operation Mode                | Capture/Compare Register | How to Write Compare Register |
|-------------------------------|--------------------------|-------------------------------|
| Interval timer                | Compare register         | Anytime write                 |
| External event counter        | Compare register         | Anytime write                 |
| External trigger pulse output | Compare register         | Batch write                   |
| One-shot pulse output         | Compare register         | Anytime write                 |
| PWM output                    | Compare register         | Batch write                   |
| Free-running timer            | Capture/compare register | Anytime write                 |
| Pulse width measurement       | Capture register         | -                             |

#### (8) TMPn capture/compare register 1 (TPnCCR1)

The TPnCCR1 register can be used as a capture register or a compare register depending on the mode.

This register can be used as a capture register or a compare register only in the free-running timer mode, depending on the setting of the TPnOPT0.TPnCCS1 bit. In the pulse width measurement mode, the TPnCCR1 register can be used only as a capture register. In any other mode, this register can be used only as a compare register.

The TPnCCR1 register can be read or written during operation.

This register can be read or written in 16-bit units.

Reset input clears this register to 0000H.

Caution Accessing the TPnCCR1 register is prohibited in the following statuses. For details, see 3.4.9 (2) Accessing specific on-chip peripheral I/O registers.

- When the CPU operates with the subclock and the main clock oscillation is stopped
- When the CPU operates with the internal oscillation clock



#### (a) Function as compare register

The TPnCCR1 register can be rewritten even when the TPnCTL0.TPnCE bit = 1.

The set value of the TPnCCR1 register is transferred to the CCR1 buffer register. When the value of the 16-bit counter matches the value of the CCR1 buffer register, a compare match interrupt request signal (INTTPnCC1) is generated. If TOPn1 pin output is enabled at this time, the output of the TOPn1 pin is inverted.

#### (b) Function as capture register

When the TPnCCR1 register is used as a capture register in the free-running timer mode, the count value of the 16-bit counter is stored in the TPnCCR1 register if the valid edge of the capture trigger input pin (TIPn1 pin) is detected. In the pulse-width measurement mode, the count value of the 16-bit counter is stored in the TPnCCR1 register and the 16-bit counter is cleared (0000H) if the valid edge of the capture trigger input pin (TIPn1) is detected.

Even if the capture operation and reading the TPnCCR1 register conflict, the correct value of the TPnCCR1 register can be read.

The following table shows the functions of the capture/compare register in each mode, and how to write data to the compare register.

Table 7-3. Function of Capture/Compare Register in Each Mode and How to Write Compare Register

| Operation Mode                | Capture/Compare Register | How to Write Compare Register |  |
|-------------------------------|--------------------------|-------------------------------|--|
| Interval timer                | Compare register         | Anytime write                 |  |
| External event counter        | Compare register         | Anytime write                 |  |
| External trigger pulse output | Compare register         | Batch write                   |  |
| One-shot pulse output         | Compare register         | Anytime write                 |  |
| PWM output                    | Compare register         | Batch write                   |  |
| Free-running timer            | Capture/compare register | Anytime write                 |  |
| Pulse width measurement       | Capture register         | -                             |  |

#### (9) TMPn counter read buffer register (TPnCNT)

The TPnCNT register is a read buffer register that can read the count value of the 16-bit counter.

If this register is read when the TPnCTL0.TPnCE bit = 1, the count value of the 16-bit timer can be read.

This register is read-only, in 16-bit units.

The value of the TPnCNT register is cleared to 0000H when the TPnCE bit = 0. If the TPnCNT register is read at this time, the value of the 16-bit counter (FFFFH) is not read, but 0000H is read.

The value of the TPnCNT register is cleared to 0000H after reset, as the TPnCE bit is cleared to 0.

# Caution Accessing the TPnCNT register is prohibited in the following statuses. For details, see 3.4.9 (2) Accessing specific on-chip peripheral I/O registers.

- When the CPU operates with the subclock and the main clock oscillation is stopped
- When the CPU operates with the internal oscillation clock



## 7.5 Operation

TMPn can perform the following operations.

| Operation                                            | TPnCTL1.TPnEST Bit (Software Trigger Bit) | TIPn0 Pin<br>(External Trigger Input) | Capture/Compare<br>Register Setting | Compare Register<br>Write |
|------------------------------------------------------|-------------------------------------------|---------------------------------------|-------------------------------------|---------------------------|
| Interval timer mode                                  | Invalid                                   | Invalid                               | Compare only                        | Anytime write             |
| External event count mode <sup>Note 1</sup>          | Invalid                                   | Invalid                               | Compare only                        | Anytime write             |
| External trigger pulse output mode <sup>Note 2</sup> | Valid                                     | Valid                                 | Compare only                        | Batch write               |
| One-shot pulse output mode <sup>Note 2</sup>         | Valid                                     | Valid                                 | Compare only                        | Anytime write             |
| PWM output mode                                      | Invalid                                   | Invalid                               | Compare only                        | Batch write               |
| Free-running timer mode                              | Invalid                                   | Invalid                               | Switching enabled                   | Anytime write             |
| Pulse width measurement mode <sup>Note 2</sup>       | Invalid                                   | Invalid                               | Capture only                        | Not applicable            |

- **Notes 1.** To use the external event count mode, specify that the valid edge of the TIPn0 pin capture trigger input is not detected (by clearing the TPnIOC1.TPnIS1 and TPnIOC1.TPnIS0 bits to "00").
  - 2. When using the external trigger pulse output mode, one-shot pulse output mode, and pulse width measurement mode, select the internal clock as the count clock (by clearing the TPnCTL1.TPnEEE bit to 0).

**Remark** n = 0 to 5

## 7.5.1 Interval timer mode (TPnMD2 to TPnMD0 bits = 000)

In the interval timer mode, an interrupt request signal (INTTPnCC0) is generated at the specified interval if the TPnCTL0.TPnCE bit is set to 1. A square wave whose half cycle is equal to the interval can be output from the TOPn0 pin.

Usually, the TPnCCR1 register is not used in the interval timer mode.



Figure 7-2. Configuration of Interval Timer





When the TPnCE bit is set to 1, the value of the 16-bit counter is cleared from FFFFH to 0000H in synchronization with the count clock, and the counter starts counting. At this time, the output of the TOPn0 pin is inverted. Additionally, the set value of the TPnCCR0 register is transferred to the CCR0 buffer register.

When the count value of the 16-bit counter matches the value of the CCR0 buffer register, the 16-bit counter is cleared to 0000H, the output of the TOPn0 pin is inverted, and a compare match interrupt request signal (INTTPnCC0) is generated.

The interval can be calculated by the following expression.

Interval = (Set value of TPnCCR0 register + 1) × Count clock cycle

**Remark** n = 0 to 5

Figure 7-4. Register Setting for Interval Timer Mode Operation (1/2)



Figure 7-4. Register Setting for Interval Timer Mode Operation (2/2)



#### (d) TMPn counter read buffer register (TPnCNT)

By reading the TPnCNT register, the count value of the 16-bit counter can be read.

## (e) TMPn capture/compare register 0 (TPnCCR0)

If the TPnCCR0 register is set to Do, the interval is as follows.

 $Interval = (D_0 + 1) \times Count \ clock \ cycle$ 

## (f) TMPn capture/compare register 1 (TPnCCR1)

Usually, the TPnCCR1 register is not used in the interval timer mode. However, the set value of the TPnCCR1 register is transferred to the CCR1 buffer register. A compare match interrupt request signal (INTTPnCC1) is generated when the count value of the 16-bit counter matches the value of the CCR1 buffer register.

Therefore, mask the interrupt request by using the corresponding interrupt mask flag (TPnCCMK1).

**Remarks 1.** TMPn I/O control register 1 (TPnIOC1), TMPn I/O control register 2 (TPnIOC2), and TMPn option register 0 (TPnOPT0) are not used in the interval timer mode.

**2.** n = 0 to 5

## (1) Interval timer mode operation flow

Figure 7-5. Software Processing Flow in Interval Timer Mode



## (2) Interval timer mode operation timing

## (a) Operation if TPnCCR0 register is set to 0000H

If the TPnCCR0 register is set to 0000H, the INTTPnCC0 signal is generated at each count clock of the second clock or later, and the output of the TOPn0 pin is inverted.

The value of the 16-bit counter is always 0000H.



## (b) Operation if TPnCCR0 register is set to FFFFH

If the TPnCCR0 register is set to FFFFH, the 16-bit counter counts up to FFFFH. The counter is cleared to 0000H in synchronization with the next count-up timing. The INTTPnCC0 signal is generated and the output of the TOPn0 pin is inverted. At this time, an overflow interrupt request signal (INTTPnOV) is not generated, nor is the overflow flag (TPnOPT0.TPnOVF bit) set to 1.



#### (c) Notes on rewriting TPnCCR0 register

To change the value of the TPnCCR0 register to a smaller value, stop counting once and then change the set value.

If the value of the TPnCCR0 register is rewritten to a smaller value during counting, the 16-bit counter may overflow.



If the value of the TPnCCR0 register is changed from  $D_1$  to  $D_2$  while the count value is greater than  $D_2$  but less than  $D_1$ , the count value is transferred to the CCR0 buffer register as soon as the TPnCCR0 register has been rewritten. Consequently, the value of the 16-bit counter that is compared is  $D_2$ .

Because the count value has already exceeded D<sub>2</sub>, however, the 16-bit counter counts up to FFFFH, overflows, and then counts up again from 0000H. When the count value matches D<sub>2</sub>, the INTTPnCC0 signal is generated and the output of the TOPn0 pin is inverted.

Therefore, the INTTPnCC0 signal may not be generated at the interval time " $(D_1 + 1) \times$  Count clock cycle" or " $(D_2 + 1) \times$  Count clock cycle" originally expected, but may be generated at an interval of " $(10000H + D_2 + 1) \times$  Count clock period".

## (d) Operation of TPnCCR1 register

Figure 7-6. Configuration of TPnCCR1 Register



If the set value of the TPnCCR1 register is less than the set value of the TPnCCR0 register, the INTTPnCC1 signal is generated once per cycle. At the same time, the output of the TOPn1 pin is inverted. The TOPn1 pin outputs a square wave with the same cycle as that output by the TOPn0 pin.



Figure 7-7. Timing Chart When  $D_{01} \ge D_{11}$ 

If the set value of the TPnCCR1 register is greater than the set value of the TPnCCR0 register, the count value of the 16-bit counter does not match the value of the TPnCCR1 register. Consequently, the INTTPnCC1 signal is not generated, nor is the output of the TOPn1 pin changed.



Figure 7-8. Timing Chart When  $D_{01} < D_{11}$ 

#### 7.5.2 External event count mode (TPnMD2 to TPnMD0 bits = 001)

In the external event count mode, the valid edge of the external event count input is counted when the TPnCTL0.TPnCE bit is set to 1, and an interrupt request signal (INTTPnCC0) is generated each time the specified number of edges have been counted. The TOPn0 pin cannot be used.

Usually, the TPnCCR1 register is not used in the external event count mode.



Figure 7-9. Configuration in External Event Count Mode





When the TPnCE bit is set to 1, the value of the 16-bit counter is cleared from FFFFH to 0000H. The counter counts each time the valid edge of external event count input is detected. Additionally, the set value of the TPnCCR0 register is transferred to the CCR0 buffer register.

When the count value of the 16-bit counter matches the value of the CCR0 buffer register, the 16-bit counter is cleared to 0000H, and a compare match interrupt request signal (INTTPnCC0) is generated.

The INTTPnCC0 signal is generated each time the valid edge of the external event count input has been detected (set value of TPnCCR0 register + 1) times.

Figure 7-11. Register Setting for Operation in External Event Count Mode (1/2)



Figure 7-11. Register Setting for Operation in External Event Count Mode (2/2)

#### (f) TMPn capture/compare register 0 (TPnCCR0)

If  $D_0$  is set to the TPnCCR0 register, the counter is cleared and a compare match interrupt request signal (INTTPnCC0) is generated when the number of external event counts reaches ( $D_0 + 1$ ).

## (g) TMPn capture/compare register 1 (TPnCCR1)

Usually, the TPnCCR1 register is not used in the external event count mode. However, the set value of the TPnCCR1 register is transferred to the CCR1 buffer register. When the count value of the 16-bit counter matches the value of the CCR1 buffer register, a compare match interrupt request signal (INTTPnCC1) is generated.

Therefore, mask the interrupt signal by using the interrupt mask flag (TPnCCMK1).

- **Remarks 1.** TMPn I/O control register 1 (TPnIOC1) and TMPn option register 0 (TPnOPT0) are not used in the external event count mode.
  - **2.** n = 0 to 5

## (1) External event count mode operation flow

Figure 7-12. Flow of Software Processing in External Event Count Mode



#### (2) Operation timing in external event count mode

- Cautions 1. In the external event count mode, do not set the TPnCCR0 register to 0000H.
  - 2. In the external event count mode, use of the timer output is disabled. If performing timer output using external event count input, set the interval timer mode, and select the operation enabled by the external event count input for the count clock (TPnCTL1.TPnMD2 to TPnCTL1.TPnMD0 bits = 000, TPnCTL1.TPnEEE bit = 1).

## (a) Operation if TPnCCR0 register is set to FFFFH

If the TPnCCR0 register is set to FFFFH, the 16-bit counter counts to FFFFH each time the valid edge of the external event count signal has been detected. The 16-bit counter is cleared to 0000H in synchronization with the next count-up timing, and the INTTPnCC0 signal is generated. At this time, the TPnOPT0.TPnOVF bit is not set.



#### (b) Notes on rewriting the TPnCCR0 register

To change the value of the TPnCCR0 register to a smaller value, stop counting once and then change the set value.

If the value of the TPnCCR0 register is rewritten to a smaller value during counting, the 16-bit counter may overflow.



If the value of the TPnCCR0 register is changed from  $D_1$  to  $D_2$  while the count value is greater than  $D_2$  but less than  $D_1$ , the count value is transferred to the CCR0 buffer register as soon as the TPnCCR0 register has been rewritten. Consequently, the value that is compared with the 16-bit counter is  $D_2$ .

Because the count value has already exceeded D<sub>2</sub>, however, the 16-bit counter counts up to FFFFH, overflows, and then counts up again from 0000H. When the count value matches D<sub>2</sub>, the INTTPnCC0 signal is generated.

Therefore, the INTTPnCC0 signal may not be generated at the valid edge count of " $(D_1 + 1)$  times" or " $(D_2 + 1)$  times" originally expected, but may be generated at the valid edge count of " $(10000H + D_2 + 1)$  times".

## (c) Operation of TPnCCR1 register

Figure 7-13. Configuration of TPnCCR1 Register



If the set value of the TPnCCR1 register is smaller than the set value of the TPnCCR0 register, the INTTPnCC1 signal is generated once per cycle.

Figure 7-14. Timing Chart When  $D_{01} \ge D_{11}$ 



If the set value of the TPnCCR1 register is greater than the set value of the TPnCCR0 register, the INTTPnCC1 signal is not generated because the count value of the 16-bit counter and the value of the TPnCCR1 register do not match.



Figure 7-15. Timing Chart When D<sub>01</sub> < D<sub>11</sub>

#### 7.5.3 External trigger pulse output mode (TPnMD2 to TPnMD0 bits = 010)

In the external trigger pulse output mode, 16-bit timer/event counter P waits for a trigger when the TPnCTL0.TPnCE bit is set to 1. When the valid edge of an external trigger input signal is detected, 16-bit timer/event counter P starts counting, and outputs a PWM waveform from the TOPn1 pin.

Pulses can also be output by generating a software trigger instead of using the external trigger. When using a software trigger, a square wave that has one cycle of the PWM waveform as half its cycle can also be output from the TOPn0 pin.



Figure 7-16. Configuration in External Trigger Pulse Output Mode



Figure 7-17. Basic Timing in External Trigger Pulse Output Mode

16-bit timer/event counter P waits for a trigger when the TPnCE bit is set to 1. When the trigger is generated, the 16-bit counter is cleared from FFFFH to 0000H, starts counting at the same time, and outputs a PWM wave\form from the TOPn1 pin. If the trigger is generated again while the counter is operating, the counter is cleared to 0000H and restarted. (The output of the TOPn0 pin is inverted. The TOPn1 pin outputs a high-level regardless of the status (high/low) when a trigger occurs.)

The active level width, cycle, and duty factor of the PWM waveform can be calculated as follows.

Active level width = (Set value of TPnCCR1 register) × Count clock cycle

Cycle = (Set value of TPnCCR0 register + 1) × Count clock cycle

Duty factor = (Set value of TPnCCR1 register)/(Set value of TPnCCR0 register + 1)

The compare match request signal INTTPnCC0 is generated when the 16-bit counter counts next time after its count value matches the value of the CCR0 buffer register, and the 16-bit counter is cleared to 0000H. The compare match interrupt request signal INTTPnCC1 is generated when the count value of the 16-bit counter matches the value of the CCR1 buffer register.

The value set to the TPnCCRm register is transferred to the CCRm buffer register when the count value of the 16-bit counter matches the value of the CCRm buffer register and the 16-bit counter is cleared to 0000H.

The valid edge of an external trigger input signal, or setting the software trigger (TPnCTL1.TPnEST bit) to 1 is used as the trigger.

**Remark** n = 0 to 5, m = 0, 1

Figure 7-18. Setting of Registers in External Trigger Pulse Output Mode (1/2)



Figure 7-18. Setting of Registers in External Trigger Pulse Output Mode (2/2)

#### (d) TMPn I/O control register 2 (TPnIOC2)

TPnEES1 TPnEES0 TPnETS1 TPnETS0

TPnIOC2 0 0 0 0 0 0/1 0/1 0/1 0/1

Select valid edge of external trigger input

Select valid edge of external event count input

## (e) TMPn counter read buffer register (TPnCNT)

The value of the 16-bit counter can be read by reading the TPnCNT register.

## (f) TMPn capture/compare registers 0 and 1 (TPnCCR0 and TPnCCR1)

If  $D_0$  is set to the TPnCCR0 register and  $D_1$  to the TPnCCR1 register, the cycle and active level of the PWM waveform are as follows.

 $\begin{aligned} & \text{Cycle} = (D_0 + 1) \times \text{Count clock cycle} \\ & \text{Active level width} = D_1 \times \text{Count clock cycle} \end{aligned}$ 

**Remarks 1.** TMPn I/O control register 1 (TPnIOC1) and TMPn option register 0 (TPnOPT0) are not used in the external trigger pulse output mode.

**2.** n = 0 to 5

## (1) Operation flow in external trigger pulse output mode

Figure 7-19. Software Processing Flow in External Trigger Pulse Output Mode (1/2)





Figure 7-19. Software Processing Flow in External Trigger Pulse Output Mode (2/2)

### (2) External trigger pulse output mode operation timing

## (a) Note on changing pulse width during operation

To change the PWM waveform while the counter is operating, write the TPnCCR1 register last.

Rewrite the TPnCCRm register after writing the TPnCCR1 register after the INTTPnCC0 signal is detected.



In order to transfer data from the TPnCCRm register to the CCRm buffer register, the TPnCCR1 register must be written.

To change both the cycle and active level width of the PWM waveform at this time, first set the cycle to the TPnCCR0 register and then set the active level width to the TPnCCR1 register.

To change only the cycle of the PWM waveform, first set the cycle to the TPnCCR0 register, and then write the same value to the TPnCCR1 register.

To change only the active level width (duty factor) of the PWM waveform, only the TPnCCR1 register has to be set.

After data is written to the TPnCCR1 register, the value written to the TPnCCRm register is transferred to the CCRm buffer register in synchronization with clearing of the 16-bit counter, and is used as the value compared with the 16-bit counter.

To write the TPnCCR0 or TPnCCR1 register again after writing the TPnCCR1 register once, do so after the INTTPnCC0 signal is generated. Otherwise, the value of the CCRm buffer register may become undefined because the timing of transferring data from the TPnCCRm register to the CCRm buffer register conflicts with writing the TPnCCRm register.

**Remark** n = 0 to 5 m = 0, 1

### (b) 0%/100% output of PWM waveform

To output a 0% waveform, set the TPnCCR1 register to 0000H. If the set value of the TPnCCR0 register is FFFFH, the INTTPnCC1 signal is generated periodically.



To output a 100% waveform, set a value of (set value of TPnCCR0 register + 1) to the TPnCCR1 register. If the set value of the TPnCCR0 register is FFFFH, 100% output cannot be produced.



### (c) Conflict between trigger detection and match with TPnCCR1 register

If the trigger is detected immediately after the INTTPnCC1 signal is generated, the 16-bit counter is immediately cleared to 0000H, the output signal of the TOPn1 pin is asserted, and the counter continues counting. Consequently, the inactive period of the PWM waveform is shortened.



If the trigger is detected immediately before the INTTPnCC1 signal is generated, the INTTPnCC1 signal is not generated, and the 16-bit counter is cleared to 0000H and continues counting. The output signal of the TOPn1 pin remains active. Consequently, the active period of the PWM waveform is extended.



### (d) Conflict between trigger detection and match with TPnCCR0 register

If the trigger is detected immediately after the INTTPnCC0 signal is generated, the 16-bit counter is cleared to 0000H and continues counting up. Therefore, the active period of the TOPn1 pin is extended by time from generation of the INTTPnCC0 signal to trigger detection.



If the trigger is detected immediately before the INTTPnCC0 signal is generated, the INTTPnCC0 signal is not generated. The 16-bit counter is cleared to 0000H, the TOPn1 pin is asserted, and the counter continues counting. Consequently, the inactive period of the PWM waveform is shortened.



### (e) Generation timing of compare match interrupt request signal (INTTPnCC1)

The timing of generation of the INTTPnCC1 signal in the external trigger pulse output mode differs from the timing of other INTTPnCC1 signals; the INTTPnCC1 signal is generated when the count value of the 16-bit counter matches the value of the TPnCCR1 register.



Usually, the INTTPnCC1 signal is generated in synchronization with the next count up, after the count value of the 16-bit counter matches the value of the TPnCCR1 register.

In the external trigger pulse output mode, however, it is generated one clock earlier. This is because the timing is changed to match the timing of changing the output signal of the TOPn1 pin.

### 7.5.4 One-shot pulse output mode (TPnMD2 to TPnMD0 bits = 011)

In the one-shot pulse output mode, 16-bit timer/event counter P waits for a trigger when the TPnCTL0.TPnCE bit is set to 1. When the valid edge of an external trigger input is detected, 16-bit timer/event counter P starts counting, and outputs a one-shot pulse from the TOPn1 pin.

Instead of the external trigger, a software trigger can also be generated to output the pulse. When the software trigger is used, the TOPn0 pin outputs the active level while the 16-bit counter is counting, and the inactive level when the counter is stopped (waiting for a trigger).



Figure 7-20. Configuration in One-Shot Pulse Output Mode



Figure 7-21. Basic Timing in One-Shot Pulse Output Mode

When the TPnCE bit is set to 1, 16-bit timer/event counter P waits for a trigger. When the trigger is generated, the 16-bit counter is cleared from FFFFH to 0000H, starts counting, and outputs a one-shot pulse from the TOPn1 pin. After the one-shot pulse is output, the 16-bit counter is set to FFFFH, stops counting, and waits for a trigger. If a trigger is generated again while the one-shot pulse is being output, it is ignored.

The output delay period and active level width of the one-shot pulse can be calculated as follows.

Output delay period = (Set value of TPnCCR1 register) × Count clock cycle

Active level width = (Set value of TPnCCR0 register – Set value of TPnCCR1 register + 1) × Count clock cycle

The compare match interrupt request signal INTTPnCC0 is generated when the 16-bit counter counts after its count value matches the value of the CCR0 buffer register. The compare match interrupt request signal INTTPnCC1 is generated when the count value of the 16-bit counter matches the value of the CCR1 buffer register.

The valid edge of an external trigger input or setting the software trigger (TPnCTL1.TPnEST bit) to 1 is used as the trigger.

**Remark** n = 0 to 5 m = 0, 1

Figure 7-22. Setting of Registers in One-Shot Pulse Output Mode (1/2)



Figure 7-22. Setting of Registers in One-Shot Pulse Output Mode (2/2)

## (d) TMPn I/O control register 2 (TPnIOC2)

TPnECS1 TPnEES0 TPnETS1 TPnETS0

TPnIOC2 0 0 0 0 0 0/1 0/1 0/1 0/1

Select valid edge of external trigger input

Select valid edge of external event count input

### (e) TMPn counter read buffer register (TPnCNT)

The value of the 16-bit counter can be read by reading the TPnCNT register.

# (f) TMPn capture/compare registers 0 and 1 (TPnCCR0 and TPnCCR1)

If  $D_0$  is set to the TPnCCR0 register and  $D_1$  to the TPnCCR1 register, the active level width and output delay period of the one-shot pulse are as follows.

Active level width =  $(D_1 - D_0 + 1) \times Count$  clock cycle

Output delay period =  $D_1 \times Count$  clock cycle

**Remarks 1.** TMPn I/O control register 1 (TPnIOC1) and TMPn option register 0 (TPnOPT0) are not used in the one-shot pulse output mode.

**2.** n = 0 to 5

### (1) Operation flow in one-shot pulse output mode

Figure 7-23. Software Processing Flow in One-Shot Pulse Output Mode



### (2) Operation timing in one-shot pulse output mode

### (a) Note on rewriting TPnCCRm register

To change the set value of the TPnCCRm register to a smaller value, stop counting once, and then change the set value.

If the value of the TPnCCRm register is rewritten to a smaller value during counting, the 16-bit counter may overflow.



When the TPnCCR0 register is rewritten from  $D_{00}$  to  $D_{01}$  and the TPnCCR1 register from  $D_{10}$  to  $D_{11}$  where  $D_{00} > D_{01}$  and  $D_{10} > D_{11}$ , if the TPnCCR1 register is rewritten when the count value of the 16-bit counter is greater than  $D_{11}$  and less than  $D_{10}$  and if the TPnCCR0 register is rewritten when the count value is greater than  $D_{01}$  and less than  $D_{00}$ , each set value is reflected as soon as the register has been rewritten and compared with the count value. The counter counts up to FFFFH and then counts up again from 0000H. When the count value matches  $D_{11}$ , the counter generates the INTTPnCC1 signal and asserts the TOPn1 pin. When the count value matches  $D_{01}$ , the counter generates the INTTPnCC0 signal, deasserts the TOPn1 pin, and stops counting.

Therefore, the counter may output a pulse with a delay period or active period different from that of the one-shot pulse that is originally expected.

**Remark** 
$$n = 0 \text{ to } 5$$
  $m = 0, 1$ 

### (b) Generation timing of compare match interrupt request signal (INTTPnCC1)

The generation timing of the INTTPnCC1 signal in the one-shot pulse output mode is different from other INTTPnCC1 signals; the INTTPnCC1 signal is generated when the count value of the 16-bit counter matches the value of the TPnCCR1 register.



Usually, the INTTPnCC1 signal is generated when the 16-bit counter counts up next time after its count value matches the value of the TPnCCR1 register.

In the one-shot pulse output mode, however, it is generated one clock earlier. This is because the timing is changed to match the change timing of the TOPn1 pin.

**Remark** n = 0 to 5

## 7.5.5 PWM output mode (TPnMD2 to TPnMD0 bits = 100)

In the PWM output mode, a PWM waveform is output from the TOPn1 pin when the TPnCTL0.TPnCE bit is set to 1. In addition, a pulse with one cycle of the PWM waveform as half its cycle is output from the TOPn0 pin.



Figure 7-24. Configuration in PWM Output Mode



Figure 7-25. Basic Timing in PWM Output Mode

When the TPnCE bit is set to 1, the 16-bit counter is cleared from FFFFH to 0000H, starts counting, and outputs a PWM waveform from the TOPn1 pin.

The active level width, cycle, and duty factor of the PWM waveform can be calculated as follows.

```
Active level width = (Set value of TPnCCR1 register ) \times Count clock cycle Cycle = (Set value of TPnCCR0 register + 1) \times Count clock cycle Duty factor = (Set value of TPnCCR1 register)/(Set value of TPnCCR0 register + 1)
```

The PWM waveform can be changed by rewriting the TPnCCRm register while the counter is operating. The newly written value is reflected when the count value of the 16-bit counter matches the value of the CCR0 buffer register and the 16-bit counter is cleared to 0000H.

The compare match interrupt request signal INTTPnCC0 is generated when the 16-bit counter counts next time after its count value matches the value of the CCR0 buffer register, and the 16-bit counter is cleared to 0000H. The compare match interrupt request signal INTTPnCC1 is generated when the count value of the 16-bit counter matches the value of the CCR1 buffer register.

The value set to the TPnCCRm register is transferred to the CCRm buffer register when the count value of the 16-bit counter matches the value of the CCRm buffer register and the 16-bit counter is cleared to 0000H.

**Remark** n = 0 to 5, m = 0, 1

Figure 7-26. Setting of Registers in PWM Output Mode (1/2)



Figure 7-26. Register Setting in PWM Output Mode (2/2)

### (d) TMPn I/O control register 2 (TPnIOC2)



### (e) TMPn counter read buffer register (TPnCNT)

The value of the 16-bit counter can be read by reading the TPnCNT register.

### (f) TMPn capture/compare registers 0 and 1 (TPnCCR0 and TPnCCR1)

If  $D_0$  is set to the TPnCCR0 register and  $D_1$  to the TPnCCR1 register, the cycle and active level of the PWM waveform are as follows.

$$\label{eq:cycle} \begin{split} & \text{Cycle} = (D_0 + 1) \times \text{Count clock cycle} \\ & \text{Active level width} = D_1 \times \text{Count clock cycle} \end{split}$$

**Remarks 1.** TMPn I/O control register 1 (TPnIOC1) and TMPn option register 0 (TPnOPT0) are not used in the PWM output mode.

**2.** n = 0 to 5

## (1) Operation flow in PWM output mode

Figure 7-27. Software Processing Flow in PWM Output Mode (1/2)



<3> TPnCCR0, TPnCCR1 register <1> Count operation start flow setting change flow Only writing of the TPnCCR1 **START** register must be performed when the set duty factor is changed. When the counter is cleared after setting, the Setting of TPnCCR1 register value of compare register m Initial setting of these is transferred to the CCRm Register initial setting registers is performed buffer register. TPnCTL0 register before setting the (TPnCKS0 to TPnCKS2 bits) TPnCE bit to 1. TPnCTL1 register, TPnIOC0 register, TPnIOC2 register, TPnCCR0 register, TPnCCR1 register <4> TPnCCR0, TPnCCR1 register setting change flow The TPnCKS0 to TPnCKS2 bits can be set at the same time TPnCE bit = 1 when counting is When the counter is enabled (TPnCE bit = 1). cleared after setting. Setting of TPnCCR0 register the value of the TPnCCRm register is transferred to the CCRm buffer register. Setting of TPnCCR1 register <2> TPnCCR0, TPnCCR1 register setting change flow <5> Count operation stop flow TPnCCR1 write TPnCE bit = 0 Counting is stopped. Setting of TPnCCR0 register processing is necessary only when the set cycle is changed. When the counter is STOP Setting of TPnCCR1 register cleared after setting, the value of the TPnCCRm register is transferred to the CCRm buffer register. **Remark** n = 0 to 5m = 0, 1

Figure 7-27. Software Processing Flow in PWM Output Mode (2/2)

### (2) PWM output mode operation timing

### (a) Changing pulse width during operation

To change the PWM waveform while the counter is operating, write the TPnCCR1 register last.

Rewrite the TPnCCRm register after writing the TPnCCR1 register after the INTTPnCC1 signal is detected.



To transfer data from the TPnCCRm register to the CCRm buffer register, the TPnCCR1 register must be written.

To change both the cycle and active level of the PWM waveform at this time, first set the cycle to the TPnCCR0 register and then set the active level to the TPnCCR1 register.

To change only the cycle of the PWM waveform, first set the cycle to the TPnCCR0 register, and then write the same value to the TPnCCR1 register.

To change only the active level width (duty factor) of the PWM waveform, only the TPnCCR1 register has to be set.

After data is written to the TPnCCR1 register, the value written to the TPnCCRm register is transferred to the CCRm buffer register in synchronization with clearing of the 16-bit counter, and is used as the value compared with the 16-bit counter.

To write the TPnCCR0 or TPnCCR1 register again after writing the TPnCCR1 register once, do so after the INTTPnCC0 signal is generated. Otherwise, the value of the CCRm buffer register may become undefined because the timing of transferring data from the TPnCCRm register to the CCRm buffer register conflicts with writing the TPnCCRm register.

**Remark** n = 0 to 5, m = 0, 1

### (b) 0%/100% output of PWM waveform

To output a 0% waveform, set the TPnCCR1 register to 0000H. If the set value of the TPnCCR0 register is FFFFH, the INTTPnCC1 signal is generated periodically.



To output a 100% waveform, set a value of (set value of TPnCCR0 register + 1) to the TPnCCR1 register. If the set value of the TPnCCR0 register is FFFFH, 100% output cannot be produced.



### (c) Generation timing of compare match interrupt request signal (INTTPnCC1)

The timing of generation of the INTTPnCC1 signal in the PWM output mode differs from the timing of other INTTPnCC1 signals; the INTTPnCC1 signal is generated when the count value of the 16-bit counter matches the value of the TPnCCR1 register.



Usually, the INTTPnCC1 signal is generated in synchronization with the next counting up after the count value of the 16-bit counter matches the value of the TPnCCR1 register.

In the PWM output mode, however, it is generated one clock earlier. This is because the timing is changed to match the change timing of the output signal of the TOPn1 pin.

### 7.5.6 Free-running timer mode (TPnMD2 to TPnMD0 bits = 101)

In the free-running timer mode, 16-bit timer/event counter P starts counting when the TPnCTL0.TPnCE bit is set to 1. At this time, the TPnCCRm register can be used as a compare register or a capture register, depending on the setting of the TPnOPT0.TPnCCS0 and TPnOPT0.TPnCCS1 bits.



Figure 7-28. Configuration in Free-Running Timer Mode

When the TPnCE bit is set to 1, 16-bit timer/event counter P starts counting, and the output signals of the TOPn0 and TOPn1 pins are inverted. When the count value of the 16-bit counter later matches the set value of the TPnCCRm register, a compare match interrupt request signal (INTTPnCCm) is generated, and the output signal of the TOPnm pin is inverted.

The 16-bit counter continues counting in synchronization with the count clock. When it counts up to FFFFH, it generates an overflow interrupt request signal (INTTPnOV) at the next clock, is cleared to 0000H, and continues counting. At this time, the overflow flag (TPnOPT0.TPnOVF bit) is also set to 1. Clear the overflow flag to 0 by executing the CLR instruction by software.

The TPnCCRm register can be rewritten while the counter is operating. If it is rewritten, the new value is reflected at that time, and compared with the count value.



Figure 7-29. Basic Timing in Free-Running Timer Mode (Compare Function)

When the TPnCE bit is set to 1, the 16-bit counter starts counting. When the valid edge input to the TIPnm pin is detected, the count value of the 16-bit counter is stored in the TPnCCRm register, and a capture interrupt request signal (INTTPnCCm) is generated.

The 16-bit counter continues counting in synchronization with the count clock. When it counts up to FFFFH, it generates an overflow interrupt request signal (INTTPnOV) at the next clock, is cleared to 0000H, and continues counting. At this time, the overflow flag (TPnOPT0.TPnOVF bit) is also set to 1. Clear the overflow flag to 0 by executing the CLR instruction by software.



Figure 7-30. Basic Timing in Free-Running Timer Mode (Capture Function)

Figure 7-31. Register Setting in Free-Running Timer Mode (1/2)



Figure 7-31. Register Setting in Free-Running Timer Mode (2/2)



## (1) Operation flow in free-running timer mode

## (a) When using capture/compare register as compare register

Figure 7-32. Software Processing Flow in Free-Running Timer Mode (Compare Function) (1/2)



Figure 7-32. Software Processing Flow in Free-Running Timer Mode (Compare Function) (2/2)



## (b) When using capture/compare register as capture register

Figure 7-33. Software Processing Flow in Free-Running Timer Mode (Capture Function) (1/2)



Figure 7-33. Software Processing Flow in Free-Running Timer Mode (Capture Function) (2/2)



### (2) Operation timing in free-running timer mode

## (a) Interval operation with compare register

When 16-bit timer/event counter P is used as an interval timer with the TPnCCRm register used as a compare register, software processing is necessary for setting a comparison value to generate the next interrupt request signal each time the INTTPnCCm signal has been detected.



When performing an interval operation in the free-running timer mode, two intervals can be set with one channel.

To perform the interval operation, the value of the corresponding TPnCCRm register must be re-set in the interrupt servicing that is executed when the INTTPnCCm signal is detected.

The set value for re-setting the TPnCCRm register can be calculated by the following expression, where " $D_m$ " is the interval period.

Compare register default value: Dm - 1

Value set to compare register second and subsequent time: Previous set value + Dm

(If the calculation result is greater than FFFFH, subtract 10000H from the result and set this value to the register.)

**Remark** n = 0 to 5m = 0, 1

### (b) Pulse width measurement with capture register

When pulse width measurement is performed with the TPnCCRm register used as a capture register, software processing is necessary for reading the capture register each time the INTTPnCCm signal has been detected and for calculating an interval.



When executing pulse width measurement in the free-running timer mode, two pulse widths can be measured with one channel.

To measure a pulse width, the pulse width can be calculated by reading the value of the TPnCCRm register in synchronization with the INTTPnCCm signal, and calculating the difference between the read value and the previously read value.

**Remark** 
$$n = 0 \text{ to } 5$$
  
 $m = 0, 1$ 

### (c) Processing of overflow when two capture registers are used

Care must be exercised in processing the overflow flag when two capture registers are used. First, an example of incorrect processing is shown below.



The following problem may occur when two pulse widths are measured in the free-running timer mode.

- <1> Read the TPnCCR0 register (setting of the default value of the TIPn0 pin input).
- <2> Read the TPnCCR1 register (setting of the default value of the TIPn1 pin input).
- <3> Read the TPnCCR0 register.

Read the overflow flag. If the overflow flag is 1, clear it to 0.

Because the overflow flag is 1, the pulse width can be calculated by  $(10000H + D_{01} - D_{00})$ .

<4> Read the TPnCCR1 register.

Read the overflow flag. Because the flag is cleared in <3>, 0 is read.

Because the overflow flag is 0, the pulse width can be calculated by  $(D_{11} - D_{10})$  (incorrect).

When two capture registers are used, and if the overflow flag is cleared to 0 by one capture register, the other capture register may not obtain the correct pulse width.

Use software when using two capture registers. An example of how to use software is shown below.





Note The TPnOVF0 and TPnOVF1 flags are set on the internal RAM by software.

- <1> Read the TPnCCR0 register (setting of the default value of the TIPn0 pin input).
- <2> Read the TPnCCR1 register (setting of the default value of the TIPn1 pin input).
- <3> An overflow occurs. Set the TPnOVF0 and TPnOVF1 flags to 1 in the overflow interrupt servicing, and clear the overflow flag to 0.
- <4> Read the TPnCCR0 register.
  - Read the TPnOVF0 flag. If the TPnOVF0 flag is 1, clear it to 0.
  - Because the TPnOVF0 flag is 1, the pulse width can be calculated by  $(10000H + D_{01} D_{00})$ .
- <5> Read the TPnCCR1 register.
  - Read the TPnOVF1 flag. If the TPnOVF1 flag is 1, clear it to 0 (the TPnOVF0 flag is cleared in <4>, and the TPnOVF1 flag remains 1).
  - Because the TPnOVF1 flag is 1, the pulse width can be calculated by  $(10000H + D_{11} D_{10})$  (correct).
- <6> Same as <3>





Note The TPnOVF0 and TPnOVF1 flags are set on the internal RAM by software.

- <1> Read the TPnCCR0 register (setting of the default value of the TIPn0 pin input).
- <2> Read the TPnCCR1 register (setting of the default value of the TIPn1 pin input).
- <3> An overflow occurs. Nothing is done by software.
- <4> Read the TPnCCR0 register.

Read the overflow flag. If the overflow flag is 1, set only the TPnOVF1 flag to 1, and clear the overflow flag to 0.

Because the overflow flag is 1, the pulse width can be calculated by  $(10000H + D_{01} - D_{00})$ .

<5> Read the TPnCCR1 register.

Read the overflow flag. Because the overflow flag is cleared in <4>, 0 is read.

Read the TPnOVF1 flag. If the TPnOVF1 flag is 1, clear it to 0.

Because the TPnOVF1 flag is 1, the pulse width can be calculated by  $(10000H + D_{11} - D_{10})$  (correct).

<6> Same as <3>

## (d) Processing of overflow if capture trigger interval is long

If the pulse width is greater than one cycle of the 16-bit counter, care must be exercised because an overflow may occur more than once from the first capture trigger to the next. First, an example of incorrect processing is shown below.



The following problem may occur when long pulse width is measured in the free-running timer mode.

- <1> Read the TPnCCRm register (setting of the default value of the TIPnm pin input).
- <2> An overflow occurs. Nothing is done by software.
- <3> An overflow occurs a second time. Nothing is done by software.
- <4> Read the TPnCCRm register.

Read the overflow flag. If the overflow flag is 1, clear it to 0.

Because the overflow flag is 1, the pulse width can be calculated by (10000H +  $D_{m1}$  -  $D_{m0}$ ) (incorrect).

Actually, the pulse width must be (20000H + D<sub>m1</sub> - D<sub>m0</sub>) because an overflow occurs twice.

If an overflow occurs twice or more when the capture trigger interval is long, the correct pulse width may not be obtained.

If the capture trigger interval is long, slow the count clock to lengthen one cycle of the 16-bit counter, or use software. An example of how to use software is shown next.



**Note** The overflow counter is set arbitrarily by software on the internal RAM.

- <1> Read the TPnCCRm register (setting of the default value of the TIPnm pin input).
- <2> An overflow occurs. Increment the overflow counter and clear the overflow flag to 0 in the overflow interrupt servicing.
- <3> An overflow occurs a second time. Increment (+1) the overflow counter and clear the overflow flag to 0 in the overflow interrupt servicing.
- <4> Read the TPnCCRm register.

Read the overflow counter.

 $\rightarrow$  When the overflow counter is "N", the pulse width can be calculated by (N  $\times$  10000H + D<sub>m1</sub> - D<sub>m0</sub>).

In this example, the pulse width is  $(20000H + D_{m1} - D_{m0})$  because an overflow occurs twice. Clear the overflow counter (0H).

## (e) Clearing overflow flag

The overflow flag can be cleared to 0 by clearing the TPnOVF bit to 0 with the CLR instruction and by writing 8-bit data (bit 0 is 0) to the TPnOPT0 register. To accurately detect an overflow, read the TPnOVF bit when it is 1, and then clear the overflow flag by using a bit manipulation instruction.



To clear the overflow flag to 0, read the overflow flag to check if it is set to 1, and clear it with the CLR instruction. If 0 is written to the overflow flag without checking if the flag is 1, the set information of overflow may be erased by writing 0 ((ii) in the above chart). Therefore, software may judge that no overflow has occurred even when an overflow actually has occurred.

If execution of the CLR instruction conflicts with occurrence of an overflow when the overflow flag is cleared to 0 with the CLR instruction, the overflow flag remains set even after execution of the clear instruction.

## 7.5.7 Pulse width measurement mode (TPnMD2 to TPnMD0 bits = 110)

In the pulse width measurement mode, 16-bit timer/event counter P starts counting when the TPnCTL0.TPnCE bit is set to 1. Each time the valid edge input to the TIPnm pin has been detected, the count value of the 16-bit counter is stored in the TPnCCRm register, and the 16-bit counter is cleared to 0000H.

The interval of the valid edge can be measured by reading the TPnCCRm register after a capture interrupt request signal (INTTPnCCm) occurs.

Select either the TIPn0 or TIPn1 pin as the capture trigger input pin. Specify "No edge detected" by using the TPnIOC1 register for the unused pins.

When an external clock is used as the count clock, measure the pulse width of the TIPn1 pin because the external clock is fixed to the TIPn0 pin. At this time, clear the TPnIOC1.TPnIS1 and TPnIOC1.TPnIS0 bits to 00 (capture trigger input (TIPn0 pin): No edge detected).



Figure 7-34. Configuration in Pulse Width Measurement Mode



Figure 7-35. Basic Timing in Pulse Width Measurement Mode

When the TPnCE bit is set to 1, the 16-bit counter starts counting. When the valid edge input to the TIPnm pin is later detected, the count value of the 16-bit counter is stored in the TPnCCRm register, the 16-bit counter is cleared to 0000H, and a capture interrupt request signal (INTTPnCCm) is generated.

The pulse width is calculated as follows.

Pulse width = Captured value × Count clock cycle

If the valid edge is not input to the TIPnm pin even when the 16-bit counter counted up to FFFFH, an overflow interrupt request signal (INTTPnOV) is generated at the next count clock, and the counter is cleared to 0000H and continues counting. At this time, the overflow flag (TPnOPT0.TPnOVF bit) is also set to 1. Clear the overflow flag to 0 by executing the CLR instruction via software.

If the overflow flag is set to 1, the pulse width can be calculated as follows.

Pulse width = (10000H × TPnOVF bit set (1) count + Captured value) × Count clock cycle

**Remark** 
$$n = 0 \text{ to } 5$$
  
 $m = 0, 1$ 

Figure 7-36. Register Setting in Pulse Width Measurement Mode (1/2)



Figure 7-36. Register Setting in Pulse Width Measurement Mode (2/2)

# (e) TMPn option register 0 (TPnOPT0)



# (f) TMPn counter read buffer register (TPnCNT)

The value of the 16-bit counter can be read by reading the TPnCNT register.

## (g) TMPn capture/compare registers 0 and 1 (TPnCCR0 and TPnCCR1)

These registers store the count value of the 16-bit counter when the valid edge input to the TIPnm pin is detected.

Remarks 1. TMPn I/O control register 0 (TPnIOC0) is not used in the pulse width measurement mode.

**2.** n = 0 to 5

m = 0, 1

## (1) Operation flow in pulse width measurement mode

Figure 7-37. Software Processing Flow in Pulse Width Measurement Mode



## (2) Operation timing in pulse width measurement mode

## (a) Clearing overflow flag

The overflow flag can be cleared to 0 by clearing the TPnOVF bit to 0 with the CLR instruction and by writing 8-bit data (bit 0 is 0) to the TPnOPT0 register. To accurately detect an overflow, read the TPnOVF bit when it is 1, and then clear the overflow flag by using a bit manipulation instruction.



To clear the overflow flag to 0, read the overflow flag to check if it is set to 1, and clear it with the CLR instruction. If 0 is written to the overflow flag without checking if the flag is 1, the set information of overflow may be erased by writing 0 ((ii) in the above chart). Therefore, software may judge that no overflow has occurred even when an overflow actually has occurred.

If execution of the CLR instruction conflicts with occurrence of an overflow when the overflow flag is cleared to 0 with the CLR instruction, the overflow flag remains set even after execution of the clear instruction.

# 7.5.8 Timer output operations

The following table shows the operations and output levels of the TOPn0 and TOPn1 pins.

Table 7-4. Timer Output Control in Each Mode

| Operation Mode                     | TOPn1 Pin                         | TOPn0 Pin               |
|------------------------------------|-----------------------------------|-------------------------|
| Interval timer mode                | Square wave output                |                         |
| External event count mode          | Square wave output                | _                       |
| External trigger pulse output mode | External trigger pulse output     | Square wave output      |
| One-shot pulse output mode         | One-shot pulse output             |                         |
| PWM output mode                    | PWM output                        |                         |
| Free-running timer mode            | Square wave output (only when con | npare function is used) |
| Pulse width measurement mode       |                                   | -                       |

**Remark** n = 0 to 5

Table 7-5. Truth Table of TOPn0 and TOPn1 Pins Under Control of Timer Output Control Bits

| TPnIOC0.TPnOLm Bit | TPnIOC0.TPnOEm Bit | TPnCTL0.TPnCE Bit | Level of TOPnm Pin                                                          |
|--------------------|--------------------|-------------------|-----------------------------------------------------------------------------|
| 0                  | 0                  | ×                 | Low-level output                                                            |
|                    | 1                  | 0                 | Low-level output                                                            |
|                    |                    | 1                 | Low level immediately before counting, high level after counting is started |
| 1                  | 0                  | ×                 | High-level output                                                           |
|                    | 1                  | 0                 | High-level output                                                           |
|                    |                    | 1                 | High level immediately before counting, low level after counting is started |

**Remark** n = 0 to 5 m = 0, 1

#### 7.6 Selector Function

In the V850ES/SG2, the TIP input/RXDA input and the TIQ input/TSOUT signal can be used to select the capture trigger input of TMP and TMQ, respectively.

By using this function, the following is possible.

- The TIQ02 input signal of TMQ0 can be selected from the port/timer alternate-function pins (TIQ02 pin) and the TSOUT signal of the CAN controller.
  - $\rightarrow$  If the TSOUT signal of CAN0 is selected, the time stamp function of the CAN controller can be used.
- The TIP10 and TIP11 input signals of TMP1 can be selected from the port/timer alternate-function pins (TIP10 and TIP11 pins) and the UARTA reception alternate-function pins (RXDA0 and RXDA1).
  - → When the RXDA0 or RXDA1 signal of UART0 or UART1 is selected, the LIN reception transfer rate and baud rate error of UARTA can be calculated.
  - Cautions 1. When using the selector function, set the capture trigger input of TMP or TMQ before connecting the timer.
    - 2. When setting the selector function, first disable the peripheral I/O to be connected (TMP/UARTA or TMQ/CAN controller).

The capture input for the selector function is specified by the following register.

## (1) Selector operation control register 0 (SELCNT0)

The SELCNT0 register is an 8-bit register that selects the capture trigger for TMP1, TMP3, and TMQ0.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.



**Note** The ISEL0 bit is valid only for the CAN controller version.

0

1

Cautions 1. To set the ISEL0, ISEL3, and ISEL4 bits to 1, set the corresponding pin in the capture input mode.

2. Be sure to clear bits 7 to 5 and 2 and 1 to 0.

TIQ02 pin input

TSOUT signal of CAN0

## 7.7 Cautions

## (1) Capture operation

When the capture operation is used and a slow clock is selected as the count clock, FFFFH, not 0000H, may be captured in the TPnCCR0 and TPnCCR1 registers if the capture trigger is input immediately after the TPnCE bit is set to 1.



# CHAPTER 8 16-BIT TIMER/EVENT COUNTER Q (TMQ)

Timer Q (TMQ) is a 16-bit timer/event counter. The V850ES/SG2 incorporates TMQ0.

## 8.1 Overview

An outline of TMQ0 is shown below.

| Clock selection:                                                     | 8 ways |
|----------------------------------------------------------------------|--------|
| Capture/trigger input pins:                                          | 4      |
| <ul> <li>External event count input pins:</li> </ul>                 | 1      |
| External trigger input pins:                                         | 1      |
| Timer/counters:                                                      | 1      |
| Capture/compare registers:                                           | 4      |
| <ul> <li>Capture/compare match interrupt request signals:</li> </ul> | 4      |
| Timer output pins:                                                   | 4      |

## 8.2 Functions

TMQ0 has the following functions.

- Interval timer
- External event counter
- External trigger pulse output
- One-shot pulse output
- PWM output
- Free-running timer
- Pulse width measurement

## 8.3 Configuration

TMQ0 includes the following hardware.

Item Configuration

Timer register 16-bit counter

Registers TMQ0 capture/compare registers 0 to 3 (TQ0CCR0 to TQ0CCR3) TMQ0 counter read buffer register (TQ0CNT) CCR0 to CCR3 buffer registers

Timer inputs 4 (TIQ00<sup>Note 1</sup> to TIQ03 pins)

Timer outputs 4 (TOQ00 to TOQ03 pins)

Control registers<sup>Note 2</sup> TMQ0 control registers 0, 1 (TQ0CTL0, TQ0CTL1) TMQ0 I/O control registers 0 to 2 (TQ0IOC0 to TQ0IOC2)

Table 8-1. Configuration of TMQ0

**Notes 1.** The TIQ00 pin functions alternately as a capture trigger input signal, external event count input signal, and external trigger input signal.

TMQ0 option register 0 (TQ0OPT0)

2. When using the functions of the TIQ00 to TIQ03 and TOQ00 to TOQ03 pins, see **Table 4-15 Using** Port Pin as Alternate-Function Pin.



Figure 8-1. Block Diagram of TMQ0

#### (1) 16-bit counter

This 16-bit counter can count internal clocks or external events.

The count value of this counter can be read by using the TQ0CNT register.

When the TQ0CTL0.TQ0CE bit = 0, the value of the 16-bit counter is FFFFH. If the TQ0CNT register is read at this time, 0000H is read.

Reset input clears the TQ0CE bit to 0. Therefore, the 16-bit counter is set to FFFFH.

#### (2) CCR0 buffer register

This is a 16-bit compare register that compares the count value of the 16-bit counter.

When the TQ0CCR0 register is used as a compare register, the value written to the TQ0CCR0 register is transferred to the CCR0 buffer register. When the count value of the 16-bit counter matches the value of the CCR0 buffer register, a compare match interrupt request signal (INTTQ0CC0) is generated.

The CCR0 buffer register cannot be read or written directly.

The CCR0 buffer register is cleared to 0000H after reset, as the TQ0CCR0 register is cleared to 0000H.

## (3) CCR1 buffer register

This is a 16-bit compare register that compares the count value of the 16-bit counter.

When the TQ0CCR1 register is used as a compare register, the value written to the TQ0CCR1 register is transferred to the CCR1 buffer register. When the count value of the 16-bit counter matches the value of the CCR1 buffer register, a compare match interrupt request signal (INTTQ0CC1) is generated.

The CCR1 buffer register cannot be read or written directly.

The CCR1 buffer register is cleared to 0000H after reset, as the TQ0CCR1 register is cleared to 0000H.

#### (4) CCR2 buffer register

This is a 16-bit compare register that compares the count value of the 16-bit counter.

When the TQ0CCR2 register is used as a compare register, the value written to the TQ0CCR2 register is transferred to the CCR2 buffer register. When the count value of the 16-bit counter matches the value of the CCR2 buffer register, a compare match interrupt request signal (INTTQ0CC2) is generated.

The CCR2 buffer register cannot be read or written directly.

The CCR2 buffer register is cleared to 0000H after reset, as the TQ0CCR2 register is cleared to 0000H.

#### (5) CCR3 buffer register

This is a 16-bit compare register that compares the count value of the 16-bit counter.

When the TQ0CCR3 register is used as a compare register, the value written to the TQ0CCR3 register is transferred to the CCR3 buffer register. When the count value of the 16-bit counter matches the value of the CCR3 buffer register, a compare match interrupt request signal (INTTQ0CC3) is generated.

The CCR3 buffer register cannot be read or written directly.

The CCR3 buffer register is cleared to 0000H after reset, as the TQ0CCR3 register is cleared to 0000H.

## (6) Edge detector

This circuit detects the valid edges input to the TIQ00 and TIQ03 pins. No edge, rising edge, falling edge, or both the rising and falling edges can be selected as the valid edge by using the TQ0IOC1 and TQ0IOC2 registers.

#### (7) Output controller

This circuit controls the output of the TOQ00 to TOQ03 pins. The output controller is controlled by the TQ0IOC0 register.

# (8) Selector

This selector selects the count clock for the 16-bit counter. Eight types of internal clocks or an external event can be selected as the count clock.

## 8.4 Registers

The registers that control TMQ0 are as follows.

- TMQ0 control register 0 (TQ0CTL0)
- TMQ0 control register 1 (TQ0CTL1)
- TMQ0 I/O control register 0 (TQ0IOC0)
- TMQ0 I/O control register 1 (TQ0IOC1)
- TMQ0 I/O control register 2 (TQ0IOC2)
- TMQ0 option register 0 (TQ0OPT0)
- TMQ0 capture/compare register 0 (TQ0CCR0)
- TMQ0 capture/compare register 1 (TQ0CCR1)
- TMQ0 capture/compare register 2 (TQ0CCR2)
- TMQ0 capture/compare register 3 (TQ0CCR3)
- TMQ0 counter read buffer register (TQ0CNT)

Remark When using the functions of the TIQ00 to TIQ03 and TOQ00 to TOQ03 pins, see Table 4-15 Using Port Pin as Alternate-Function Pin.

# (1) TMQ0 control register 0 (TQ0CTL0)

The TQ0CTL0 register is an 8-bit register that controls the operation of TMQ0.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

The same value can always be written to the TQ0CTL0 register by software.

| After res | et: 00H | R/W | Address: | FFFFF54 | HOH |         |         |         |
|-----------|---------|-----|----------|---------|-----|---------|---------|---------|
|           | <7>     | 6   | 5        | 4       | 3   | 2       | 1       | 0       |
| TQ0CTL0   | TQ0CE   | 0   | 0        | 0       | 0   | TQ0CKS2 | TQ0CKS1 | TQ0CKS0 |

| TQ0CE | TMQ0 operation control                                                |
|-------|-----------------------------------------------------------------------|
| 0     | TMQ0 operation disabled (TMQ0 reset asynchronously <sup>Note</sup> ). |
| 1     | TMQ0 operation enabled. TMQ0 operation started.                       |

| TQ0CKS2 | TQ0CKS1 | TQ0CKS0 | Internal count clock selection |
|---------|---------|---------|--------------------------------|
| 0       | 0       | 0       | fxx                            |
| 0       | 0       | 1       | fxx/2                          |
| 0       | 1       | 0       | fxx/4                          |
| 0       | 1       | 1       | fxx/8                          |
| 1       | 0       | 0       | fxx/16                         |
| 1       | 0       | 1       | fxx/32                         |
| 1       | 1       | 0       | fxx/64                         |
| 1       | 1       | 1       | fxx/128                        |

Note TQ00PT0.TQ00VF bit, 16-bit counter, timer output (TOQ00 to TOQ03 pins)

Cautions 1. Set the TQ0CKS2 to TQ0CKS0 bits when the TQ0CE bit = 0.

When the value of the TQ0CE bit is changed from 0 to 1, the TQ0CKS2 to TQ0CKS0 bits can be set simultaneously.

2. Be sure to clear bits 3 to 6 to 0.

Remark fxx: Main clock frequency

## (2) TMQ0 control register 1 (TQ0CTL1)

The TQ0CTL1 register is an 8-bit register that controls the operation of TMQ0.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

 After reset: 00H
 R/W
 Address:
 FFFFF541H

 7
 <6>
 <5>
 4
 3
 2
 1
 0

 TQ0CTL1
 0
 TQ0EST
 TQ0EEE
 0
 0
 TQ0MD2
 TQ0MD1
 TQ0MD0

| TQ0EST | Software trigger control                                                                                                                                                                                                                                                           |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | <del>-</del>                                                                                                                                                                                                                                                                       |
| 1      | Generate a valid signal for external trigger input.  In one-shot pulse output mode: A one-shot pulse is output with writing  1 to the TQ0EST bit as the trigger.  In external trigger pulse output mode: A PWM waveform is output with writing 1 to the TQ0EST bit as the trigger. |

| TQ0EEE  | Count clock selection                                                                                                                     |  |  |  |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0       | Disable operation with external event count input. (Perform counting with the count clock selected by the TQ0CTL0.TQ0CK0 to TQ0CK2 bits.) |  |  |  |
| 1       | Enable operation with external event count input. (Perform counting at the valid edge of the external event count input signal.)          |  |  |  |
| The TOO | The TOOFEE hit colocts whether counting is performed with the internal count clock                                                        |  |  |  |

The TQ0EEE bit selects whether counting is performed with the internal count clock or the valid edge of the external event count input.

| TQ0MD2 | TQ0MD1 | TQ0MD0 | Timer mode selection               |
|--------|--------|--------|------------------------------------|
| 0      | 0      | 0      | Interval timer mode                |
| 0      | 0      | 1      | External event count mode          |
| 0      | 1      | 0      | External trigger pulse output mode |
| 0      | 1      | 1      | One-shot pulse output mode         |
| 1      | 0      | 0      | PWM output mode                    |
| 1      | 0      | 1      | Free-running timer mode            |
| 1      | 1      | 0      | Pulse width measurement mode       |
| 1      | 1      | 1      | Setting prohibited                 |

- Cautions 1. The TQ0EST bit is valid only in the external trigger pulse output mode or one-shot pulse output mode. In any other mode, writing 1 to this bit is ignored.
  - 2. External event count input is selected in the external event count mode regardless of the value of the TQ0EEE bit.
  - 3. Set the TQ0EEE and TQ0MD2 to TQ0MD0 bits when the TQ0CTL0.TQ0CE bit = 0. (The same value can be written when the TQ0CE bit = 1.) The operation is not guaranteed when rewriting is performed with the TQ0CE bit = 1. If rewriting was mistakenly performed, clear the TQ0CE bit to 0 and then set the bits again.
  - 4. Be sure to clear bits 3, 4, and 7 to 0.

## (3) TMQ0 I/O control register 0 (TQ0IOC0)

The TQ0IOC0 register is an 8-bit register that controls the timer output (TOQ00 to TOQ03 pins).

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

 After reset: 00H
 R/W
 Address:
 FFFFF542H

 7
 <6>
 5
 <4>
 3
 <2>
 1
 <0>

 TQ0IOC0
 TQ0OL3
 TQ0OE3
 TQ0OL2
 TQ0OE2
 TQ0OL1
 TQ0OE1
 TQ0OL0
 TQ0OE0

| TQ0OLm | TOQ0m pin output level setting (m = 0 to 3) |  |
|--------|---------------------------------------------|--|
| 0      | TOQ0m pin output inversion disabled         |  |
| 1      | TOQ0m pin output inversion enabled          |  |

| TQ00Em | TOQ0m pin output setting (m = 0 to 3)                                                                                                                |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | Timer output disabled  • When TQ00Lm bit = 0: Low level is output from the TOQ0m pin  • When TQ00Lm bit = 1: High level is output from the TOQ0m pin |
| 1      | Timer output enabled (A square wave is output from the TOQ0m pin).                                                                                   |

- Cautions 1. Rewrite the TQ00Lm and TQ00Em bits when the TQ0CTL0.TQ0CE bit = 0. (The same value can be written when the TQ0CE bit = 1.) If rewriting was mistakenly performed, clear the TQ0CE bit to 0 and then set the bits again.
  - 2. Even if the TQ0OLm bit is manipulated when the TQ0CE and TQ0OEm bits are 0, the TOQ0m pin output level varies.

**Remark** m = 0 to 3

# (4) TMQ0 I/O control register 1 (TQ0IOC1)

The TQ0IOC1 register is an 8-bit register that controls the valid edge of the capture trigger input signals (TIQ00 to TIQ03 pins).

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

After reset: 00H R/W Address: FFFF543H 7 6 5 4 3 1 0 TQ0IOC1 TQ0IS7 TQ0IS6 TQ0IS5 TQ0IS4 TQ0IS3 TQ0IS2 TQ0IS1 TQ0IS0

| TQ0IS7 | TQ0IS6 | Capture trigger input signal (TIQ03 pin) valid edge setting |
|--------|--------|-------------------------------------------------------------|
| 0      | 0      | No edge detection (capture operation invalid)               |
| 0      | 1      | Detection of rising edge                                    |
| 1      | 0      | Detection of falling edge                                   |
| 1      | 1      | Detection of both edges                                     |

| TQ0IS5 | TQ0IS4 | Capture trigger input signal (TIQ02 pin) valid edge detection |
|--------|--------|---------------------------------------------------------------|
| 0      | 0      | No edge detection (capture operation invalid)                 |
| 0      | 1      | Detection of rising edge                                      |
| 1      | 0      | Detection of falling edge                                     |
| 1      | 1      | Detection of both edges                                       |

| TQ0IS3 | TQ0IS2 | Capture trigger input signal (TIQ01 pin) valid edge setting |
|--------|--------|-------------------------------------------------------------|
| 0      | 0      | No edge detection (capture operation invalid)               |
| 0      | 1      | Detection of rising edge                                    |
| 1      | 0      | Detection of falling edge                                   |
| 1      | 1      | Detection of both edges                                     |

| TQ0IS1 | TQ0IS0 | Capture trigger input signal (TIQ00 pin) valid edge setting |
|--------|--------|-------------------------------------------------------------|
| 0      | 0      | No edge detection (capture operation invalid)               |
| 0      | 1      | Detection of rising edge                                    |
| 1      | 0      | Detection of falling edge                                   |
| 1      | 1      | Detection of both edges                                     |

- Cautions 1. Rewrite the TQ0IS7 to TQ0IS0 bits when the TQ0CTL0.TQ0CE bit = 0. (The same value can be written when the TQ0CE bit = 1.) If rewriting was mistakenly performed, clear the TQ0CE bit to 0 and then set the bits again.
  - 2. The TQ0IS7 to TQ0IS0 bits are valid only in the free-running timer mode and the pulse width measurement mode. In all other modes, a capture operation is not possible.

## (5) TMQ0 I/O control register 2 (TQ0IOC2)

The TQ0IOC2 register is an 8-bit register that controls the valid edge of the external event count input signal (TIQ00 pin) and external trigger input signal (TIQ00 pin).

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

| After res | et: 00H | R/W | Address: | FFFFF54 | 14H     |         |         |         |
|-----------|---------|-----|----------|---------|---------|---------|---------|---------|
|           | 7       | 6   | 5        | 4       | 3       | 2       | 1       | 0       |
| TQ0IOC2   | 0       | 0   | 0        | 0       | TQ0EES1 | TQ0EES0 | TQ0ETS1 | TQ0ETS0 |

| TQ0EES1 | TQ0EES0 | External event count input signal (TIQ00 pin) valid edge setting |
|---------|---------|------------------------------------------------------------------|
| 0       | 0       | No edge detection (external event count invalid)                 |
| 0       | 1       | Detection of rising edge                                         |
| 1       | 0       | Detection of falling edge                                        |
| 1       | 1       | Detection of both edges                                          |

| TQ0ETS1 | TQ0ETS0 | External trigger input signal (TIQ00 pin) valid edge setting |
|---------|---------|--------------------------------------------------------------|
| 0       | 0       | No edge detection (external trigger invalid)                 |
| 0       | 1       | Detection of rising edge                                     |
| 1       | 0       | Detection of falling edge                                    |
| 1       | 1       | Detection of both edges                                      |

- Cautions 1. Rewrite the TQ0EES1, TQ0EES0, TQ0ETS1, and TQ0ETS0 bits when the TQ0CTL0.TQ0CE bit = 0. (The same value can be written when the TQ0CE bit = 1.) If rewriting was mistakenly performed, clear the TQ0CE bit to 0 and then set the bits again.
  - The TQ0EES1 and TQ0EES0 bits are valid only when the TQ0CTL1.TQ0EEE bit = 1 or when the external event count mode (TQ0CTL1.TQ0MD2 to TQ0CTL1.TQ0MD0 bits = 001) has been set.
  - 3. The TQ0ETS1 and TQ0ETS0 bits are valid only when the external trigger pulse output mode (TQ0CTL1.TQ0MD2 to TQ0CTL1.TQ0MD0 bits = 010) or the one-shot pulse output mode (TQ0CTL1.TQ0MD2 to TQ0CTL1.TQ0MD0 = 011) is set.

## (6) TMQ0 option register 0 (TQ0OPT0)

The TQ0OPT0 register is an 8-bit register used to set the capture/compare operation and detect an overflow. This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

After reset: 00H R/W Address: FFFF545H

7 6 5 4 3 2 1 <0>
TQ0OPT0 TQ0CCS3 TQ0CCS2 TQ0CCS1 TQ0CCS0 0 0 TQ0OVF

| TQ0CCSm | TQ0CCRm register capture/compare selection                            |  |  |  |  |  |  |  |
|---------|-----------------------------------------------------------------------|--|--|--|--|--|--|--|
| 0       | Compare register selected                                             |  |  |  |  |  |  |  |
| 1       | 1 Capture register selected                                           |  |  |  |  |  |  |  |
| The TQ0 | The TQ0CCSm bit setting is valid only in the free-running timer mode. |  |  |  |  |  |  |  |

| TQ0OVF    | TMQ0 overflow detection                       |
|-----------|-----------------------------------------------|
| Set (1)   | Overflow occurred                             |
| Reset (0) | TQ0OVF bit 0 written or TQ0CTL0.TQ0CE bit = 0 |

- The TQ0OVF bit is reset when the 16-bit counter count value overflows from FFFFH to 0000H in the free-running timer mode or the pulse width measurement mode.
- An interrupt request signal (INTTQ0OV) is generated at the same time that the TQ0OVF bit is set to 1. The INTTQ0OV signal is not generated in modes other than the free-running timer mode and the pulse width measurement mode.
- The TQ0OVF bit is not cleared even when the TQ0OVF bit or the TQ0OPT0 register are read when the TQ0OVF bit = 1.
- The TQ0OVF bit can be both read and written, but the TQ0OVF bit cannot be set to 1 by software. Writing 1 has no influence on the operation of TMQ0.
- Cautions 1. Rewrite the TQ0CCS3 to TQ0CCS0 bits when the TQ0CTL0.TQ0CE bit = 0. (The same value can be written when the TQ0CE bit = 1.) If rewriting was mistakenly performed, clear the TQ0CE bit to 0 and then set the bits again.
  - 2. Be sure to clear bits 1 to 3 to 0.

**Remark** m = 0 to 3

## (7) TMQ0 capture/compare register 0 (TQ0CCR0)

The TQ0CCR0 register can be used as a capture register or a compare register depending on the mode.

This register can be used as a capture register or a compare register only in the free-running timer mode, depending on the setting of the TQ0OPT0.TQ0CCS0 bit. In the pulse width measurement mode, the TQ0CCR0 register can be used only as a capture register. In any other mode, this register can be used only as a compare register.

The TQ0CCR0 register can be read or written during operation.

This register can be read or written in 16-bit units.

Reset input clears this register to 0000H.

Caution Accessing the TQ0CCR0 register is prohibited in the following statuses. For details, see 3.4.9 (2) Accessing specific on-chip peripheral I/O registers.

- When the CPU operates with the subclock and the main clock oscillation is stopped
- When the CPU operates with the internal oscillation clock

| TQ0CCR0 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | After res | set: 0 | 000H | F  | R/W | Ad | dress | : F | FFFF | 546H | ł |   |   |   |   |   |   |
|-----------------------------------------------|-----------|--------|------|----|-----|----|-------|-----|------|------|---|---|---|---|---|---|---|
| TQ0CCR0                                       |           | 15     | 14   | 13 | 12  | 11 | 10    | 9   | 8    | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|                                               | TQ0CCR0   |        |      |    |     |    |       |     |      |      |   |   |   |   |   |   |   |

#### (a) Function as compare register

The TQ0CCR0 register can be rewritten even when the TQ0CTL0.TQ0CE bit = 1.

The set value of the TQ0CCR0 register is transferred to the CCR0 buffer register. When the value of the 16-bit counter matches the value of the CCR0 buffer register, a compare match interrupt request signal (INTTQ0CC0) is generated. If TOQ00 pin output is enabled at this time, the output of the TOQ00 pin is inverted.

When the TQ0CCR0 register is used as a cycle register in the interval timer mode, external event count mode, external trigger pulse output mode, one-shot pulse output mode, or PWM output mode, the value of the 16-bit counter is cleared (0000H) if its count value matches the value of the CCR0 buffer register.

## (b) Function as capture register

When the TQ0CCR0 register is used as a capture register in the free-running timer mode, the count value of the 16-bit counter is stored in the TQ0CCR0 register if the valid edge of the capture trigger input pin (TIQ00 pin) is detected. In the pulse-width measurement mode, the count value of the 16-bit counter is stored in the TQ0CCR0 register and the 16-bit counter is cleared (0000H) if the valid edge of the capture trigger input pin (TIQ00 pin) is detected.

Even if the capture operation and reading the TQ0CCR0 register conflict, the correct value of the TQ0CCR0 register can be read.

The following table shows the functions of the capture/compare register in each mode, and how to write data to the compare register.

Table 8-2. Function of Capture/Compare Register in Each Mode and How to Write Compare Register

| Operation Mode                | Capture/Compare Register | How to Write Compare Register |
|-------------------------------|--------------------------|-------------------------------|
| Interval timer                | Compare register         | Anytime write                 |
| External event counter        | Compare register         | Anytime write                 |
| External trigger pulse output | Compare register         | Batch write                   |
| One-shot pulse output         | Compare register         | Anytime write                 |
| PWM output                    | Compare register         | Batch write                   |
| Free-running timer            | Capture/compare register | Anytime write                 |
| Pulse width measurement       | Capture register         | -                             |

## (8) TMQ0 capture/compare register 1 (TQ0CCR1)

The TQ0CCR1 register can be used as a capture register or a compare register depending on the mode.

This register can be used as a capture register or a compare register only in the free-running timer mode, depending on the setting of the TQ0OPT0.TQ0CCS1 bit. In the pulse width measurement mode, the TQ0CCR1 register can be used only as a capture register. In any other mode, this register can be used only as a compare register.

The TQ0CCR1 register can be read or written during operation.

This register can be read or written in 16-bit units.

Reset input clears this register to 0000H.

Caution Accessing the TQ0CCR1 register is prohibited in the following statuses. For details, see 3.4.9 (2) Accessing specific on-chip peripheral I/O registers.

- When the CPU operates with the subclock and the main clock oscillation is stopped
- When the CPU operates with the internal oscillation clock

| TQ0CCR1 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | After res | set: 0 | 000H | F  | R/W | Ad | dress: | : F | FFFF | :548H | ļ |   |   |   |   |   |   |
|-----------------------------------------------|-----------|--------|------|----|-----|----|--------|-----|------|-------|---|---|---|---|---|---|---|
| TQ0CCR1                                       |           | 15     | 14   | 13 | 12  | 11 | 10     | 9   | 8    | 7     | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|                                               | TQ0CCR1   |        |      |    |     |    |        |     |      |       |   |   |   |   |   |   |   |

## (a) Function as compare register

The TQ0CCR1 register can be rewritten even when the TQ0CTL0.TQ0CE bit = 1.

The set value of the TQ0CCR1 register is transferred to the CCR1 buffer register. When the value of the 16-bit counter matches the value of the CCR1 buffer register, a compare match interrupt request signal (INTTQ0CC1) is generated. If TOQ01 pin output is enabled at this time, the output of the TOQ01 pin is inverted.

#### (b) Function as capture register

When the TQ0CCR1 register is used as a capture register in the free-running timer mode, the count value of the 16-bit counter is stored in the TQ0CCR1 register if the valid edge of the capture trigger input pin (TIQ01 pin) is detected. In the pulse-width measurement mode, the count value of the 16-bit counter is stored in the TQ0CCR1 register and the 16-bit counter is cleared (0000H) if the valid edge of the capture trigger input pin (TIQ01 pin) is detected.

Even if the capture operation and reading the TQ0CCR1 register conflict, the correct value of the TQ0CCR1 register can be read.

The following table shows the functions of the capture/compare register in each mode, and how to write data to the compare register.

Table 8-3. Function of Capture/Compare Register in Each Mode and How to Write Compare Register

| Operation Mode                | Capture/Compare Register | How to Write Compare Register |
|-------------------------------|--------------------------|-------------------------------|
| Interval timer                | Compare register         | Anytime write                 |
| External event counter        | Compare register         | Anytime write                 |
| External trigger pulse output | Compare register         | Batch write                   |
| One-shot pulse output         | Compare register         | Anytime write                 |
| PWM output                    | Compare register         | Batch write                   |
| Free-running timer            | Capture/compare register | Anytime write                 |
| Pulse width measurement       | Capture register         | -                             |

## (9) TMQ0 capture/compare register 2 (TQ0CCR2)

The TQ0CCR2 register can be used as a capture register or a compare register depending on the mode.

This register can be used as a capture register or a compare register only in the free-running timer mode, depending on the setting of the TQ0OPT0.TQ0CCS2 bit. In the pulse width measurement mode, the TQ0CCR2 register can be used only as a capture register. In any other mode, this register can be used only as a compare register.

The TQ0CCR2 register can be read or written during operation.

This register can be read or written in 16-bit units.

Reset input clears this register to 0000H.

Caution Accessing the TQ0CCR2 register is prohibited in the following statuses. For details, see 3.4.9 (2) Accessing specific on-chip peripheral I/O registers.

- When the CPU operates with the subclock and the main clock oscillation is stopped
- When the CPU operates with the internal oscillation clock

| TQ0CCR2 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | After res | set: 0 | 000H | F  | R/W | Ad | dress | : F | FFFF | -54AH | 1 |   |   |   |   |   |   |
|-----------------------------------------------|-----------|--------|------|----|-----|----|-------|-----|------|-------|---|---|---|---|---|---|---|
| TQ0CCR2                                       |           | 15     | 14   | 13 | 12  | 11 | 10    | 9   | 8    | 7     | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|                                               | TQ0CCR2   |        |      |    |     |    |       |     |      |       |   |   |   |   |   |   |   |

## (a) Function as compare register

The TQ0CCR2 register can be rewritten even when the TQ0CTL0.TQ0CE bit = 1.

The set value of the TQ0CCR2 register is transferred to the CCR2 buffer register. When the value of the 16-bit counter matches the value of the CCR2 buffer register, a compare match interrupt request signal (INTTQ0CC2) is generated. If TOQ02 pin output is enabled at this time, the output of the TOQ02 pin is inverted.

## (b) Function as capture register

When the TQ0CCR2 register is used as a capture register in the free-running timer mode, the count value of the 16-bit counter is stored in the TQ0CCR2 register if the valid edge of the capture trigger input pin (TIQ02 pin) is detected. In the pulse-width measurement mode, the count value of the 16-bit counter is stored in the TQ0CCR2 register and the 16-bit counter is cleared (0000H) if the valid edge of the capture trigger input pin (TIQ02 pin) is detected.

Even if the capture operation and reading the TQ0CCR2 register conflict, the correct value of the TQ0CCR2 register can be read.

The following table shows the functions of the capture/compare register in each mode, and how to write data to the compare register.

Table 8-4. Function of Capture/Compare Register in Each Mode and How to Write Compare Register

| Operation Mode                | Capture/Compare Register | How to Write Compare Register |
|-------------------------------|--------------------------|-------------------------------|
| Interval timer                | Compare register         | Anytime write                 |
| External event counter        | Compare register         | Anytime write                 |
| External trigger pulse output | Compare register         | Batch write                   |
| One-shot pulse output         | Compare register         | Anytime write                 |
| PWM output                    | Compare register         | Batch write                   |
| Free-running timer            | Capture/compare register | Anytime write                 |
| Pulse width measurement       | Capture register         | -                             |

## (10) TMQ0 capture/compare register 3 (TQ0CCR3)

The TQ0CCR3 register can be used as a capture register or a compare register depending on the mode.

This register can be used as a capture register or a compare register only in the free-running timer mode, depending on the setting of the TQ0OPT0.TQ0CCS3 bit. In the pulse width measurement mode, the TQ0CCR3 register can be used only as a capture register. In any other mode, this register can be used only as a compare register.

The TQ0CCR3 register can be read or written during operation.

This register can be read or written in 16-bit units.

Reset input clears this register to 0000H.

Caution Accessing the TQ0CCR3 register is prohibited in the following statuses. For details, see 3.4.9 (2) Accessing specific on-chip peripheral I/O registers.

- When the CPU operates with the subclock and the main clock oscillation is stopped
- When the CPU operates with the internal oscillation clock

| TQ0CCR3 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | After res | set: 0 | 000H | F  | R/W | Ad | dress | : F | FFFF | 54CH | 1 |   |   |   |   |   |   |
|-----------------------------------------------|-----------|--------|------|----|-----|----|-------|-----|------|------|---|---|---|---|---|---|---|
| TQ0CCR3                                       |           | 15     | 14   | 13 | 12  | 11 | 10    | 9   | 8    | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|                                               | TQ0CCR3   |        |      |    |     |    |       |     |      |      |   |   |   |   |   |   |   |

## (a) Function as compare register

The TQ0CCR3 register can be rewritten even when the TQ0CTL0.TQ0CE bit = 1.

The set value of the TQ0CCR3 register is transferred to the CCR3 buffer register. When the value of the 16-bit counter matches the value of the CCR3 buffer register, a compare match interrupt request signal (INTTQ0CC3) is generated. If TOQ03 pin output is enabled at this time, the output of the TOQ03 pin is inverted.

#### (b) Function as capture register

When the TQ0CCR3 register is used as a capture register in the free-running timer mode, the count value of the 16-bit counter is stored in the TQ0CCR3 register if the valid edge of the capture trigger input pin (TIQ03 pin) is detected. In the pulse-width measurement mode, the count value of the 16-bit counter is stored in the TQ0CCR3 register and the 16-bit counter is cleared (0000H) if the valid edge of the capture trigger input pin (TIQ03 pin) is detected.

Even if the capture operation and reading the TQ0CCR3 register conflict, the correct value of the TQ0CCR3 register can be read.

The following table shows the functions of the capture/compare register in each mode, and how to write data to the compare register.

Table 8-5. Function of Capture/Compare Register in Each Mode and How to Write Compare Register

| Operation Mode                | Capture/Compare Register | How to Write Compare Register |
|-------------------------------|--------------------------|-------------------------------|
| Interval timer                | Compare register         | Anytime write                 |
| External event counter        | Compare register         | Anytime write                 |
| External trigger pulse output | Compare register         | Batch write                   |
| One-shot pulse output         | Compare register         | Anytime write                 |
| PWM output                    | Compare register         | Batch write                   |
| Free-running timer            | Capture/compare register | Anytime write                 |
| Pulse width measurement       | Capture register         | -                             |

## (11) TMQ0 counter read buffer register (TQ0CNT)

The TQ0CNT register is a read buffer register that can read the count value of the 16-bit counter.

If this register is read when the TQ0CTL0.TQ0CE bit = 1, the count value of the 16-bit timer can be read.

This register is read-only, in 16-bit units.

The value of the TQ0CNT register is cleared to 0000H when the TQ0CE bit = 0. If the TQ0CNT register is read at this time, the value of the 16-bit counter (FFFFH) is not read, but 0000H is read.

The value of the TQ0CNT register is cleared to 0000H after reset, as the TQ0CE bit is cleared to 0.

# Caution Accessing the TQ0CNT register is prohibited in the following statuses. For details, see 3.4.9 (2) Accessing specific on-chip peripheral I/O registers.

- When the CPU operates with the subclock and the main clock oscillation is stopped
- When the CPU operates with the internal oscillation clock



# 8.5 Operation

TMQ0 can perform the following operations.

| Operation                                            | TQ0CTL1.TQ0EST Bit (Software Trigger Bit) | TIQ00 Pin<br>(External Trigger Input) | Capture/Compare<br>Register Setting | Compare Register<br>Write |
|------------------------------------------------------|-------------------------------------------|---------------------------------------|-------------------------------------|---------------------------|
| Interval timer mode                                  | Invalid                                   | Invalid                               | Compare only                        | Anytime write             |
| External event count mode <sup>Note 1</sup>          | Invalid                                   | Invalid                               | Compare only                        | Anytime write             |
| External trigger pulse output mode <sup>Note 2</sup> | Valid                                     | Valid                                 | Compare only                        | Batch write               |
| One-shot pulse output mode <sup>Note 2</sup>         | Valid                                     | Valid                                 | Compare only                        | Anytime write             |
| PWM output mode                                      | Invalid                                   | Invalid                               | Compare only                        | Batch write               |
| Free-running timer mode                              | Invalid                                   | Invalid                               | Switching enabled                   | Anytime write             |
| Pulse width measurement mode <sup>Note 2</sup>       | Invalid                                   | Invalid                               | Capture only                        | Not applicable            |

- **Notes 1.** To use the external event count mode, specify that the valid edge of the TIQ00 pin capture trigger input is not detected (by clearing the TQ0IOC1.TQ0IS1 and TQ0IOC1.TQ0IS0 bits to "00").
  - 2. When using the external trigger pulse output mode, one-shot pulse output mode, and pulse width measurement mode, select the internal clock as the count clock (by clearing the TQ0CTL1.TQ0EEE bit to 0).

## 8.5.1 Interval timer mode (TQ0MD2 to TQ0MD0 bits = 000)

In the interval timer mode, an interrupt request signal (INTTQ0CC0) is generated at the specified interval if the TQ0CTL0.TQ0CE bit is set to 1. A square wave whose half cycle is equal to the interval can be output from the TQQ00 pin.

Usually, the TQ0CCR1 to TQ0CCR3 registers are not used in the interval timer mode.



Figure 8-2. Configuration of Interval Timer





When the TQ0CE bit is set to 1, the value of the 16-bit counter is cleared from FFFFH to 0000H in synchronization with the count clock, and the counter starts counting. At this time, the output of the TQ000 pin is inverted. Additionally, the set value of the TQ0CCR0 register is transferred to the CCR0 buffer register.

When the count value of the 16-bit counter matches the value of the CCR0 buffer register, the 16-bit counter is cleared to 0000H, the output of the TOQ00 pin is inverted, and a compare match interrupt request signal (INTTQ0CC0) is generated.

The interval can be calculated by the following expression.

Interval = (Set value of TQ0CCR0 register + 1) × Count clock cycle

Figure 8-4. Register Setting for Interval Timer Mode Operation (1/2)



(c) TMQ0 I/O control register 0 (TQ0IOC0) TQ00L3 TQ00E3 TQ00L2 TQ00E2 TQ00L1 TQ00E1 TQ00L0 TQ00E0 TQ0IOC0 0/1 0/1  $\Omega/1$ 0/1 0/1 0/1 0/1 0/1 0: Disable TOQ00 pin output 1: Enable TOQ00 pin output Setting of output level with operation of TOQ00 pin disabled 0: Low level 1: High level 0: Disable TOQ01 pin output 1: Enable TOQ01 pin output Setting of output level with operation of TOQ01 pin disabled 0: Low level 1: High level 0: Disable TOQ02 pin output 1: Enable TOQ02 pin output Setting of output level with operation of TOQ02 pin disabled 0: Low level 1: High level 0: Disable TOQ03 pin output 1: Enable TOQ03 pin output Setting of output level with operation of TOQ03 pin disabled 0: Low level 1: High level (d) TMQ0 counter read buffer register (TQ0CNT) By reading the TQ0CNT register, the count value of the 16-bit counter can be read.

Figure 8-4. Register Setting for Interval Timer Mode Operation (2/2)

### (e) TMQ0 capture/compare register 0 (TQ0CCR0)

If the TQ0CCR0 register is set to Do, the interval is as follows.

Interval =  $(D_0 + 1) \times Count clock cycle$ 

# (f) TMQ0 capture/compare registers 1 to 3 (TQ0CCR1 to TQ0CCR3)

Usually, the TQ0CCR1 to TQ0CCR3 registers are not used in the interval timer mode. However, the set value of the TQ0CCR1 to TQ0CCR3 registers are transferred to the CCR1 to CCR3 buffer registers. The compare match interrupt request signals (INTTQ0CC1 to INTTQ0CCR3) is generated when the count value of the 16-bit counter matches the value of the CCR1 to CCR3 buffer registers.

Therefore, mask the interrupt request by using the corresponding interrupt mask flags (TQ0CCMK1 to TQ0CCMK3).

**Remark** TMQ0 I/O control register 1 (TQ0IOC1), TMQ0 I/O control register 2 (TQ0IOC2), and TMQ0 option register 0 (TQ0OPT0) are not used in the interval timer mode.

# (1) Interval timer mode operation flow

Figure 8-5. Software Processing Flow in Interval Timer Mode



### (2) Interval timer mode operation timing

# (a) Operation if TQ0CCR0 register is set to 0000H

If the TQ0CCR0 register is set to 0000H, the INTTQ0CC0 signal is generated at each count clock of the second clock or later, and the output of the TOQ00 pin is inverted.

The value of the 16-bit counter is always 0000H.



### (b) Operation if TQ0CCR0 register is set to FFFFH

If the TQ0CCR0 register is set to FFFFH, the 16-bit counter counts up to FFFFH. The counter is cleared to 0000H in synchronization with the next count-up timing. The INTTQ0CC0 signal is generated and the output of the TOQ00 pin is inverted. At this time, an overflow interrupt request signal (INTTQ0OV) is not generated, nor is the overflow flag (TQ0OPT0.TQ0OVF bit) set to 1.



### (c) Notes on rewriting TQ0CCR0 register

To change the value of the TQ0CCR0 register to a smaller value, stop counting once and then change the set value.

If the value of the TQ0CCR0 register is rewritten to a smaller value during counting, the 16-bit counter may overflow.



If the value of the TQ0CCR0 register is changed from  $D_1$  to  $D_2$  while the count value is greater than  $D_2$  but less than  $D_1$ , the count value is transferred to the CCR0 buffer register as soon as the TQ0CCR0 register has been rewritten. Consequently, the value of the 16-bit counter that is compared is  $D_2$ .

Because the count value has already exceeded D<sub>2</sub>, however, the 16-bit counter counts up to FFFFH, overflows, and then counts up again from 0000H. When the count value matches D<sub>2</sub>, the INTTQ0CC0 signal is generated and the output of the TOQ00 pin is inverted.

Therefore, the INTTQ0CC0 signal may not be generated at the interval time " $(D_1 + 1) \times$  Count clock cycle" or " $(D_2 + 1) \times$  Count clock cycle" originally expected, but may be generated at an interval of " $(10000H + D_2 + 1) \times$  Count clock period".

# (d) Operation of TQ0CCR1 to TQ0CCR3 registers

Figure 8-6. Configuration of TQ0CCR1 to TQ0CCR3 Registers



If the set value of the TQ0CCRk register is less than the set value of the TQ0CCR0 register, the INTTQ0CCk signal is generated once per cycle. At the same time, the output of the TOPQ0k pin is inverted.

The TOQ0k pin outputs a square wave with the same cycle as that output by the TOQ00 pin.

**Remark** k = 1 to 3

Figure 8-7. Timing Chart When  $D_{01} \ge D_{k1}$ 



If the set value of the TQ0CCRk register is greater than the set value of the TQ0CCR0 register, the count value of the 16-bit counter does not match the value of the TQ0CCRk register. Consequently, the INTTQ0CCk signal is not generated, nor is the output of the TQQ0k pin changed.

**Remark** k = 1 to 3

Figure 8-8. Timing Chart When  $D_{01} < D_{k1}$ 



### 8.5.2 External event count mode (TQ0MD2 to TQ0MD0 bits = 001)

In the external event count mode, the valid edge of the external event count input is counted when the TQ0CTL0.TQ0CE bit is set to 1, and an interrupt request signal (INTTQ0CC0) is generated each time the specified number of edges have been counted. The TQQ00 pin cannot be used.

Usually, the TQ0CCR1 to TQ0CCR3 registers are not used in the external event count mode.



Figure 8-9. Configuration in External Event Count Mode





When the TQ0CE bit is set to 1, the value of the 16-bit counter is cleared from FFFFH to 0000H. The counter counts each time the valid edge of external event count input is detected. Additionally, the set value of the TQ0CCR0 register is transferred to the CCR0 buffer register.

When the count value of the 16-bit counter matches the value of the CCR0 buffer register, the 16-bit counter is cleared to 0000H, and a compare match interrupt request signal (INTTQ0CC0) is generated.

The INTTQ0CC0 signal is generated each time the valid edge of the external event count input has been detected (set value of TQ0CCR0 register + 1) times.

Figure 8-11. Register Setting for Operation in External Event Count Mode (1/2)



Figure 8-11. Register Setting for Operation in External Event Count Mode (2/2)

# (f) TMQ0 capture/compare register 0 (TQ0CCR0)

If  $D_0$  is set to the TQ0CCR0 register, the counter is cleared and a compare match interrupt request signal (INTTQ0CC0) is generated when the number of external event counts reaches ( $D_0 + 1$ ).

# (g) TMQ0 capture/compare registers 1 to 3 (TQ0CCR1 to TQ0CCR3)

Usually, the TQ0CCR1 to TQ0CCR3 registers are not used in the external event count mode. However, the set value of the TQ0CCR1 to TQ0CCR3 registers are transferred to the CCR1 to CCR3 buffer registers. When the count value of the 16-bit counter matches the value of the CCR1 to CCR3 buffer registers, compare match interrupt request signals (INTTQ0CC1 to INTTQ0CC3) are generated. Therefore, mask the interrupt signal by using the interrupt mask flags (TQ0CCMK1 to TQ0CCMK3).

**Remark** The TMQ0 I/O control register 1 (TQ0IOC1) and TMQ0 option register 0 (TQ0OPT0) are not used in the external event count mode.

# (1) External event count mode operation flow

Figure 8-12. Flow of Software Processing in External Event Count Mode



### (2) Operation timing in external event count mode

- Cautions 1. In the external event count mode, do not set the TQ0CCR0 register to 0000H.
  - 2. In the external event count mode, use of the timer output is disabled. If performing timer output using external event count input, set the interval timer mode, and select the operation enabled by the external event count input for the count clock (TQ0CTL1.TQ0MD2 to TQ0CTL1.TQ0MD0 bits = 000, TQ0CTL1.TQ0EEE bit = 1).

### (a) Operation if TQ0CCR0 register is set to FFFFH

If the TQ0CCR0 register is set to FFFFH, the 16-bit counter counts to FFFFH each time the valid edge of the external event count signal has been detected. The 16-bit counter is cleared to 0000H in synchronization with the next count-up timing, and the INTTQ0CC0 signal is generated. At this time, the TQ0OPT0.TQ0OVF bit is not set.



### (b) Notes on rewriting the TQ0CCR0 register

To change the value of the TQ0CCR0 register to a smaller value, stop counting once and then change the set value.

If the value of the TQ0CCR0 register is rewritten to a smaller value during counting, the 16-bit counter may overflow.



If the value of the TQ0CCR0 register is changed from  $D_1$  to  $D_2$  while the count value is greater than  $D_2$  but less than  $D_1$ , the count value is transferred to the CCR0 buffer register as soon as the TQ0CCR0 register has been rewritten. Consequently, the value that is compared with the 16-bit counter is  $D_2$ .

Because the count value has already exceeded D<sub>2</sub>, however, the 16-bit counter counts up to FFFFH, overflows, and then counts up again from 0000H. When the count value matches D<sub>2</sub>, the INTTQ0CC0 signal is generated.

Therefore, the INTTQ0CC0 signal may not be generated at the valid edge count of " $(D_1 + 1)$  times" or " $(D_2 + 1)$  times" originally expected, but may be generated at the valid edge count of " $(10000H + D_2 + 1)$  times".

# (c) Operation of TQ0CCR1 to TQ0CCR3 registers

Figure 8-13. Configuration of TQ0CCR1 to TQ0CCR3 Registers



If the set value of the TQ0CCRk register is smaller than the set value of the TQ0CCR0 register, the INTTQ0CCk signal is generated once per cycle.

### **Remark** k = 1 to 3

Figure 8-14. Timing Chart When  $D_{01} \ge D_{k1}$ 



If the set value of the TQ0CCRk register is greater than the set value of the TQ0CCR0 register, the INTTQ0CCk signal is not generated because the count value of the 16-bit counter and the value of the TQ0CCRk register do not match.

**Remark** k = 1 to 3

Figure 8-15. Timing Chart When  $D_{01} < D_{k1}$ 



### 8.5.3 External trigger pulse output mode (TQ0MD2 to TQ0MD0 bits = 010)

In the external trigger pulse output mode, 16-bit timer/event counter Q waits for a trigger when the TQ0CTL0.TQ0CE bit is set to 1. When the valid edge of an external trigger input signal is detected, 16-bit timer/event counter Q starts counting, and outputs a PWM waveform from the TOQ01 to TOQ03 pins.

Pulses can also be output by generating a software trigger instead of using the external trigger. When using a software trigger, a square wave that has one cycle of the PWM waveform as half its cycle can also be output from the TOQ00 pin.



Figure 8-16. Configuration in External Trigger Pulse Output Mode



Figure 8-17. Basic Timing in External Trigger Pulse Output Mode

16-bit timer/event counter Q waits for a trigger when the TQ0CE bit is set to 1. When the trigger is generated, the 16-bit counter is cleared from FFFFH to 0000H, starts counting at the same time, and outputs a PWM waveform from the TOQ0k pin. If the trigger is generated again while the counter is operating, the counter is cleared to 0000H and restarted. (The output of the TOQ00 pin is inverted. The TOQ0k pin outputs a high-level regardless of the status (high/low) when a trigger is generated.)

The active level width, cycle, and duty factor of the PWM waveform can be calculated as follows.

```
Active level width = (Set value of TQ0CCRk register) × Count clock cycle

Cycle = (Set value of TQ0CCR0 register + 1) × Count clock cycle

Duty factor = (Set value of TQ0CCRk register)/(Set value of TQ0CCR0 register + 1)
```

The compare match request signal INTTQ0CC0 is generated when the 16-bit counter counts next time after its count value matches the value of the CCR0 buffer register, and the 16-bit counter is cleared to 0000H. The compare match interrupt request signal INTTQ0CCk is generated when the count value of the 16-bit counter matches the value of the CCRk buffer register.

The value set to the TQ0CCRm register is transferred to the CCRm buffer register when the count value of the 16-bit counter matches the value of the CCR0 buffer register and the 16-bit counter is cleared to 0000H.

The valid edge of an external trigger input signal, or setting the software trigger (TQ0CTL1.TQ0EST bit) to 1 is used as the trigger.

```
Remark k = 1 \text{ to } 3
m = 0 \text{ to } 3
```

Figure 8-18. Setting of Registers in External Trigger Pulse Output Mode (1/3)



(b) TMQ0 control register 1 (TQ0CTL1) TQ0EST TQ0EEE TQ0MD2 TQ0MD1 TQ0MD0 TQ0CTL1 0 0 0 0 0, 1, 0: External trigger pulse output mode 0: Operate on count clock selected by TQ0CKS0 to TQ0CKS2 bits 1: Count with external event input signal Generate software trigger when 1 is written (c) TMQ0 I/O control register 0 (TQ0IOC0) TQ00L3 TQ00E3 TQ00L2 TQ00E2 TQ00L1 TQ00E1 TQ00L0 TQ0OE0 0/1 Note TQ0IOC0 0: Disable TOQ00 pin output 1: Enable TOQ00 pin output Setting of output level while operation of TOQ00 pin is disabled 0: Low level 1: High level 0: Disable TOQ01 pin output 1: Enable TOQ01 pin output Specification of active level of TOQ01 pin output 0: Active-high 1: Active-low 0: Disable TOQ02 pin output 1: Enable TOQ02 pin output Specification of active level of TOQ02 pin output 0: Active-high 1: Active-low 0: Disable TOQ03 pin output 1: Enable TOQ03 pin output Specification of active level of TOQ03 pin output 0: Active-high 1: Active-low • When TQ0OLk bit = 0 • When TQ0OLk bit = 1 16-bit counter 16-bit counter TOQ0k pin output TOQ0k pin output Note Clear this bit to 0 when the TOQ00 pin is not used in the external trigger pulse output mode.

Figure 8-18. Setting of Registers in External Trigger Pulse Output Mode (2/3)

Figure 8-18. Setting of Registers in External Trigger Pulse Output Mode (3/3)

# (d) TMQ0 I/O control register 2 (TQ0IOC2) TQ0EES1 TQ0EES0 TQ0ETS1 TQ0ETS0 TQ0IOC2 0 0 0 0 0/1 0/1 0/1 0/1 Select valid edge of external trigger input Select valid edge of external event count input

### (e) TMQ0 counter read buffer register (TQ0CNT)

The value of the 16-bit counter can be read by reading the TQ0CNT register.

### (f) TMQ0 capture/compare registers 0 to 3 (TQ0CCR0 to TQ0CCR3)

If  $D_0$  is set to the TQ0CCR0 register,  $D_1$  to the TQ0CCR1 register,  $D_2$  to the TQ0CCR2 register, and  $D_3$ , to the TQ0CCR3 register, the cycle and active level of the PWM waveform are as follows.

Cycle =  $(D_0 + 1) \times Count clock cycle$ 

TOQ01 pin PWM waveform active level width =  $D_1 \times Count \ clock \ cycle$ 

TOQ02 pin PWM waveform active level width =  $D_2 \times Count \ clock \ cycle$ 

TOQ03 pin PWM waveform active level width =  $D_3 \times Count$  clock cycle

# **Remarks 1.** TMQ0 I/O control register 1 (TQ0IOC1) and TMQ0 option register 0 (TQ0OPT0) are not used in the external trigger pulse output mode.

2. Updating TMQ0 capture/compare register 2 (TQ0CCR2) and TMQ0 capture/compare register 3 (TQ0CCR3) is validated by writing TMQ0 capture/compare register 1 (TQ0CCR1).

# (1) Operation flow in external trigger pulse output mode

Figure 8-19. Software Processing Flow in External Trigger Pulse Output Mode (1/2)



<1> Count operation start flow <4> TQ0CCR1 to TQ0CCR3 register setting change flow Writing of the TQ0CCR1 **START** Setting of TQ0CCR2. register must be performed TQ0CCR3 registers when the set duty factor is only changed after writing the TQ0CCR2 and TQ0CCR3 Register initial setting registers. Initial setting of these Setting of TQ0CCR1 register TQ0CTL0 register When the counter is cleared registers is performed (TQ0CKS0 to TQ0CKS2 bits) after setting, the value of the before setting the TQ0CTL1 register, TQ0CCRm register is transferred TQ0CE bit to 1. TQ0IOC0 register, to the CCRm buffer register. TQ0IOC2 register, TQ0CCR0 to TQ0CCR3 registers <5> TQ0CCR2, TQ0CCR3 register setting change flow The TQ0CKS0 to TQ0CE bit = 1 TQ0CKS2 bits can be TQ0CCR1 register writing of the same value is necessary only set at the same time Setting of TQ0CCR2, when the set duty factor of when counting is enabled (TQ0CE bit = 1). TQ0CCR3 registers TOQ02 and TOQ03 pin outputs is changed. Trigger wait status When the counter is cleared after setting, Setting of TQ0CCR1 register the value of the TQ0CCRm <2> TQ0CCR0 to TQ0CCR3 register register is transferred to setting change flow the CCRm buffer register. Writing of the TQ0CCR1 register must be performed Setting of TQ0CCR0, TQ0CCR2 after writing the TQ0CCR0, and TQ0CCR3 registers TQ0CCR2, and TQ0CCR3 <6> TQ0CCR1 register setting change flow registers. When the counter is cleared Only writing of the TQ0CCR1 TQ0CCR1 register after setting, the value register must be performed when of the TQ0CCRm register is the set duty factor is only changed. Setting of TQ0CCR1 register transferred to the CCRm buffer When counter is cleared after registers. setting, the value of the TQ0CCRm register is transferred to the CCRm buffer register. <3> TQ0CCR0 register setting change flow TQ0CCR1 register writing of the same value is Setting of TQ0CCR0 register necessary only when the <7> Count operation stop flow set cycle is changed. TQ0CE bit = 0When the counter is Counting is stopped. Setting of TQ0CCR1 register cleared after setting, the value of the TQ0CCRm register is transferred to the CCRm buffer register. STOP **Remark** m = 0 to 3

Figure 8-19. Software Processing Flow in External Trigger Pulse Output Mode (2/2)

# (2) External trigger pulse output mode operation timing

# (a) Note on changing pulse width during operation

To change the PWM waveform while the counter is operating, write the TQ0CCR1 register last.

Rewrite the TQ0CCRk register after writing the TQ0CCR1 register after the INTTQ0CC0 signal is detected.



In order to transfer data from the TQ0CCRm register to the CCRm buffer register, the TQ0CCR1 register must be written.

To change both the cycle and active level width of the PWM waveform at this time, first set the cycle to the TQ0CCR0 register, set the active level width to the TQ0CCR2 and TQ0CCR3 registers, and then set an active level to the TQ0CCR1 register.

To change only the cycle of the PWM waveform, first set the cycle to the TQ0CCR0 register, and then write the same value to the TQ0CCR1 register.

To change only the active level width (duty factor) of the PWM waveform, first set an active level to the TQ0CCR2 and TQ0CCR3 registers and then set an active level to the TQ0CCR1 register.

To change only the active level width (duty factor) of the PWM waveform output by the TOQ01 pin, only the TQ0CCR1 register has to be set.

To change only the active level width (duty factor) of the PWM waveform output by the TOQ02 and TOQ03 pins, first set an active level width to the TQ0CCR2 and TQ0CCR3 registers, and then write the same value to the TQ0CCR1 register.

After data is written to the TQ0CCR1 register, the value written to the TQ0CCRm register is transferred to the CCRm buffer register in synchronization with clearing of the 16-bit counter, and is used as the value compared with the 16-bit counter.

To write the TQ0CCR0 to TQ0CCR3 registers again after writing the TQ0CCR1 register once, do so after the INTTQ0CC0 signal is generated. Otherwise, the value of the CCRm buffer register may become undefined because timing of transferring data from the TQ0CCRm register to the CCRm buffer register conflicts with writing the TQ0CCRm register.

**Remark** m = 0 to 3

### (b) 0%/100% output of PWM waveform

To output a 0% waveform, set the TQ0CCRk register to 0000H. If the set value of the TQ0CCR0 register is FFFFH, the INTTQ0CCk signal is generated periodically.



To output a 100% waveform, set a value of (set value of TQ0CCR0 register + 1) to the TQ0CCRk register. If the set value of the TQ0CCR0 register is FFFFH, 100% output cannot be produced.



### (c) Conflict between trigger detection and match with CCRk buffer register

If the trigger is detected immediately after the INTTQ0CCk signal is generated, the 16-bit counter is immediately cleared to 0000H, the output signal of the TOQ0k pin is asserted, and the counter continues counting. Consequently, the inactive period of the PWM waveform is shortened.



If the trigger is detected immediately before the INTTQ0CCk signal is generated, the INTTQ0CCk signal is not generated, and the 16-bit counter is cleared to 0000H and continues counting. The output signal of the TOQ0k pin remains active. Consequently, the active period of the PWM waveform is extended.



# (d) Conflict between trigger detection and match with CCR0 buffer register

If the trigger is detected immediately after the INTTQ0CC0 signal is generated, the 16-bit counter is cleared to 0000H and continues counting up. Therefore, the active period of the TOQ0k pin is extended by time from generation of the INTTQ0CC0 signal to trigger detection.



If the trigger is detected immediately before the INTTQ0CC0 signal is generated, the INTTQ0CC0 signal is not generated. The 16-bit counter is cleared to 0000H, the TOQ0k pin is asserted, and the counter continues counting. Consequently, the inactive period of the PWM waveform is shortened.



# (e) Generation timing of compare match interrupt request signal (INTTQ0CCk)

The timing of generation of the INTTQ0CCk signal in the external trigger pulse output mode differs from the timing of other INTTQ0CCk signals; the INTTQ0CCk signal is generated when the count value of the 16-bit counter matches the value of the CCRk buffer register.



Usually, the INTTQ0CCk signal is generated in synchronization with the next count up after the count value of the 16-bit counter matches the value of the CCRk buffer register.

In the external trigger pulse output mode, however, it is generated one clock earlier. This is because the timing is changed to match the timing of changing the output signal of the TOQ0k pin.

### 8.5.4 One-shot pulse output mode (TQ0MD2 to TQ0MD0 bits = 011)

In the one-shot pulse output mode, 16-bit timer/event counter Q waits for a trigger when the TQ0CTL0.TQ0CE bit is set to 1. When the valid edge of an external trigger input is detected, 16-bit timer/event counter Q starts counting, and outputs a one-shot pulse from the TQQ01 to TQQ03 pins.

Instead of the external trigger, a software trigger can also be generated to output the pulse. When the software trigger is used, the TOQ00 pin outputs the active level while the 16-bit counter is counting, and the inactive level when the counter is stopped (waiting for a trigger).



Figure 8-20. Configuration in One-Shot Pulse Output Mode



Figure 8-21. Basic Timing in One-Shot Pulse Output Mode

When the TQ0CE bit is set to 1, 16-bit timer/event counter Q waits for a trigger. When the trigger is generated, the 16-bit counter is cleared from FFFFH to 0000H, starts counting, and outputs a one-shot pulse from the TOQ0k pin. After the one-shot pulse is output, the 16-bit counter is set to FFFFH, stops counting, and waits for a trigger. If a trigger is generated again while the one-shot pulse is being output, it is ignored.

The output delay period and active level width of the one-shot pulse can be calculated as follows.

Output delay period = (Set value of TQ0CCRk register) × Count clock cycle

Active level width = (Set value of TQ0CCR0 register – Set value of TQ0CCRk register + 1) × Count clock cycle

The compare match interrupt request signal INTTQ0CC0 is generated when the 16-bit counter counts after its count value matches the value of the CCR0 buffer register. The compare match interrupt request signal INTTQ0CCk is generated when the count value of the 16-bit counter matches the value of the CCRk buffer register.

The valid edge of an external trigger input or setting the software trigger (TQ0CTL1.TQ0EST bit) to 1 is used as the trigger.

**Remark** k = 1 to 3

Figure 8-22. Setting of Registers in One-Shot Pulse Output Mode (1/3)



(c) TMQ0 I/O control register 0 (TQ0IOC0) TQ00L3 TQ00E3 TQ00L2 TQ00E2 TQ00L1 TQ00E1 TQ00L0 TQ00E0 0/1<sup>Note</sup> TQ0IOC0 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0: Disable TOQ00 pin output 1: Enable TOQ00 pin output Setting of output level while operation of TOQ00 pin is disabled 0: Low level 1: High level 0: Disable TOQ01 pin output 1: Enable TOQ01 pin output Specification of active level of TOQ01 pin output 0: Active-high 1: Active-low 0: Disable TOQ02 pin output 1: Enable TOQ02 pin output Specification of active level of TOQ02 pin output 0: Active-high 1: Active-low 0: Disable TOQ03 pin output 1: Enable TOQ03 pin output Specification of active level of TOQ03 pin output 0: Active-high 1: Active-low • When TQ0OLk bit = 0 • When TQ0OLk bit = 1 16-bit counter 16-bit counter TOQ0k pin output TOQ0k pin output (d) TMQ0 I/O control register 2 (TQ0IOC2) TQ0EES1 TQ0EES0 TQ0ETS1 TQ0ETS0 TQ0IOC2 0 0 0/1 0/1 0/1 0/1 Select valid edge of external trigger input Select valid edge of external event count input **Note** Clear this bit to 0 when the TOQ00 pin is not used in the one-shot pulse output mode.

Figure 8-22. Register Setting in One-Shot Pulse Output Mode (2/3)

# Figure 8-22. Register Setting in One-Shot Pulse Output Mode (3/3)

# (e) TMQ0 counter read buffer register (TQ0CNT)

The value of the 16-bit counter can be read by reading the TQ0CNT register.

# (f) TMQ0 capture/compare registers 0 to 3 (TQ0CCR0 to TQ0CCR3)

If  $D_0$  is set to the TQ0CCR0 register and  $D_k$  to the TQ0CCRk register, the active level width and output delay period of the one-shot pulse are as follows.

Active level width =  $(D_k - D_0 + 1) \times Count clock$  cycle

Output delay period =  $D_k \times Count clock cycle$ 

- **Remarks 1.** TMQ0 I/O control register 1 (TQ0IOC1) and TMQ0 option register 0 (TQ0OPT0) are not used in the one-shot pulse output mode.
  - **2.** k = 1 to 3

# (1) Operation flow in one-shot pulse output mode

Figure 8-23. Software Processing Flow in One-Shot Pulse Output Mode (1/2)



<1> Count operation start flow <2> TQ0CCR0 to TQ0CCR3 register setting change flow As rewriting the TQ0CCRm register START immediately forwards to the CCRm buffer Setting of TQ0CCR0 to TQ0CCR3 register, rewriting registers immediately after Register initial setting Initial setting of these the generation of the TQ0CTL0 register registers is performed INTTQ0CCR0 signal (TQ0CKS0 to TQ0CKS2 bits) before setting the is recommended. TQ0CTL1 register, TQ0IOC0 register, TQ0CE bit to 1. TQ0IOC2 register, TQ0CCR0 to TQ0CCR3 registers <3> Count operation stop flow The TQ0CKS0 to Count operation is TQ0CKS2 bits can be TQ0CE bit = 0stopped set at the same time TQ0CE bit = 1 when counting has been started (TQ0CE bit = 1). Trigger wait status STOP **Remark** m = 0 to 3

Figure 8-23. Software Processing Flow in One-Shot Pulse Output Mode (2/2)

### (2) Operation timing in one-shot pulse output mode

## (a) Note on rewriting TQ0CCRm register

To change the set value of the TQ0CCRm register to a smaller value, stop counting once, and then change the set value.

If the value of the TQ0CCR0 register is rewritten to a smaller value during counting, the 16-bit counter may overflow.



When the TQ0CCR0 register is rewritten from  $D_{00}$  to  $D_{01}$  and the TQ0CCRk register from  $D_{k0}$  to  $D_{k1}$  where  $D_{00} > D_{01}$  and  $D_{k0} > D_{k1}$ , if the TQ0CCRk register is rewritten when the count value of the 16-bit counter is greater than  $D_{k1}$  and less than  $D_{k0}$  and if the TQ0CCR0 register is rewritten when the count value is greater than  $D_{01}$  and less than  $D_{00}$ , each set value is reflected as soon as the register has been rewritten and compared with the count value. The counter counts up to FFFFH and then counts up again from 0000H. When the count value matches  $D_{k1}$ , the counter generates the INTTQ0CCk signal and asserts the TQQ0k pin. When the count value matches  $D_{01}$ , the counter generates the INTTQ0CC0 signal, deasserts the TQQ0k pin, and stops counting.

Therefore, the counter may output a pulse with a delay period or active period different from that of the one-shot pulse that is originally expected.

## (b) Generation timing of compare match interrupt request signal (INTTQ0CCk)

The generation timing of the INTTQ0CCk signal in the one-shot pulse output mode is different from other INTTQ0CCk signals; the INTTQ0CCk signal is generated when the count value of the 16-bit counter matches the value of the TQ0CCRk register.



Usually, the INTTQ0CCk signal is generated when the 16-bit counter counts up next time after its count value matches the value of the TQ0CCRk register.

In the one-shot pulse output mode, however, it is generated one clock earlier. This is because the timing is changed to match the change timing of the TOQ0k pin.

### 8.5.5 PWM output mode (TQ0MD2 to TQ0MD0 bits = 100)

In the PWM output mode, a PWM waveform is output from the TOQ01 to TOQ03 pins when the TQ0CTL0.TQ0CE bit is set to 1.

In addition, a pulse with one cycle of the PWM waveform as half its cycle is output from the TOQ00 pin.

TQ0CCR1 register Transfer Output CCR1 buffer S controller → © TOQ01 pin register (RS-FF) Match signal ► INTTQ0CC1 signal TQ0CCR2 register Transfer Output S CCR2 buffer controller ○ TOQ02 pin register (RS-FF) Match signal ► INTTQ0CC2 signal TQ0CCR3 register Transfer Output S CCR3 buffer controller O TOQ03 pin register (RS-FF) Match signal ► INTTQ0CC3 signal Clear Count Count Output clock -O TOQ00 pin 16-bit counter start controller selection control Match signal ► INTTQ0CC0 signal TQ0CE bit CCR0 buffer register

Figure 8-24. Configuration in PWM Output Mode

TQ0CCR0 register

Transfer



Figure 8-25. Basic Timing in PWM Output Mode

When the TQ0CE bit is set to 1, the 16-bit counter is cleared from FFFFH to 0000H, starts counting, and outputs PWM waveform from the TQQ0k pin.

The active level width, cycle, and duty factor of the PWM waveform can be calculated as follows.

```
Active level width = (Set value of TQ0CCRk register) × Count clock cycle

Cycle = (Set value of TQ0CCR0 register + 1) × Count clock cycle

Duty factor = (Set value of TQ0CCRk register)/(Set value of TQ0CCR0 register + 1)
```

The PWM waveform can be changed by rewriting the TQ0CCRm register while the counter is operating. The newly written value is reflected when the count value of the 16-bit counter matches the value of the CCR0 buffer register and the 16-bit counter is cleared to 0000H.

The compare match interrupt request signal INTTQ0CC0 is generated when the 16-bit counter counts next time after its count value matches the value of the CCR0 buffer register, and the 16-bit counter is cleared to 0000H. The compare match interrupt request signal INTTQ0CCk is generated when the count value of the 16-bit counter matches the value of the CCRk buffer register.

**Remark** k = 1 to 3 m = 0 to 3

Figure 8-26. Setting of Registers in PWM Output Mode (1/3)



Figure 8-26. Setting of Registers in PWM Output Mode (2/3) (c) TMQ0 I/O control register 0 (TQ0IOC0) TQ00L3 TQ00E3 TQ00L2 TQ00E2 TQ00L1 TQ00E1 TQ00L0 TQ00E0 0/1<sup>Note</sup> TQ0IOC0 0/1 0/1 0/10/1 0/1 0/1 0/1 0: Disable TOQ00 pin output 1: Enable TOQ00 pin output Setting of output level while operation of TOQ00 pin is disabled 0: Low level 1: High level 0: Disable TOQ01 pin output 1: Enable TOQ01 pin output Specification of active level of TOQ01 pin output 0: Active-high 1: Active-low 0: Disable TOQ02 pin output 1: Enable TOQ02 pin output Specification of active level of TOQ02 pin output 0: Active-high 1: Active-low 0: Disable TOQ03 pin output 1: Enable TOQ03 pin output Specification of active level of TOQ03 pin output 0: Active-high 1: Active-low • When TQ0OLk bit = 0 • When TQ0OLk bit = 1 16-bit counter 16-bit counter TOQ0k pin output TOQ0k pin output (d) TMQ0 I/O control register 2 (TQ0IOC2) TQ0EES1 TQ0EES0 TQ0ETS1 TQ0ETS0 TQ0IOC2 0/1 0 0/1 0 0 0 Select valid edge of external event count input.

The value of the 16-bit counter can be read by reading the TQ0CNT register.

**Note** Clear this bit to 0 when the TOQ00 pin is not used in the PWM output mode.

(e) TMQ0 counter read buffer register (TQ0CNT)

## Figure 8-26. Register Setting in PWM Output Mode (3/3)

### (f) TMQ0 capture/compare registers 0 to 3 (TQ0CCR0 and TQ0CCR3)

If  $D_0$  is set to the TQ0CCR0 register and  $D_k$  to the TQ0CCR1 register, the cycle and active level of the PWM waveform are as follows.

 $\begin{aligned} & \text{Cycle} = (D_0 + 1) \times \text{Count clock cycle} \\ & \text{Active level width} = D_k \times \text{Count clock cycle} \end{aligned}$ 

- **Remarks 1.** TMQ0 I/O control register 1 (TQ0IOC1) and TMQ0 option register 0 (TQ0OPT0) are not used in the PWM output mode.
  - 2. Updating the TMQ0 capture/compare register 2 (TQ0CCR2) and TMQ0 capture/compare register 3 (TQ0CCR3) is validated by writing the TMQ0 capture/compare register 1 (TQ0CCR1).

# (1) Operation flow in PWM output mode

Figure 8-27. Software Processing Flow in PWM Output Mode (1/2)



<1> Count operation start flow <4> TQ0CCR1, TQ0CCR3 register setting change flow Only writing of the TQ0CCR1 START Setting of TQ0CCR2. register must be performed TQ0CCR3 registers when the set duty factor is only changed after writing the TQ0CCR2 and TQ0CCR3 Register initial setting Setting of TQ0CCR1 register registers. Initial setting of these TQ0CTL0 register When the counter is cleared after registers is performed (TQ0CKS0 to TQ0CKS2 bits) setting, the value of the before the TQ0CE TQ0CTL1 register, TQ0CCRm register is transferred bit is set to 1. TQ0IOC0 register, to the CCRm buffer register. TQ0IOC2 register. TQ0CCR0 to TQ0CCR1 registers <5> TQ0CCR2, TQ0CCR3 register setting change flow The TQ0CKS0 to TQ0CE bit = 1 TQ0CKS2 bits can be TQ0CCR1 register writing of the same value is necessary only set at the same time Setting of TQ0CCR2, when the set duty factor of when counting is TQ0CCR3 registers TOQ02 and TOQ03 pin enabled (TQ0CE bit = 1). outputs is changed. When the counter is cleared after setting, Setting of TQ0CCR1 register the value of the TQ0CCRm <2> TQ0CCR0 to TQ0CCR3 register register is transferred to setting change flow the CCRm buffer register. Writing of the TQ0CCR1 register must be performed Setting of TQ0CCR0, TQ0CCR2, after writing the TQ0CCR0, and TQ0CCR3 registers TQ0CCR2, and TQ0CCR3 <6> TQ0CCR1 register setting change flow registers. When the counter is cleared Only writing of the TQ0CCR1 TQ0CCR1 register after setting, the value register must be performed when of the TQ0CCRm register is the set duty factor is only changed. transferred to the CCRm buffer Setting of TQ0CCR1 register When counter is cleared after registers. setting, the value of the TQ0CCRm register is transferred to the CCRm buffer register. <3> TQ0CCR0 register setting change flow TQ0CCR1 writing of the same value is Setting of TQ0CCR0 register necessary only when the <7> Count operation stop flow set cycle is changed. TQ0CE bit = 0When the counter is Counting is stopped. Setting of TQ0CCR1 register cleared after setting, the value of the TQ0CCRm register is transferred to the CCRm buffer register. STOP **Remark** k = 1 to 3m = 0 to 3

Figure 8-27. Software Processing Flow in PWM Output Mode (2/2)

## (2) PWM output mode operation timing

# (a) Changing pulse width during operation

To change the PWM waveform while the counter is operating, write the TQ0CCR1 register last.

Rewrite the TQ0CCRk register after writing the TQ0CCR1 register after the INTTQ0CC1 signal is detected.



To transfer data from the TQ0CCRm register to the CCRm buffer register, the TQ0CCR1 register must be written.

To change both the cycle and active level of the PWM waveform at this time, first set the cycle to the TQ0CCR0 register, set the active level width to the TQ0CCR2 and TQ0CCR3 registers, and then set an active level width to the TQ0CCR1 register.

To change only the active level width (duty factor) of PWM wave, first set the active level to the TQ0CCR2 and TQ0CCR3 registers, and then set an active level to the TQ0CCR1 register.

To change only the active level width (duty factor) of the PWM waveform output by the TOQ01 pin, only the TQ0CCR1 register has to be set.

To change only the active level width (duty factor) of the PWM waveform output by the TOQ02 and TOQ03 pins, first set an active level width to the TQ0CCR2 and TQ0CCR3 registers, and then write the same value to the TQ0CCR1 register.

After the TQ0CCR1 register is written, the value written to the TQ0CCRm register is transferred to the CCRm buffer register in synchronization with the timing of clearing the 16-bit counter, and is used as a value to be compared with the value of the 16-bit counter.

To change only the cycle of the PWM waveform, first set a cycle to the TQ0CCR0 register, and then write the same value to the TQ0CCR1 register.

To write the TQ0CCR0 to TQ0CCR3 registers again after writing the TQ0CCR1 register once, do so after the INTTQ0CC0 signal is generated. Otherwise, the value of the CCRm buffer register may become undefined because the timing of transferring data from the TQ0CCRm register to the CCRm buffer register conflicts with writing the TQ0CCRm register.

### (b) 0%/100% output of PWM waveform

To output a 0% waveform, set the TQ0CCRk register to 0000H. If the set value of the TQ0CCR0 register is FFFFH, the INTTQ0CCk signal is generated periodically.



To output a 100% waveform, set a value of (set value of TQ0CCR0 register + 1) to the TQ0CCRk register. If the set value of the TQ0CCR0 register is FFFFH, 100% output cannot be produced.



## (c) Generation timing of compare match interrupt request signal (INTTQ0CCk)

The timing of generation of the INTTQ0CCk signal in the PWM output mode differs from the timing of other INTTQ0CCk signals; the INTTQ0CCk signal is generated when the count value of the 16-bit counter matches the value of the TQ0CCRk register.



Usually, the INTTQ0CCk signal is generated in synchronization with the next counting up after the count value of the 16-bit counter matches the value of the TQ0CCRk register.

In the PWM output mode, however, it is generated one clock earlier. This is because the timing is changed to match the change timing of the output signal of the TOQ0k pin.

### 8.5.6 Free-running timer mode (TQ0MD2 to TQ0MD0 bits = 101)

In the free-running timer mode, 16-bit timer/event counter Q starts counting when the TQ0CTL0.TQ0CE bit is set to 1. At this time, the TQ0CCRm register can be used as a compare register or a capture register, depending on the setting of the TQ0OPT0.TQ0CCS0 and TQ0OPT0.TQ0CCS1 bits.

Figure 8-28. Configuration in Free-Running Timer Mode



When the TQ0CE bit is set to 1, 16-bit timer/event counter Q starts counting, and the output signals of the TQ000 to TQQ03 pins are inverted. When the count value of the 16-bit counter later matches the set value of the TQ0CCRm register, a compare match interrupt request signal (INTTQ0CCm) is generated, and the output signal of the TQQ0m pin is inverted.

The 16-bit counter continues counting in synchronization with the count clock. When it counts up to FFFFH, it generates an overflow interrupt request signal (INTTQ0OV) at the next clock, is cleared to 0000H, and continues counting. At this time, the overflow flag (TQ0OPT0.TQ0OVF bit) is also set to 1. Clear the overflow flag to 0 by executing the CLR instruction by software.

The TQ0CCRm register can be rewritten while the counter is operating. If it is rewritten, the new value is reflected at that time, and compared with the count value.



Figure 8-29. Basic Timing in Free-Running Timer Mode (Compare Function)

When the TQ0CE bit is set to 1, the 16-bit counter starts counting. When the valid edge input to the TIQ0m pin is detected, the count value of the 16-bit counter is stored in the TQ0CCRm register, and a capture interrupt request signal (INTTQ0CCm) is generated.

The 16-bit counter continues counting in synchronization with the count clock. When it counts up to FFFFH, it generates an overflow interrupt request signal (INTTQ0OV) at the next clock, is cleared to 0000H, and continues counting. At this time, the overflow flag (TQ0OVF bit) is also set to 1. Clear the overflow flag to 0 by executing the CLR instruction by software.



Figure 8-30. Basic Timing in Free-Running Timer Mode (Capture Function)

Figure 8-31. Register Setting in Free-Running Timer Mode (1/3)



(c) TMQ0 I/O control register 0 (TQ0IOC0) TQ00L3 TQ00E3 TQ00L2 TQ00E2 TQ00L1 TQ00E1 TQ00L0 TQ00E0 TQ0IOC0 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0: Disable TOQ00 pin output 1: Enable TOQ00 pin output Setting of output level with operation of TOQ00 pin disabled 0: Low level 1: High level 0: Disable TOQ01 pin output 1: Enable TOQ01 pin output Setting of output level with operation of TOQ01 pin disabled 0: Low level 1: High level 0: Disable TOQ02 pin output 1: Enable TOQ02 pin output Setting of output level with operation of TOQ02 pin disabled 0: Low level 1: High level 0: Disable TOQ03 pin output 1: Enable TOQ03 pin output Setting of output level with operation of TOQ03 pin disabled 0: Low level 1: High level (d) TMQ0 I/O control register 1 (TQ0IOC1) TQ0IS7 TQ0IS6 TQ0IS5 TQ0IS4 TQ0IS3 TQ0IS2 TQ0IS1 TQ0IS0 TQ0IOC1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 Select valid edge of TIQ00 pin input Select valid edge of TIQ01 pin input

Figure 8-31. Register Setting in Free-Running Timer Mode (2/3)

Select valid edge of TIQ02 pin input Select valid edge of TIQ03 pin input

Figure 8-31. Register Setting in Free-Running Timer Mode (3/3)



TOQ0m pin is inverted.

# (1) Operation flow in free-running timer mode

# (a) When using capture/compare register as compare register

Figure 8-32. Software Processing Flow in Free-Running Timer Mode (Compare Function) (1/2)



Figure 8-32. Software Processing Flow in Free-Running Timer Mode (Compare Function) (2/2)



## (b) When using capture/compare register as capture register

Figure 8-33. Software Processing Flow in Free-Running Timer Mode (Capture Function) (1/2)



Figure 8-33. Software Processing Flow in Free-Running Timer Mode (Capture Function) (2/2)



## (2) Operation timing in free-running timer mode

# (a) Interval operation with compare register

When 16-bit timer/event counter Q is used as an interval timer with the TQ0CCRm register used as a compare register, software processing is necessary for setting a comparison value to generate the next interrupt request signal each time the INTTQ0CCm signal has been detected.



When performing an interval operation in the free-running timer mode, two intervals can be set with one channel.

To perform the interval operation, the value of the corresponding TQ0CCRm register must be re-set in the interrupt servicing that is executed when the INTTQ0CCm signal is detected.

The set value for re-setting the TQ0CCRm register can be calculated by the following expression, where " $D_m$ " is the interval period.

Compare register default value: Dm - 1

Value set to compare register second and subsequent time: Previous set value + Dm

(If the calculation result is greater than FFFFH, subtract 10000H from the result and set this value to the register.)

### (b) Pulse width measurement with capture register

When pulse width measurement is performed with the TQ0CCRm register used as a capture register, software processing is necessary for reading the capture register each time the INTTQ0CCm signal has been detected and for calculating an interval.



When executing pulse width measurement in the free-running timer mode, four pulse widths can be measured with one channel.

To measure a pulse width, the pulse width can be calculated by reading the value of the TQ0CCRm register in synchronization with the INTTQ0CCm signal, and calculating the difference between the read value and the previously read value.

### (c) Processing of overflow when two or more capture registers are used

Care must be exercised in processing the overflow flag when two capture registers are used. First, an example of incorrect processing is shown below.



The following problem may occur when two pulse widths are measured in the free-running timer mode.

- <1> Read the TQ0CCR0 register (setting of the default value of the TIQ00 pin input).
- <2> Read the TQ0CCR1 register (setting of the default value of the TIQ01 pin input).
- <3> Read the TQ0CCR0 register.

Read the overflow flag. If the overflow flag is 1, clear it to 0.

Because the overflow flag is 1, the pulse width can be calculated by  $(10000H + D_{01} - D_{00})$ .

<4> Read the TQ0CCR1 register.

Read the overflow flag. Because the flag is cleared in <3>, 0 is read.

Because the overflow flag is 0, the pulse width can be calculated by  $(D_{11} - D_{10})$  (incorrect).

When two capture registers are used, and if the overflow flag is cleared to 0 by one capture register, the other capture register may not obtain the correct pulse width.

Use software when using two capture registers. An example of how to use software is shown below.





Note The TQ0OVF0 and TQ0OVF1 flags are set on the internal RAM by software.

- <1> Read the TQ0CCR0 register (setting of the default value of the TIQ00 pin input).
- <2> Read the TQ0CCR1 register (setting of the default value of the TIQ01 pin input).
- <3> An overflow occurs. Set the TQ0OVF0 and TQ0OVF1 flags to 1 in the overflow interrupt servicing, and clear the overflow flag to 0.
- <4> Read the TQ0CCR0 register.
  - Read the TQ0OVF0 flag. If the TQ0OVF0 flag is 1, clear it to 0.
  - Because the TQ0OVF0 flag is 1, the pulse width can be calculated by  $(10000H + D_{01} D_{00})$ .
- <5> Read the TQ0CCR1 register.
  - Read the TQ00VF1 flag. If the TQ00VF1 flag is 1, clear it to 0 (the TQ00VF0 flag is cleared in <4>, and the TQ00VF1 flag remains 1).
  - Because the TQ0OVF1 flag is 1, the pulse width can be calculated by  $(10000H + D_{11} D_{10})$  (correct).
- <6> Same as <3>





Note The TQ0OVF0 and TQ0OVF1 flags are set on the internal RAM by software.

- <1> Read the TQ0CCR0 register (setting of the default value of the TIQ00 pin input).
- <2> Read the TQ0CCR1 register (setting of the default value of the TIQ01 pin input).
- <3> An overflow occurs. Nothing is done by software.
- <4> Read the TQ0CCR0 register.

Read the overflow flag. If the overflow flag is 1, set only the TQ0OVF1 flag to 1, and clear the overflow flag to 0.

Because the overflow flag is 1, the pulse width can be calculated by  $(10000H + D_{01} - D_{00})$ .

<5> Read the TQ0CCR1 register.

Read the overflow flag. Because the overflow flag is cleared in <4>, 0 is read.

Read the TQ0OVF1 flag. If the TQ0OVF1 flag is 1, clear it to 0.

Because the TQ0OVF1 flag is 1, the pulse width can be calculated by  $(10000H + D_{11} - D_{10})$  (correct).

<6> Same as <3>

### (d) Processing of overflow if capture trigger interval is long

If the pulse width is greater than one cycle of the 16-bit counter, care must be exercised because an overflow may occur more than once from the first capture trigger to the next. First, an example of incorrect processing is shown below.



The following problem may occur when a long pulse width in the free-running timer mode.

- <1> Read the TQ0CCRm register (setting of the default value of the TIQ0m pin input).
- <2> An overflow occurs. Nothing is done by software.
- <3> An overflow occurs a second time. Nothing is done by software.
- <4> Read the TQ0CCRm register.

Read the overflow flag. If the overflow flag is 1, clear it to 0.

Because the overflow flag is 1, the pulse width can be calculated by (10000H +  $D_{m1}$  -  $D_{m0}$ ) (incorrect).

Actually, the pulse width must be (20000H + D<sub>m1</sub> - D<sub>m0</sub>) because an overflow occurs twice.

If an overflow occurs twice or more when the capture trigger interval is long, the correct pulse width may not be obtained.

If the capture trigger interval is long, slow the count clock to lengthen one cycle of the 16-bit counter, or use software. An example of how to use software is shown next.



**Note** The overflow counter is set arbitrarily by software on the internal RAM.

- <1> Read the TQ0CCRm register (setting of the default value of the TIQ0m pin input).
- <2> An overflow occurs. Increment the overflow counter and clear the overflow flag to 0 in the overflow interrupt servicing.
- <3> An overflow occurs a second time. Increment (+1) the overflow counter and clear the overflow flag to 0 in the overflow interrupt servicing.
- <4> Read the TQ0CCRm register.

Read the overflow counter.

 $\rightarrow$  When the overflow counter is "N", the pulse width can be calculated by (N  $\times$  10000H + D<sub>m1</sub> - D<sub>m0</sub>).

In this example, the pulse width is  $(20000H + D_{m1} - D_{m0})$  because an overflow occurs twice. Clear the overflow counter (0H).

### (e) Clearing overflow flag

The overflow flag can be cleared to 0 by clearing the TQ0OVF bit to 0 with the CLR instruction and by writing 8-bit data (bit 0 is 0) to the TQ0OPT0 register. To accurately detect an overflow, read the TQ0OVF bit when it is 1, and then clear the overflow flag by using a bit manipulation instruction.



To clear the overflow flag to 0, read the overflow flag to check if it is set to 1, and clear it with the CLR instruction. If 0 is written to the overflow flag without checking if the flag is 1, the set information of overflow may be erased by writing 0 ((ii) in the above chart). Therefore, software may judge that no overflow has occurred even when an overflow actually has occurred.

If execution of the CLR instruction conflicts with occurrence of an overflow when the overflow flag is cleared to 0 with the CLR instruction, the overflow flag remains set even after execution of the clear instruction.

### 8.5.7 Pulse width measurement mode (TQ0MD2 to TQ0MD0 bits = 110)

In the pulse width measurement mode, 16-bit timer/event counter Q starts counting when the TQ0CTL0.TQ0CE bit is set to 1. Each time the valid edge input to the TIQ0m pin has been detected, the count value of the 16-bit counter is stored in the TQ0CCRm register, and the 16-bit counter is cleared to 0000H.

The interval of the valid edge can be measured by reading the TQ0CCRm register after a capture interrupt request signal (INTTQ0CCm) occurs.

Select either of the TIQ00 to TIQ03 pins as the capture trigger input pin. Specify "No edge detected" by using the TQ0IOC1 register for the unused pins.

When an external clock is used as the count clock, measure the pulse width of the TIQ0k pin because the external clock is fixed to the TIQ00 pin. At this time, clear the TQ0IOC1.TQ0IS1 and TQ0IOC1.TQ0IS0 bits to 00 (capture trigger input (TIQ00 pin): No edge detected).

**Remark** m = 0 to 3k = 1 to 3

Figure 8-34. Configuration in Pulse Width Measurement Mode





Figure 8-35. Basic Timing in Pulse Width Measurement Mode

When the TQ0CE bit is set to 1, the 16-bit counter starts counting. When the valid edge input to the TIQ0m pin is later detected, the count value of the 16-bit counter is stored in the TQ0CCRm register, the 16-bit counter is cleared to 0000H, and a capture interrupt request signal (INTTQ0CCm) is generated.

The pulse width is calculated as follows.

Pulse width = Captured value × Count clock cycle

If the valid edge is not input to the TIQ0m pin even when the 16-bit counter counted up to FFFFH, an overflow interrupt request signal (INTTQ0OV) is generated at the next count clock, and the counter is cleared to 0000H and continues counting. At this time, the overflow flag (TQ0OPT0.TQ0OVF bit) is also set to 1. Clear the overflow flag to 0 by executing the CLR instruction via software.

If the overflow flag is set to 1, the pulse width can be calculated as follows.

Pulse width = (10000H × TQ0OVF bit set (1) count + Captured value) × Count clock cycle

Figure 8-36. Register Setting in Pulse Width Measurement Mode (1/2)



Figure 8-36. Register Setting in Pulse Width Measurement Mode (2/2)

# (e) TMQ0 option register 0 (TQ0OPT0)

TQ0CCS3 TQ0CCS2 TQ0CCS1 TQ0CCS0 TQ0OVF
TQ0OPT0 0 0 0 0 0 0 0 0/1

Overflow flag

## (f) TMQ0 counter read buffer register (TQ0CNT)

The value of the 16-bit counter can be read by reading the TQ0CNT register.

## (g) TMQ0 capture/compare registers 0 to 3 (TQ0CCR0 to TQ0CCR3)

These registers store the count value of the 16-bit counter when the valid edge input to the TIQ0m pin is detected.

**Remarks 1.** TMQ0 I/O control register 0 (TQ0IOC0) is not used in the pulse width measurement mode.

**2.** m = 0 to 3

## (1) Operation flow in pulse width measurement mode

Figure 8-37. Software Processing Flow in Pulse Width Measurement Mode



#### (2) Operation timing in pulse width measurement mode

#### (a) Clearing overflow flag

The overflow flag can be cleared to 0 by clearing the TQ0OVF bit to 0 with the CLR instruction and by writing 8-bit data (bit 0 is 0) to the TQ0OPT0 register. To accurately detect an overflow, read the TQ0OVF bit when it is 1, and then clear the overflow flag by using a bit manipulation instruction.



To clear the overflow flag to 0, read the overflow flag to check if it is set to 1, and clear it with the CLR instruction. If 0 is written to the overflow flag without checking if the flag is 1, the set information of overflow may be erased by writing 0 ((ii) in the above chart). Therefore, software may judge that no overflow has occurred even when an overflow actually has occurred.

If execution of the CLR instruction conflicts with occurrence of an overflow when the overflow flag is cleared to 0 with the CLR instruction, the overflow flag remains set even after execution of the clear instruction.

## 8.5.8 Timer output operations

The following table shows the operations and output levels of the TOQ00 and TOQ01 pins.

Table 8-6. Timer Output Control in Each Mode

| Operation Mode                     | TOQn0 Pin                                               | TOQn1 Pin                     | TOQn2 Pin                     | TOQn3 Pin                     |
|------------------------------------|---------------------------------------------------------|-------------------------------|-------------------------------|-------------------------------|
| Interval timer mode                | Square wave output                                      |                               |                               |                               |
| External event count mode          | Square wave output                                      |                               | _                             |                               |
| External trigger pulse output mode | Square wave output                                      | External trigger pulse output | External trigger pulse output | External trigger pulse output |
| One-shot pulse output mode         |                                                         | One-shot pulse output         | One-shot pulse output         | One-shot pulse output         |
| PWM output mode                    |                                                         | PWM output                    | PWM output                    | PWM output                    |
| Free-running timer mode            | Square wave output (only when compare function is used) |                               |                               |                               |
| Pulse width measurement mode       | _                                                       | _                             | -                             |                               |

Table 8-7. Truth Table of TOQ00 to TOQ03 Pins Under Control of Timer Output Control Bits

| TQ0IOC0.TQ0OLm Bit | TQ0IOC0.TQ0OEm Bit | TQ0CTL0.TQ0CE Bit | Level of TOQ0m Pin                                                          |
|--------------------|--------------------|-------------------|-----------------------------------------------------------------------------|
| 0                  | 0                  | ×                 | Low-level output                                                            |
|                    | 1                  | 0                 | Low-level output                                                            |
|                    |                    | 1                 | Low level immediately before counting, high level after counting is started |
| 1                  | 0                  | ×                 | High-level output                                                           |
|                    | 1                  | 0                 | High-level output                                                           |
|                    |                    | 1                 | High level immediately before counting, low level after counting is started |

**Remark** m = 0 to 3

## 8.6 Selector Function

For the selector function, see **7.6 Selector Function**.

## 8.7 Cautions

## (1) Capture operation

When the capture operation is used and a slow clock is selected as the count clock, FFFFH, not 0000H, may be captured in the TQ0CCR0, TQ0CCR1, TQ0CCR2, and TQ0CCR3 registers if the capture trigger is input immediately after the TQ0CE bit is set to 1.



# CHAPTER 9 16-BIT INTERVAL TIMER M (TMM)

#### 9.1 Overview

- Interval function
- 8 clocks selectable
- 16-bit counter × 1

(The 16-bit counter cannot be read during timer count operation.)

- Compare register × 1
  - (The compare register cannot be written during timer counter operation.)
- Compare match interrupt  $\times$  1

Timer M supports only the clear & start mode. The free-running timer mode is not supported.

## 9.2 Configuration

TMM0 includes the following hardware.

Table 9-1. Configuration of TMM0

| Item             | Configuration                     |
|------------------|-----------------------------------|
| Timer register   | 16-bit counter                    |
| Register         | TMM0 compare register 0 (TM0CMP0) |
| Control register | TMM0 control register 0 (TM0CTL0) |

Figure 9-1. Block Diagram of TMM0



#### (1) 16-bit counter

This is a 16-bit counter that counts the internal clock.

The 16-bit counter cannot be read or written.

#### (2) TMM0 compare register 0 (TM0CMP0)

The TM0CMP0 register is a 16-bit compare register.

This register can be read or written in 16-bit units.

Reset input clears this register to 0000H.

The same value can always be written to the TM0CMP0 register by software.

TM0CMP0 register rewrite is prohibited when the TM0CTL0.TM0CE bit = 1.



## 9.3 Register

## (1) TMM0 control register (TM0CTL0)

The TM0CTL0 register is an 8-bit register that controls the TMM0 operation.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

The same value can always be written to the TM0CTL0 register by software.

| TM0CE | Internal clock operation enable/disable specification                                                |
|-------|------------------------------------------------------------------------------------------------------|
| 0     | TMM0 operation disabled (16-bit counter reset asynchronously).  Operation clock application stopped. |
| 1     | TMM0 operation enabled. Operation clock application started. TMM0 operation started.                 |

The internal clock control and internal circuit reset for TMM0 are performed asynchronously with the TM0CE bit. When the TM0CE bit is cleared to 0, the internal clock of TMM0 is disabled (fixed to low level) and 16-bit counter is reset asynchronously.

| TM0CKS2 | TM0CKS1 | TM0CKS0 | Count clock selection |
|---------|---------|---------|-----------------------|
| 0       | 0       | 0       | fxx                   |
| 0       | 0       | 1       | fxx/2                 |
| 0       | 1       | 0       | fxx/4                 |
| 0       | 1       | 1       | fxx/64                |
| 1       | 0       | 0       | fxx/512               |
| 1       | 0       | 1       | INTWT                 |
| 1       | 1       | 0       | f <sub>R</sub> /8     |
| 1       | 1       | 1       | fxт                   |

#### Cautions 1. Set the TM0CKS2 to TM0CKS0 bits when TM0CE bit = 0.

When changing the value of TM0CE from 0 to 1, it is not possible to set the value of the TM0CKS2 to TM0CKS0 bits simultaneously.

2. Be sure to clear bits 3 to 6 to 0.

Remark fxx: Main clock frequency

fr: Internal oscillation clock frequency

fxT: Subclock frequency

# 9.4 Operation

Caution Do not set the TM0CMP0 register to FFFFH.

#### 9.4.1 Interval timer mode

In the interval timer mode, an interrupt request signal (INTTM0EQ0) is generated at the specified interval if the TM0CTL0.TM0CE bit is set to 1.

Count clock selection

16-bit counter

Match signal

TM0CE bit

TM0CMP0 register

Figure 9-2. Configuration of Interval Timer





When the TM0CE bit is set to 1, the value of the 16-bit counter is cleared from FFFFH to 0000H in synchronization with the count clock, and the counter starts counting.

When the count value of the 16-bit counter matches the value of the TM0CMP0 register, the 16-bit counter is cleared to 0000H and a compare match interrupt request signal (INTTM0EQ0) is generated.

The interval can be calculated by the following expression.

Interval = (Set value of TM0CMP0 register + 1) × Count clock cycle

Figure 9-4. Register Setting for Interval Timer Mode Operation



## (1) Interval timer mode operation flow

Figure 9-5. Software Processing Flow in Interval Timer Mode



## (2) Interval timer mode operation timing

Caution Do not set the TM0CMP0 register to FFFFH.

## (a) Operation if TM0CMP0 register is set to 0000H

If the TM0CMP0 register is set to 0000H, the INTTM0EQ0 signal is generated at each count clock. The value of the 16-bit counter is always 0000H.



#### (b) Operation if TM0CMP0 register is set to N

If the TM0CMP0 register is set to N, the 16-bit counter counts up to N. The counter is cleared to 0000H in synchronization with the next count-up timing and the INTTM0EQ0 signal is generated.



## 9.4.2 Cautions

(1) It takes the 16-bit counter up to the following time to start counting after the TM0CTL0.TM0CE bit is set to 1, depending on the count clock selected.

| Selected Count Clock | Maximum Time Before Counting Start |
|----------------------|------------------------------------|
| fxx                  | 2/fxx                              |
| fxx/2                | 6/fxx                              |
| fxx/4                | 24/fxx                             |
| fxx/64               | 128/fxx                            |
| fxx/512              | 1024/fxx                           |
| INTWT                | Second rising edge of INTWT signal |
| fe/8                 | 16/f <sub>R</sub>                  |
| fхт                  | 2/fхт                              |

(2) Rewriting the TM0CMP0 and TM0CTL0 registers is prohibited while TMM0 is operating.

If these registers are rewritten while the TM0CE bit is 1, the operation cannot be guaranteed.

If they are rewritten by mistake, clear the TM0CTL0.TM0CE bit to 0, and re-set the registers.

## **CHAPTER 10 WATCH TIMER FUNCTIONS**

## 10.1 Functions

The watch timer has the following functions.

- Watch timer: An interrupt request signal (INTWT) is generated at intervals of 0.5 or 0.25 seconds by using the main clock or subclock.
- Interval timer: An interrupt request signal (INTWTI) is generated at set intervals.

The watch timer and interval timer functions can be used at the same time.

## 10.2 Configuration

The block diagram of the watch timer is shown below.

Internal bus PRSM0 register BGCE0 BGCS01 BGCS00 Clear PRSCM0 register 3-bit Clock control prescaler Match 1/2 fx/8 fx/4 Selector **f**BGCS 8-bit counter fx/2 fx Selector Selector Clear 5-bit counter - INTWT **f**BRG Selector 11-bit prescaler Clear fw/24 fw/25 fw/26 fw/27 fw/28 fw/210 fw/211 fw/29 fxT Selector INTWTI WTM7 WTM6 WTM5 WTM4 WTM3 WTM2 WTM1 WTM0 Watch timer operation mode register (WTM) Internal bus Remark fx: Main clock oscillation frequency fagcs: Watch timer source clock frequency Watch timer count clock frequency fBRG: fxT: Subclock frequency Watch timer clock frequency fw: INTWT: Watch timer interrupt request signal INTWTI: Interval timer interrupt request signal

Figure 10-1. Block Diagram of Watch Timer

#### (1) Clock control

This block controls supplying and stopping the operating clock (fx) when the watch timer operates on the main clock.

#### (2) 3-bit prescaler

This prescaler divides fx to generate fx/2, fx/4, or fx/8.

#### (3) 8-bit counter

This 8-bit counter counts the source clock (fBGCS).

#### (4) 11-bit prescaler

This prescaler divides fw to generate a clock of fw/2<sup>4</sup> to fw/2<sup>11</sup>.

#### (5) 5-bit counter

This counter counts fw or fw/2°, and generates a watch timer interrupt request signal at intervals of 2⁴/fw, 2⁵/fw, 2¹²/fw, or 2¹⁴/fw.

#### (6) Selector

The watch timer has the following five selectors.

- Selector that selects one of fx, fx/2, fx/4, or fx/8 as the source clock of the watch timer
- Selector that selects the main clock (fx) or subclock (fxT) as the clock of the watch timer
- Selector that selects fw or fw/29 as the count clock frequency of the 5-bit counter
- Selector that selects 2<sup>4</sup>/fw, 2<sup>13</sup>/fw, 2<sup>5</sup>/fw, or 2<sup>14</sup>/fw as the INTWT signal generation time interval
- Selector that selects 2<sup>4</sup>/fw to 2<sup>11</sup>/fw as the interval timer interrupt request signal (INTWTI) generation time interval

#### (7) PRSCM register

This is an 8-bit compare register that sets the interval time.

#### (8) PRSM register

This register controls clock supply to the watch timer.

### (9) WTM register

This is an 8-bit register that controls the operation of the watch timer/interval timer, and sets the interrupt request signal generation interval.

## 10.3 Control Registers

The following registers are provided for the watch timer.

- Prescaler mode register 0 (PRSM0)
- Prescaler compare register 0 (PRSCM0)
- Watch timer operation mode register (WTM)

## (1) Prescaler mode register 0 (PRSM0)

The PRSM0 register controls the generation of the watch timer count clock.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.



| I | BGCE0 | Main clock operation enable |
|---|-------|-----------------------------|
|   | 0     | Disabled                    |
|   | 1     | Enabled                     |

| BGCS01 | BGCS00 | Selection of watch timer source clock (faccs) |        |              |  |  |
|--------|--------|-----------------------------------------------|--------|--------------|--|--|
|        |        |                                               | 5 MHz  | 4 MHz        |  |  |
| 0      | 0      | fx                                            | 200 ns | 250 ns       |  |  |
| 0      | 1      | fx/2                                          | 400 ns | 500 ns       |  |  |
| 1      | 0      | fx/4                                          | 800 ns | 1 μs         |  |  |
| 1      | 1      | fx/8                                          | 1.6 µs | 2 <i>μ</i> s |  |  |

- Cautions 1. Do not change the values of the BGCS00 and BGCS01 bits during watch timer operation.
  - 2. Set the PRSM0 register before setting the BGCE0 bit to 1.
  - 3. Set the PRSM0 and PRSCM0 registers according to the main clock frequency that is used so as to obtain an fBRG frequency of 32.768 kHz.

# (2) Prescaler compare register 0 (PRSCM0)

The PRSCM0 register is an 8-bit compare register.

This register can be read or written in 8-bit units.

Reset input clears this register to 00H.



Cautions 1. Do not rewrite the PRSCM0 register during watch timer operation.

- 2. Set the PRSCM0 register before setting the PRSM0.BGCE0 bit to 1.
- 3. Set the PRSM0 and PRSCM0 registers according to the main clock frequency that is used so as to obtain an fare frequency of 32.768 kHz.

The calculation for fBRG is shown below.

 $f_{BRG} = f_{BGCS}/2N$ 

Remark faces: Watch timer source clock set by the PRSM0 register

N: Set value of the PRSCM0 register = 1 to 256

However, N = 256 when the PRSCM0 register is set to 00H.

## (3) Watch timer operation mode register (WTM)

The WTM register enables or disables the count clock and operation of the watch timer, sets the interval time of the prescaler, controls the operation of the 5-bit counter, and sets the set time of the watch flag.

Set the PRSM0 register before setting the WTM register.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

(1/2)

|     | 7    | 6    | 5    | 4    | 3    | 2    | <1>  | <0>  |   |
|-----|------|------|------|------|------|------|------|------|---|
| WTM | WTM7 | WTM6 | WTM5 | WTM4 | WTM3 | WTM2 | WTM1 | WTM0 | • |

| WTM7 | WTM6 | WTM5 | WTM4 | Selection of interval time of prescaler           |
|------|------|------|------|---------------------------------------------------|
| 0    | 0    | 0    | 0    | $2^4$ /fw (488 $\mu$ s: fw = fxT)                 |
| 0    | 0    | 0    | 1    | $2^{5}$ /fw (977 $\mu$ s: fw = fxT)               |
| 0    | 0    | 1    | 0    | $2^{6}/f_{W}$ (1.95 ms: $f_{W} = f_{XT}$ )        |
| 0    | 0    | 1    | 1    | $2^{7}$ /fw (3.91 ms: fw = fxT)                   |
| 0    | 1    | 0    | 0    | $2^{8}$ /fw (7.81 ms: fw = fxT)                   |
| 0    | 1    | 0    | 1    | $2^{9}$ /fw (15.6 ms: fw = fxT)                   |
| 0    | 1    | 1    | 0    | $2^{10}$ /fw (31.3 ms: fw = fxT)                  |
| 0    | 1    | 1    | 1    | $2^{11}$ /fw (62.5 ms: fw = fxT)                  |
| 1    | 0    | 0    | 0    | $2^4$ /fw (488 $\mu$ s: fw = f <sub>BRG</sub> )   |
| 1    | 0    | 0    | 1    | $2^{5}$ /fw (977 $\mu$ s: fw = f <sub>BRG</sub> ) |
| 1    | 0    | 1    | 0    | $2^{6}$ /fw (1.95 ms: fw = f <sub>BRG</sub> )     |
| 1    | 0    | 1    | 1    | $2^{7}$ /fw (3.90 ms: fw = f <sub>BRG</sub> )     |
| 1    | 1    | 0    | 0    | 28/fw (7.81 ms: fw = fBRG)                        |
| 1    | 1    | 0    | 1    | 29/fw (15.6 ms: fw = fBRG)                        |
| 1    | 1    | 1    | 0    | $2^{10}$ /fw (31.2 ms: fw = f <sub>BRG</sub> )    |
| 1    | 1    | 1    | 1    | $2^{11}$ /fw (62.5 ms: fw = f <sub>BRG</sub> )    |

(2/2)

| WTM7 | WTM3 | WTM2 | Selection of set time of watch flag                          |  |
|------|------|------|--------------------------------------------------------------|--|
| 0    | 0    | 0    | $2^{14}/f_W$ (0.5 s: $f_W = f_{XT}$ )                        |  |
| 0    | 0    | 1    | 2 <sup>13</sup> /fw (0.25 s: fw = fxτ)                       |  |
| 0    | 1    | 0    | $2^{5}/\text{fw} (977 \mu\text{s}: \text{ fw} = \text{fxt})$ |  |
| 0    | 1    | 1    | $2^4$ /fw (488 $\mu$ s: fw = fx $\tau$ )                     |  |
| 1    | 0    | 0    | 2 <sup>14</sup> /fw (0.5 s: fw = f <sub>BRG</sub> )          |  |
| 1    | 0    | 1    | 2 <sup>13</sup> /fw (0.25 s: fw = f <sub>BRG</sub> )         |  |
| 1    | 1    | 0    | $2^{5}$ /fw (977 $\mu$ s: fw = f <sub>BRG</sub> )            |  |
| 1    | 1    | 1    | $2^4$ /fw (488 $\mu$ s: fw = f <sub>BRG</sub> )              |  |

| WTM1 | Control of 5-bit counter operation |  |  |  |  |
|------|------------------------------------|--|--|--|--|
| 0    | Clears after operation stops       |  |  |  |  |
| 1    | Starts                             |  |  |  |  |

| WTM0 | Watch timer operation enable                              |  |  |  |
|------|-----------------------------------------------------------|--|--|--|
| 0    | Stops operation (clears both prescaler and 5-bit counter) |  |  |  |
| 1    | Enables operation                                         |  |  |  |

Caution Rewrite the WTM2 to WTM7 bits while both the WTM0 and WTM1 bits are 0.

Remarks 1. fw: Watch timer clock frequency

2. Values in parentheses apply to operation with fw = 32.768 kHz

#### 10.4 Operation

#### 10.4.1 Operation as watch timer

The watch timer generates an interrupt request signal (INTWT) at fixed time intervals. The watch timer operates using time intervals of 0.25 or 0.5 seconds with the subclock (32.768 kHz) or main clock.

The count operation starts when the WTM.WTM1 and WTM.WTM0 bits are set to 11. When the WTM0 bit is cleared to 0, the 11-bit prescaler and 5-bit counter are cleared and the count operation stops.

The time of the watch timer can be adjusted by clearing the WTM1 bit to 0 and then the 5-bit counter when operating at the same time as the interval timer. At this time, an error of up to 15.6 ms may occur for the watch timer, but the interval timer is not affected.

If the main clock is used as the count clock of the watch timer, set the count clock using the PRSM0.BGCS01 and BGCS00 bits, the 8-bit comparison value using the PRSCM0 register, and the count clock frequency (fbrg) of the watch timer to 32.768 kHz.

When the PRSM0.BGCE0 bit is set (1), fBRG is supplied to the watch timer.

fbrg can be calculated by the following expression.

$$f_{BRG} = f_X/(2^{m+1} \times N)$$

To set fBRG to 32.768 kHz, perform the following calculation and set the BGCS01 and BGCS00 bits and the PRSCM0 register.

- <1> Set N = fx/65,536. Set m = 0.
- <2> When the value resulting from rounding up the first decimal place of N is even, set N before the roundup as N/2 and m as m + 1.
- <3> Repeat <2> until N is odd or m=3.
- <4> Set the value resulting from rounding up the first decimal place of N to the PRSCM0 register and m to the BGCS01 and BGCS00 bits.

Example: When fx = 4.00 MHz

<1> N = 4,000,000/65,536 = 61.03..., m = 0

<2>, <3> Because N (round up the first decimal place) is odd, N = 61, m = 0.

<4> Set value of PRSCM0 register: 3DH (61), set value of BGCS01 and BGCS00 bits: 00

At this time, the actual fBRG frequency is as follows.

fbrg = 
$$fx/(2^{m+1} \times N) = 4,000,000/(2 \times 61)$$
  
= 32.787 kHz

**Remark** m: Division value (set value of BGCS01 and BGCS00 bits) = 0 to 3

N: Set value of PRSCM0 register = 1 to 256

However, N = 256 when PRSCM0 register is set to 00H.

fx: Main clock oscillation frequency

## 10.4.2 Operation as interval timer

The watch timer can also be used as an interval timer that repeatedly generates an interrupt request signal (INTWTI) at intervals specified by a preset count value.

The interval time can be selected by the WTM4 to WTM7 bits of the WTM register.

Table 10-1. Interval Time of Interval Timer

| WTM7 | WTM6 | WTM5 | WTM4 | Interval Time               |                                                               |  |
|------|------|------|------|-----------------------------|---------------------------------------------------------------|--|
| 0    | 0    | 0    | 0    | $2^4 \times 1/fw$           | 488 $\mu$ s (operating at fw = fxT = 32.768 kHz)              |  |
| 0    | 0    | 0    | 1    | $2^5 \times 1/fw$           | 977 $\mu$ s (operating at fw = fxT = 32.768 kHz)              |  |
| 0    | 0    | 1    | 0    | $2^6 \times 1/fw$           | 1.95 ms (operating at fw = fxT = 32.768 kHz)                  |  |
| 0    | 0    | 1    | 1    | $2^7 \times 1/fw$           | 3.91 ms (operating at $f_W = f_{XT} = 32.768 \text{ kHz}$ )   |  |
| 0    | 1    | 0    | 0    | $2^8 \times 1/fw$           | 7.81 ms (operating at $f_W = f_{XT} = 32.768 \text{ kHz}$ )   |  |
| 0    | 1    | 0    | 1    | 2° × 1/fw                   | 15.6 ms (operating at $f_W = f_{XT} = 32.768 \text{ kHz}$ )   |  |
| 0    | 1    | 1    | 0    | $2^{10} \times 1/\text{fw}$ | 31.3 ms (operating at $f_W = f_{XT} = 32.768 \text{ kHz}$ )   |  |
| 0    | 1    | 1    | 1    | $2^{11} \times 1/\text{fw}$ | 62.5 ms (operating at $f_W = f_{XT} = 32.768 \text{ kHz}$ )   |  |
| 1    | 0    | 0    | 0    | $2^4 \times 1/fw$           | 488 $\mu$ s (operating at fw = f <sub>BRG</sub> = 32.768 kHz) |  |
| 1    | 0    | 0    | 1    | $2^5 \times 1/fw$           | 977 $\mu$ s (operating at fw = f <sub>BRG</sub> = 32.768 kHz) |  |
| 1    | 0    | 1    | 0    | $2^6 \times 1/fw$           | 1.95 ms (operating at fw = f <sub>BRG</sub> = 32.768 kHz)     |  |
| 1    | 0    | 1    | 1    | $2^7 \times 1/fw$           | 3.91 ms (operating at fw = f <sub>BRG</sub> = 32.768 kHz)     |  |
| 1    | 1    | 0    | 0    | $2^8 \times 1/fw$           | 7.81 ms (operating at fw = f <sub>BRG</sub> = 32.768 kHz)     |  |
| 1    | 1    | 0    | 1    | 2 <sup>9</sup> × 1/fw       | 15.6 ms (operating at fw = f <sub>BRG</sub> = 32.768 kHz)     |  |
| 1    | 1    | 1    | 0    | $2^{10} \times 1/\text{fw}$ | 31.3 ms (operating at fw = f <sub>BRG</sub> = 32.768 kHz)     |  |
| 1    | 1    | 1    | 1    | $2^{11} \times 1/\text{fw}$ | 62.5 ms (operating at $fw = f_{BRG} = 32.768 \text{ kHz}$ )   |  |

Remark fw: Watch timer clock frequency



Figure 10-2. Operation Timing of Watch Timer/Interval Timer

#### 10.4.3 Cautions

Some time is required before the first watch timer interrupt request signal (INTWT) is generated after operation is enabled (WTM.WTM1 and WTM.WTM0 bits = 1).

Figure 10-3. Example of Generation of Watch Timer Interrupt Request Signal (INTWT) (When Interrupt Cycle = 0.5 s)



## **CHAPTER 11 FUNCTIONS OF WATCHDOG TIMER 2**

#### 11.1 Functions

Watchdog timer 2 has the following functions.

- Default-start watchdog timer Note 1
  - → Reset mode: Reset operation upon overflow of watchdog timer 2 (generation of WDT2RES signal)
  - → Non-maskable interrupt request mode: NMI operation upon overflow of watchdog timer 2 (generation of INTWDT2 signal)<sup>Note 2</sup>
- Input selectable from main clock, internal oscillation clock, and subclock as the source clock
  - Notes 1. Watchdog timer 2 automatically starts in the reset mode following reset release.

    When watchdog timer 2 is not used, either stop its operation before reset is executed via this function, or clear watchdog timer 2 once and stop it within the next interval time.

    Also, write to the WDTM2 register for verification purposes only once, even if the default settings (reset mode, interval time: fr/2<sup>19</sup>) do not need to be changed.
    - 2. For the non-maskable interrupt servicing due to a non-maskable interrupt request signal (INTWDT2), see 22.2.2 (2) INTWDT2 signal.

## 11.2 Configuration

The following shows the block diagram of watchdog timer 2.

 $fxx/2^{18}$  to  $fxx/2^{25}$ fxt/29 to fxt/216, fxx/29 -INTWDT2 Clock f<sub>R</sub>/2<sup>12</sup> to f<sub>R</sub>/2<sup>19</sup> Output 16-bit **f**xT input Selector controller counter WDT2RES controller  $f_R/2^3$ (internal reset signal) 2 13 Clear 3 0 WDM21 WDM20 WDCS24 WDCS23 WDCS22 WDCS21 WDCS2 Watchdog timer enable register (WDTE) Watchdog timer mode register 2 (WDTM2) Internal bus Remark fxx: Main clock frequency fxT: Subclock frequency fR: Internal oscillation clock frequency INTWDT2: Non-maskable interrupt request signal from watchdog timer 2 WDTRES2: Watchdog timer 2 reset signal

Figure 11-1. Block Diagram of Watchdog Timer 2

Watchdog timer 2 consists of the following hardware.

Table 11-1. Configuration of Watchdog Timer 2

| Item Configuration |                                        |
|--------------------|----------------------------------------|
| Control registers  | Watchdog timer mode register 2 (WDTM2) |
|                    | Watchdog timer enable register (WDTE)  |

## 11.3 Registers

## (1) Watchdog timer mode register 2 (WDTM2)

The WDTM2 register sets the overflow time and operation clock of watchdog timer 2.

This register can be read or written in 8-bit units. This register can be read any number of times, but it can be written only once following reset release.

Reset input sets this register to 67H.

Caution Accessing the WDTM2 register is prohibited in the following statuses. For details, see 3.4.9
(2) Accessing specific on-chip peripheral I/O registers.

- When the CPU operates with the subclock and the main clock oscillation is stopped
- When the CPU operates with the internal oscillation clock

After reset: 67H R/W Address: FFFFF6D0H

7 6 5 4 3 2 1 0

WDTM2 0 WDM21 WDM20 WDCS24 WDCS23 WDCS22 WDCS21 WDCS20

| WDM21 | WDM20 | Selection of operation mode of watchdog timer 2                    |  |
|-------|-------|--------------------------------------------------------------------|--|
| 0     | 0     | Stops operation                                                    |  |
| 0     | 1     | Non-maskable interrupt request mode (generation of INTWDT2 signal) |  |
| 1     | _     | Reset mode (generation of WDT2RES signal)                          |  |

- Cautions 1. For details of the WDCS20 to WDCS24 bits, see Table 11-2 Watchdog Timer 2 Clock Selection.
  - 2. Although watchdog timer 2 can be stopped just by stopping operation of the internal oscillator, clear the WDTM2 register to 00H to securely stop the timer (to avoid selection of the main clock or subclock due to an erroneous write operation).
  - 3. If the WDTM2 register is rewritten twice after reset, an overflow signal is forcibly generated and the counter is reset.
  - 4. To intentionally generate an overflow signal, write data to the WDTM2 register only twice, or write a value other than "ACH" to the WDTE register only once.
  - 5. To stop the operation of watchdog timer 2, set the RCM.RSTP bit to 1 (to stop the internal oscillator) and write 00H in the WDTM2 register. If the RCM.RSTP bit cannot be set to 1, set the WDCS23 bit to 1 (2"/fxx is selected and the clock can be stopped in the IDLE1, IDLW2, sub-IDLE, and subclock operation modes).

Table 11-2. Watchdog Timer 2 Clock Selection

| WDCS24 | WDCS23 | WDCS22 | WDCS21 | WDCS20 | Selected                         | 100 kHz (MIN.)   | 200 kHz (TYP.) | 400 kHz (MAX.) |
|--------|--------|--------|--------|--------|----------------------------------|------------------|----------------|----------------|
|        |        |        |        |        | Clock                            |                  |                |                |
| 0      | 0      | 0      | 0      | 0      | 2 <sup>12</sup> /f <sub>R</sub>  | 41.0 ms          | 20.5 ms        | 10.2 ms        |
| 0      | 0      | 0      | 0      | 1      | 2 <sup>13</sup> /f <sub>R</sub>  | 81.9 ms          | 41.0 ms        | 20.5 ms        |
| 0      | 0      | 0      | 1      | 0      | 2 <sup>14</sup> /f <sub>R</sub>  | 163.8 ms         | 81.9 ms        | 41.0 ms        |
| 0      | 0      | 0      | 1      | 1      | 2 <sup>15</sup> /f <sub>R</sub>  | 327.7 ms         | 163.8 ms       | 81.9 ms        |
| 0      | 0      | 1      | 0      | 0      | 2 <sup>16</sup> /f <sub>R</sub>  | 655.4 ms         | 327.7 ms       | 163.8 ms       |
| 0      | 0      | 1      | 0      | 1      | 2 <sup>17</sup> /f <sub>R</sub>  | 1,310.7 ms       | 655.4 ms       | 327.7 ms       |
| 0      | 0      | 1      | 1      | 0      | 2 <sup>18</sup> /f <sub>R</sub>  | 2,621.4 ms       | 1,310.7 ms     | 655.4 ms       |
| 0      | 0      | 1      | 1      | 1      | 2 <sup>19</sup> /f <sub>R</sub>  | 5,242.9 ms       | 2,621.47 ms    | 1,310.7 ms     |
|        |        |        |        |        |                                  | fxx = 32 MHz     | fxx = 20 MHz   | fxx = 10 MHz   |
| 0      | 1      | 0      | 0      | 0      | 2 <sup>18</sup> /fxx             | 8.2 ms           | 13.1 ms        | 26.2 ms        |
| 0      | 1      | 0      | 0      | 1      | 2 <sup>19</sup> /fxx             | 16.4 ms          | 26.2 ms        | 52.4 ms        |
| 0      | 1      | 0      | 1      | 0      | 2 <sup>20</sup> /fxx             | 32.8 ms          | 52.4 ms        | 104.9 ms       |
| 0      | 1      | 0      | 1      | 1      | 2 <sup>21</sup> /fxx             | 65.5 ms          | 104.9 ms       | 209.7 ms       |
| 0      | 1      | 1      | 0      | 0      | 2 <sup>22</sup> /fxx             | 131.1 ms         | 209.7 ms       | 419.4 ms       |
| 0      | 1      | 1      | 0      | 1      | 2 <sup>23</sup> /fxx             | 262.1 ms         | 419.4 ms       | 838.9 ms       |
| 0      | 1      | 1      | 1      | 0      | 2 <sup>24</sup> /fxx             | 524.3 ms         | 838.9 ms       | 1,677.7 ms     |
| 0      | 1      | 1      | 1      | 1      | 2 <sup>25</sup> /fxx             | 1,048.6 ms       | 1,677.7 ms     | 3,355.4 ms     |
|        |        |        |        |        |                                  | fxт = 32.768 kHz |                |                |
| 1      | ×      | 0      | 0      | 0      | 29/fxT                           | 15.625 ms        |                |                |
| 1      | ×      | 0      | 0      | 1      | 2 <sup>10</sup> /fxT             | 31.25 ms         |                |                |
| 1      | ×      | 0      | 1      | 0      | 2 <sup>11</sup> /fxT             | 62.5 ms          |                |                |
| 1      | ×      | 0      | 1      | 1      | 2 <sup>12</sup> /fxT             | 125 ms           |                |                |
| 1      | ×      | 1      | 0      | 0      | 2 <sup>13</sup> /f <sub>XT</sub> | 250 ms           |                |                |
| 1      | ×      | 1      | 0      | 1      | 2 <sup>14</sup> /fxT             | 500 ms           |                |                |
| 1      | ×      | 1      | 1      | 0      | 2 <sup>15</sup> /fxT             | 1,000 ms         |                |                |
| 1      | ×      | 1      | 1      | 1      | 2 <sup>16</sup> /fxT             | 2,000 ms         |                |                |

#### (2) Watchdog timer enable register (WDTE)

The counter of watchdog timer 2 is cleared and counting restarted by writing "ACH" to the WDTE register.

The WDTE register can be read or written in 8-bit units.

Reset input sets this register to 9AH.



Cautions 1. When a value other than "ACH" is written to the WDTE register, an overflow signal is forcibly output.

- 2. When a 1-bit memory manipulation instruction is executed for the WDTE register, an overflow signal is forcibly output.
- 3. To intentionally generate an overflow signal, write a value other than "ACH" to the WDTE register only once, or write data to the WDTM2 register only twice.
- 4. The read value of the WDTE register is "9AH" (which differs from written value "ACH").

### 11.4 Operation

Watchdog timer 2 automatically starts in the reset mode following reset release.

The WDTM2 register can be written to only once following reset using byte access. To use watchdog timer 2, write the operation mode and the interval time to the WDTM2 register using an 8-bit memory manipulation instruction. After this, the operation of watchdog timer 2 cannot be stopped.

The WDCS24 to WDCS20 bits of the WDTM2 register are used to select the watchdog timer 2 loop detection time interval.

Writing ACH to the WDTE register clears the counter of watchdog timer 2 and starts the count operation again. After the count operation has started, write ACH to WDTE within the loop detection time interval.

If the time interval expires without ACH being written to the WDTE register, a reset signal (WDT2RES) or a non-maskable interrupt request signal (INTWDT2) is generated, depending on the set values of the WDM21 and WDTM2.WDM20 bits.

When the WDTM2.WDM21 bit is set to 1 (reset mode), if a WDT overflow occurs during oscillation stabilization after a reset or standby is released, no internal reset will occur and the CPU clock will switch to the internal oscillation clock.

To not use watchdog timer 2, write 00H to the WDTM2 register.

For the non-maskable interrupt servicing while the non-maskable interrupt request mode is set, see 22.2.2 (2) INTWDT2 signal.

# CHAPTER 12 REAL-TIME OUTPUT FUNCTION (RTO)

#### 12.1 Function

The real-time output function transfers preset data to the RTBL0 and RTBH0 registers, and then transfers this data by hardware to an external device via the output latches, upon occurrence of a timer interrupt. The pins through which the data is output to an external device constitute a port called the real-time output function (RTO).

Because RTO can output signals without jitter, it is suitable for controlling a stepper motor.

In the V850ES/SG2, one 6-bit real-time output port channel is provided.

The real-time output port can be set to the port mode or real-time output port mode in 1-bit units.

## 12.2 Configuration

The block diagram of RTO is shown below.

Real-time output Real-time output buffer register 0H (RTBH0) RTP04, Internal bus latch 0H RTP05 Real-time output Real-time output buffer register 0L (RTBL0) RTP00 to latch 0L RTP03 INTTP0CC0 Transfer trigger (H) Selector INTTP5CC0 Transfer trigger (L) INTTP4CC0 2 4 RTPOE0 RTPEG0 BYTE0 RTPM05 RTPM04 RTPM03 RTPM02 RTPM01 RTPM00 Real-time output port control Real-time output port mode register 0 (RTPC0) register 0 (RTPM0)

Figure 12-1. Block Diagram of RTO

RTO consists of the following hardware.

Table 12-1. Configuration of RTO

| Item Configuration                                                |                                                                                                |
|-------------------------------------------------------------------|------------------------------------------------------------------------------------------------|
| Registers Real-time output buffer registers 0L, 0H (RTBL0, RTBH0) |                                                                                                |
| Control registers                                                 | Real-time output port mode register 0 (RTPM0) Real-time output port control register 0 (RTPC0) |

#### (1) Real-time output buffer registers 0L, 0H (RTBL0, RTBH0)

The RTBL0 and RTBH0 registers are 4-bit registers that hold preset output data.

These registers are mapped to independent addresses in the peripheral I/O register area.

These registers can be read or written in 8-bit or 1-bit units.

Reset input clears these registers to 00H.

If an operation mode of 4 bits  $\times$  1 channel or 2 bits  $\times$  1 channel is specified (RTPC0.BYTE0 bit = 0), data can be individually set to the RTBL0 and RTBH0 registers. The data of both these registers can be read at once by specifying the address of either of these registers.

If an operation mode of 6 bits  $\times$  1 channel is specified (BYTE0 bit = 1), 8-bit data can be set to both the RTBL0 and RTBH0 registers by writing the data to either of these registers. Moreover, the data of both these registers can be read at once by specifying the address of either of these registers.

Table 12-2 shows the operation when the RTBL0 and RTBH0 registers are manipulated.



Cautions 1. When writing to bits 6 and 7 of the RTBH0 register, always write 0.

- 2. Accessing the RTBL0 and RTBH0 registers is prohibited in the following statuses. For details, see 3.4.9 (2) Accessing specific on-chip peripheral I/O registers.
  - When the CPU operates with the subclock and the main clock oscillation is stopped
  - When the CPU operates with the internal oscillation clock

Table 12-2. Operation During Manipulation of RTBL0 and RTBH0 Registers

| Operation Mode      | Register to Be | Read          |              | Write <sup>Note</sup> |              |
|---------------------|----------------|---------------|--------------|-----------------------|--------------|
|                     | Manipulated    | Higher 4 Bits | Lower 4 Bits | Higher 4 Bits         | Lower 4 Bits |
| 4 bits × 1 channel, | RTBL0          | RTBH0         | RTBL0        | Invalid               | RTBL0        |
| 2 bits × 1 channel  | RTBH0          | RTBH0         | RTBL0        | RTBH0                 | Invalid      |
| 6 bits × 1 channel  | RTBL0          | RTBH0         | RTBL0        | RTBH0                 | RTBL0        |
|                     | RTBH0          | RTBH0         | RTBL0        | RTBH0                 | RTBL0        |

**Note** After setting the real-time output port, set output data to the RTBL0 and RTBH0 registers by the time a real-time output trigger is generated.

## 12.3 Registers

RTO is controlled using the following two registers.

- Real-time output port mode register 0 (RTPM0)
- Real-time output port control register 0 (RTPC0)

## (1) Real-time output port mode register 0 (RTPM0)

The RTPM0 register selects the real-time output port mode or port mode in 1-bit units.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.



| RTPM0m | Control of real-time output port (m = 0 to 5) |  |
|--------|-----------------------------------------------|--|
| 0      | Real-time output disabled                     |  |
| 1      | 1 Real-time output enabled                    |  |

- Cautions 1. By enabling the real-time output operation (RTPC0.RTPOE0 bit = 1), the bits enabled to real-time output among the RTP00 to RTP05 signals perform real-time output, and the bits set to port mode output 0.
  - 2. If real-time output is disabled (RTPOE0 bit = 0), the real-time output pins (RTP00 to RTP05) all output 0, regardless of the RTPM0 register setting.
  - 3. In order to use this register as the real-time output pins (RTP00 to RTP05), set these pins as real-time output port pins using the PMC and PFC registers.

#### (2) Real-time output port control register 0 (RTPC0)

The RTPC0 register is a register that sets the operation mode and output trigger of the real-time output port.

The relationship between the operation mode and output trigger of the real-time output port is as shown in Table 12-3.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

After reset: 00H R/W Address: FFFF6E5H

<7> 6 5 4 3 2 1 0

RTPC0 RTPC60 RTPEG0 BYTE0 EXTR0 0 0 0 0

| RTPOE0 | Control of real-time output operation |  |
|--------|---------------------------------------|--|
| 0      | Disables operation <sup>Note 1</sup>  |  |
| 1      | Enables operation                     |  |

| RTPEG0 | Valid edge of INTTP0CC0 signal |
|--------|--------------------------------|
| 0      | Falling edge <sup>Note 2</sup> |
| 1      | Rising edge                    |

| BYTE0 | Specification of channel configuration for real-time output |  |
|-------|-------------------------------------------------------------|--|
| 0     | 4 bits × 2 channels, 2 bits × 2 channels                    |  |
| 1     | 6 bits × 2 channels                                         |  |

**Notes 1.** When the real-time output operation is disabled (RTPOE0 bit = 0), all the bits of the real-time output signals (RTP00 to RTP05) output "0".

2. The INTTPOCCO signal is output for 1 clock of the count clock selected by TMP0.

Caution Set the RTPEG0, BYTE0, and EXTR0 bits only when RTPOE0 bit = 0.

Table 12-3. Operation Modes and Output Triggers of Real-Time Output Port

| BYTE0 | EXTR0 | Operation Mode      | RTBH0 (RTP04, RTP05) | RTBL0 (RTP00 to RTP03) |
|-------|-------|---------------------|----------------------|------------------------|
| 0     | 0     | 4 bits × 1 channel, | INTTP5CC0            | INTTP4CC0              |
|       | 1     | 2 bits × 1 channel  | INTTP4CC0            | INTTP0CC0              |
| 1     | 0     | 6 bits × 1 channel  | INTTP4CC0            |                        |
|       | 1     |                     | INTTP0CC0            |                        |

## 12.4 Operation

If the real-time output operation is enabled by setting the RTPC0.RTPOE0 bit to 1, the data of the RTBH0 and RTBL0 registers is transferred to the real-time output latch in synchronization with the generation of the selected transfer trigger (set by the RTPC0.EXTR0 and RTPC0.BYTE0 bits). Of the transferred data, only the data of the bits for which real-time output is enabled by the RTPM0 register is output from the RTP00 to RTP05 bits. The bits for which real-time output is disabled by the RTPM0 register output 0.

If the real-time output operation is disabled by clearing the RTPOE0 bit to 0, the RTP00 to RTP05 signals output 0 regardless of the setting of the RTPM0 register.



Figure 12-2. Example of Operation Timing of RTO0 (When EXTR0 Bit = 0, BYTE0 Bit = 0)

Remark For the operation during standby, see CHAPTER 24 STANDBY FUNCTION.

## 12.5 Usage

(1) Disable real-time output.

Clear the RTPC0.RTPOE0 bit to 0.

- (2) Perform initialization as follows.
  - Set the alternate-function pins of port 5

Set the PFC5.PFC5m bit and PFCE5.PFCE5m bit to 1, and then set the PMC5.PMC5m bit to 1 (m = 0 to 5).

- Specify the real-time output port mode or port mode in 1-bit units.
  - Set the RTPM0 register.
- Channel configuration: Select the trigger and valid edge.

Set the RTPC0.EXTR0, RTPC0.BYTE0, and RTPC0.RTPEG0 bits.

- Set the initial values to the RTBH0 and RTBL0 registers Note 1.
- (3) Enable real-time output.

Set the RTPOE0 bit = 1.

- (4) Set the next output value to the RTBH0 and RTBL0 registers by the time the selected transfer trigger is generated<sup>Note 2</sup>.
- (5) Set the next real-time output value to the RTBH0 and RTBL0 registers via interrupt servicing corresponding to the selected trigger.
  - **Notes 1.** If the RTBH0 and RTBL0 registers are written when the RTPOE0 bit = 0, that value is transferred to real-time output latches 0H and 0L, respectively.
    - 2. Even if the RTBH0 and RTBL0 registers are written when the RTPOE0 bit = 1, data is not transferred to real-time output latches 0H and 0L.

### 12.6 Cautions

- (1) Prevent the following conflicts by software.
  - Conflict between real-time output disable/enable switching (RTPOE0 bit) and selected real-time output trigger.
  - Conflict between writing to the RTBH0 and RTBL0 registers in the real-time output enabled status and the selected real-time output trigger.
- (2) Before performing initialization, disable real-time output (RTPOE0 bit = 0).
- (3) Once real-time output has been disabled (RTPOE0 bit = 0), be sure to initialize the RTBH0 and RTBL0 registers before enabling real-time output again (RTPOE0 bit =  $0 \rightarrow 1$ ).

## **CHAPTER 13 A/D CONVERTER**

#### 13.1 Overview

The A/D converter converts analog input signals into digital values, has a resolution of 10 bits, and can handle 12 analog input signal channels (ANI0 to ANI11).

The A/D converter has the following features.

- O 10-bit resolution
- O 12 channels
- O Successive approximation method
- O Operating voltage: AVREF0 = 3.0 to 3.6 V
- O Analog input voltage: 0 V to AVREFO
- O The following functions are provided as operation modes.
  - · Continuous select mode
  - Continuous scan mode
  - One-shot select mode
  - One-shot scan mode
- O The following functions are provided as trigger modes.
  - Software trigger mode
  - External trigger mode (external, 1)
  - Timer trigger mode
- O Power-fail monitor function (conversion result compare function)

#### 13.2 Functions

### (1) 10-bit resolution A/D conversion

An analog input channel is selected from ANI0 to ANI11, and an A/D conversion operation is repeated at a resolution of 10 bits. Each time A/D conversion has been completed, an interrupt request signal (INTAD) is generated.

#### (2) Power-fail detection function

This function is used to detect a drop in the battery voltage. The result of A/D conversion (the value of the ADA0CRnH register) is compared with the value of the ADA0PFT register, and the INTAD signal is generated only when a specified comparison condition is satisfied (n = 0 to 11).

# 13.3 Configuration

The block diagram of the A/D converter is shown below.

O AVREFO ADA0CE bit ANIO 🔾 Sample & hold circuit ANI1 O Tap selector ANI2 Selector ANI9 🔿 ADA0CE bit ANI10 Voltage ANI11 O comparator SAR ADA0TMD1 bit ADA0TMD0 bit - INTAD INTTP2CC0 ADA0PFE bit Selector ADA0PFC bit Controller INTTP2CC1 Controller ADA0CR0 ADTRG O ADA0CR1 ADA0CR2 Voltage ADA0ETS0 bit comparator ADA0ETS1 bit ADA0CR10 ADA0M0 ADA0M1 ADA0M2 ADA0S ADA0PFM ADA0CR11 ADA0PFT Internal bus

Figure 13-1. Block Diagram of A/D Converter

The A/D converter includes the following hardware.

Table 13-1. Configuration of A/D Converter

| Item              | Configuration                                                                                                                                                                                                  |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Analog inputs     | 12 channels (ANI0 to ANI11 pins)                                                                                                                                                                               |
| Registers         | Successive approximation register (SAR) A/D conversion result registers 0 to 11 (ADA0CR0 to ADA0CR11) A/D conversion result registers 0H to 11H (ADCR0H to ADCR11H): Only higher 8 bits can be read            |
| Control registers | A/D converter mode registers 0 to 2 (ADA0M0 to ADA0M2) A/D converter channel specification register 0 (ADA0S) Power fail compare mode register (ADA0PFM) Power fail compare threshold value register (ADA0PFT) |

#### (1) Successive approximation register (SAR)

The SAR register compares the voltage value of the analog input signal with the voltage tap (compare voltage) value from the series resistor string, and holds the comparison result starting from the most significant bit (MSB).

When the comparison result has been held down to the least significant bit (LSB) (i.e., when A/D conversion is complete), the contents of the SAR register are transferred to the ADAOCRn register.

**Remark** n = 0 to 11

## (2) A/D conversion result register n (ADA0CRn), A/D conversion result register nH (ADA0CRnH)

The ADA0CRn register is a 16-bit register that stores the A/D conversion result. ADA0ARn consist of 12 registers and the A/D conversion result is stored in the 10 higher bits of the AD0CRn register corresponding to analog input. (The lower 6 bits are fixed to 0.)

#### (3) A/D converter mode register 0 (ADA0M0)

This register specifies the operation mode and controls the conversion operation by the A/D converter.

#### (4) A/D converter mode register 1 (ADA0M1)

This register sets the conversion time of the analog input signal to be converted.

#### (5) A/D converter mode register 2 (ADA0M2)

This register sets the hardware trigger mode.

#### (6) A/D converter channel specification register (ADA0S)

This register sets the input port that inputs the analog voltage to be converted.

## (7) Power-fail compare mode register (ADA0PFM)

This register sets the power-fail monitor mode.

### (8) Power-fail compare threshold value register (ADA0PFT)

The ADA0PFT register sets a threshold value that is compared with the value of A/D conversion result register nH (ADA0CRnH). The 8-bit data set to the ADA0PFT register is compared with the higher 8 bits of the A/D conversion result register (ADA0CRnH).

### (9) Controller

The controller compares the result of the A/D conversion (the value of the ADA0CRnH register) with the value of the ADA0PFT register when A/D conversion is completed or when the power-fail detection function is used, and generates the INTAD signal only when a specified comparison condition is satisfied.

## (10) Sample & hold circuit

The sample & hold circuit samples each of the analog input signals selected by the input circuit and sends the sampled data to the voltage comparator. This circuit also holds the sampled analog input signal voltage during A/D conversion.

## (11) Voltage comparator

The voltage comparator compares a voltage value that has been sampled and held with the voltage value of the series resistor string.

## (12) Series resistor string

This series resistor string is connected between AVREFO and AVss and generates a voltage for comparison with the analog input signal.

## (13) ANIO to ANI11 pins

These are analog input pins for the 12 A/D converter channels and are used to input analog signals to be converted into digital signals. Pins other than the one selected as the analog input by the ADA0S register can be used as input port pins.

Caution Make sure that the voltages input to the ANI0 to ANI11 pins do not exceed the rated values. In particular if a voltage of AVREFO or higher is input to a channel, the conversion value of that channel becomes undefined, and the conversion values of the other channels may also be affected.

#### (14) AVREFO pin

This is the pin used to input the reference voltage of the A/D converter. Always make the potential at this pin the same as that at the V<sub>DD</sub> pin even when the A/D converter is not used. The signals input to the ANI0 to ANI11 pins are converted to digital signals based on the voltage applied between the AV<sub>REFO</sub> and AV<sub>SS</sub> pins.

#### (15) AVss pin

This is the ground pin of the A/D converter. Always make the potential at this pin the same as that at the Vss pin even when the A/D converter is not used.

## 13.4 Registers

The A/D converter is controlled by the following registers.

- A/D converter mode registers 0, 1, 2 (ADA0M0, ADA0M1, ADA0M2)
- A/D converter channel specification register 0 (ADA0S)
- Power-fail compare mode register (ADA0PFM)

The following registers are also used.

- A/D conversion result register n (ADA0CRn)
- A/D conversion result register nH (ADA0CRnH)
- Power-fail compare threshold value register (ADA0PFT)

## (1) A/D converter mode register 0 (ADA0M0)

The ADA0M0 register is an 8-bit register that specifies the operation mode and controls conversion operations. This register can be read or written in 8-bit or 1-bit units. However, ADA0EF bit is read-only. Reset input clears this register to 00H.

Caution Accessing the ADA0M0 register is prohibited in the following statuses. For details, see 3.4.9

(2) Accessing specific on-chip peripheral I/O registers.

- When the CPU operates with the subclock and the main clock oscillation is stopped
- When the CPU operates with the internal oscillation clock

(1/2)Address: FFFFF200H After reset: 00H R/W 6 5 3 <0> <7> 0 ADA0MD1 | ADA0MD0 | ADA0ETS1 | ADA0ETS0 | ADA0TMD ADA0M0 ADA0CE ADA0EF ADA0CE A/D conversion control 0 Stops A/D conversion 1 Enables A/D conversion ADA0MD1 ADA0MD0 Specification of A/D converter operation mode 0 Continuous select mode 0 1 Continuous scan mode 1 0 One-shot select mode 1 One-shot scan mode

(2/2)

| ADA0ETS1 ADA0ETS0 |   | Specification of external trigger (ADTRG pin) input valid edge |
|-------------------|---|----------------------------------------------------------------|
| 0                 | 0 | No edge detection                                              |
| 0                 | 1 | Falling edge detection                                         |
| 1                 | 0 | Rising edge detection                                          |
| 1                 | 1 | Detection of both rising and falling edges                     |

| ADA0TMD | Trigger mode specification               |
|---------|------------------------------------------|
| 0       | Software trigger mode                    |
| 1       | External trigger mode/timer trigger mode |

| ADA0EF | A/D converter status display |
|--------|------------------------------|
| 0      | A/D conversion stopped       |
| 1      | A/D conversion in progress   |

Cautions 1. If bit 0 is written, this is ignored.

- 2. Changing the ADA0M1.ADA0FR2 to ADA0M1.ADA0FR0 bits is prohibited while A/D conversion is enabled (ADA0CE bit = 1).
- 3. In the following modes, write data to the ADA0M0, ADA0M2, ADA0S, ADA0PFM, and ADA0PFT registers while A/D conversion is stopped (ADA0CE bit = 0), and then enable the A/D conversion operation (ADA0CE bit = 1).
  - Normal conversion mode
  - One-shot select mode/one-shot scan mode of high-speed conversion mode
     If data is written to the ADA0M0, ADA0M2, ADA0S, ADA0PFM, and ADA0PFT registers
     in any other modes during A/D conversion (ADA0EF bit = 1), the operation is performed
     as follows, depending on the mode.
  - In software trigger mode
     A/D conversion is stopped and started again from the beginning.
  - In hardware trigger mode
     A/D conversion is stopped, and the trigger standby state is set.
- 4. To select the external trigger mode/timer trigger mode (ADA0TMD bit = 1), set the high-speed conversion mode (ADA0M1.ADA0HS1 bit = 1). Do not input a trigger during stabilization time that is inserted once after the A/D conversion operation is enabled (ADA0CE bit = 1).
- 5. When not using the A/D converter, stop the operation by setting the ADA0CE bit to 0 to reduce the power consumption.

## (2) A/D converter mode register 1 (ADA0M1)

The ADA0M1 register is an 8-bit register that specifies the conversion time.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this bit to 00H.



- Cautions 1. Changing the ADA0M1 register is prohibited while A/D conversion is enabled (ADA0M0.ADA0CE bit = 1).
  - To select the external trigger mode/timer trigger mode (ADA0M0.ADA0TMD bit = 1), set
    the high-speed conversion mode (ADA0M1.ADA0HS1 bit = 1). Do not input a trigger
    during stabilization time that is inserted only once after the A/D conversion operation
    is enabled (ADA0CE bit = 1).
  - 3. Be sure to clear bits 6 to 4 to 0.

**Remark** For A/D conversion time setting examples, see **Tables 13-2** and **13-3**.

Table 13-2. Conversion Time Selection in Normal Conversion Mode (ADA0HS1 Bit = 0)

| ADA0FR3 to       | A/D Conversion Time         |                    |                    |                    |                    |               |  |  |
|------------------|-----------------------------|--------------------|--------------------|--------------------|--------------------|---------------|--|--|
| ADA0FR0 Bits     | Stabilization Time +        | fxx = 32 MHz       | fxx = 20 MHz       | fxx = 16 MHz       | fxx = 4 MHz        | Trigger       |  |  |
|                  | Conversion Time + Wait Time |                    |                    |                    |                    | Response Time |  |  |
| 0000             | 13/fxx + 26/fxx + 26/fxx    | Setting prohibited | Setting prohibited | Setting prohibited | 16.25 <i>μ</i> s   | 4/fxx         |  |  |
| 0001             | 26/fxx + 52/fxx + 52/fxx    | Setting prohibited | 6.5 <i>μ</i> s     | 8.125 <i>μ</i> s   | Setting prohibited | 5/fxx         |  |  |
| 0010             | 39/fxx + 78/fxx + 78/fxx    | Setting prohibited | 9.75 <i>μ</i> s    | 12.1875 <i>μ</i> s | Setting prohibited | 6/fxx         |  |  |
| 0011             | 50/fxx + 104/fxx + 104/fxx  | 8.0625 <i>μ</i> s  | 12.9 <i>μ</i> s    | 16.125 <i>μ</i> s  | Setting prohibited | 7/fxx         |  |  |
| 0100             | 50/fxx + 130/fxx + 130/fxx  | 9.6875 <i>μ</i> s  | 15.5 <i>μ</i> s    | 19.375 <i>μ</i> s  | Setting prohibited | 8/fxx         |  |  |
| 0101             | 50/fxx + 156/fxx + 156/fxx  | 11.3125 <i>μ</i> s | 18.1 <i>μ</i> s    | 22.625 <i>μ</i> s  | Setting prohibited | 9/fxx         |  |  |
| 0110             | 50/fxx + 182/fxx + 182/fxx  | 12.9375 <i>μ</i> s | 20.7 μs            | Setting prohibited | Setting prohibited | 10/fxx        |  |  |
| 0111             | 50/fxx + 208/fxx + 208/fxx  | 14.5625 <i>μ</i> s | 23.3 μs            | Setting prohibited | Setting prohibited | 11/fxx        |  |  |
| 1000             | 50/fxx + 234/fxx + 234/fxx  | 16.1875 <i>μ</i> s | Setting prohibited | Setting prohibited | Setting prohibited | 12/fxx        |  |  |
| 1001             | 50/fxx + 260/fxx + 260/fxx  | 17.8125 <i>μ</i> s | Setting prohibited | Setting prohibited | Setting prohibited | 13/fxx        |  |  |
| 1010             | 50/fxx + 286/fxx + 286/fxx  | 19.4375 <i>μ</i> s | Setting prohibited | Setting prohibited | Setting prohibited | 14/fxx        |  |  |
| 1011             | 50/fxx + 312/fxx + 312/fxx  | 21.0625 μs         | Setting prohibited | Setting prohibited | Setting prohibited | 15/fxx        |  |  |
| Other than above | Setting prohibited          |                    |                    |                    |                    |               |  |  |

**Remark** Stabilization time: A/D converter setup time (1  $\mu$ s or longer)

Conversion time: Actual A/D conversion time (2.6 to 10.4  $\mu$ s)

Conversion time: Actual A/D conversion time (2.6 to 10.4  $\mu$ s) Wait time: Wait time inserted before the next conversion

Trigger response time: If a software trigger, external trigger, or timer trigger is generated after the

stabilization time, it is inserted before the conversion time.

In the normal conversion mode, the conversion is started after the stabilization time elapsed from the ADA0M0.ADA0CE bit is set to 1, and A/D conversion is performed only during the conversion time (2.6 to 10.4  $\mu$ s). Operation is stopped after the conversion ends and the A/D conversion end interrupt request signal (INTAD) is generated after the wait time is elapsed.

Because the conversion operation is stopped during the wait time, operation current can be reduced.

Caution Set as 2.6  $\mu$ s  $\leq$  conversion time  $\leq$  10.4  $\mu$ s.

Table 13-3. Conversion Time Selection in High-Speed Conversion Mode (ADA0HS1 Bit = 1)

| ADA0FR3 to       | A/D Conversion Time                       |                            |                                      |                           |                       |                          |  |  |  |
|------------------|-------------------------------------------|----------------------------|--------------------------------------|---------------------------|-----------------------|--------------------------|--|--|--|
| ADA0FR0 Bits     | Conversion Time<br>(+ Stabilization Time) | fxx = 32 MHz               | fxx = 20 MHz                         | fxx = 16 MHz              | fxx = 4 MHz           | Trigger<br>Response Time |  |  |  |
| 0000             | 26/fxx (+ 13/fxx)                         | Setting prohibited         | Setting prohibited                   | Setting prohibited        | 6.5 μs<br>(+ 3.25 μs) | 4/fxx                    |  |  |  |
| 0001             | 52/fxx (+ 26/fxx)                         | Setting prohibited         | 2.6 μs<br>(+ 1.3 μs)                 | 3.25 μs<br>(+ 1.625 μs)   | Setting prohibited    | 5/fxx                    |  |  |  |
| 0010             | 78/fxx (+ 39/fxx)                         | Setting prohibited         | 3.9 μs<br>(+ 1.95 μs)                | 4.875 μs<br>(+ 2.4375 μs) | Setting prohibited    | 6/fxx                    |  |  |  |
| 0011             | 104/fxx (+ 50/fxx)                        | 3.25 μs<br>(+ 1.5625 μs)   | 5.2 μs<br>(+ 2.5 μs)                 | 6.5 μs<br>(+ 3.125 μs)    | Setting prohibited    | 7/fxx                    |  |  |  |
| 0100             | 130/fxx (+ 50/fxx)                        | 4.0625 μs<br>(+ 1.5625 μs) | 6.5 μs<br>(+ 2.5 μs)                 | 8.125 μs<br>(+ 3.125 μs)  | Setting prohibited    | 8/fxx                    |  |  |  |
| 0101             | 156/fxx (+ 50/fxx)                        | 4.875 μs<br>(+ 1.5625 μs)  | 7.8 μs<br>(+ 2.5 μs)                 | 9.75 μs<br>(+ 3.125 μs)   | Setting prohibited    | 9/fxx                    |  |  |  |
| 0110             | 182/fxx (+ 50/fxx)                        | 5.6875 μs<br>(+ 1.5625 μs) | 9.1 <i>μ</i> s<br>(+ 2.5 <i>μ</i> s) | Setting prohibited        | Setting prohibited    | 10/fxx                   |  |  |  |
| 0111             | 208/fxx (+ 50/fxx)                        | 6.5 μs<br>(+ 1.5625 μs)    | 10.4 μs<br>(+ 2.5 μs)                | Setting prohibited        | Setting prohibited    | 11/fxx                   |  |  |  |
| 1000             | 234/fxx (+ 50/fxx)                        | 7.3125 μs<br>(+ 1.5625 μs) | Setting prohibited                   | Setting prohibited        | Setting prohibited    | 12/fxx                   |  |  |  |
| 1001             | 260/fxx (+ 50/fxx)                        | 8.125 μs<br>(+ 1.5625 μs)  | Setting prohibited                   | Setting prohibited        | Setting prohibited    | 13/fxx                   |  |  |  |
| 1010             | 286/fxx (+ 50/fxx)                        | 8.9375 μs<br>(+ 1.5625 μs) | Setting prohibited                   | Setting prohibited        | Setting prohibited    | 14/fxx                   |  |  |  |
| 1011             | 312/fxx (+ 50/fxx)                        | 9.75 μs<br>(+ 1.5625 μs)   | Setting prohibited                   | Setting prohibited        | Setting prohibited    | 15/fxx                   |  |  |  |
| Other than above | Setting prohibited                        | •                          |                                      |                           |                       |                          |  |  |  |

**Remark** Conversion time: Actual A/D conversion time (2.6 to 10.4  $\mu$ s) Stabilization time: A/D converter setup time (1  $\mu$ s or longer)

Trigger response time: If a software trigger, external trigger, or timer trigger is generated after the

stabilization time, it is inserted before the conversion time.

In the high-speed conversion mode, the conversion is started after the stabilization time elapsed from the ADA0M0.ADA0CE bit is set to 1, and A/D conversion is performed only during the conversion time (2.6 to 10.4  $\mu$ s). The A/D conversion end interrupt request signal (INTAD) is generated immediately after the conversion ends.

In continuous conversion mode, the stabilization time is inserted only before the first conversion, and not inserted after the second conversion (the A/D converter remains running).

Caution Set as 2.6  $\mu$ s  $\leq$  conversion time  $\leq$  10.4  $\mu$ s.

# (3) A/D converter mode register 2 (ADA0M2)

The ADA0M2 register specifies the hardware trigger mode.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

| After reset: 00H R/W |   | R/W | Address: F | FFFF203H | ł |   |          |          |
|----------------------|---|-----|------------|----------|---|---|----------|----------|
|                      | 7 | 6   | 5          | 4        | 3 | 2 | 1        | 0        |
| ADA0M2               | 0 | 0   | 0          | 0        | 0 | 0 | ADA0TMD1 | ADA0TMD0 |

| ADA0TMD1 | ADA0TMD0 | Specification of hardware trigger mode                            |
|----------|----------|-------------------------------------------------------------------|
| 0        | 0        | External trigger mode (when ADTRG pin valid edge detected)        |
| 0        | 1        | Timer trigger mode 0 (when INTTP2CC0 interrupt request generated) |
| 1        | 0        | Timer trigger mode 1 (when INTTP2CC1 interrupt request generated) |
| 1        | 1        | Setting prohibited                                                |

- Cautions 1. In the following modes, write data to the ADA0M2 register while A/D conversion is stopped (ADA0M0.ADA0CE bit = 0), and then enable the A/D conversion operation (ADA0CE bit = 1).
  - Normal conversion mode
  - One-shot select mode/one-shot scan mode of the high-speed conversion mode
  - 2. Be sure to clear bits 7 to 2 to 0.

# (4) Analog input channel specification register 0 (ADA0S)

The ADAOS register specifies the pin that inputs the analog voltage to be converted into a digital signal.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

After reset: 00H R/W Address: FFFFF202H

7 6 5 4 3 2 1 0

ADA0S 0 0 0 ADA0S3 ADA0S2 ADA0S1 ADA0S0

| ADA0S3 | ADA0S2 | ADA0S1 | ADA0S0 | Select mode        | Scan mode          |
|--------|--------|--------|--------|--------------------|--------------------|
| 0      | 0      | 0      | 0      | ANI0               | ANI0               |
| 0      | 0      | 0      | 1      | ANI1               | ANIO, ANI1         |
| 0      | 0      | 1      | 0      | ANI2               | ANI0 to ANI2       |
| 0      | 0      | 1      | 1      | ANI3               | ANI0 to ANI3       |
| 0      | 1      | 0      | 0      | ANI4               | ANI0 to ANI4       |
| 0      | 1      | 0      | 1      | ANI5               | ANI0 to ANI5       |
| 0      | 1      | 1      | 0      | ANI6               | ANI0 to ANI6       |
| 0      | 1      | 1      | 1      | ANI7               | ANI0 to ANI7       |
| 1      | 0      | 0      | 0      | ANI8               | ANI0 to ANI8       |
| 1      | 0      | 0      | 1      | ANI9               | ANI0 to ANI9       |
| 1      | 0      | 1      | 0      | ANI10              | ANI0 to ANI10      |
| 1      | 0      | 1      | 1      | ANI11              | ANI0 to ANI11      |
| 1      | 1      | 0      | 0      | Setting prohibited | Setting prohibited |
| 1      | 1      | 0      | 1      | Setting prohibited | Setting prohibited |
| 1      | 1      | 1      | 0      | Setting prohibited | Setting prohibited |
| 1      | 1      | 1      | 1      | Setting prohibited | Setting prohibited |

Cautions 1. In the following modes, write data to the ADA0S register while A/D conversion is stopped (ADA0M0.ADA0CE bit = 0), and then enable the A/D conversion operation (ADA0CE bit = 1).

- Normal conversion mode
- One-shot select mode/one-shot scan mode of the high-speed conversion mode
- 2. Be sure to clear bits 7 to 4 to 0.

# (5) A/D conversion result registers n, nH (ADA0CRn, ADA0CRnH)

The ADA0CRn and ADA0CRnH registers store the A/D conversion results.

These registers are read-only, in 16-bit or 8-bit units. However, specify the ADA0CRn register for 16-bit access and the ADA0CRnH register for 8-bit access. The 10 bits of the conversion result are read from the higher 10 bits of the ADA0CRn register, and 0 is read from the lower 6 bits. The higher 8 bits of the conversion result are read from the ADA0CRnH register.

Caution Accessing the ADA0CRn and ADA0CRnH registers is prohibited in the following statuses. For details, see 3.4.9 (2) Accessing specific on-chip peripheral I/O registers.

- When the CPU operates with the subclock and the main clock oscillation is stopped
- When the CPU operates with the internal oscillation clock



be read if a sequence other than the above is used.

ADA0CRn register to become undefined. After the conversion, read the conversion result before writing to the ADA0M0 and ADA0S registers. Correct conversion results may not

442

The relationship between the analog voltage input to the analog input pins (ANI0 to ANI11) and the A/D conversion result (ADA0CRn register) is as follows.

$$ADA0CR = INT (\frac{V_{IN}}{AV_{REF0}} \times 1,024 + 0.5)$$

$$\mathsf{ADA0CR}^{\mathsf{Note}} = \mathsf{SAR} \times 64$$

Or,

$$(SAR - 0.5) \times \frac{AV_{REF0}}{1,024} \le V_{IN} < (SAR + 0.5) \times \frac{AV_{REF0}}{1,024}$$

INT(): Function that returns the integer of the value in ()

VIN: Analog input voltage AVREF0: AVREF0 pin voltage

ADA0CR: Value of ADA0CRn register

Note The lower 6 bits of the ADA0CRn register are fixed to 0.

The following shows the relationship between the analog input voltage and the A/D conversion results.





## (6) Power-fail compare mode register (ADA0PFM)

The ADA0PFM register is an 8-bit register that sets the power-fail compare mode.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

| ADA0PFE | Selection of power-fail compare enable/disable |
|---------|------------------------------------------------|
| 0       | Power-fail compare disabled                    |
| 1       | Power-fail compare enabled                     |

| ADA0PFC | Selection of power-fail compare mode                                  |  |  |  |  |  |
|---------|-----------------------------------------------------------------------|--|--|--|--|--|
| 0       | Generates an interrupt request signal (INTAD) when ADA0CRnH ≥ ADA0PFT |  |  |  |  |  |
| 1       | Generates an interrupt request signal (INTAD) when ADA0CRnH < ADA0PFT |  |  |  |  |  |

- Cautions 1. In the select mode, the 8-bit data set to the ADA0PFT register is compared with the value of the ADA0CRnH register specified by the ADA0S register. If the result matches the condition specified by the ADA0PFC bit, the conversion result is stored in the ADA0CRn register and the INTAD signal is generated. If it does not match, however, the interrupt signal is not generated.
  - 2. In the scan mode, the 8-bit data set to the ADA0PFT register is compared with the contents of the ADA0CR0H register. If the result matches the condition specified by the ADA0PFC bit, the conversion result is stored in the ADA0CR0 register and the INTAD signal is generated. If it does not match, however, the INTAD signal is not generated. Regardless of the comparison result, the scan operation is continued and the conversion result is stored in the ADA0CRn register until the scan operation is completed. However, the INTAD signal is not generated after the scan operation has been completed.
  - In the following modes, write data to the ADA0PFM register while A/D conversion is stopped (ADA0M0.ADA0CE bit = 0), and then enable the A/D conversion operation (ADA0CE bit = 1).
    - Normal conversion mode
    - One-shot select mode/one-shot scan mode of the high-speed conversion mode

# (7) Power-fail compare threshold value register (ADA0PFT)

The ADAOPFT register sets the compare value in the power-fail compare mode.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.



Caution In the following modes, write data to the ADA0PFT register while A/D conversion is stopped (ADA0M0.ADA0CE bit = 0), and then enable the A/D conversion operation (ADA0CE bit = 1).

- Normal conversion mode
- One-shot select mode/one-shot scan mode of the high-speed conversion mode

## 13.5 Operation

## 13.5.1 Basic operation

- <1> Set the operation mode, trigger mode, and conversion time for executing A/D conversion by using the ADA0M0, ADA0M1, ADA0M2, and ADA0S registers. When the ADA0CE bit of the ADA0M0 register is set, conversion is started in the software trigger mode and the A/D converter waits for a trigger in the external or timer trigger mode.
- <2> When A/D conversion is started, the voltage input to the selected analog input channel is sampled by the sample & hold circuit.
- <3> When the sample & hold circuit samples the input channel for a specific time, it enters the hold status, and holds the input analog voltage until A/D conversion is complete.
- <4> Set bit 9 of the successive approximation register (SAR). The tap selector selects (1/2) AVREFO as the voltage tap of the series resistor string.
- <5> The voltage difference between the voltage of the series resistor string and the analog input voltage is compared by the voltage comparator. If the analog input voltage is higher than (1/2) AVREFO, the MSB of the SAR register remains set. If it is lower than (1/2) AVREFO, the MSB is reset.
- <6> Next, bit 8 of the SAR register is automatically set and the next comparison is started. Depending on the value of bit 9, to which a result has been already set, the voltage tap of the series resistor string is selected as follows.
  - Bit 9 = 1: (3/4) AVREFO
  - Bit 9 = 0: (1/4) AVREFO

This voltage tap and the analog input voltage are compared and, depending on the result, bit 8 is manipulated as follows.

Analog input voltage ≥ Voltage tap: Bit 8 = 1

Analog input voltage  $\leq$  Voltage tap: Bit 8 = 0

- <7> This comparison is continued to bit 0 of the SAR register.
- <8> When comparison of the 10 bits is complete, the valid digital result is stored in the SAR register, which is then transferred to and stored in the ADA0CRn register. After that, an A/D conversion end interrupt request signal (INTAD) is generated.
- <9> In one-shot select mode, conversion is stopped Note. In one-shot scan mode, conversion is stopped after scanning once Note. In continuous select mode, repeat steps <2> to <8> until the ADA0M0.ADA0CE bit is cleared to 0. In continuous scan mode, repeat steps <2> to <8> for each channel.

**Note** In the external trigger mode, timer trigger mode 0, or timer trigger mode 1, the trigger standby status is entered.

**Remark** The trigger standby status means the status after the stabilization time has elapsed.

## 13.5.2 Conversion operation timing

Figure 13-3. Conversion Operation Timing (Continuous Conversion)



## (2) Operation in high-speed conversion mode (ADA0HS1 bit = 1)



| ADA0FR3 to ADA0FR0 bits | Stabilization time | Conversion time (sampling time) | Wait time | Trigger response time |
|-------------------------|--------------------|---------------------------------|-----------|-----------------------|
| 0000                    | 13/fxx             | 26/fxx (4/fxx)                  | 26/fxx    | 4/fxx                 |
| 0001                    | 26/fxx             | 52/fxx (8/fxx)                  | 52/fxx    | 5/fxx                 |
| 0010                    | 39/fxx             | 78/fxx (12/fxx)                 | 78/fxx    | 6/fxx                 |
| 0011                    | 50/fxx             | 104/fxx (16/fxx)                | 104/fxx   | 7/fxx                 |
| 0100                    | 50/fxx             | 130/fxx (20/fxx)                | 130/fxx   | 8/fxx                 |
| 0101                    | 50/fxx             | 156/fxx (24/fxx)                | 156/fxx   | 9/fxx                 |
| 0110                    | 50/fxx             | 182/fxx (28/fxx)                | 182/fxx   | 10/fxx                |
| 0111                    | 50/fxx             | 208/fxx (32/fxx)                | 208/fxx   | 11/fxx                |
| 1000                    | 50/fxx             | 234/fxx (36/fxx)                | 234/fxx   | 12/fxx                |
| 1001                    | 50/fxx             | 260/fxx (40/fxx)                | 260/fxx   | 13/fxx                |
| 1010                    | 50/fxx             | 286/fxx (44/fxx)                | 286/fxx   | 14/fxx                |
| 1011                    | 50/fxx             | 312/fxx (48/fxx)                | 312/fxx   | 15/fxx                |
| Other than above        | Setting prohibited |                                 |           |                       |

**Remark** The above timings are when a trigger generates within the stabilization time. If the trigger generates after the stabilization time, a trigger response time is inserted.

#### 13.5.3 Trigger mode

The timing of starting the conversion operation is specified by setting a trigger mode. The trigger mode includes a software trigger mode and hardware trigger modes. The hardware trigger modes include timer trigger modes 0 and 1, and external trigger mode. The ADA0M0.ADA0TMD bit is used to set the trigger mode. The hardware trigger modes are set by the ADA0M2.ADA0TMD1 and ADA0M2.ADA0TMD0 bits.

#### (1) Software trigger mode

When the ADA0M0.ADA0CE bit is set to 1, the signal of the analog input pin (ANI0 to ANI11 pin) specified by the ADA0S register is converted. When conversion is complete, the result is stored in the ADA0CRn register. At the same time, the A/D conversion end interrupt request signal (INTAD) is generated.

If the operation mode specified by the ADA0M0.ADA0MD1 and ADA0M0.ADA0MD0 bits is the continuous select/scan mode, the next conversion is started, unless the ADA0CE bit is cleared to 0 after completion of the first conversion. Conversion is performed once and ends if the operation mode is the one-shot select/scan mode.

When conversion is started, the ADA0M0.ADA0EF bit is set to 1 (indicating that conversion is in progress). If the ADA0M0, ADA0M2, ADA0S, ADA0PFM, or ADA0PFT register is written during conversion, the conversion is aborted and started again from the beginning. However, writing these registers is prohibited in the normal conversion mode and one-shot select mode/one-shot scan mode of the high-speed conversion mode.

#### (2) External trigger mode

In this mode, converting the signal of the analog input pin (ANI0 to ANI11) specified by the ADAOS register is started when an external trigger is input (to the ADTRG pin). Which edge of the external trigger is to be detected (i.e., the rising edge, falling edge, or both rising and falling edges) can be specified by using the ADAOMO.ADAOETS1 and ADAOMO.ATAOETS0 bits. When the ADAOCE bit is set to 1, the A/D converter waits for the trigger, and starts conversion after the external trigger has been input.

When conversion is completed, the result of conversion is stored in the ADA0CRn register, regardless of whether the continuous select, continuous scan, one-shot select, or one-shot scan mode is set as the operation mode by the ADA0MD1 and ADA0MD0 bits. At the same time, the INTAD signal is generated, and the A/D converter waits for the trigger again.

When conversion is started, the ADA0EF bit is set to 1 (indicating that conversion is in progress). While the A/D converter is waiting for the trigger, however, the ADA0EF bit is cleared to 0 (indicating that conversion is stopped). If the valid trigger is input during the conversion operation, the conversion is aborted and started again from the beginning.

If the ADA0M0, ADA0M2, ADA0PFM, or ADA0PFT register is written during the conversion operation, the conversion is not aborted, and the A/D converter waits for the trigger again. However, writing these registers is prohibited in the one-shot select mode/one-shot scan mode.

Caution To select the external trigger mode, set the high-speed conversion mode. Do not input a trigger during stabilization time that is inserted once after the A/D conversion operation is enabled (ADA0M0.ADA0CE bit = 1).

**Remark** The trigger standby status means the status after the stabilization time has elapsed.

### (3) Timer trigger mode

In this mode, converting the signal of the analog input pin (ANI0 to ANI11) specified by the ADAOS register is started by the compare match interrupt request signal (INTTP2CC0 or INTTP2CC1) of the capture/compare register connected to the timer. The INTTP2CC0 or INTTP2CC1 signal is selected by the ADAOTMD1 and ADAOTMD0 bits, and conversion is started at the rising edge of the specified compare match interrupt request signal. When the ADAOCE bit is set to 1, the A/D converter waits for a trigger, and starts conversion when the compare match interrupt request signal of the timer is input.

When conversion is completed, regardless of whether the continuous select, continuous scan, one-shot select, or one-shot scan mode is set as the operation mode by the ADA0MD1 and ADA0MD0 bits, the result of the conversion is stored in the ADA0CRn register. At the same time, the INTAD signal is generated, and the A/D converter waits for the trigger again.

When conversion is started, the ADA0EF bit is set to 1 (indicating that conversion is in progress). While the A/D converter is waiting for the trigger, however, the ADA0EF bit is cleared to 0 (indicating that conversion is stopped). If the valid trigger is input during the conversion operation, the conversion is aborted and started again from the beginning.

If the ADA0M0, ADA0M2, ADA0S, ADA0PFM, or ADA0PFT register is written during conversion, the conversion is stopped and the A/D converter waits for the trigger again. However, writing these registers is prohibited in the one-shot select mode/one-shot scan mode.

Caution To select the timer trigger mode, set the high-speed conversion mode. Do not input a trigger during stabilization time that is inserted once after the A/D conversion operation is enabled (ADA0M0.ADA0CE bit = 1).

Remark The trigger standby status means the status after the stabilization time has elapsed.

#### 13.5.4 Operation mode

Four operation modes are available as the modes in which to set the ANI0 to ANI11 pins: continuous select mode, continuous scan mode, one-shot select mode, and one-shot scan mode.

The operation mode is selected by the ADA0M0.ADA0MD1 and ADA0M0.ADA0MD0 bits.

#### (1) Continuous select mode

In this mode, the voltage of one analog input pin selected by the ADA0S register is continuously converted into a digital value.

The conversion result is stored in the ADA0CRn register corresponding to the analog input pin. In this mode, an analog input pin corresponds to an ADA0CRn register on a one-to-one basis. Each time A/D conversion is completed, the A/D conversion end interrupt request signal (INTAD) is generated. After completion of conversion, the next conversion is started, unless the ADA0M0.ADA0CE bit is cleared to 0 (n = 0 to 11).



Figure 13-4. Timing Example of Continuous Select Mode Operation (ADA0S Register = 01H)

## (2) Continuous scan mode

In this mode, analog input pins are sequentially selected, from the ANIO pin to the pin specified by the ADAOS register, and their values are converted into digital values.

The result of each conversion is stored in the ADA0CRn register corresponding to the analog input pin. When conversion of the analog input pin specified by the ADA0S register is complete, the INTAD signal is generated, and A/D conversion is started again from the ANI0 pin, unless the ADA0CE bit is cleared to 0 (n = 0 to 11).



Figure 13-5. Timing Example of Continuous Scan Mode Operation (ADA0S Register = 03H)

## (3) One-shot select mode

In this mode, the voltage on the analog input pin specified by the ADAOS register is converted into a digital value only once.

The conversion result is stored in the ADA0CRn register corresponding to the analog input pin. In this mode, an analog input pin and an ADA0CRn register correspond on a one-to-one basis. When A/D conversion has been completed once, the INTAD signal is generated. The A/D conversion operation is stopped after it has been completed (n = 0 to 11).



Figure 13-6. Timing Example of One-Shot Select Mode Operation (ADA0S Register = 01H)

## (4) One-shot scan mode

In this mode, analog input pins are sequentially selected, from the ANI0 pin to the pin specified by the ADA0S register, and their values are converted into digital values.

Each conversion result is stored in the ADA0CRn register corresponding to the analog input pin. When conversion of the analog input pin specified by the ADA0S register is complete, the INTAD signal is generated. A/D conversion is stopped after it has been completed (n = 0 to 11).



Figure 13-7. Timing Example of One-Shot Scan Mode Operation (ADA0S Register = 03H)

## 13.5.5 Power-fail compare mode

The A/D conversion end interrupt request signal (INTAD) can be controlled as follows by the ADA0PFM and ADA0PFT registers.

- When the ADA0PFM.ADA0PFE bit = 0, the INTAD signal is generated each time conversion is completed (normal use of the A/D converter).
- When the ADA0PFE bit = 1 and when the ADA0PFM.ADA0PFC bit = 0, the value of the ADA0CRnH register is compared with the value of the ADA0PFT register when conversion is completed, and the INTAD signal is generated only if ADA0CRnH ≥ ADA0PFT.
- When the ADA0PFE bit = 1 and when the ADA0PFC bit = 1, the value of the ADA0CRnH register is compared
  with the value of the ADA0PFT register when conversion is completed, and the INTAD signal is generated only if
  ADA0CRnH < ADA0PFT.</li>

**Remark** n = 0 to 11

In the power-fail compare mode, four modes are available as modes in which to set the ANI0 to ANI11 pins: continuous select mode, continuous scan mode, one-shot select mode, and one-shot scan mode.

#### (1) Continuous select mode

In this mode, the result of converting the voltage of the analog input pin specified by the ADAOS register is compared with the set value of the ADAOPFT register. If the result of power-fail comparison matches the condition set by the ADAOPFC bit, the conversion result is stored in the ADAOCRn register, and the INTAD signal is generated. If it does not match, the conversion result is stored in the ADAOCRn register, and the INTAD signal is not generated. After completion of the first conversion, the next conversion is started, unless the ADAOMO.ADAOCE bit is cleared to 0 (n = 0 to 11).



Figure 13-8. Timing Example of Continuous Select Mode Operation (When Power-Fail Comparison Is Made: ADA0S Register = 01H)

#### (2) Continuous scan mode

In this mode, the results of converting the voltages of the analog input pins sequentially selected from the ANI0 pin to the pin specified by the ADA0S register are stored, and the set value of the ADA0CR0H register of channel 0 is compared with the value of the ADA0PFT register. If the result of power-fail comparison matches the condition set by the ADA0PFC bit, the conversion result is stored in the ADA0CR0 register, and the INTAD signal is generated. If it does not match, the conversion result is stored in the ADA0CR0 register, and the INTAD signal is not generated.

After the result of the first conversion has been stored in the ADA0CR0 register, the results of sequentially converting the voltages on the analog input pins up to the pin specified by the ADA0S register are continuously stored. After completion of conversion, the next conversion is started from the ANI0 pin again, unless the ADA0CE bit is cleared to 0.

(b) Timing example ANI0 Data 1 Data 5 ANI1 Data 6 Data 2 Data 7 Data 3 ANI2 ANI3 Data 4 Data 1 Data 2 Data 3 Data 4 Data 5 Data 6 Data 7 A/D conversion (ANIO) (ANI2) (ANI3) (ANI1) (ANI2) (ANI1) (ANIO) Data 2 Data 1 Data 3 Data 4 Data 5 Data 6 ADA0CRn (ANIO) (ANI1) (ANI2) (ANI3) (ANIO) (ANI1) INTAD ADA0PFT ADA0PFT unmatch Conversion start Set ADA0CE bit = 1 (b) Block diagram Analog input pin ADA0CRn register ANI0 ADA0CR0  $\bigcirc$ ANI1 ADA0CR1 ANI2  $\bigcirc$ ADA0CR2  $\bigcirc$ A/D converter ADA0CR3 ANI3  $\bigcirc$ ANI4 ADA0CR4  $\bigcirc$ ANI5 ADA0CR5  $\bigcirc$  $\bigcirc$ ANI9  $\bigcirc$ ADA0CR9 ANI10  $\bigcirc$ ADA0CR10 ANI11 🔾 ADA0CR11

Figure 13-9. Timing Example of Continuous Scan Mode Operation (When Power-Fail Comparison Is Made: ADA0S Register = 03H)

#### (3) One-shot select mode

In this mode, the result of converting the voltage of the analog input pin specified by the ADAOS register is compared with the set value of the ADAOPFT register. If the result of power-fail comparison matches the condition set by the ADAOPFC bit, the conversion result is stored in the ADAOCRn register, and the INTAD signal is generated. If it does not match, the conversion result is stored in the ADAOCRn register, and the INTAD signal is not generated. Conversion is stopped after it has been completed.



Figure 13-10. Timing Example of One-Shot Select Mode Operation (When Power-Fail Comparison Is Made: ADA0S Register = 01H)

## (4) One-shot scan mode

In this mode, the results of converting the voltages of the analog input pins sequentially selected from the ANIO pin to the pin specified by the ADAOS register are stored, and the set value of the ADAOCROH register of channel 0 is compared with the set value of the ADAOPFT register. If the result of power-fail comparison matches the condition set by the ADAOPFC bit, the conversion result is stored in the ADAOCRO register and the INTAD signal is generated. If it does not match, the conversion result is stored in the ADAOCRO register, and the INTADO signal is not generated. After the result of the first conversion has been stored in the ADAOCRO register, the results of converting the signals on the analog input pins specified by the ADAOS register are sequentially stored. The conversion is stopped after it has been completed.

(a) Timing example ANI0 Data 1 Data 5 ANI1 Data 6 Data 2 Data 7 Data 3 ANI2 ANI3 Data 4 Data 2 Data 4 Data 1 Data 3 A/D conversion (ANIO) (ANI1) (ANI2) (ANI3) Data 1 Data 2 Data 3 Data 4 ADA0CRn (ANI3) (ANIO) (ANI1) (ANI2) INTAD ADA0PFT match Conversion end Conversion start Set ADA0CE bit = 1 (b) Block diagram ADA0CRn register Analog input pin ANI0  $\bigcirc$ ADA0CR0  $\bigcirc$ ADA0CR1 ANI1 ADA0CR2 ANI2  $\circ$  $\bigcirc$ ADA0CR3 ANI3 A/D converter  $\bigcirc$ ADA0CR4 ANI4  $\bigcirc$ ANI5 ADA0CR5  $\bigcirc$  $\bigcirc$ 0 ADA0CR9 ANI9 ANI10  $\bigcirc$ ADA0CR10 ANI11  $\bigcirc$ ADA0CR11

Figure 13-11. Timing Example of One-Shot Scan Mode Operation (When Power-Fail Comparison Is Made: ADA0S Register = 03H)

## 13.6 Cautions

## (1) When A/D converter is not used

When the A/D converter is not used, the power consumption can be reduced by clearing the ADA0M0.ADA0CE bit to 0.

#### (2) Input range of ANI0 to ANI11 pins

Input the voltage within the specified range to the ANI0 to ANI11 pins. If a voltage equal to or higher than AVREFO or equal to or lower than AVss (even within the range of the absolute maximum ratings) is input to any of these pins, the conversion value of that channel is undefined, and the conversion value of the other channels may also be affected.

#### (3) Countermeasures against noise

To maintain the 10-bit resolution, the ANI0 to ANI11 pins must be effectively protected from noise. The influence of noise increases as the output impedance of the analog input source becomes higher. To lower the noise, connecting an external capacitor as shown in Figure 13-12 is recommended.



Figure 13-12. Processing of Analog Input Pin

#### (4) Alternate I/O

The analog input pins (ANI0 to ANI11) function alternately as port pins. When selecting one of the ANI0 to ANI11 pins to execute A/D conversion, do not execute an instruction to read an input port or write to an output port during conversion as the conversion resolution may drop.

Also the conversion resolution may drop at the pins set as output port pins during A/D conversion if the output current fluctuates due to the effect of the external circuit connected to the port pins.

If a digital pulse is applied to a pin adjacent to the pin whose input signal is being converted, the A/D conversion value may not be as expected due to the influence of coupling noise. Therefore, do not apply a pulse to a pin adjacent to the pin undergoing A/D conversion.

## (5) Interrupt request flag (ADIF)

The interrupt request flag (ADIF) is not cleared even if the contents of the ADAOS register are changed. If the analog input pin is changed during A/D conversion, therefore, the result of converting the previously selected analog input signal may be stored and the conversion end interrupt request flag may be set immediately before the ADAOS register is rewritten. If the ADIF flag is read immediately after the ADAOS register is rewritten, the ADIF flag may be set even though the A/D conversion of the newly selected analog input pin has not been completed. When A/D conversion is stopped, clear the ADIF flag before resuming conversion.



Figure 13-13. Generation Timing of A/D Conversion End Interrupt Request

## (6) Internal equivalent circuit

The following shows the equivalent circuit of the analog input block.



Figure 13-14. Internal Equivalent Circuit of ANIn Pin

## (7) AVREFO pin

- (a) The AVREFO pin is used as the power supply pin of the A/D converter and also supplies power to the alternate-function ports. In an application where a backup power supply is used, be sure to supply the same voltage as VDD to the AVREFO pin as shown in Figure 13-15.
- (b) The AVREFO pin is also used as the reference voltage pin of the A/D converter. If the source supplying power to the AVREFO pin has a high impedance or if the power supply has a low current supply capability, the reference voltage may fluctuate due to the current that flows during conversion (especially, immediately after the conversion operation enable bit ADAOCE has been set to 1). As a result, the conversion accuracy may drop. To avoid this, it is recommended to connect a capacitor across the AVREFO and AVss pins to suppress the reference voltage fluctuation as shown in Figure 13-15.
- (c) If the source supplying power to the AVREFO pin has a high DC resistance (for example, because of insertion of a diode), the voltage when conversion is enabled may be lower than the voltage when conversion is stopped, because of a voltage drop caused by the A/D conversion current.

Main power supply

Mote

AVREFO

AVSS

Note Parasitic inductance

Figure 13-15. AVREFO Pin Processing Example

#### (8) Reading ADA0CRn register

When the ADA0M0 to ADA0M2 or ADA0S register is written, the contents of the ADA0CRn register may be undefined. Read the conversion result after completion of conversion and before writing to the ADA0M0 to ADA0M2 and ADA0S registers. The correct conversion result may not be read at a timing different from the above.

#### (9) Standby mode

Because the A/D converter stops operating in the STOP mode, conversion results are invalid, so power consumption can be reduced. Operations are resumed after the STOP mode is released, but the A/D conversion results after the STOP mode is released are invalid. When using the A/D converter after the STOP mode is released, before setting the STOP mode or releasing the STOP mode, clear the ADA0M0.ADA0CE bit to 0 then set the ADA0CE bit to 1 after releasing the STOP mode.

In the IDLE1, IDLE2, or subclock operation mode, operation continues. To lower the power consumption, therefore, clear the ADA0M0.ADA0CE bit to 0. In the IDLE1 and IDLE2 modes, since the analog input voltage value cannot be retained, the A/D conversion results after the IDLE1 and IDLE2 modes are released are invalid. The results of conversions before the IDLE1 and IDLE2 modes were set are valid.

#### (10) Restriction for each mode

- (a) To select the external trigger mode/timer trigger mode, set the high-speed conversion mode. Do not input a trigger during stabilization time that is inserted once after the A/D conversion operation is enabled (ADA0M0.ADA0CE bit = 1).
- (b) In the following modes, write data to the A/D control register while A/D conversion is stopped (ADA0CE bit = 0), and then enable the A/D conversion operation (ADA0CE bit = 1).
  - Normal conversion mode
  - One-shot select mode/one-shot scan mode of high-speed conversion mode

Remark A/D control registers: ADA0M0, ADA0M2, ADA0S, ADA0PFM, and ADA0PFT registers

### (12) Variation of A/D conversion results

The results of the A/D conversion may vary depending on the fluctuation of the supply voltage, or may be affected by noise. To reduce the variation, take counteractive measures with the program such as averaging the A/D conversion results.

#### (13) A/D conversion result hysteresis characteristics

The successive comparison type A/D converter holds the analog input voltage in the internal sample & hold capacitor and then performs A/D conversion. After the A/D conversion has finished, the analog input voltage remains in the internal sample & hold capacitor. As a result, the following phenomena may occur.

- When the same channel is used for A/D conversions, if the voltage is higher or lower than the previous A/D conversion, then hysteresis characteristics may appear where the conversion result is affected by the previous value. Thus, even if the conversion is performed at the same potential, the result may vary.
- When switching the analog input channel, hysteresis characteristics may appear where the conversion result is affected by the previous channel value. This is because one A/D converter is used for the A/D conversions. Thus, even if the conversion is performed at the same potential, the result may vary.

#### 13.7 How to Read A/D Converter Characteristics Table

This section describes the terms related to the A/D converter.

## (1) Resolution

The minimum analog input voltage that can be recognized, i.e., the ratio of an analog input voltage to 1 bit of digital output is called 1 LSB (least significant bit). The ratio of 1 LSB to the full scale is expressed as %FSR (full-scale range). %FSR is the ratio of a range of convertible analog input voltages expressed as a percentage, and can be expressed as follows, independently of the resolution.

 $1\%FSR = (Maximum\ value\ of\ convertible\ analog\ input\ voltage - Minimum\ value\ of\ convertible\ analog\ input\ voltage)/100$ 

 $= (AV_{REF0} - 0)/100$ 

= AVREF0/100

When the resolution is 10 bits, 1 LSB is as follows:

1 LSB = 
$$1/2^{10}$$
 =  $1/1,024$   
=  $0.098\%$ FSR

The accuracy is determined by the overall error, independently of the resolution.

## (2) Overall error

This is the maximum value of the difference between an actually measured value and a theoretical value. It is a total of zero-scale error, full-scale error, linearity error, and a combination of these errors. The overall error in the characteristics table does not include the quantization error.





## (3) Quantization error

This is an error of  $\pm 1/2$  LSB that inevitably occurs when an analog value is converted into a digital value. Because the A/D converter converts analog input voltages in a range of  $\pm 1/2$  LSB into the same digital codes, a quantization error is unavoidable.

This error is not included in the overall error, zero-scale error, full-scale error, integral linearity error, or differential linearity error in the characteristics table.



Figure 13-17. Quantization Error

# (4) Zero-scale error

This is the difference between the actually measured analog input voltage and its theoretical value when the digital output changes from 0...000 to 0...001 (1/2 LSB).



Figure 13-18. Zero-Scale Error

## (5) Full-scale error

This is the difference between the actually measured analog input voltage and its theoretical value when the digital output changes from 1...110 to 1...111 (full scale -3/2 LSB).



Figure 13-19. Full-Scale Error

## (6) Differential linearity error

Ideally, the width to output a specific code is 1 LSB. This error indicates the difference between the actually measured value and its theoretical value when a specific code is output. This indicates the basic characteristics of the A/D conversion when the voltage applied to the analog input pins of the same channel is consistently increased bit by bit from AVss to AVREFO. When the input voltage is increased or decreased, or when two or more channels are used, see 13.7 (2) Overall error.



Figure 13-20. Differential Linearity Error

## (7) Integral linearity error

This error indicates the extent to which the conversion characteristics differ from the ideal linear relationship. It indicates the maximum value of the difference between the actually measured value and its theoretical value where the zero-scale error and full-scale error are 0.



Figure 13-21. Integral Linearity Error

## (8) Conversion time

This is the time required to obtain a digital output after each trigger has been generated.

The conversion time in the characteristics table includes the sampling time.

## (9) Sampling time

This is the time for which the analog switch is ON to load an analog voltage to the sample & hold circuit.

→ Sampling time → Conversion time → Convers

Figure 13-22. Sampling Time

# **CHAPTER 14 D/A CONVERTER**

## 14.1 Functions

The D/A converter has the following functions.

- O 8-bit resolution × 2 channels (DA0CS0, DA0CS1)
- O R-2R ladder method
- O Settling time: 3  $\mu$ s max. (when AV<sub>REF1</sub> is 3.0 to 3.6 V and external load is 20 pF)
- O Analog output voltage: AVREF1 × m/256 (m = 0 to 255; value set to DA0CSn register)
- O Operation modes: Normal mode, real-time output mode

**Remark** n = 0, 1

# 14.2 Configuration

The D/A converter configuration is shown below.

DACS0 register write DACS0 register DA0M.DAMD0 bit INTTP2CC0 signal O ANO0 pin DA0M.DACE0 bit AVREF1 pin O-Selector AVss pin ⊙-O ANO1 pin Selector DA0M.DACE1 bit -DACS1 register write DA0M.DAMD1 bit DACS1 register INTTP3CC0 signal Cautions 1. DAC0 and DAC1 share the AVREF1 pin. 2. DAC0 and DAC1 share the AVss pin. The AVss pin is also shared by the A/D converter.

Figure 14-1. Block Diagram of D/A Converter

The D/A converter consists of the following hardware.

Table 14-1. Configuration of D/A Converter

| Item              | Configuration                                                |
|-------------------|--------------------------------------------------------------|
| Control registers | D/A converter mode register (DA0M)                           |
|                   | D/A conversion value setting registers 0, 1 (DA0CS0, DA0CS1) |

# 14.3 Registers

The registers that control the D/A converter are as follows.

- D/A converter mode register (DA0M)
- D/A conversion value setting registers 0, 1 (DA0CS0, DA0CS1)

# (1) D/A converter mode register (DA0M)

The DA0M register controls the operation of the D/A converter.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

 After reset:
 00H
 R/W
 Address:
 FFFF282H

 7
 6
 <5>
 <4>
 3
 2
 1
 0

 DAOM
 0
 DAOCE1
 DAOCE0
 0
 0
 DAOMD1
 DAOMD0

| DA0CEn | Control of D/A converter operation enable/disable ( $n = 0, 1$ ) |  |
|--------|------------------------------------------------------------------|--|
| 0      | Disables operation                                               |  |
| 1      | Enables operation                                                |  |

| DA0MDn | Selection of D/A converter operation mode $(n = 0, 1)$ |  |
|--------|--------------------------------------------------------|--|
| 0      | Normal mode                                            |  |
| 1      | Real-time output mode <sup>Note</sup>                  |  |

**Note** The output trigger in the real-time output mode (DA0MDn bit = 1) is as follows.

- When n = 0: INTTP2CC0 signal (see CHAPTER 7 16-BIT TIMER/EVENT COUNTER P (TMP))
- When n = 1: INTTP3CC0 signal (see CHAPTER 7 16-BIT TIMER/EVENT COUNTER P (TMP))

# (2) D/A conversion value setting registers 0, 1 (DA0CS0, DA0CS1)

The DA0CS0 and DA0CS1 registers set the analog voltage value output to the ANO0 and ANO1 pins.

These registers can be read or written in 8-bit units.

Reset input clears these registers to 00H.



Caution In the real-time output mode (DA0M.DA0MDn bit = 1), set the DA0CSn register before the INTTP2CC0/INTTP3CC0 signals are generated. D/A conversion starts when the INTTP2CC0/INTTP3CC0 signals are generated.

**Remark** n = 0, 1

## 14.4 Operation

# 14.4.1 Operation in normal mode

D/A conversion is performed using a write operation to the DA0CSn register as the trigger.

The setting method is described below.

- <1> Set the DA0M.DA0MDn bit to 0 (normal mode).
- <2> Set the analog voltage value to be output to the ANOn pin to the DA0CSn register.
  - Steps <1> and <2> above constitute the initial settings.
- <3> Set the DA0M.DA0CEn bit to 1 (D/A conversion enable).
  - D/A conversion starts when this setting is performed.
- <4> To perform subsequent D/A conversions, write to the DA0CSn register.

The previous D/A conversion result is held until the next D/A conversion is performed.

Remarks 1. For the alternate-function pin settings, see Table 4-15 Using Port Pin as Alternate-Function Pin.

**2.** n = 0, 1

#### 14.4.2 Operation in real-time output mode

D/A conversion is performed using the interrupt request signals (INTTP2CC0 and INTTP3CC0) of TMP2 and TMP3 as triggers.

The setting method is described below.

- <1> Set the DA0M.DA0MDn bit to 1 (real-time output mode).
- <2> Set the analog voltage value to be output to the ANOn pin to the DA0CSn register.
- <3> Set the DA0M.DA0CEn bit to 1 (D/A conversion enable).
  Steps <1> to <3> above constitute the initial settings.
- <4> Operate TMP2 and TMP3.
- <5> D/A conversion starts when the INTTP2CC0 and INTTP3CC0 signals are generated.
- <6> After that, the value set in DA0CSn register is output every time the INTTP2CC0 and INTTP3CC0 signals are generated.
- Remarks 1. The output values of the ANO0 and ANO1 pins up to <5> above are undefined.
  - 2. For the output values of the ANO0 and ANO1 pins in the HALT, IDLE1, IDLE2, and STOP modes, see CHAPTER 24 STANDBY FUNCTION.
  - 3. For the alternate-function pin settings, see Table 4-15 Using Port Pin as Alternate-Function Pin.

## 14.4.3 Cautions

Observe the following cautions when using the D/A converter of the V850ES/SG2.

- (1) Do not change the set value of the DA0CSn register while the trigger signal is being issued in the real-time output mode.
- (2) Before changing the operation mode, be sure to clear the DA0M.DA0CEn bit to 0.
- (3) When using one of the P10/AN00 and P11/AN01 pins as an I/O port and the other as a D/A output pin, do so in an application where the port I/O level does not change during D/A output.
- (4) Make sure that AVREF0 = VDD = AVREF1 = 3.0 to 3.6 V. If this range is exceeded, the operation is not guaranteed.
- (5) Apply power to AVREF1 at the same timing as AVREF0.
- (6) No current can be output from the ANOn pin (n = 0, 1) because the output impedance of the D/A converter is high. When connecting a resistor of 2 M $\Omega$  or less, insert a JFET input operational amplifier between the resistor and the ANOn pin.

Figure 14-2. External Pin Connection Example



- (7) Because the D/A converter stops operation in the STOP mode, the ANO0 and ANO1 pins go into a high-impedance state, and the power consumption can be reduced.
  - In the IDLE1, IDLE2, or subclock operation mode, however, the operation continues. To lower the power consumption, therefore, clear the DA0M.DA0CEn bit to 0.

# CHAPTER 15 ASYNCHRONOUS SERIAL INTERFACE A (UARTA)

# 15.1 Mode Switching of UARTA and Other Serial Interfaces

# 15.1.1 CSIB4 and UARTA0 mode switching

In the  $I^2C$  bus versions (Y versions) of the V850ES/SG2, CSIB4 and UARTA0 are alternate functions of the same pin and therefore cannot be used simultaneously. Set UARTA0 in advance, using the PMC3 and PFC3 registers, before use.

Caution The transmit/receive operation of CSIB4 and UARTA0 is not guaranteed if these functions are switched during transmission or reception. Be sure to disable the one that is not used.

After reset: 0000H R/W Address: FFFFF446H, FFFFF447H 15 14 8 PMC38 PMC3 0 0 0 0 0 0 PMC39 2 6 5 4 3 0 PMC37 PMC36 PMC35 PMC34 PMC33 PMC32 PMC31 PMC30 After reset: 0000H Address: FFFFF466H, FFFFF467H R/W 15 14 13 12 11 10 9 8 PFC3 PFC38 0 0 PFC39 0 0 0 0 7 6 5 4 3 2 0 1 PFC37 PFC36 PFC35 PFC34 PFC33 PFC32 PFC31 PFC30 After reset: 00H R/W Address: FFFFF706H 2 6 3 0 PFCE3L 0 0 0 PFCE32 0 0 0 0 Operation mode PMC32 PFCE32 PFC32 0 × Port I/O mode ASCKA0 mode 0 0 SCKB4 mode 0 1 1 PMC3n PFC3n Operation mode 0 Port I/O mode × 0 UARTA0 mode 1 CSIB4 mode 1

Figure 15-1. CSIB4 and UARTA0 Mode Switch Settings

**Remarks 1.** n = 0, 1

2.  $\times$  = don't care

## 15.1.2 UARTA2 and I<sup>2</sup>C00 mode switching

In the V850ES/SG2, UARTA2 and I<sup>2</sup>C00 are alternate functions of the same pin and therefore cannot be used simultaneously. Set UARTA2 in advance, using the PMC3 and PFC3 registers, before use.

Caution The transmit/receive operation of UARTA2 and I<sup>2</sup>C00 is not guaranteed if these functions are switched during transmission or reception. Be sure to disable the one that is not used.

Figure 15-2. UARTA2 and I<sup>2</sup>C00 Mode Switch Settings



**Remarks 1.** n = 8, 9

**2.**  $\times$  = don't care

## 15.1.3 UARTA1 and I<sup>2</sup>C02 mode switching

In the V850ES/SG2, UARTA1 and I<sup>2</sup>C02 are alternate functions of the same pin and therefore cannot be used simultaneously. Set UARTA1 in advance, using the PMC9, PFC9, and PMCE9 registers, before use.

Caution The transmit/receive operation of UARTA1 and I<sup>2</sup>C02 is not guaranteed if these functions are switched during transmission or reception. Be sure to disable the one that is not used.

Figure 15-3. UARTA1 and I<sup>2</sup>C02 Mode Switch Settings



#### 15.2 Features

O Transfer rate: 300 bps to 312.5 kbps (using internal system clock of 32 MHz and dedicated baud rate generator)

O Full-duplex communication: Internal UARTAn receive data register (UAnRX)

Internal UARTAn transmit data register (UAnTX)

O 2-pin configuration: TXDAn: Transmit data output pin

RXDAn: Receive data input pin

O Reception error output function

• Parity error

· Framing error

• Overrun error

O Interrupt sources: 2

• Reception complete interrupt (INTUAnR): This interrupt occurs upon transfer of receive data from the

receive shift register to receive data register after serial

transfer completion, in the reception enabled status.

• Transmission enable interrupt (INTUAnT): This interrupt occurs upon transfer of transmit data from the

transmit data register to the transmit shift register in the

transmission enabled status.

O Character length: 7, 8 bits

O Parity function: Odd, even, 0, none

O Transmission stop bit: 1, 2 bits

O On-chip dedicated baud rate generator

O MSB-/LSB-first transfer selectable

O Transmit/receive data inverted input/output possible

O SBF (Sync Break Field) transmission/reception in the LIN (Local Interconnect Network) communication format

• 13 to 20 bits selectable for the SBF transmission

• Recognition of 11 bits or more possible for SBF reception

· SBF reception flag provided

**Remark** n = 0 to 2

# 15.3 Configuration

The block diagram of the UARTAn is shown below.

Internal bus INTUAnT -INTUAnR -Transmission Reception unit UAnRX UAnTX unit Receive Reception Transmission Transmit shift register shift register controller controller Filter Baud rate Baud rate Selector **-**⊚TXDAn generator generator ⊚RXDAn Selector fxx to fxx/2<sup>10</sup> — ASCKA0<sup>Note</sup>© selector UAnCTL1 UAnCTL0 **UAnSTR** UAnOTP0 UAnCTL2 Internal bus Note UARTA0 only **Remarks 1.** n = 0 to 2 2. For the configuration of the baud rate generator, see Figure 15-16.

Figure 15-4. Block Diagram of Asynchronous Serial Interface An

UARTAn consists of the following hardware units.

Table 15-1. Configuration of UARTAn

| Item      | Configuration                                                                                                                                                                                                        |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Registers | UARTAn control register 0 (UAnCTL0) UARTAn control register 1 (UAnCTL1) UARTAn control register 2 (UAnCTL2) UARTAn option control register 0 (UAnOPT0) UARTAn status register (UAnSTR) UARTAn receive shift register |
|           | UARTAn receive data register (UAnRX)  UARTAn transmit shift register  UARTAn transmit data register (UAnTX)                                                                                                          |

#### (1) UARTAn control register 0 (UAnCTL0)

The UAnCTL0 register is an 8-bit register used to specify the UARTAn operation.

#### (2) UARTAn control register 1 (UAnCTL1)

The UAnCTL1 register is an 8-bit register used to select the input clock for the UARTAn.

#### (3) UARTAn control register 2 (UAnCTL2)

The UAnCTL2 register is an 8-bit register used to control the baud rate for the UARTAn.

## (4) UARTAn option control register 0 (UAnOPT0)

The UAnOPT0 register is an 8-bit register used to control serial transfer for the UARTAn.

#### (5) UARTAn status register (UAnSTR)

The UAnSTRn register consists of flags indicating the error contents when a reception error occurs. Each one of the reception error flags is set (to 1) upon occurrence of a reception error and is reset (to 0) by reading the UAnSTR register.

# (6) UARTAn receive shift register

This is a shift register used to convert the serial data input to the RXDAn pin into parallel data. Upon reception of 1 byte of data and detection of the stop bit, the receive data is transferred to the UAnRX register.

This register cannot be manipulated directly.

## (7) UARTAn receive data register (UAnRX)

The UAnRX register is an 8-bit register that holds receive data. When 7 characters are received, 0 is stored in the highest bit (when data is received LSB first).

In the reception enabled status, receive data is transferred from the UARTAn receive shift register to the UARRX register in synchronization with the completion of shift-in processing of 1 frame.

Transfer to the UAnRX register also causes the reception complete interrupt request signal (INTUAnR) to be output.

### (8) UARTAn transmit shift register

The transmit shift register is a shift register used to convert the parallel data transferred from the UAnTX register into serial data.

When 1 byte of data is transferred from the UAnTX register, the shift register data is output from the TXDAn pin. This register cannot be manipulated directly.

#### (9) UARTAn transmit data register (UAnTX)

The UAnTX register is an 8-bit transmit data buffer. Transmission starts when transmit data is written to the UAnTX register. When data can be written to the UAnTX register (when data of one frame is transferred from the UAnTX register to the UARTAn transmit shift register), the transmission enable interrupt request signal (INTUAnT) is generated.

# 15.4 Registers

# (1) UARTAn control register 0 (UAnCTL0)

The UAnCTL0 register is an 8-bit register that controls the UARTAn serial transfer operation.

This register can be read or written in 8-bit or 1-bit units.

Reset input sets this register to 10H.

(1/2)

After reset: 10H R/W Address: UA0CTL0 FFFFA00H, UA1CTL0 FFFFA10H, UA2CTL0 FFFFA20H

UAnCTL0 (n = 0 to 2)

| <7>    | <6>    | <5>    | <4>    | 3      | 2      | 1     | 0     |
|--------|--------|--------|--------|--------|--------|-------|-------|
| UAnPWR | UAnTXE | UAnRXE | UAnDIR | UAnPS1 | UAnPS0 | UAnCL | UAnSL |

| UAnPWR | UARTAn operation control                               |
|--------|--------------------------------------------------------|
| 0      | Disable UARTAn operation (UARTAn reset asynchronously) |
| 1      | Enable UARTAn operation                                |

The UARTAn operation is controlled by the UAnPWR bit. The TXDAn pin output is fixed to high level by clearing the UAnPWR bit to 0 (fixed to low level if UAnOPT0.UAnTDL bit = 1).

| UAnTXE | Transmission operation enable  |
|--------|--------------------------------|
| 0      | Disable transmission operation |
| 1      | Enable transmission operation  |

- To start transmission, set the UAnPWR bit to 1 and then set the UAnTXE bit to 1. To stop, transmission clear the UAnTXE bit to 0 and then UAnPWR bit to 0.
- To initialize the transmission unit, clear the UAnTXE bit to 0, wait for two cycles of the base clock, and then set the UAnTXE bit to 1 again. Otherwise, initialization may not be executed (for the base clock, see 15.7 (1) (a) Base clock).

| UAnRXE | Reception operation enable  |
|--------|-----------------------------|
| 0      | Disable reception operation |
| 1      | Enable reception operation  |

- To start reception, set the UAnPWR bit to 1 and then set the UAnRXE bit to 1. To stop reception, clear the UAnRXE bit to 0 and then UAnPWR bit to 0.
- To initialize the reception unit, clear the UAnRXE bit to 0, wait for two periods of the base clock, and then set the UAnRXE bit to 1 again. Otherwise, initialization may not be executed (for the base clock, see 15.7 (1) (a) Base clock).

(2/2)

| UAnDIR | Transfer direction selection |
|--------|------------------------------|
| 0      | MSB-first transfer           |
| 1      | LSB-first transfer           |

This register can be rewritten only when the UAnPWR bit = 0 or the UAnTXE bit = the UAnRXE bit = 0.

| UAnPS1 | UAnPS0 | Parity selection during transmission | Parity selection during reception |
|--------|--------|--------------------------------------|-----------------------------------|
| 0      | 0      | No parity output                     | Reception with no parity          |
| 0      | 1      | 0 parity output                      | Reception with 0 parity           |
| 1      | 0      | Odd parity output                    | Odd parity check                  |
| 1      | 1      | Even parity output                   | Even parity check                 |

- This register is rewritten only when the UAnPWR bit = 0 or the UAnTXE bit = the UAnRXE bit = 0.
- If "Reception with 0 parity" is selected during reception, a parity check is not performed. Therefore, the UAnSTR.UAnPE bit is not set.
- When transmission and reception are performed in the LIN format, clear the UAnPS1 and UAnPS0 bits to 00.

| UAnCL | Specification of data character length of 1 frame of transmit/receive data |
|-------|----------------------------------------------------------------------------|
| 0     | 7 bits                                                                     |
| 1     | 8 bits                                                                     |

This register can be rewritten only when the UAnPWR bit = 0 or the UAnTXE bit = the UAnRXE bit = 0.

| UAnSL | Specification of length of stop bit for transmit data |
|-------|-------------------------------------------------------|
| 0     | 1 bit                                                 |
| 1     | 2 bits                                                |

This register can be rewritten only when the UAnPWR bit = 0 or the UAnTXE bit = the UAnRXE bit = 0.

Remark For details of parity, see 15.6.9 Parity types and operations.

# (2) UARTAn control register 1 (UAnCTL1)

For details, see 15.7 (2) UARTAn control register 1 (UAnCTL1).

### (3) UARTAn control register 2 (UAnCTL2)

For details, see 15.7 (3) UARTAn control register 2 (UAnCTL2).

## (4) UARTAn option control register 0 (UAnOPT0)

The UAnOPT0 register is an 8-bit register that controls the serial transfer operation of the UARTAn register.

This register can be read or written in 8-bit or 1-bit units.

Reset input sets this register to 14H.

(1/2)

After reset: 14H R/W Address: UA0OPT0 FFFFA03H, UA1OPT0 FFFFA13H, UA2OPT0 FFFFA23H

UAnOPT0(n = 0 to 2)

| <7>    | 6      | 5      | 4       | 3       | 2       | 1      | 0      |
|--------|--------|--------|---------|---------|---------|--------|--------|
| UAnSRF | UAnSRT | UAnSTT | UAnSLS2 | UAnSLS1 | UAnSLS0 | UAnTDL | UAnRDL |
|        |        |        |         |         |         |        |        |

| UAnSRF | SBF reception flag                                                                                   |
|--------|------------------------------------------------------------------------------------------------------|
| 0      | When the UAnCTL0.UAnPWR bit = UAnCTL0.UAnRXE bit = 0 are set. Also upon normal end of SBF reception. |
| 1      | During SBF reception                                                                                 |

- SBF (Sync Break Field) reception is judged during LIN communication.
- The UAnSRF bit is held at 1 when an SBF reception error occurs, and then SBF reception is started again.

| UAnSRT | SBF reception trigger |
|--------|-----------------------|
| 0      | -                     |
| 1      | SBF reception trigger |

- This is the SBF reception trigger bit during LIN communication, and when read, "0" is always read. For SBF reception, set the UAnSRT bit (to 1) to enable SBF reception.
- Set the UAnSRT bit after setting the UAnPWR bit = UAnRXE bit = 1.

| UAnSTT | SBF transmission trigger |
|--------|--------------------------|
| 0      | -                        |
| 1      | SBF transmission trigger |

- This is the SBF transmission trigger bit during LIN communication, and when read, "0" is always read.
- Set the UAnSTT bit after setting the UAnPWR bit = UAnTXE bit = 1.

Caution Do not set the UAnSRT and UAnSTT bits (to 1) during SBF reception (UAnSRF bit = 1).

(2/2)

| UAnSLS2 | UAnSLS1 | UAnSLS0 | SBF transmit length selection |
|---------|---------|---------|-------------------------------|
| 1       | 0       | 1       | 13-bit output (reset value)   |
| 1       | 1       | 0       | 14-bit output                 |
| 1       | 1       | 1       | 15-bit output                 |
| 0       | 0       | 0       | 16-bit output                 |
| 0       | 0       | 1       | 17-bit output                 |
| 0       | 1       | 0       | 18-bit output                 |
| 0       | 1       | 1       | 19-bit output                 |
| 1       | 0       | 0       | 20-bit output                 |

This register can be set when the UAnPWR bit = 0 or when the UAnTXE bit = 0.

| UAnTDL | Transmit data level bit          |
|--------|----------------------------------|
| 0      | Normal output of transfer data   |
| 1      | Inverted output of transfer data |

- The output level of the TXDAn pin can be inverted using the UAnTDL bit.
- This register can be set when the UAnPWR bit = 0 or when the UAnTXE bit = 0.

| UAnRDL | Receive data level bit          |  |
|--------|---------------------------------|--|
| 0      | Normal input of transfer data   |  |
| 1      | Inverted input of transfer data |  |

- The input level of the RXDAn pin can be inverted using the UAnRDL bit.
- This register can be set when the UAnPWR bit = 0 or the UAnRXE bit = 0.

# (5) UARTAn status register (UAnSTR)

The UAnSTR register is an 8-bit register that displays the UARTAn transfer status and reception error contents. This register can be read or written in 8-bit or 1-bit units, but the UAnTSF bit is a read-only bit, while the UAnPE, UAnFE, and UAnOVE bits can both be read and written. However, these bits can only be cleared by writing 0; they cannot be set by writing 1 (even if 1 is written to them, the value is retained).

The initialization conditions are shown below.

| Register/Bit              | Initialization Conditions                          |
|---------------------------|----------------------------------------------------|
| UAnSTR register           | <ul><li>Reset</li><li>UAnCTL0.UAnPWR = 0</li></ul> |
| UAnTSF bit                | • UAnCTL0.UAnTXE = 0                               |
| UAnPE, UAnFE, UAnOVE bits | 0 write     UAnCTL0.UAnRXE = 0                     |

After reset: 00H R/W Address: UA0STR FFFFA04H, UA1STR FFFFFA14H,

UA2STR FFFFFA24H

UAnSTR (n = 0 to 2)

| <7>    | 6 | 5 | 4 | 3 | <2>   | <1>   | <0>    |
|--------|---|---|---|---|-------|-------|--------|
| UAnTSF | 0 | 0 | 0 | 0 | UAnPE | UAnFE | UAnOVE |

| UAnTSF | Transfer status flag                                                                                                                                                              |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | <ul> <li>When the UAnPWR bit = 0 or the UAnTXE bit = 0 has been set.</li> <li>When, following transfer completion, there was no next data transfer from UAnTX register</li> </ul> |
| 1      | Write to UAnTX register                                                                                                                                                           |

The UAnTSF bit is always 1 when performing continuous transmission. When initializing the transmission unit, check that the UAnTSF bit = 0 before performing initialization. The transmit data is not guaranteed when initialization is performed while the UAnTSF bit = 1.

| UAnPE | Parity error flag                                                                   |
|-------|-------------------------------------------------------------------------------------|
| 0     | When the UAnPWR bit = 0 or the UAnRXE bit = 0 has been set. When 0 has been written |
| 1     | When parity of data and parity bit do not match during reception.                   |

- The operation of the UAnPE bit is controlled by the settings of the UAnCTL0.UAnPS1 and UAnCTL0.UAnPS0 bits.
- The UAnPE bit can be read and written, but it can only be cleared by writing 0 to it, and it cannot be set by writing 1 to it. When 1 is written to this bit, the value is retained.

| UAnFE | Framing error flag                                                                  |
|-------|-------------------------------------------------------------------------------------|
| 0     | When the UAnPWR bit = 0 or the UAnRXE bit = 0 has been set  When 0 has been written |
| 1     | When no stop bit is detected during reception                                       |

- Only the first bit of the receive data stop bits is checked, regardless of the value of the UAnCTL0.UAnSL bit.
- The UAnFE bit can be both read and written, but it can only be cleared by writing 0 to it, and it cannot be set by writing 1 to it. When 1 is written to this bit, the value is retained.

| UAnOVE | Overrun error flag                                                                                                                      |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 0      | When the UAnPWR bit = 0 or the UAnRXE bit = 0 has been set. When 0 has been written                                                     |
| 1      | When receive data has been set to the UAnRX register and the next receive operation is completed before that receive data has been read |

- When an overrun error occurs, the data is discarded without the next receive data being written to the receive buffer.
- The UAnOVE bit can be both read and written, but it can only be cleared by writing 0 to it. When 1 is written to this bit, the value is retained.

## (6) UARTAn receive data register (UAnRX)

The UAnRX register is an 8-bit buffer register that stores parallel data converted by the receive shift register.

The data stored in the receive shift register is transferred to the UAnRX register upon completion of reception of 1 byte of data.

During LSB-first reception when the data length has been specified as 7 bits, the receive data is transferred to bits 6 to 0 of the UAnRX register and the MSB always becomes 0. During MSB-first reception, the receive data is transferred to bits 7 to 1 of the UAnRX register and the LSB always becomes 0.

When an overrun error (UAnOVE) occurs, the receive data at this time is not transferred to the UAnRX register and is discarded.

This register is read-only, in 8-bit units.

In addition to reset input, the UAnRX register can be set to FFH by clearing the UAnCTL0.UAnPWR bit to 0.



### (7) UARTAn transmit data register (UAnTX)

The UAnTX register is an 8-bit register used to set transmit data.

This register can be read or written in 8-bit units.

Reset input sets this register to FFH.



# 15.5 Interrupt Request Signals

The following two interrupt request signals are generated from UARTAn.

- Reception complete interrupt request signal (INTUAnR)
- Transmission enable interrupt request signal (INTUAnT)

The default priority for these two interrupt request signals is reception complete interrupt request signal then transmission enable interrupt request signal.

Table 15-2. Interrupts and Their Default Priorities

| Interrupt           | Priority |  |  |  |
|---------------------|----------|--|--|--|
| Reception complete  | High     |  |  |  |
| Transmission enable | Low      |  |  |  |

### (1) Reception complete interrupt request signal (INTUAnR)

A reception complete interrupt request signal is output when data is shifted into the receive shift register and transferred to the UAnRX register in the reception enabled status.

When a reception complete interrupt request signal is received and the data is read, read the UAnSTR register and check that the reception result is not an error.

No reception complete interrupt request signal is generated in the reception disabled status.

# (2) Transmission enable interrupt request signal (INTUAnT)

If transmit data is transferred from the UAnTX register to the UARTAn transmit shift register with transmission enabled, the transmission enable interrupt request signal is generated.

# 15.6 Operation

# 15.6.1 Data format

Full-duplex serial data reception and transmission is performed.

As shown in Figure 15-5, one data frame of transmit/receive data consists of a start bit, character bits, parity bit, and stop bit(s).

Specification of the character bit length within 1 data frame, parity selection, specification of the stop bit length, and specification of MSB/LSB-first transfer are performed using the UAnCTL0 register.

Moreover, control of UART output/inverted output for the TXDAn bit is performed using the UAnOPT0.UAnTDL bit.

- Start bit ...... 1 bit
- Character bits...... 7 bits/8 bits
- Parity bit ...... Even parity/odd parity/0 parity/no parity
- Stop bit..... 1 bit/2 bits

Figure 15-5. UARTA Transmit/Receive Data Format



#### 15.6.2 SBF transmission/reception format

The V850ES/SG2 has an SBF (Sync Break Field) transmission/reception control function to enable use of the LIN function.

**Remark** LIN stands for Local Interconnect Network and is a low-speed (1 to 20 kbps) serial communication protocol intended to aid the cost reduction of an automotive network.

LIN communication is single-master communication, and up to 15 slaves can be connected to one master.

The LIN slaves are used to control the switches, actuators, and sensors, and these are connected to the LIN master via the LIN network.

Normally, the LIN master is connected to a network such as CAN (Controller Area Network).

In addition, the LIN bus uses a single-wire method and is connected to the nodes via a transceiver that complies with ISO9141.

In the LIN protocol, the master transmits a frame with baud rate information and the slave receives it and corrects the baud rate error. Therefore, communication is possible when the baud rate error in the slave is  $\pm 15\%$  or less.

Figures 15-6 and 15-7 outline the transmission and reception manipulations of LIN.



Figure 15-6. LIN Transmission Manipulation Outline

- **Notes 1.** The interval between each field is controlled by software.
  - 2. SBF output is performed by hardware. The output width is the bit length set by the UAnOPT0.UAnSBL2 to UAnOPT0.UAnSBL0 bits. If even finer output width adjustments are required, such adjustments can be performed using the UAnCTLn.UAnBRS7 to UAnCTLn.UAnBRS0 bits.
  - **3.** 80H transfer in the 8-bit mode is substituted for the wakeup signal frame.
  - **4.** A transmission enable interrupt request signal (INTUAnT) is output at the start of each transmission. The INTUAnT signal is also output at the start of each SBF transmission.



Figure 15-7. LIN Reception Manipulation Outline

- **Notes 1.** The wakeup signal is sent by the pin edge detector, UARTAn is enabled, and the SBF reception mode is set.
  - 2. The receive operation is performed until detection of the stop bit. Upon detection of SBF reception of 11 or more bits, normal SBF reception end is judged, and an interrupt signal is output. Upon detection of SBF reception of less than 11 bits, an SBF reception error is judged, no interrupt signal is output, and the mode returns to the SBF reception mode.
  - 3. If SBF reception ends normally, an interrupt request signal is output. The timer is enabled by an SBF reception complete interrupt. Moreover, error detection for the UAnSTR.UAnOVE, UAnSTR.UAnPE, and UAnSTR.UAnFE bits is suppressed and UART communication error detection processing and UARTAn receive shift register and data transfer of the UAnRX register are not performed. The UARTAn receive shift register holds the initial value, FFH.
  - 4. The RXDAn pin is connected to TI (capture input) of the timer, the transfer rate is calculated, and the baud rate error is calculated. The value of the UAnCTL2 register obtained by correcting the baud rate error after dropping UARTA enable is set again, causing the status to become the reception status.
  - **5.** Check-sum field distinctions are made by software. UARTAn is initialized following CSF reception, and the processing for setting the SBF reception mode again is performed by software.

## 15.6.3 SBF transmission

When the UAnCTL0.UAnPWR bit = UAnCTL0.UAnTXE bit = 1, the transmission enabled status is entered, and SBF transmission is started by setting (to 1) the SBF transmission trigger (UAnOPT0.UAnSTT bit).

Thereafter, a low level the width of bits 13 to 20 specified by the UAnOPT0.UAnSLS2 to UAnOPT0.UAnSLS0 bits is output. A transmission enable interrupt request signal (INTUAnT) is generated upon SBF transmission start. Following the end of SBF transmission, the UAnSTT bit is automatically cleared. Thereafter, the UART transmission mode is restored.

Transmission is suspended until the data to be transmitted next is written to the UAnTX register, or until the SBF transmission trigger (UAnSTT bit) is set.



Figure 15-8. SBF Transmission

## 15.6.4 SBF reception

The reception enabled status is achieved by setting the UAnCTL0.UAnPWR bit to 1 and then setting the UAnCTL0.UAnRXE bit to 1.

The SBF reception wait status is set by setting the SBF reception trigger (UAnOPT0.UAnSTR bit) to 1.

In the SBF reception wait status, similarly to the UART reception wait status, the RXDAn pin is monitored and start bit detection is performed.

Following detection of the start bit, reception is started and the internal counter counts up according to the set baud rate.

When a stop bit is received, if the SBF width is 11 or more bits, normal processing is judged and a reception complete interrupt request signal (INTUAnR) is output. The UAnOPT0.UAnSRF bit is automatically cleared and SBF reception ends. Error detection for the UAnSTR.UAnOVE, UAnSTR.UAnPE, and UAnSTR.UAnFE bits is suppressed and UART communication error detection processing is not performed. Moreover, data transfer of the UARTAn reception shift register and UAnRX register is not performed and FFH, the initial value, is held. If the SBF width is 10 or fewer bits, reception is terminated as error processing without outputting an interrupt, and the SBF reception mode is returned to. The UAnSRF bit is not cleared at this time.



Figure 15-9. SBF Reception

## 15.6.5 UART transmission

A high level is output to the TXDAn pin by setting the UAnCTL0.UAnPWR bit to 1.

Next, the transmission enabled status is set by setting the UAnCTL0.UAnTXE bit to 1, and transmission is started by writing transmit data to the UAnTX register. The start bit, parity bit, and stop bit are automatically added.

Since the CTS (transmit enable signal) input pin is not provided in UARTAn, use a port to check that reception is enabled at the transmit destination.

The data in the UAnTX register is transferred to the UARTAn transmit shift register upon the start of the transmit operation.

A transmission enable interrupt request signal (INTUAnT) is generated upon completion of transmission of the data of the UAnTX register to the UARTAn transmit shift register, and thereafter the contents of the UARTAn transmit shift register are output to the TXDAn pin.

Write of the next transmit data to the UAnTX register is enabled after the INTUAnT signal is generated.

**TXDAn** Start Parity Stop D0 D1 D2 D7 D3 D4 D5 D6 bit bit bit **INTUAnT** Remark LSB first

Figure 15-10. UART Transmission

## 15.6.6 Continuous transmission procedure

UARTAn can write the next transmit data to the UARTX register when the UARTAn transmit shift register starts the shift operation. The transmit timing of the UARTAn transmit shift register can be judged from the transmission enable interrupt request signal (INTUAnT).

An efficient communication rate is realized by writing the data to be transmitted next to the UAnTX register during transfer.

Caution When initializing transmissions during the execution of continuous transmissions, make sure that the UAnSTR.UAnTSF bit is 0, then perform the initialization. Transmit data that is initialized when the UAnTSF bit is 1 cannot be guaranteed.

Register settings

UANTX write

Occurrence of transmission interrupt?

Yes

Required number of writes performed?

Yes

End

Figure 15-11. Continuous Transmission Processing Flow



Figure 15-12. Continuous Transmission Operation Timing

#### 15.6.7 UART reception

The reception wait status is set by setting the UAnCTL0.UAnPWR bit to 1 and then setting the UAnCTL0.UAnRXE bit to 1. In the reception wait status, the RXDAn pin is monitored and start bit detection is performed.

Start bit detection is performed using a two-step detection routine.

First the rising edge of the RXDAn pin is detected and sampling is started at the falling edge. The start bit is recognized if the RXDAn pin is low level at the start bit sampling point. After a start bit has been recognized, the receive operation starts, and serial data is saved to the UARTAn receive shift register according to the set baud rate.

When the reception complete interrupt request signal (INTUAnR) is output upon reception of the stop bit, the data of the UARTAn receive shift register is written to the UAnRX register. However, if an overrun error (UAnSTR.UAnOVE bit) occurs, the receive data at this time is not written to the UAnRX register and is discarded.

Even if a parity error (UAnSTR.UAnPE bit) or a framing error (UAnSTR.UAnFE bit) occurs during reception, reception continues until the reception position of the first stop bit, and INTUAnR is output following reception completion.



Figure 15-13. UART Reception

- Cautions 1. Be sure to read the UAnRX register even when a reception error occurs. If the UAnRX register is not read, an overrun error occurs during reception of the next data, and reception errors continue occurring indefinitely.
  - 2. The operation during reception is performed assuming that there is only one stop bit. A second stop bit is ignored.
  - 3. When reception is completed, read the UAnRX register after the reception complete interrupt request signal (INTUAnR) has been generated, and clear the UAnPWR or UAnRXE bit to 0. If the UAnPWR or UAnRXE bit is cleared to 0 before the INTUAnR signal is generated, the read value of the UAnRX register cannot be guaranteed.
  - 4. If receive completion processing (INTUANR signal generation) of UARTAn and the UAnPWR bit = 0 or UAnRXE bit = 0 conflict, the INTUANR signal may be generated in spite of these being no data stored in the UAnRX register.

To complete reception without waiting INTUARR signal generation, be sure to clear (0) the interrupt request flag (UAnRIF) of the UAnRIC register, after setting (1) the interrupt mask flag (UAnRMK) of the interrupt control register (UAnRIC) and then set (1) the UAnPWR bit = 0 or UAnRXE bit = 0.

## 15.6.8 Reception errors

Errors during a receive operation are of three types: parity errors, framing errors, and overrun errors. Data reception result error flags are set in the UAnSTR register and a reception complete interrupt request signal (INTUAnR) is output when an error occurs.

It is possible to ascertain which error occurred during reception by reading the contents of the UAnSTR register. Clear the reception error flag by writing 0 to it after reading it.

#### · Receive data read flow



# · Reception error causes

| Error Flag | Reception Error | Cause                                                                     |
|------------|-----------------|---------------------------------------------------------------------------|
| UAnPE      | Parity error    | Received parity bit does not match the setting                            |
| UAnFE      | Framing error   | Stop bit not detected                                                     |
| UAnOVE     | Overrun error   | Reception of next data completed before data was read from receive buffer |

When reception errors occur, perform the following procedures depending upon the kind of error.

# • Parity error

If false data is received due to problems such as noise in the reception line, discard the received data and retransmit.

## Framing error

A baud rate error may have occurred between the reception side and transmission side or the start bit may have been erroneously detected. Since this is a fatal error for the communication format, check the operation stop in the transmission side, perform initialization processing each other, and then start the communication again.

### Overrun error

Since the next reception is completed before reading receive data, 1 frame of data is discarded. If this data was needed, do a retransmission.

Caution If a receive error interrupt occurs during continuous reception, read the contents of the UAnSTR register must be read before the next reception is completed, then perform error processing.

#### 15.6.9 Parity types and operations

## Caution When using the LIN function, fix the UAnPS1 and UAnPS0 bits of the UAnCTL0 register to 00.

The parity bit is used to detect bit errors in the communication data. Normally the same parity is used on the transmission side and the reception side.

In the case of even parity and odd parity, it is possible to detect odd-count bit errors. In the case of 0 parity and no parity, errors cannot be detected.

## (a) Even parity

# (i) During transmission

The number of bits whose value is "1" among the transmit data, including the parity bit, is controlled so as to be an even number. The parity bit values are as follows.

- Odd number of bits whose value is "1" among transmit data: 1
- Even number of bits whose value is "1" among transmit data: 0

#### (ii) During reception

The number of bits whose value is "1" among the reception data, including the parity bit, is counted, and if it is an odd number, a parity error is output.

# (b) Odd parity

## (i) During transmission

Opposite to even parity, the number of bits whose value is "1" among the transmit data, including the parity bit, is controlled so that it is an odd number. The parity bit values are as follows.

- Odd number of bits whose value is "1" among transmit data: 0
- Even number of bits whose value is "1" among transmit data: 1

# (ii) During reception

The number of bits whose value is "1" among the receive data, including the parity bit, is counted, and if it is an even number, a parity error is output.

# (c) 0 parity

During transmission, the parity bit is always made 0, regardless of the transmit data.

During reception, parity bit check is not performed. Therefore, no parity error occurs, regardless of whether the parity bit is 0 or 1.

#### (d) No parity

No parity bit is added to the transmit data.

Reception is performed assuming that there is no parity bit. No parity error occurs since there is no parity bit.

## 15.6.10 Receive data noise filter

This filter samples the RXDAn pin using the base clock of the prescaler output.

When the same sampling value is read twice, the match detector output changes and the RXDAn signal is sampled as the input data. Therefore, data not exceeding 2 clock width is judged to be noise and is not delivered to the internal circuit (see **Figure 15-15**). See **15.7 (1) (a) Base clock** regarding the base clock.

Moreover, since the circuit is as shown in Figure 15-14, the processing that goes on within the receive operation is delayed by 3 clocks in relation to the external signal status.



Figure 15-14. Noise Filter Circuit





#### 15.7 Dedicated Baud Rate Generator

The dedicated baud rate generator consists of a source clock selector block and an 8-bit programmable counter, and generates a serial clock during transmission and reception with UARTAn. Regarding the serial clock, a dedicated baud rate generator output can be selected for each channel.

There is an 8-bit counter for transmission and another one for reception.

### (1) Baud rate generator configuration

Figure 15-16. Configuration of Baud Rate Generator



# (a) Base clock

When the UAnCTL0.UAnPWR bit is 1, the clock selected by the UAnCTL1.UAnCKS3 to UAnCTL1.UAnCKS0 bits is supplied to the 8-bit counter. This clock is called the base clock (fuclk).

## (b) Serial clock generation

A serial clock can be generated by setting the UAnCTL1 register and the UAnCTL2 register (n = 0 to 2). The base clock is selected by UAnCTL1.UAnCKS3 to UAnCTL1.UAnCKS0 bits.

The frequency division value for the 8-bit counter can be set using the UAnCTL2.UAnBRS7 to UAnCTL2.UAnBRS0 bits.

# (2) UARTAn control register 1 (UAnCTL1)

The UAnCTL1 register is an 8-bit register that selects the UARTAn base clock.

This register can be read or written in 8-bit units.

Reset input clears this register to 00H.

Caution Clear the UAnCTL0.UAnPWR bit to 0 before rewriting the UAnCTL1 register.

After reset: 00H R/W Address: UA0CTL1 FFFFA01H, UA1CTL1 FFFFA11H, UA2CTL1 FFFFA21H

UAnCTL1 (n = 0 to 2)

| 7 | 6 | 5 | 4 | 3       | 2       | 1       | 0       |
|---|---|---|---|---------|---------|---------|---------|
| 0 | 0 | 0 | 0 | UAnCKS3 | UAnCKS2 | UAnCKS1 | UAnCKS0 |

| UAnCKS3          | UAnCKS2 | UAnCKS1 | UAnCKS0 | Base clock (fuclk) selection                |  |  |
|------------------|---------|---------|---------|---------------------------------------------|--|--|
| 0                | 0       | 0       | 0       | fxx                                         |  |  |
| 0                | 0       | 0       | 1       | fxx/2                                       |  |  |
| 0                | 0       | 1       | 0       | fxx/4                                       |  |  |
| 0                | 0       | 1       | 1       | fxx/8                                       |  |  |
| 0                | 1       | 0       | 0       | fxx/16                                      |  |  |
| 0                | 1       | 0       | 1       | fxx/32                                      |  |  |
| 0                | 1       | 1       | 0       | fxx/64                                      |  |  |
| 0                | 1       | 1       | 1       | fxx/128                                     |  |  |
| 1                | 0       | 0       | 0       | fxx/256                                     |  |  |
| 1                | 0       | 0       | 1       | fxx/512                                     |  |  |
| 1                | 0       | 1       | 0       | fxx/1,024                                   |  |  |
| 1                | 0       | 1       | 1       | External clock <sup>Note</sup> (ASCKA0 pin) |  |  |
| Other than above |         |         |         | Setting prohibited                          |  |  |

Note Only UARTA0 is valid; setting UARTA1 and UARTA2 is prohibited.

Remark fxx: Main clock frequency

# (3) UARTAn control register 2 (UAnCTL2)

 $\label{thm:condition} \text{The UAnCTL2 register is an 8-bit register that selects the baud rate (serial transfer speed) clock of UARTAn. }$ 

This register can be read or written in 8-bit units.

Reset input sets this register to FFH.

Caution Clear the UAnCTL0.UAnPWR bit to 0 or clear the UAnTXE and UAnRXE bits to 00 before rewriting the UAnCTL2 register.

After reset FFH R/W Address: UA0CTL2 FFFFA02H, UA1CTL2 FFFFA12H, UA2CTL2 FFFFA22H

7 6 5 4 3 2 1 0
UAnCTL2 UAnBRS7 UAnBRS6 UAnBRS5 UAnBRS4 UAnBRS3 UAnBRS2 UAnBRS1 UAnBRS0

(n = 0 to 2)

| UAn  | Default | Serial             |
|------|------|------|------|------|------|------|------|---------|--------------------|
| BRS7 | BRS6 | BRS5 | BRS4 | BRS3 | BRS2 | BRS1 | BRS0 | (k)     | clock              |
| 0    | 0    | 0    | 0    | 0    | 0    | ×    | ×    | ×       | Setting prohibited |
| 0    | 0    | 0    | 0    | 0    | 1    | 0    | 0    | 4       | fuclk/4            |
| 0    | 0    | 0    | 0    | 0    | 1    | 0    | 1    | 5       | fuclk/5            |
| 0    | 0    | 0    | 0    | 0    | 1    | 1    | 0    | 6       | fuclk/6            |
| :    | :    | :    | :    | :    | :    | :    | :    | :       | :                  |
| 1    | 1    | 1    | 1    | 1    | 1    | 0    | 0    | 252     | fuclk/252          |
| 1    | 1    | 1    | 1    | 1    | 1    | 0    | 1    | 253     | fuclk/253          |
| 1    | 1    | 1    | 1    | 1    | 1    | 1    | 0    | 254     | fuclk/254          |
| 1    | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 255     | fucьк/255          |

Remark fuclk: Clock frequency selected by the UAnCTL1.UAnCKS3 to UAnCTL1.UAnCKS0 bits

## (4) Baud rate

The baud rate is obtained by the following equation.

Baud rate = 
$$\frac{\text{fuclk}}{2 \times \text{k}}$$
 [bps]

When using the internal clock, the equation will be as follows (when using the ASCKA0 pin as clock at UARTA0, calculate using the above equation).

Baud rate = 
$$\frac{fxx}{2^{m+1} \times k} [bps]$$

Remark fuclk = Frequency of base clock selected by the UAnCTL1.UAnCKS3 to UAnCTL1.UAnCKS0 bits

fxx: Main clock frequency

m = Value set using the UAnCTL1.UAnCKS3 to UAnCTL1.UAnCKS0 bits (m = 0 to 10)

k = Value set using the UAnCTL2.UAnBRS7 to UAnCTL2.UAnBRS0 bits (k = 4 to 255)

The baud rate error is obtained by the following equation.

Error (%) = 
$$\left(\frac{\text{Actual baud rate (baud rate with error)}}{\text{Target baud rate (correct baud rate)}} - 1\right) \times 100 \, [\%]$$
  
=  $\left(\frac{\text{fuclk}}{2 \times \text{k} \times \text{Target baud rate}} - 1\right) \times 100 \, [\%]$ 

When using the internal clock, the equation will be as follows (when using the ASCKA0 pin as clock at UARTA0, calculate the baud rate error using the above equation).

Error (%) = 
$$\frac{fxx}{2^{m+1} \times k \times Target baud rate} - 1 \times 100 [\%]$$

- Cautions 1. The baud rate error during transmission must be within the error tolerance on the receiving side.
  - 2. The baud rate error during reception must satisfy the range indicated in (5) Allowable baud rate range during reception.

To set the baud rate, perform the following calculation and set the UAnCTL1 and UAnCTL2 registers (when using internal clock).

```
<1> Set k = fxx/(2 \times Target baud rate). Set m = 0.
```

$$<2>$$
 Set k = k/2 and m = m + 1 where k ≥ 256.

<3> Repeat <2> until k < 256.

<4> Roundup the first decimal place of k.

If k = 256 by the roundup, perform <2> again (k will become 128).

<5> Set m to the UAnCTL1 register and k to the UAnCTL2 register.

```
Example: When fxx = 32 MHz and target baud rate = 153,600 bps 

<1> k = 32,000,000/(2 \times 153,600) = 104.16..., m = 0

<2>, <3> k = 104.16... < 256, m = 0

<4> Set value of UAnCTL2 register: k = 104 = 68H, set value of UAnCTL1 register: m = 0

Actual baud rate = 32,000,000/(2 \times 104)

= 153,846 [bps]
```

Baud rate error = 
$$\{32,000,000/(2 \times 104 \times 153,600) - 1\} \times 100$$
  
= 0.160 [%]

The representative examples of baud rate settings are shown below.

Table 15-3. Baud Rate Generator Setting Data

| Baud Rate |         | fxx = 32 MHz | 2       | fxx = 20 MHz |         |         | fxx = 10 MHz |         |         |
|-----------|---------|--------------|---------|--------------|---------|---------|--------------|---------|---------|
| (bps)     | UAnCTL1 | UAnCTL2      | ERR (%) | UAnCTL1      | UAnCTL2 | ERR (%) | UAnCTL1      | UAnCTL2 | ERR (%) |
| 300       | 08H     | D0H          | 0.16    | 08H          | 82H     | 0.16    | 07H          | 82H     | 0.16    |
| 600       | 07H     | D0H          | 0.16    | 07H          | 82H     | 0.16    | 06H          | 82H     | 0.16    |
| 1,200     | 06H     | D0H          | 0.16    | 06H          | 82H     | 0.16    | 05H          | 82H     | 0.16    |
| 2,400     | 05H     | D0H          | 0.16    | 05H          | 82H     | 0.16    | 04H          | 82H     | 0.16    |
| 4,800     | 04H     | D0H          | 0.16    | 04H          | 82H     | 0.16    | 03H          | 82H     | 0.16    |
| 9,600     | 03H     | D0H          | 0.16    | 03H          | 82H     | 0.16    | 02H          | 82H     | 0.16    |
| 19,200    | 02H     | D0H          | 0.16    | 02H          | 82H     | 0.16    | 01H          | 82H     | 0.16    |
| 31,250    | 02H     | 80H          | 0.00    | 01H          | A0H     | 0.00    | 00H          | A0H     | 0.00    |
| 38,400    | 01H     | D0H          | 0.16    | 01H          | 82H     | 0.16    | 00H          | 82H     | 0.16    |
| 76,800    | 00H     | D0H          | 0.16    | 00H          | 82H     | 0.16    | 00H          | 41H     | 0.16    |
| 153,600   | 00H     | 68H          | 0.16    | 00H          | 41H     | 0.16    | 00H          | 21H     | -1.36   |
| 312,500   | 00H     | 33H          | 0.39    | 00H          | 20H     | 0.00    | 00H          | 10H     | 0.00    |

Remark fxx: Main clock frequency

ERR: Baud rate error (%)

### (5) Allowable baud rate range during reception

The baud rate error range at the destination that is allowable during reception is shown below.

Caution The baud rate error during reception must be set within the allowable error range using the following equation.

Latch timing  $\nabla$  $\nabla$  $\nabla$ **UARTAn** Parity bit Start bit Bit 0 Bit 1 Bit 7 Stop bit transfer rate FL 1 data frame (11 × FL) Minimum Bit 0 Bit 1 Bit 7 Stop bit Start bit Parity bit allowable transfer rate **FLmin** Maximum Stop bit Start bit Bit 0 Bit 1 Bit 7 Parity bit allowable transfer rate **FLmax Remark** n = 0 to 2

Figure 15-17. Allowable Baud Rate Range During Reception

As shown in Figure 15-17, the receive data latch timing is determined by the counter set using the UAnCTL2 register following start bit detection. The transmit data can be normally received if up to the last data (stop bit) can be received in time for this latch timing.

When this is applied to 11-bit reception, the following is the theoretical result.

$$FL = (Brate)^{-1}$$

Brate: UARTAn baud rate (n = 0 to 2)

k: Setting value of UAnCTL2.UAnBRS7 to UAnCTL2.UAnBRS0 bits (n = 0 to 2)

FL: 1-bit data length
Latch timing margin: 2 clocks

Minimum allowable transfer rate: FLmin =  $11 \times FL - \frac{k-2}{2k} \times FL = \frac{21k+2}{2k} FL$ 

Therefore, the maximum baud rate that can be received by the destination is as follows.

BRmax = 
$$(FLmin/11)^{-1} = \frac{22k}{21k + 2}$$
 Brate

Similarly, obtaining the following maximum allowable transfer rate yields the following.

$$\frac{10}{11} \times \text{FLmax} = 11 \times \text{FL} - \frac{k+2}{2 \times k} \times \text{FL} = \frac{21k-2}{2 \times k} \text{FL}$$

$$FLmax = \frac{21k - 2}{20 \text{ k}} FL \times 11$$

Therefore, the minimum baud rate that can be received by the destination is as follows.

BRmin = 
$$(FLmax/11)^{-1} = \frac{20k}{21k - 2}$$
 Brate

Obtaining the allowable baud rate error for UARTAn and the destination from the above-described equations for obtaining the minimum and maximum baud rate values yields the following.

Table 15-4. Maximum/Minimum Allowable Baud Rate Error

| Division Ratio (k) | Maximum Allowable Baud Rate Error | Minimum Allowable Baud Rate Error |  |  |
|--------------------|-----------------------------------|-----------------------------------|--|--|
| 4                  | +2.32%                            | -2.43%                            |  |  |
| 8                  | +3.52%                            | -3.61%                            |  |  |
| 20                 | +4.26%                            | -4.30%                            |  |  |
| 50                 | +4.56%                            | -4.58%                            |  |  |
| 100                | +4.66%                            | -4.67%                            |  |  |
| 255                | +4.72%                            | -4.72%                            |  |  |

- **Remarks 1.** The reception accuracy depends on the bit count in 1 frame, the input clock frequency, and the division ratio (k). The higher the input clock frequency and the larger the division ratio (k), the higher the accuracy.
  - 2. k: Setting value of UAnCTL2.UAnBRS7 to UAnCTL2.UAnBRS0 bits (n = 0 to 2)

# (6) Baud rate during continuous transmission

During continuous transmission, the transfer rate from the stop bit to the next start bit is usually 2 base clocks longer. However, timing initialization is performed via start bit detection by the receiving side, so this has no influence on the transfer result.

Figure 15-18. Transfer Rate During Continuous Transfer



Assuming 1 bit data length: FL; stop bit length: FLstp; and base clock frequency: fuclk, we obtain the following equation.

Therefore, the transfer rate during continuous transmission is as follows.

Transfer rate =  $11 \times FL + (2/fuclk)$ 

### 15.8 Cautions

- (1) When the clock supply to UARTAn is stopped (for example, in IDLE1, IDLE2, or STOP mode), the operation stops with each register retaining the value it had immediately before the clock supply was stopped. The TXDAn pin output also holds and outputs the value it had immediately before the clock supply was stopped. However, the operation is not guaranteed after the clock supply is resumed. Therefore, after the clock supply is resumed, the circuits should be initialized by setting the UAnCTL0.UAnPWR, UAnCTL0.UAnRXEn, and UAnCTL0.UAnTXEn bits to 000.
- (2) The RXDA1 and KR7 pins must not be used at the same time. To use the RXDA1 pin, do not use the KR7 pin. To use the KR7 pin, do not use the RXDA1 pin (it is recommended to set the PFC91 bit to 1 and clear PFCE91 bit to 0).
- (3) In UARTAn, the interrupt caused by a communication error does not occur. When performing the transfer of transmit data and receive data using DMA transfer, error processing cannot be performed even if errors (parity, overrun, framing) occur during transfer. Either read the UAnSTR register after DMA transfer has been completed to make sure that there are no errors, or read the UAnSTR register during communication to check for errors.
- (4) Start up the UARTAn in the following sequence.
  - <1> Set the UAnCTL0.UAnPWR bit to 1.
  - <2> Set the ports.
  - <3> Set the UAnCTL0.UAnTXE bit to 1, UAnCTL0.UAnRXE bit to 1.
- (5) Stop the UARTAn in the following sequence.
  - <1> Set the UAnCTL0.UAnTXE bit to 0, UAnCTL0.UAnRXE bit to 0.
  - <2> Set the ports and set the UAnCTL0.UAnPWR bit to 0 (it is not a problem if port setting is not changed).
- (6) In transmit mode (UAnCTL0.UAnPWR bit = 1 and UAnCTL0.UAnTXE bit = 1), do not overwrite the same value to the UAnTX register by software because transmission starts by writing to this register. To transmit the same value continuously, overwrite the same value.
- (7) In continuous transmission, the communication rate from the stop bit to the next start bit is extended 2 base clocks more than usual. However, the reception side initializes the timing by detecting the start bit, so the reception result is not affected.

# CHAPTER 16 3-WIRE VARIABLE-LENGTH SERIAL I/O (CSIB)

# 16.1 Mode Switching of CSIB and Other Serial Interfaces

# 16.1.1 CSIB4 and UARTA0 mode switching

In the V850ES/SG2, CSIB4 and UARTA0 are alternate functions of the same pin and therefore cannot be used simultaneously. Set CSIB4 in advance, using the PMC3 and PFC3 registers, before use.

Caution The transmit/receive operation of CSIB4 and UARTA0 is not guaranteed if these functions are switched during transmission or reception. Be sure to disable the one that is not used.

Figure 16-1. CSIB4 and UARTA0 Mode Switch Settings

| Allerie  | set: 0000H         | l R/W                  | Address                      | : FFFFF4                  | 16H, FFFFI                  | F447H                      |       |       |
|----------|--------------------|------------------------|------------------------------|---------------------------|-----------------------------|----------------------------|-------|-------|
|          | 15                 | 14                     | 13                           | 12                        | 11                          | 10                         | 9     | 8     |
| PMC3     | 0                  | 0                      | 0                            | 0                         | 0                           | 0                          | PMC39 | PMC38 |
|          | 7                  | 6                      | 5                            | 4                         | 3                           | 2                          | 1     | 0     |
|          | PMC37              | PMC36                  | PMC35                        | PMC34                     | PMC33                       | PMC32                      | PMC31 | PMC30 |
| After re | set: 0000H         | R/W                    | Address                      | : FFFFF46                 | 6H, FFFFF                   | -467H                      |       |       |
|          | 15                 | 14                     | 13                           | 12                        | 11                          | 10                         | 9     | 8     |
| PFC3     | 0                  | 0                      | 0                            | 0                         | 0                           | 0                          | PFC39 | PFC38 |
|          | 7                  | 6                      | 5                            | 4                         | 3                           | 2                          | 1     | 0     |
|          | PFC37              | PFC36                  | PFC35                        | PFC34                     | PFC33                       | PFC32                      | PFC31 | PFC30 |
| After re | set: 00H           |                        |                              | FFFF706F                  |                             | 332                        |       | 11000 |
| After re |                    |                        |                              | I                         |                             | 2                          | 1     | 0     |
| After re | set: 00H           | R/W                    | Address: F                   | -FFFF706H                 | 1                           |                            |       |       |
|          | set: 00H           | <b>R/W</b> 6           | Address: F                   | FFFF706H                  | 3 0                         | 2                          | 1 0   | 0     |
|          | set: 00H<br>7<br>0 | R/W 6 0                | Address: F                   | FFFF706H                  | 3<br>0                      | 2<br>PFCE32                | 1 0   | 0     |
|          | 7 0 PMC32          | R/W<br>6<br>0          | Address: F 5 0               | FFFF706H<br>4<br>0        | 3<br>0                      | 2<br>PFCE32                | 1 0   | 0     |
|          | set: 00H 7 0       | R/W 6 0 PFCE32 ×       | Address: F 5 0 PFC32 ×       | FFFF706H<br>4<br>0        | 3<br>0<br>Onode<br>mode     | 2<br>PFCE32                | 1 0   | 0     |
|          | 9 PMC32 0 1        | R/W 6 0 0 PFCE32 × 0   | Address: F 5 0  PFC32 × 0    | FFFF706H<br>4<br>0        | 3<br>0<br>Onode<br>mode     | 2<br>PFCE32<br>peration mo | 1 0   | 0     |
|          | PMC32<br>0<br>1    | PFCE32<br>×<br>0       | Address: F 5 0  PFC32 × 0    | Port I/O m ASCKA0 SCKB4 m | 3<br>0<br>O<br>node<br>mode | 2<br>PFCE32<br>peration mo | 1 0   | 0     |
|          | PMC32 0 1 1 PMC3n  | PFCE32  ×  0  0  PFC3n | Address: F 5 0 0 PFC32 × 0 1 | Port I/O n ASCKA0 SCKB4 m | 3<br>0<br>O<br>node<br>mode | 2<br>PFCE32<br>peration mo | 1 0   | 0     |

**Remarks 1.** n = 0, 1

**2.**  $\times$  = don't care

# 16.1.2 CSIB0 and I2C01 mode switching

In the V850ES/SG2, CSIB0 and I<sup>2</sup>C01 are alternate functions of the same pin and therefore cannot be used simultaneously. Set CSIB0 in advance, using the PMC4 and PFC4 registers, before use.

Caution The transmit/receive operation of CSIB0 and I<sup>2</sup>C01 is not guaranteed if these functions are switched during transmission or reception. Be sure to disable the one that is not used.

Figure 16-2. CSIB0 and I<sup>2</sup>C01 Mode Switch Settings



**Remarks 1.** n = 0, 1

**2.**  $\times$  = don't care

# 16.2 Features

- O Transfer rate: 8 Mbps MAX. (fxx = 32 MHz, using internal clock)
- O Master mode and slave mode selectable
- O 8-bit to 16-bit transfer, 3-wire serial interface
- O Interrupt request signals (INTCBnT, INTCBnR)  $\times$  2
- O Serial clock and data phase switchable
- O Transfer data length selectable in 1-bit units between 8 and 16 bits
- O Transfer data MSB-first/LSB-first switchable
- O 3-wire transfer SOBn: Serial data output

SIBn: Serial data input

SCKBn: Serial clock output

Transmission mode, reception mode, and transmission/reception mode specifiable

**Remark** n = 0 to 4

# 16.3 Configuration

The following shows the block diagram of CSIBn.

Internal bus CBnCTL1 CBnCTL2 CBnCTL0 **CBnSTR -**INTCBnT Controller **-**INTCBnR fxx/2 fxx/4 fxx/8 Selector fxx/16 fxx/32 Phase control fxx/64 **f**BRGm CBnTX SCKBn (0) Phase SO latch ►⊙ SOBn control SIBn 🔘 Shift register **CBnRX Remark** n = 0 to 4m = 1 (n = 0, 1)m = 2 (n = 2, 3)m = 3 (n = 4)

Figure 16-3. Block Diagram of CSIBn

CSIBn includes the following hardware.

Table 16-1. Configuration of CSIBn

| Item              | Configuration                                                                                                                           |  |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|
| Registers         | CSIBn receive data register (CBnRX) CSIBn transmit data register (CBnTX)                                                                |  |
| Control registers | CSIBn control register 0 (CBnCTL0) CSIBn control register 1 (CBnCTL1) CSIBn control register 2 (CBnCTL2) CSIBn status register (CBnSTR) |  |

### (1) CSIBn receive data register (CBnRX)

The CBnRX register is a 16-bit buffer register that holds receive data.

This register is read-only, in 16-bit units.

The receive operation is started by reading the CBnRX register in the reception enabled status.

If the transfer data length is 8 bits, the lower 8 bits of this register are read-only in 8-bit units as the CBnRXL register.

Reset input clears this register to 0000H.

In addition to reset input, the CBnRX register can be initialized by clearing (to 0) the CBnPWR bit of the CBnCTL0 register.



### (2) CSIB transmit data register (CBnTX)

The CBnTX register is a 16-bit buffer register used to write the CSIBn transfer data.

This register can be read or written in 16-bit units.

The transmit operation is started by writing data to the CBnTX register in the transmission enabled status.

If the transfer data length is 8 bits, the lower 8 bits of this register are read-only in 8-bit units as the CBnTXL register.

Reset input clears this register to 0000H.



**Remark** The communication start conditions are shown below.

Transmission mode (CBnTXE bit = 1, CBnRXE bit = 0): Write to CBnTX register

Transmission/reception mode (CBnTXE bit = 1, CBnRXE bit = 1): Write to CBnTX register

Reception mode (CBnTXE bit = 0, CBnRXE bit = 1): Read from CBnRX register

# 16.4 Registers

The following registers are used to control CSIBn.

- CSIBn control register 0 (CBnCTL0)
- CSIBn control register 1 (CBnCTL1)
- CSIBn control register 2 (CBnCTL2)
- CSIBn status register (CBnSTR)

# (1) CSIBn control register 0 (CBnCTL0)

CBnCTL0 is a register that controls the CSIBn serial transfer operation.

This register can be read or written in 8-bit or 1-bit units.

Reset input sets this register to 01H.

(1/3)

<0>

**CBnSCE** 

After reset: 01H R/W Address: CB0CTL0 FFFFFD00H, CB1CTL0 FFFFFD10H, CB2CTL0 FFFFD20H, CB3CTL0 FFFFD30H, CB4CTL0 FFFFFD40H

<6> <5> 2 <7> <4> CBnPWR CBnTXENote CBnRXENote CBnDIRNote CBnCTL0 0 0 CBnTMS<sup>Note</sup>

(n = 0 to 4)

| CBnPWR                                                                       | Specification of CSIBn operation disable/enable       |  |  |  |
|------------------------------------------------------------------------------|-------------------------------------------------------|--|--|--|
| 0                                                                            | Disable CSIBn operation and reset the CBnSTR register |  |  |  |
| 1                                                                            | Enable CSIBn operation                                |  |  |  |
| The CBnPWR bit controls the CSIBn operation and resets the internal circuit. |                                                       |  |  |  |

| CBnTXE <sup>Note</sup> | Specification of transmit operation disable/enable |  |  |  |
|------------------------|----------------------------------------------------|--|--|--|
| 0                      | Disable transmit operation                         |  |  |  |
| 1                      | Enable transmit operation                          |  |  |  |
| • The SOI              | Bn output is low level when the CBnTXE bit is 0.   |  |  |  |

| CBnRXE <sup>Note</sup> | Specification of receive operation disable/enable |  |  |  |  |
|------------------------|---------------------------------------------------|--|--|--|--|
| 0                      | Disable receive operation                         |  |  |  |  |
| 1                      | Enable receive operation                          |  |  |  |  |

• When the CBnRXE bit is cleared to 0, no reception complete interrupt is output even when the prescribed data is transferred in order to disable the receive operation, and the receive data (CBnRX register) is not updated.

Note These bits can only be rewritten when the CBnPWR bit = 0. However, CBnPWR bit = 1 can also be set at the same time as rewriting these bits.

Caution To forcibly suspend transmission/reception, clear the CBnPWR bit instead of the CBnRxE bit to 0. At this time, the clock output is stopped.

(2/3)

| CBnDIR <sup>Note</sup> | Specification of transfer direction mode (MSB/LSB) |
|------------------------|----------------------------------------------------|
| 0                      |                                                    |
| 1                      |                                                    |

| CBnTMS <sup>Note</sup> | Transfer mode specification |  |  |  |  |
|------------------------|-----------------------------|--|--|--|--|
| 0                      | Single transfer mode        |  |  |  |  |
| 1                      | Continuous transfer mode    |  |  |  |  |

#### [In single transfer mode]

The reception complete interrupt (INTCBnR) occurs when communication is complete.

Even if transmission is enabled (CBnTXE bit = 1), the transmission enable interrupt (INTCBnT) does not occur.

If the next transmit data is written during communication (CBnSTR.CBnTSF bit = 1), it is ignored and the next communication is not started. Also, if reception-only communication is set (CBnTXE bit = 0, CBnRXE bit = 1), the next communication is not started even if the receive data is read during communication (CBnSTR. CBnTSF bit = 1).

#### [In continuous transfer mode]

The continuous transmission is enabled by writing the next transmit data during communication (CBnSTR.CBnTSF bit = 1). Writing the next transmission data is enabled after a transmission enable interrupt (INTCBnT) occurrence.

If reception-only communication is set (CBnTXE bit = 0, CBnRXE bit = 1) in the continuous transfer mode, the next reception is started continuously after a reception complete interrupt (INTCBnR) regardless of the read operation of the CBnRX register.

Therefore, read immediately the receive data from the CBnRX register. If this read operation is delayed, an overrun error (CBnOVE bit = 1) occurs.

**Note** These bits can only be rewritten when the CBnPWR bit = 0. However, the CBnPWR can be set to 1 at the same time as these bits are rewritten.

(3/3)

| CBnSCE | Specification of start transfer disable/enable |  |  |  |
|--------|------------------------------------------------|--|--|--|
| 0      | Communication start trigger invalid            |  |  |  |
| 1      | Communication start trigger valid              |  |  |  |

#### In master mode

This bit enables or disables the communication start trigger.

- (a) In single transmission or transmission/reception mode, or continuous transmission or continuous transmission/reception mode The setting of the CBnSCE bit has no influence on communication operation.
- (b) In single reception mode
  - Clear the CBnSCE bit to 0 before reading the last receive data because reception is started by reading the receive data (CBnRX register) to disable the reception startup<sup>Note 1</sup>.
- (c) In continuous reception mode

  Clear the CBnSCE bit to 0 one communication clock before reception of the last data is completed to disable the reception startup after the last data is received<sup>Note 2</sup>.
- In slave mode

This bit enables or disables the communication start trigger. Set the CBnSCE bit to 1.

#### [Usage of CBnSCE bit]

- In single reception mode
  - <1>When reception of the last data is completed by INTCBnR interrupt servicing, clear the CBnSCE bit to 0 before reading the CBnRX register.
  - <2>After confirming the CBnSTR.CBnTSF bit = 0, clear the CBnRXE bit to 0 to disable reception.
    - To continue reception, set the CBnSCE bit to 1 to start up the next reception by dummy-reading the CBnRX register.
- In continuous reception mode
  - <1>Clear the CBnSCE bit to 0 during the reception of the last data by INTCBnR interrupt servicing.
  - <2>Read the CBnRX register.
  - <3>Read the last reception data by reading the CBnRX register after acknowledging the CBnTIR interrupt.
  - <4> After confirming the CBnSTR.CBnTSF bit = 0, clear the CBnRXE bit to 0 to disable reception.
    - To continue reception, set the CBnSCE bit to 1 to wait for the next reception by dummy-reading the CBnRX register.
- Notes 1. If the CBnSCE bit is read while it is 1, the next communication operation is started.
  - **2.** The CBnSCE bit is not cleared to 0 one communication clock before the completion of the last data reception, the next communication operation is automatically started.

Caution Be sure to clear bits 3 and 2 to 0.

### (2) CSIBn control register 1 (CBnCTL1)

CBnCTL1 is an 8-bit register that controls the CSIBn serial transfer operation.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

Caution The CBnCTL1 register can be rewritten only when the CBnCTL0.CBnPWR bit = 0.



| CBnCKS2 | CBnCKS1 | CBnCKS0 | Communication clock    | Mode        |
|---------|---------|---------|------------------------|-------------|
| 0       | 0       | 0       | fxx/2                  | Master mode |
| 0       | 0       | 1       | fxx/4                  | Master mode |
| 0       | 1       | 0       | fxx/8                  | Master mode |
| 0       | 1       | 1       | fxx/16                 | Master mode |
| 1       | 0       | 0       | fxx/32                 | Master mode |
| 1       | 0       | 1       | fxx/64                 | Master mode |
| 1       | 1       | 0       | <b>f</b> BRGm          | Master mode |
| 1       | 1       | 1       | External clock (SCKBn) | Slave mode  |

**Remark** When n = 0, 1, m = 1

When n = 2, 3, m = 2

When n = 4, m = 3

For details of fBRGm, see 16.8 Baud Rate Generator.

# (3) CSIBn control register 2 (CBnCTL2)

CBnCTL2 is an 8-bit register that controls the number of CSIBn serial transfer bits.

This register can be read or written in 8-bit units.

Reset input clears this register to 00H.

After reset: 00H

R/W

Caution The CBnCTL2 register can be rewritten only when the CBnCTL0.CBnPWR bit = 0 or when both the CBnTXE and CBnRXE bits = 0.

Address: CB0CTL2 FFFFFD02H, CB1CTL2 FFFFFD12H,

CB2CTL2 FFFFFD22H, CB3CTL2 FFFFD32H,
CB4CTL2 FFFFD42H

7 6 5 4 3 2 1 0

CBnCTL2 0 0 0 CBnCL3 CBnCL2 CBnCL1 CBnCL0

(n = 0 to 4)

| CBnCL3 | CBnCL2 | CBnCL1 | CBnCL0 | Serial register bit length |
|--------|--------|--------|--------|----------------------------|
| 0      | 0      | 0      | 0      | 8 bits                     |
| 0      | 0      | 0      | 1      | 9 bits                     |
| 0      | 0      | 1      | 0      | 10 bits                    |
| 0      | 0      | 1      | 1      | 11 bits                    |
| 0      | 1      | 0      | 0      | 12 bits                    |
| 0      | 1      | 0      | 1      | 13 bits                    |
| 0      | 1      | 1      | 0      | 14 bits                    |
| 0      | 1      | 1      | 1      | 15 bits                    |
| 1      | ×      | ×      | ×      | 16 bits                    |

**Remarks 1.** If the number of transfer bits is other than 8 or 16, prepare and use data stuffed from the LSB of the CBnTX and CBnRX registers.

2. ×: don't care

# (a) Transfer data length change function

The CSIBn transfer data length can be set in 1-bit units between 8 and 16 bits using the CBnCTL2.CBnCL3 to CBnCTL2.CBnCL0 bits.

When the transfer bit length is set to a value other than 16 bits, set the data to the CBnTX or CBnRX register starting from the LSB, regardless of whether the transfer start bit is the MSB or LSB. Any data can be set for the higher bits that are not used, but the receive data becomes 0 following serial transfer.



### (4) CSIBn status register (CBnSTR)

CBnSTR is an 8-bit register that displays the CSIBn status.

This register can be read or written in 8-bit or 1-bit units, but the CBnTSF flag is read-only.

Reset input clears this register to 00H.

In addition to reset input, the CBnSTR register can be initialized by clearing (0) the CBnCTL0.CBnPWR bit.

After reset 00H R/W Address: CB0STR FFFFD03H, CB1STR FFFFD13H, CB2STR FFFFD23H, CB3STR FFFFD33H, CB4STR FFFFD43H

CBnSTR (n = 0 to 4)

| <7>    | 6 | 5 | 4 | 3 | 2 | 1 | <0>    |
|--------|---|---|---|---|---|---|--------|
| CBnTSF | 0 | 0 | 0 | 0 | 0 | 0 | CBnOVE |

| CBnTSF | Communication status flag |  |  |
|--------|---------------------------|--|--|
| 0      | Communication stopped     |  |  |
| 1      | Communicating             |  |  |

 During transmission, this register is set when data is prepared in the CBnTX register, and during reception, it is set when a dummy read of the CBnRX register is performed.

When transfer ends, this flag is cleared to 0 at the last edge of the clock.

| CBnOVE | Overrun error flag |
|--------|--------------------|
| 0      | No overrun         |
| 1      | Overrun            |

- An overrun error occurs when the next reception starts without reading the value of the receive buffer by CPU, upon completion of the receive operation.
- The CBnOVE flag displays the overrun error occurrence status in this case.
- The CBnOVE bit is valid also in the single transfer mode. Therefore, when only using transmission, note the following.
- Do not check the CBnOVE flag.
- Read this bit even if reading the reception data is not required.
- The CBnOVE flag is cleared by writing 0 to it. It cannot be set even by writing 1 to it.

# 16.5 Operation

# 16.5.1 Single transfer mode (master mode, transmission/reception mode)

This section shows a case of MSB first (CBnCTL0.CBnDIR bit = 0), communication type 1 (see **16.4 (2) CSIBn control register 1 (CBnCTL1)**, and transfer data length = 8 bits (CBnCTL2.CBnCL3 to CBnCTL2.CBnCL0 bits = 0, 0, 0, 0).



- (1) Clear the CBnCTL0.CBnPWR bit to 0.
- (2) Set the CBnCTL1 and CBnCTL2 registers to specify the transfer mode.
- (3) Set the CBnTXE, CBnRXE, and CBnSCE bits of the CBnCTL0 register to 1 at the same time as specifying the transfer mode using the CBnDIR bit, to set the transmission/reception enabled status.
- (4) Set the CBnPWR bit to 1 to enable the CSIBn operation.
- (5) Write transfer data to the CBnTX register (transmission start).
- (6) The reception complete interrupt request signal (INTCBnR) is output.
- (7) Read the CBnRX register before clearing the CBnPWR bit to 0.
- (8) Check that the CBnSTR.CBnTSF bit = 0 and set the CBnPWR bit to 0 to stop operation of CSIBn (end of transmission/reception).

**Note** In single transmission or single transmission/reception mode, the INTCBnT signal is not generated. When communication is complete, the INTCBnR signal is generated.

Remark The processing of steps (3) and (4) can be set simultaneously.

### 16.5.2 Single transfer mode (master mode, reception mode)

This section shows the case using MSB first (CBnCTL0.CBnDIR bit = 0) and communication type 1 (see **16.4 (2) CSIBn control register 1 (CBnCTL1)**, transfer data length = 8 bits (CBnCTL2.CBnCL3 to CBnCTL2.CBnCL0 bits = 0, 0, 0, 0).



- (1) Clear the CBnCTL0.CBnPWR bit to 0.
- (2) Set the CBnCTL1 and CBnCTL2 registers to specify the transfer mode.
- (3) Set the CBnCTL0.CBnRXE and CBnCTL0.CBnSCE bits to 1 at the same time as specifying the transfer mode using the CBnDIR bit, to set the reception enabled status.
- (4) Set the CBnPWR bit to 1 to enable the CSIBn operation.
- (5) Perform a dummy read of the CBnRX register (reception start trigger).
- (6) The reception complete interrupt request signal (INTCBnR) is output.
- (7) Set the CBnSCE bit to 0 to set the final receive data status.
- (8) Read the CBnRX register.
- (9) Check that the CBnSTR.CBnTSF bit = 0 and set the CBnPWR bit to 0 to stop the CSIBn operation (end of reception).

**Remark** The processing of steps (3) and (4) can be set simultaneously.

### 16.5.3 Continuous mode (master mode, transmission/reception mode)

This section shows the case using MSB first (CBnCTL0.CBnDIR bit = 0) and communication type 3 (see **16.4 (2) CSIBn control register 1 (CBnCTL1)**), transfer data length = 8 bits (CBnCTL2.CBnCL3 to CBnCTL2.CBnCL0 bits = 0, 0, 0, 0).



- (1) Clear the CBnCTL0.CBnPWR bit to 0.
- (2) Set the CBnCTL1 and CBnCTL2 registers to specify the transfer mode.
- (3) Set the CBnTXE, CBnRXE, and CBnSCE bits of the CBnCTL0 register to 1 at the same time as specifying the transfer mode using the CBnDIR bit, to set the transmission/reception enabled status.
- (4) Set the CBnPWR bit to 1 to enable the CSIBn operation.
- (5) Write transfer data to the CBnTX register (transmission start).
- (6) The transmission enable interrupt request signal (INTCBnT) is received and transfer data is written to the CBnTX register.
- (7) The reception complete interrupt request signal (INTCBnR) is output.
  Read the CBnRX register before the next receive data arrives or before the CBnPWR bit is cleared to 0.
- (8) Check that the CBnSTR.CBnTSF bit = 0 and set the CBnPWR bit to 0 to stop the operation of CSIBn (end of transmission/reception).

To continue transfer, repeat steps (5) to (7) before (8).

In transmission mode or transmission/reception mode, the communication is not started by reading the CBnRX register.

### 16.5.4 Continuous mode (master mode, reception mode)

This section shows the case using MSB first (CBnCTL0.CBnDIR bit = 0) and communication type 2 (see **16.4 (2) CSIBn control register 1 (CBnCTL1)**), transfer data length = 8 bits (CBnCTL2.CBnCL3 to CBnCTL2.CBnCL0 bits = 0, 0, 0, 0).



- (1) Clear the CBnCTL0.CBnPWR bit to 0.
- (2) Set the CBnCTL1 and CBnCTL2 registers to specify the transfer mode.
- (3) Set the CBnCTL0.CBnRXE bit to 1 at the same time as specifying the transfer mode using the CBnDIR bit, to set the reception enabled status.
- (4) Set the CBnPWR bit to 1 to enable the CSIBn operation.
- (5) Perform a dummy read of the CBnRX register (reception start trigger).
- (6) The reception complete interrupt request signal (INTCBnR) is output.
  Read the CBnRX register before the next receive data arrives or before the CBnPWR bit is cleared to
  0.
- (7) Set the CBnCTL0.CBnSCE bit = 0 while the last data being received to set the final receive data status.
- (8) Check that the CBnSTR.CBnTSF bit = 0 and set the CBnPWR bit to 0 to stop the operation of CSIBn (end of reception).

To continue transfer, repeat steps (5) and (6) before (7).

### 16.5.5 Continuous reception mode (error)

This section shows the case using MSB first (CBnCTL0.CBnDIR bit = 0) and communication type 2 (see **16.4 (2) CSIBn control register 1 (CBnCTL1)**), transfer data length = 8 bits (CBnCTL2.CBnCL3 to CBnCTL2.CBnCL0 bits = 0, 0, 0, 0).



- (1) Clear the CBnCTL0.CBnPWR bit to 0.
- (2) Set the CBnCTL1 and CBnCTL2 registers to specify the transfer mode.
- (3) Set the CBnCTL0.CBnRXE bit to 1 at the same time as specifying the transfer mode using the CBnDIR bit, to set the reception enabled status.
- (4) Set the CBnPWR bit = 1 to enable CSIBn operation.
- (5) Perform a dummy read of the CBnRX register (reception start trigger).
- (6) The reception complete interrupt request signal (INTCBnR) is output.
- (7) If the data could not be read before the end of the next transfer, the CBnSTR.CBnOVE flag is set to 1 upon the end of reception and the INTCBnR signal is output.
- (8) Overrun error processing is performed after checking that the CBnOVE bit = 1 in the INTCBnR interrupt servicing.
- (9) Clear CBnOVE bit to 0.
- (10) Check that the CBnSTR.CBnTSF bit = 0 and set the CBnPWR bit to 0 to stop the operation CSIBn (end of reception).

### 16.5.6 Continuous mode (slave mode, transmission/reception mode)

This section shows the case using MSB first (CBnCTL0.CBnDIR bit = 0) and communication type 2 (see **16.4 (2) CSIBn control register 1 (CBnCTL1)**), transfer data length = 8 bits (CBnCTL2.CSnCL3 to CBnCTL2.CBnCL0 bits = 0, 0, 0, 0).



- (1) Clear the CBnCTL0.CBnPWR bit to 0.
- (2) Set the CBnCTL1 and CBnCTL2 registers to specify the transfer mode.
- (3) Set the CBnTXE, CBnRXE and CBnSCE bits of the CBnCTL0 register to 1 at the same time as specifying the transfer mode using the CBnDIR bit, to set the transmission/reception enabled status.
- (4) Set the CBnPWR bit to 1 to enable supply of the CSIBn operation.
- (5) Write the transfer data to the CBnTX register.
- (6) The transmission enable interrupt request signal (INTCBnT) is received and the transfer data is written to the CBnTX register.
- (7) The reception complete interrupt request signal (INTCBnR) is output. Read the CBnRX register.
- (8) Check that the CBnSTR.CBnTSF bit = 0 and set the CBnPWR bit to 0 to stop the operation of CSIBn (end of transmission/reception).

To continue transfer, repeat steps (5) to (7) before (8).

### 16.5.7 Continuous mode (slave mode, reception mode)

This section shows the case using MSB first (CBnCTL0.CBnDIR bit = 0) and communication type 1 (see **16.4 (2) CSIBn control register 1 (CBnCTL1)**), transfer data length = 8 bits (CBnCTL2.CBnCL3 to CBnCTL2.CBnCL0 bits = 0, 0, 0, 0).



- (1) Clear the CBnCTL0.CBnPWR bit to 0.
- (2) Set the CBnCTL1 and CBnCTL2 registers to specify the transfer mode.
- (3) Set the CBnCTL0.CBnRXE and CBnCTL0.CBnSCE bits to 1 at the same time as specifying the transfer mode using the CBnDIR bit, to set the reception enabled status.
- (4) Set the CBnPWR bit = 1 to enable CSIBn operation.
- (5) Perform a dummy read of the CBnRX register (reception start trigger).
- (6) The reception complete interrupt request signal (INTCBnR) is output.
  Read the CBnRX register. When reading the last data, clear the CBnCTL0.CBnSCE bit to 0 before reading the CBnRX register.
- (7) Check that the CBnSTR.CBnTSF bit = 0 and set the CBnPWR bit to 0 to stop the operation of CSIBn (end of reception).

To continue transfer, repeat steps (5) and (6) before (7).

### 16.5.8 Clock timing





- Notes 1. The INTCBnT interrupt is set when the data written to the transmit buffer is transferred to the data shift register in the continuous transmission or continuous transmission/reception mode. In the single transmission or single transmission/reception mode, the INTCBnT interrupt request signal is not generated, but the INTCBnR interrupt request signal is generated upon completion of communication.
  - 2. The INTCBnR interrupt occurs if reception is correctly completed and receive data is ready in the CBnRX register while reception is enabled, and if an overrun error occurs. In the single mode, the INTCBnR interrupt request signal is generated even in the transmission mode, upon completion of communication.

Caution In communication type 2, the CBnTSF bit is cleared half an SCKBn clock after generation of the INTCBnR interrupt request signal.





- **Notes 1.** The INTCBnT interrupt is set when the data written to the transmit buffer is transferred to the data shift register in the continuous transmission or continuous transmission/reception modes. In the single transmission or single transmission/reception modes, the INTCBnT interrupt request signal is not generated, but the INTCBnR interrupt request signal is generated upon completion of communication.
  - 2. The INTCBnR interrupt occurs if reception is correctly completed and receive data is ready in the CBnRX register while reception is enabled, and if an overrun error occurs. In the single mode, the INTCBnR interrupt request signal is generated even in the transmission mode, upon completion of communication.

Caution In communication type 4, the CBnTSF bit is cleared half an SCKBn clock after generation of the INTCBnR interrupt request signal.

# 16.6 Output Pins

# (1) SCKBn pin

When CSIBn operation is disabled (CBnCTL0.CBnPWR bit = 0), the SCKBn pin output status is as follows.

| CBnCKS2          | CBnCKS1 | CBnCKS0 | CBnCKP | SCKBn Pin Output    |
|------------------|---------|---------|--------|---------------------|
| 1                | 1       | 1       | ×      | High impedance      |
| Other than above |         |         | 0      | Fixed to high level |
|                  |         |         | 1      | Fixed to low level  |

**Remarks 1.** The output level of the SCKBn pin changes if any of the CBnCTL1.CBnCKP and CBnCKS2 to CBnCKS0 bits is rewritten.

- **2.** n = 0 to 4
- 3. ×: don't care

# (2) SOBn pin

When CSIBn operation is disabled (CBnPWR bit = 0), the SOBn pin output status is as follows.

| CBnTXE | CBnDAP | CBnDIR | SOBn Pin Output              |
|--------|--------|--------|------------------------------|
| 0      | ×      | ×      | Fixed to low level           |
| 1      | 0      | ×      | SOBn latch value (low level) |
|        | 1      | 0      | CBnTX register value (MSB)   |
|        |        | 1      | CBnTX register value (LSB)   |

Remarks 1. The SOBn pin output changes when any one of the CBnCTL0.CBnTXE, CBnCTL0.CBnDIR bits, and CBnCTL1.CBnDAP bit is rewritten.

- **2.** n = 0 to 4
- 3. ×: don't care

# 16.7 Operation Flow

# (1) Single transmission



# (2) Single reception



# (3) Single transmission/reception



Caution Even in the single mode, the CBnSTR.CBnOVE flag is set to 1. If only transmission is used in the transmission/reception mode, therefore, checking the CBnOVE flag is not required.

**Remark** n = 0 to 4

# (4) Continuous transmission



# (5) Continuous reception



Caution In the master mode, the clock is output without limit when dummy data is read from the CBnRX register. To stop the clock, execute the flow marked ♦ in the above flowchart.

In the slave mode, malfunction due to noise during communication can be prevented by executing the flow marked  $\spadesuit$  in the above flowchart.

Before resuming communication, set the CBnCTL0.CBnSCE bit to 1, and read dummy data from the CBnRX register.

**Remark** n = 0 to 4

# (6) Continuous transmission/reception



### 16.8 Baud Rate Generator

The BRG1 to BRG3 and CSIB0 to CSIB4 baud rate generators are connected as shown in the following block diagram.



# (1) Prescaler mode registers 1 to 3 (PRSM1 to PRSM3)

The PRSM1 to PRSM3 registers control generation of the baud rate signal for CSIB.

These registers can be read or written in 8-bit or 1-bit units.

Reset input clears these registers to 00H.



Cautions 1. Do not rewrite the PRSMm register during operation.

2. Set the PRSMm register before setting the BGCEm bit to 1.

### (2) Prescaler compare registers 1 to 3 (PRSCM1 to PRSCM3)

The PRSCM1 to PRSCM3 registers are 8-bit compare registers.

These registers can be read or written in 8-bit units.

Reset input clears these registers to 00H.

After reset: 00H R/W Address: PRSCM1 FFFF321H, PRSCM2 FFFF325H, PRSCM3 FFFF329H

7 6 5 4 3 2 1 0

PRSCMm7 PRSCMm6 PRSCMm5 PRSCMm4 PRSCMm3 PRSCMm2 PRSCMm1 PRSCMm0

Cautions 1. Do not rewrite the PRSCMm register during operation.

2. Set the PRSCMm register before setting the PRSMm.BGCEm bit to 1.

### 16.8.1 Baud rate generation

The transmission/reception clock is generated by dividing the main clock. The baud rate generated from the main clock is obtained by the following equation.

$$f_{BRGm} = \frac{f_{XX}}{2^{k+1} \times N}$$

Remark fBRGm: BRGm count clock

fxx: Main clock oscillation frequency

k: PRSMm register setting value = 0 to 3

N: PRSCMm register setting value = 1 to 256

However, N = 256 only when PRSCMm register is set to 00H.

m = 1 to 3

### 16.9 Cautions

- (1) When transferring transmit data and receive data using DMA transfer, error processing cannot be performed even if an overrun error occurs during serial transfer. Check that the no overrun error has occurred by reading the CBnSTR.CBnOVE bit after DMA transfer has been completed.
- (2) In regards to registers that are forbidden from being rewritten during operations (CBnCTL0.CBnPWR bit is 1), if rewriting has been carried out by mistake during operations, set the CBnCTL0.CBnPWR bit to 0 once, then initialize CSIBn.

Registers to which rewriting during operation are prohibited are shown below.

- CBnCTL0 register: CBnTXE, CBnRXE, CBnDIR, CBnTMS bits
- CBnCTL1 register: CBnCKP, CBnDAP, CBnCKS2 to CBnCKS0 bits
- CBnCTL2 register: CBnCL3 to CBnCL0 bits
- (3) In communication type 2 or 4 (CBnCTL1.CBnDAP bit = 1), the CBnSTR.CBnTSF bit is cleared half a SCKBn clock after occurrence of a reception complete interrupt (INTCBnR).

In the single transfer mode, writing the next transmit data is ignored during communication (CBnTSF bit = 1), and the next communication is not started. Also if reception-only communication (CBnCTL0.CBnTXE bit = 0, CBnCTL0.CBnRXE bit = 1) is set, the next communication is not started even if the receive data is read during communication (CBnTSF bit = 1).

Therefore, when using the single transfer mode with communication type 2 or 4 (CBnDAP bit = 1), pay particular attention to the following.

- To start the next transmission, confirm that CBnTSF bit = 0 and then write the transmit data to the CBnTX register.
- To perform the next reception continuously when reception-only communication (CBnTXE bit = 0, CBnRXE bit = 1) is set, confirm that CBnTSF bit = 0 and then read the CBnRX register.

Or, use the continuous transfer mode instead of the single transfer mode. Use of the continuous transfer mode is recommended especially for using DMA.

**Remark** n = 0 to 4

## CHAPTER 17 I2C BUS

To use the I2C bus function, set the P38/SDA00, P39/SCL00, P40/SDA01, P41/SCL01, P90/SDA02, and P91/SCL02 pins to N-ch open-drain output.

# 17.1 Mode Switching of I<sup>2</sup>C Bus and Other Serial Interfaces

## 17.1.1 UARTA2 and I<sup>2</sup>C00 mode switching

In the V850ES/SG2, UARTA2 and I2C00 are alternate functions of the same pin and therefore cannot be used simultaneously. Set I<sup>2</sup>C00 in advance, using the PMC3 and PFC3 registers, before use.

Caution The transmit/receive operation of UARTA2 and I2C00 is not guaranteed if these functions are switched during transmission or reception. Be sure to disable the one that is not used.

Figure 17-1. UARTA2 and I<sup>2</sup>C00 Mode Switch Settings

| After re   | set: 0000H | R/W   | Address                 | : FFFFF44 | l6H, FFFFI | -447H  |       |       |
|------------|------------|-------|-------------------------|-----------|------------|--------|-------|-------|
|            | 15         | 14    | 13                      | 12        | 11         | 10     | 9     | 8     |
| PMC3       | 0          | 0     | 0                       | 0         | 0          | 0      | PMC39 | PMC38 |
|            | 7          | 6     | 5                       | 4         | 3          | 2      | 1     | 0     |
|            | PMC37      | PMC36 | PMC35                   | PMC34     | PMC33      | PMC32  | PMC31 | PMC30 |
| DEOO       | 15         | 14    | 13                      | 12        | 11         | 10     | 9     | 8     |
| 711101 100 | set: 0000H |       |                         | : FFFFF46 |            |        |       |       |
|            |            |       |                         |           |            |        |       |       |
| PFC3       | 0          | 0     | 0                       | 0         | 0          | 0      | PFC39 | PFC38 |
|            | 7          | 6     | 5                       | 4         | 3          | 2      | 1     | 0     |
|            | PFC37      | PFC36 | PFC35                   | PFC34     | PFC33      | PFC32  | PFC31 | PFC30 |
|            | PMC3n      | PFC3n |                         |           | Operatio   | n mode |       |       |
|            | 0          | ×     | Port I/O m              | ode       |            |        |       |       |
|            | 1          | 0     | UARTA2 r                | mode      |            |        |       |       |
|            |            | 1     | I <sup>2</sup> C00 mode |           |            |        |       |       |

**2.**  $\times$  = don't care

## 17.1.2 CSIB0 and I2C01 mode switching

In the V850ES/SG2, CSIB0 and I<sup>2</sup>C01 are alternate functions of the same pin and therefore cannot be used simultaneously. Set I<sup>2</sup>C01 in advance, using the PMC4 and PFC4 registers, before use.

Caution The transmit/receive operation of CSIB0 and I<sup>2</sup>C01 is not guaranteed if these functions are switched during transmission or reception. Be sure to disable the one that is not used.

Figure 17-2. CSIB0 and I<sup>2</sup>C01 Mode Switch Settings



**Remarks 1.** n = 0, 1

**2.**  $\times$  = don't care

### 17.1.3 UARTA1 and I<sup>2</sup>C02 mode switching

In the V850ES/SG2, UARTA1 and I<sup>2</sup>C02 are alternate functions of the same pin and therefore cannot be used simultaneously. Set I<sup>2</sup>C02 in advance, using the PMC9, PFC9, and PMCE9 registers, before use.

Caution The transmit/receive operation of UARTA1 and I<sup>2</sup>C02 is not guaranteed if these functions are switched during transmission or reception. Be sure to disable the one that is not used.

Figure 17-3. UARTA1 and I<sup>2</sup>C02 Mode Switch Settings



### 17.2 Features

I<sup>2</sup>C00 to I<sup>2</sup>C02 have the following two modes.

- Operation stopped mode
- I<sup>2</sup>C (Inter IC) bus mode (multimasters supported)

### (1) Operation stopped mode

In this mode, serial transfers are not performed, thus enabling a reduction in power consumption.

### (2) I<sup>2</sup>C bus mode (multimaster support)

This mode is used for 8-bit data transfers with several devices via two lines: a serial clock pin (SCL0n) and a serial data bus pin (SDA0n).

This mode complies with the I<sup>2</sup>C bus format and the master device can generate "start condition", "address", "transfer direction specification", "data", and "stop condition" data to the slave device via the serial data bus. The slave device automatically detects the received statuses and data by hardware. This function can simplify the part of an application program that controls the I<sup>2</sup>C bus.

Since SCL0n and SDA0n pins are used for N-ch open-drain outputs, I<sup>2</sup>C0n requires pull-up resistors for the serial clock line and the serial data bus line.

**Remark** n = 0 to 2

## 17.3 Configuration

The block diagram of the I<sup>2</sup>C0n is shown below.

Internal bus IIC status register n (IICSn) MSTSn ALDn EXCn COIn TRCn ACKDn STDn SPDn IIC control register n (IICCn) IICEN LRELNWRELNSPIENWTIMNACKENSTTNSPTN Start Slave address Clear condition register n (SVAn) SDA0n ⊚-Set generator Match signal Noise eliminator Stop SO latch condition IIC shift Q CLn1, generator register n (IICn) DFCn CLn0 Data retention time **TRCn** correction circuit N-ch open-drain output Acknowledge Output control generator Wakeup controlle Acknowledge detector Start condition detector Stop condition detector SCL0n⊚<del>-</del> Interrupt request Noise **→**INTIICn Serial clock counter signal generator eliminator IICSn.MSTSn, Serial clock EXCn, COIn DFCn Serial clock wait controller IIC shift register n controller Bus status (IICn) N-ch open-drain detector IICCn.STTn, SPTn output IICSn.MSTSn, EXCn, COIn fxx Prescaler Prescaler fxx to fxx/5 OCKSENm OCKSTHm OCKSm1 OCKSm0 CLDn DADn SMCn DFCn CLn1 CLn0 CLXn STCFn | IICBSYn STCENn IICRSVn IIC division clock select IIC clock select IIC function expansion IIC flag register n register m (OCKSm) register n (IICCLn) register n (IICXn) (IICFn) Internal bus **Remark** n = 0 to 2 m = 0, 1

Figure 17-4. Block Diagram of I<sup>2</sup>C0n

A serial bus configuration example is shown below.

 $+V_{DD}$  $+V_{\text{DD}}$ Master CPU1 Master CPU2 Serial data bus SDA SDA Slave CPU2 Slave CPU1 Serial clock SCL SCL Address 1 Address 2 SDA Slave CPU3 Address 3 SCL Slave IC SDA SCL Address 4 SDA Slave IC

SCL

Address N

Figure 17-5. Serial Bus Configuration Example Using I<sup>2</sup>C Bus

 $I^2$ COn includes the following hardware (n = 0 to 2).

Table 17-1. Configuration of I<sup>2</sup>C0n

| Item              | Configuration                                                                                                                                                                                                                    |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Registers         | IIC shift register n (IICn) Slave address register n (SVAn)                                                                                                                                                                      |
| Control registers | IIC control register n (IICCn) IIC status register n (IICSn) IIC flag register n (IICF0n) IIC clock select register n (IICCLn) IIC function expansion register n (IICXn) IIC division clock select registers 0, 1 (OCKS0, OCKS1) |

## (1) IIC shift register n (IICn)

The IICn register converts 8-bit serial data into 8-bit parallel data and vice versa, and can be used for both transmission and reception (n = 0 to 2).

Write and read operations to the IICn register are used to control the actual transmit and receive operations.

This register can be read or written in 8-bit units.

Reset input clears this register to 00H.

## (2) Slave address register n (SVAn)

The SVAn register sets local addresses when in slave mode (n = 0 to 2).

This register can be read or written in 8-bit units.

Reset input clears this register to 00H.

### (3) SO latch

The SO latch is used to retain the output level of the SDA0n pin (n = 0 to 2).

### (4) Wakeup controller

This circuit generates an interrupt request signal (INTIICn) when the address received by this register matches the address value set to the SVAn register or when an extension code is received (n = 0 to 2).

### (5) Prescaler

This selects the sampling clock to be used.

### (6) Serial clock counter

This counter counts the serial clocks that are output and the serial clocks that are input during transmit/receive operations and is used to verify that 8-bit data was transmitted or received.

## (7) Interrupt request signal generator

This circuit controls the generation of interrupt request signals (INTIICn).

An I<sup>2</sup>C interrupt is generated following either of two triggers.

- Falling edge of eighth or ninth clock of the serial clock (set by IICCn.WTIMn bit)
- Interrupt occurrence due to stop condition detection (set by IICCn.SPIEn bit)

**Remark** n = 0 to 2

### (8) Serial clock controller

In master mode, this circuit generates the clock output via the SCL0n pin from the sampling clock (n = 0 to 2).

### (9) Serial clock wait controller

This circuit controls the wait timing.

## (10) ACK generator, stop condition detector, start condition detector, and ACK detector

These circuits are used to generate and detect various statuses.

#### (11) Data hold time correction circuit

This circuit generates the hold time for data corresponding to the falling edge of the SCL0n pin.

#### (12) Start condition generator

A start condition is generated when the IICCn.STTn bit is set.

However, in the communication reservation disabled status (IICFn.IICRSVn bit = 1), this request is ignored and the IICFn.STCFn bit is set to 1 if the bus is not released (IICFn.IICBSYn bit = 1).

# (13) Stop condition generator

A stop condition is generated when the IICCn.SPTn bit is set.

### (14) Bus status detector

Whether the bus is released or not is ascertained by detecting a start condition and stop condition.

However, the bus status cannot be detected immediately after operation, so set the bus status detector to the initial status by using the IICFn.STCENn bit.

## 17.4 Registers

I<sup>2</sup>C00 to I<sup>2</sup>C02 are controlled by the following registers.

- IIC control registers 0 to 2 (IICC0 to IICC2)
- IIC status registers 0 to 2 (IICS0 to IICS2)
- IIC flag registers 0 to 2 (IICF0 to IICF2)
- IIC clock select registers 0 to 2 (IICCL0 to IICCL2)
- IIC function expansion registers 0 to 2 (IICX0 to IICX2)
- IIC division clock select registers 0, 1 (OCKS0, OCKS1)

The following registers are also used.

- IIC shift registers 0 to 2 (IIC0 to IIC2)
- Slave address registers 0 to 2 (SVA0 to SVA2)

Remark For the alternate-function pin settings, see Table 4-15 Using Port Pin as Alternate-Function Pin.

### (1) IIC control registers 0 to 2 (IICC0 to IICC2)

The IICC0 to IICC2 registers enable/stop  $I^2$ C0n operations, set the wait timing, and set other  $I^2$ C operations (n = 0 to 2).

These registers can be read or written in 8-bit or 1-bit units. However, set the SPIEn, WTIMn, and ACKEn bits when the IICEn bit is 0 or during the wait period. When setting the IICEn bit from "0" to "1", these bits can also be set at the same time.

Reset input clears these registers to 00H.

(1/4)

| After reset: | 00H   | R/W   | Addres | ss: IICC0 FF | FFFD82H, II | CC1 FFFFF | 92H, IICC2 | FFFFDA2H |
|--------------|-------|-------|--------|--------------|-------------|-----------|------------|----------|
|              | <7>   | <6>   | <5>    | <4>          | <3>         | <2>       | <1>        | <0>      |
| IICCn        | IICEn | LRELn | WRELn  | SPIEn        | WTIMn       | ACKEn     | STTn       | SPTn     |
|              |       |       |        |              |             |           |            |          |

(n = 0 to 2)

| IICEn                                  | Specification of I <sup>2</sup> Cn operation enable/disable                             |                                       |  |
|----------------------------------------|-----------------------------------------------------------------------------------------|---------------------------------------|--|
| 0                                      | Operation stopped. IICSn register reset <sup>Note 1</sup> . Internal operation stopped. |                                       |  |
| 1                                      | Operation enabled.                                                                      |                                       |  |
| Be sure to                             | Be sure to set this bit to 1 when the SCL0n and SDA0n lines are high level.             |                                       |  |
| Condition for clearing (IICEn bit = 0) |                                                                                         | Condition for setting (IICEn bit = 1) |  |
| • Cleared b                            | by instruction                                                                          | Set by instruction                    |  |
| After reset                            |                                                                                         |                                       |  |

| LRELn <sup>Note 2</sup> | Exit from communications                                                                                                                                                                                                                                                                                                                                                                             |  |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0                       | Normal operation                                                                                                                                                                                                                                                                                                                                                                                     |  |
| 1                       | This exits from the current communication operation and sets standby mode. This setting is automatically cleared after being executed. Its uses include cases in which a locally irrelevant extension code has been received.  The SCL0n and SDA0n lines are set to high impedance.  The STTn and SPTn bits and the MSTSn, EXCn, COIn, TRCn, ACKDn, and STDn bits of the IICSn register are cleared. |  |

The standby mode following exit from communications remains in effect until the following communication entry conditions are met.

- After a stop condition is detected, restart is in master mode.
- An address match occurs or an extension code is received after the start condition.

| Condition for clearing (LRELn bit = 0)                | Condition for setting (LRELn bit = 1) |  |
|-------------------------------------------------------|---------------------------------------|--|
| Automatically cleared after execution     After reset | t by instruction                      |  |

| WRELn <sup>Note 2</sup>                               | Wait state cancellation control                |                                                |  |
|-------------------------------------------------------|------------------------------------------------|------------------------------------------------|--|
| 0                                                     | Wait state not canceled                        |                                                |  |
| 1                                                     | Wait state canceled. This setting is automated | atically cleared after wait state is canceled. |  |
| Condition for                                         | clearing (WRELn bit = 0)                       | Condition for setting (WRELn bit = 1)          |  |
| Automatically cleared after execution     After reset |                                                | Set by instruction                             |  |

- **Notes 1.** The IICSn register, IICFn.STCFn and IICFn.IICBSYn bits, and IICCLn.CLDn and IICCLn.DADn bits are reset.
  - **2.** This flag's signal is invalid when the IICEn bit = 0.

Caution If the I<sup>2</sup>Cn operation is enabled (IICEn bit = 1) when the SCL0n line is high level and the SDA0n line is low level, the start condition is detected immediately. To avoid this, after enabling the I<sup>2</sup>Cn operation, immediately set the LRELn bit to 1 with a bit manipulation instruction.

**Remark** The LRELn and WRELn bits are 0 when read after the data has been set.

(2/4)

| SPIEn <sup>Note</sup>                  | Enable/disable generation of interrupt request when stop condition is detected |                                       |  |
|----------------------------------------|--------------------------------------------------------------------------------|---------------------------------------|--|
| 0                                      | Disabled                                                                       |                                       |  |
| 1                                      | Enabled                                                                        |                                       |  |
| Condition for clearing (SPIEn bit = 0) |                                                                                | Condition for setting (SPIEn bit = 1) |  |
| Cleared by instruction     After reset |                                                                                | Set by instruction                    |  |

| WTIMn <sup>Note</sup> | Control of wait state and interrupt request generation                                                                                                                                                                                                                                              |  |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0                     | Interrupt request is generated at the eighth clock's falling edge.  Master mode: After output of eight clocks, clock output is set to low level and the wait state is set.  Slave mode: After input of eight clocks, the clock is set to low level and the wait state is set for the master device. |  |
| 1                     | Interrupt request is generated at the ninth clock's falling edge.  Master mode: After output of nine clocks, clock output is set to low level and the wait state is set.  Slave mode: After input of nine clocks, the clock is set to low level and the wait state is set for the master device.    |  |
| During addre          | ess transfer, an interrupt occurs at the falling edge of the ninth clock regardless of this bit setting. The                                                                                                                                                                                        |  |

During address transfer, an interrupt occurs at the falling edge of the ninth clock regardless of this bit setting. This bit setting becomes valid when the address transfer is completed. In master mode, a wait state is inserted at the falling edge of the ninth clock during address transfer. For a slave device that has received a local address, a wait state is inserted at the falling edge of the ninth clock after  $\overline{ACK}$  is generated. When the slave device has received an extension code, however, a wait state is inserted at the falling edge of the eighth clock.

| Condition for clearing (WTIMn bit = 0) | Condition for setting (WTIMn bit = 1) |  |  |
|----------------------------------------|---------------------------------------|--|--|
| Cleared by instruction                 | Set by instruction                    |  |  |
| After reset                            |                                       |  |  |

| ACKEn <sup>Note</sup> | Acknowledgement control                                                                    |  |  |
|-----------------------|--------------------------------------------------------------------------------------------|--|--|
| 0                     | Acknowledgment disabled.                                                                   |  |  |
| 1                     | Acknowledgment enabled. During the ninth clock period, the SDA0n line is set to low level. |  |  |
|                       |                                                                                            |  |  |

The ACKEn bit setting is invalid for address reception by the slave device. In this case, ACK is generated when the addresses match.

However, the ACKEn bit setting is valid for reception of the extension code. Set the ACKEn bit in the system that receives the extension code.

| Condition for clearing (ACKEn bit = 0) | Condition for setting (ACKEn bit = 1) |  |
|----------------------------------------|---------------------------------------|--|
| Cleared by instruction                 | Set by instruction                    |  |
| After reset                            |                                       |  |

**Note** This flag's signal is invalid when the IICEn bit = 0.

**Remark** n = 0 to 2

(3/4)

| STTn                                                                                                                                                                                                                                                                                                                                       | Star                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | t condition trigger                  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--|--|--|
| 0                                                                                                                                                                                                                                                                                                                                          | Start condition is not generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                      |  |  |  |
| 1                                                                                                                                                                                                                                                                                                                                          | When bus is released (in STOP mode):  A start condition is generated (for starting as master). The SDA0n line is changed from high level to low level while the SCLn line is high level and then the start condition is generated. Next, after the rated amount of time has elapsed, the SCL0n line is changed to low level.  During communication with a third party:  If the communication reservation function is enabled (IICFn.IICRSVn bit = 0)  This trigger functions as a start condition reserve flag. When set to 1, it releases the bus and the automatically generates a start condition.  If the communication reservation function is disabled (IICRSVn = 1)  The IICFn.STCFn bit is set to 1 and information set (1) to the STTn bit is cleared. This trigger does not generate a start condition.  In the wait state (when master device):  A restart condition is generated after the wait state is released. |                                      |  |  |  |
| For master For slave:                                                                                                                                                                                                                                                                                                                      | communication reservation status is entered.  • Setting to 1 at the same time as the SPTn bit is prohibited.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                      |  |  |  |
| Condition f                                                                                                                                                                                                                                                                                                                                | or clearing (STTn bit = 0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Condition for setting (STTn bit = 1) |  |  |  |
| <ul> <li>When the STTn bit is set to 1 in the communication reservation disabled status</li> <li>Cleared by loss in arbitration</li> <li>Cleared after start condition is generated by master device</li> <li>When the LRELn bit = 1 (communication save)</li> <li>When the IICEn bit = 0 (operation stop)</li> <li>After reset</li> </ul> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Set by instruction                   |  |  |  |

Remarks 1. The STTn bit is 0 if it is read immediately after data setting.

**2.** n = 0 to 2

(4/4)

| SPTn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Stop condition trigger                                                                                                                                                                                                                                                                                                                              |                                                         |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|--|--|--|
| 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Stop condition is not generated.                                                                                                                                                                                                                                                                                                                    |                                                         |  |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Stop condition is generated (termination of master device's transfer).  After the SDA0n line goes to low level, either set the SCL0n line to high level or wait until the SCL0n pin goes to high level. Next, after the rated amount of time has elapsed, the SDA0n line is changed from low level to high level and a stop condition is generated. |                                                         |  |  |  |
| Cautions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | concerning set timing                                                                                                                                                                                                                                                                                                                               |                                                         |  |  |  |
| For maste                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | r reception: Cannot be set to 1 during trans                                                                                                                                                                                                                                                                                                        | fer.                                                    |  |  |  |
| ĺ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Can be set to 1 only when the                                                                                                                                                                                                                                                                                                                       | ACKEn bit has been set to 0 and during the wait period  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | after the slave has been notified                                                                                                                                                                                                                                                                                                                   | d of final reception.                                   |  |  |  |
| For maste                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | r transmission: A stop condition cannot be gen                                                                                                                                                                                                                                                                                                      | erated normally during the ACK reception period. Set to |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1 during the wait period that fo                                                                                                                                                                                                                                                                                                                    | llows output of the ninth clock.                        |  |  |  |
| <ul> <li>Cannot I</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | be set to 1 at the same time as the STTn bit.                                                                                                                                                                                                                                                                                                       |                                                         |  |  |  |
| • The SPT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | In bit can be set to 1 only when in master mode                                                                                                                                                                                                                                                                                                     | e <sup>Note</sup> .                                     |  |  |  |
| <ul> <li>When the WTIMn bit has been set to 0, if the SPTn bit is set to 1 during the wait period that follows output of eight clocks, note that a stop condition will be generated during the high-level period of the ninth clock. The WTIMn bit should be changed from 0 to 1 during the wait period following output of eight clocks, and the SPTn bit should be set to 1 during the wait period that follows output of the ninth clock.</li> <li>When the SPTn bit is set to 1, setting the SPTn bit to 1 again is disabled until the setting is cleared to 0.</li> </ul> |                                                                                                                                                                                                                                                                                                                                                     |                                                         |  |  |  |
| Condition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Condition for clearing (SPTn bit = 0)  Condition for setting (SPTn bit = 1)                                                                                                                                                                                                                                                                         |                                                         |  |  |  |
| Automat                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | by loss in arbitration ically cleared after stop condition is detected e LRELn bit = 1 (communication save)                                                                                                                                                                                                                                         | Set by instruction                                      |  |  |  |

**Note** Set the SPTn bit to 1 only in master mode. However, when the IICRSVn bit is 0, the SPTn bit must be set to 1 and a stop condition generated before the first stop condition is detected following the switch to the operation enabled status. For details, see **17.15 Cautions**.

Caution When the TRCn bit = 1, the WRELn bit is set to 1 during the ninth clock and the wait state is canceled, after which the TRCn bit is cleared to 0 and the SDA0n line is set to high impedance.

**Remarks 1.** The SPTn bit is 0 if it is read immediately after data setting.

**2.** n = 0 to 2

• When the IICEn bit = 0 (operation stop)

• After reset

# (2) IIC status registers 0 to 2 (IICS0 to IICS2)

The IICS0 to IICS2 registers indicate the status of the  $I^2$ C0n bus (n = 0 to 2).

These registers are read-only, in 8-bit or 1-bit units. However, the IICSn register can only be read when the IICCn.STTn bit is 1 or during the wait period.

Reset input clears these registers to 00H.

Caution Accessing the IICSn register is prohibited in the following statuses. For details, see 3.4.9 (2) Accessing specific on-chip peripheral I/O registers.

- When the CPU operates with the subclock and the main clock oscillation is stopped
- When the CPU operates with the internal oscillation clock

(1/3)

| After reset: 00H R |       | Address: IICS0 FFFFD86H, IICS1 FFFFD96H, IICS2 FFFFDA6H |      |      |      |       |      |      |
|--------------------|-------|---------------------------------------------------------|------|------|------|-------|------|------|
|                    | <7>   | <6>                                                     | <5>  | <4>  | <3>  | <2>   | <1>  | <0>  |
| IICSn              | MSTSn | ALDn                                                    | EXCn | COIn | TRCn | ACKDn | STDn | SPDn |
| (n = 0  to  2)     |       |                                                         |      |      |      |       |      |      |

| MSTSn                                        | Master device status                                                                                                                          |                                       |  |  |
|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|--|--|
| 0                                            | Slave device status or communication standby status                                                                                           |                                       |  |  |
| 1                                            | Master device communication status                                                                                                            |                                       |  |  |
| Condition 1                                  | for clearing (MSTSn bit = 0)                                                                                                                  | Condition for setting (MSTSn bit = 1) |  |  |
| <ul><li>When the</li><li>Cleared I</li></ul> | stop condition is detected e ALDn bit = 1 (arbitration loss) by LRELn bit = 1 (communication save) e IICEn bit changes from 1 to 0 (operation | When a start condition is generated   |  |  |

| ALDn                                                                                             | Arbitration loss detection                                                                         |                                          |  |  |
|--------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|------------------------------------------|--|--|
| 0                                                                                                | This status means either that there was no arbitration or that the arbitration result was a "win". |                                          |  |  |
| 1                                                                                                | This status indicates the arbitration result was a "loss". The MSTSn bit is cleared to 0.          |                                          |  |  |
| Condition f                                                                                      | for clearing (ALDn bit = 0)                                                                        | Condition for setting (ALDn bit = 1)     |  |  |
| Automatically cleared after the IICSn register is read Note                                      |                                                                                                    | When the arbitration result is a "loss". |  |  |
| <ul> <li>When the IICEn bit changes from 1 to 0 (operation stop)</li> <li>After reset</li> </ul> |                                                                                                    |                                          |  |  |

| EXCn                                  | Detection of extension code reception                                                                                                            |                                                                                                                                  |  |  |
|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0                                     | Extension code was not received.                                                                                                                 |                                                                                                                                  |  |  |
| 1                                     | Extension code was received.                                                                                                                     |                                                                                                                                  |  |  |
| Condition for clearing (EXCn bit = 0) |                                                                                                                                                  | Condition for setting (EXCn bit = 1)                                                                                             |  |  |
| When a s    Cleared b                 | start condition is detected<br>stop condition is detected<br>by LRELn bit = 1 (communication save)<br>e IICEn bit changes from 1 to 0 (operation | When the higher four bits of the received address data are either "0000" or "1111" (set at the rising edge of the eighth clock). |  |  |

Note This register is also cleared when a bit manipulation instruction is executed for bits other than the IICSn register.

(2/3)

| COIn               | Matching address detection                                                                                                                       |                                                                                                                         |  |  |  |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0                  | Addresses do not match.                                                                                                                          |                                                                                                                         |  |  |  |
| 1                  | Addresses match.                                                                                                                                 |                                                                                                                         |  |  |  |
| Condition          | for clearing (COIn bit = 0)                                                                                                                      | Condition for setting (COIn bit = 1)                                                                                    |  |  |  |
| When a     Cleared | start condition is detected<br>stop condition is detected<br>by LRELn bit = 1 (communication save)<br>e IICEn bit changes from 1 to 0 (operation | When the received address matches the local<br>address (SVAn register) (set at the rising edge of the<br>eighth clock). |  |  |  |

| TRCn                                                                                                       | Transmit/receive status detection                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                         |  |  |  |  |
|------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 0                                                                                                          | Receive status (other than transmit status).                                                                                                                                                                                                                                                                | Receive status (other than transmit status). The SDA0n line is set to high impedance.                                                                                                                                   |  |  |  |  |
| 1                                                                                                          | Transmit status. The value in the SO latch is enabled for output to the SDA0n line (valid starting at the falling edge of the first byte's ninth clock).                                                                                                                                                    |                                                                                                                                                                                                                         |  |  |  |  |
| Condition f                                                                                                | for clearing (TRCn bit = 0)                                                                                                                                                                                                                                                                                 | Condition for setting (TRCn bit = 1)                                                                                                                                                                                    |  |  |  |  |
| Cleared B When the stop) Cleared B When the loss) After rese Master When "1" direction Slave When a second | stop condition is detected by LRELn bit = 1 (communication save) e IICEn bit changes from 1 to 0 (operation by IICCn.WRELn bit = 1 Note e ALDn bit changes from 0 to 1 (arbitration bet d is output to the first byte's LSB (transfer specification bit) start condition is detected used for communication | Master  When a start condition is generated  When "0" is output to the first byte's LSB (transfer direction specification bit)  Slave  When "1" is input by the first byte's LSB (transfer direction specification bit) |  |  |  |  |

| ACKDn                                                                                                                                                                                        | Ā                           | ACK detection                                                                             |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|-------------------------------------------------------------------------------------------|--|--|
| 0                                                                                                                                                                                            | ACK was not detected.       |                                                                                           |  |  |
| 1                                                                                                                                                                                            | ACK was detected.           |                                                                                           |  |  |
| Condition f                                                                                                                                                                                  | or clearing (ACKDn bit = 0) | Condition for setting (ACKD bit = 1)                                                      |  |  |
| When a stop condition is detected  At the rising edge of the next byte's first clock  Cleared by LRELn bit = 1 (communication save)  When the IICEn bit changes from 1 to 0 (operation stop) |                             | After the SDA0n bit is set to low level at the rising edge of the SCL0n pin's ninth clock |  |  |

**Note** The TRCn bit is cleared to 0 and SDA0n line becomes high impedance when the WRELn bit is set to 1 and the wait state is canceled to 0 at the ninth clock by TRCn bit = 1.

**Remark** n = 0 to 2

(3/3)

| STDn                                                       | Start condition detection                                                                                                                                             |                                      |  |  |
|------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--|--|
| 0                                                          | Start condition was not detected.                                                                                                                                     |                                      |  |  |
| 1                                                          | Start condition was detected. This indicates that the address transfer period is in effect                                                                            |                                      |  |  |
| Condition                                                  | for clearing (STDn bit = 0)                                                                                                                                           | Condition for setting (STDn bit = 1) |  |  |
| <ul><li>At the ris<br/>following</li><li>Cleared</li></ul> | stop condition is detected sing edge of the next byte's first clock address transfer by LRELn bit = 1 (communication save) e IICEn bit changes from 1 to 0 (operation | When a start condition is detected   |  |  |

| SPDn        | Stop condition detection                                                                              |                                      |  |  |
|-------------|-------------------------------------------------------------------------------------------------------|--------------------------------------|--|--|
| 0           | Stop condition was not detected.                                                                      |                                      |  |  |
| 1           | Stop condition was detected. The master device's communication is terminated and the bus is released. |                                      |  |  |
| Condition f | or clearing (SPDn bit = 0)                                                                            | Condition for setting (SPDn bit = 1) |  |  |
| clock follo | EIICEn bit changes from 1 to 0 (operation                                                             | When a stop condition is detected    |  |  |

**Remark** n = 0 to 2

# (3) IIC flag registers 0 to 2 (IICF0 to IICF2)

The IICF0 to IICF2 registers set the I<sup>2</sup>C0n operation mode and indicate the I<sup>2</sup>C bus status.

These registers can be read or written in 8-bit or 1-bit units. However, the STCFn and IICBSYn bits are readonly.

IICRSVn enables/disables the communication reservation function (see 17.14 Communication Reservation).

The initial value of the IICBSYn bit is set by using the STCENn bit (see 17.15 Cautions).

The IICRSVn and STCENn bits can be written only when operation of  $I^2C0n$  is disabled (IICCn.IICEn bit = 0).

After operation is enabled, IICFn can be read (n = 0 to 2).

Reset input clears these registers to 00H.

| After reset: 00H |       | R/W <sup>Note</sup> | Address | Address: IICF0 FFFFD8AH, IICF1 FFFFD9AH, IICF2 FFFFD |   |   |        |         |
|------------------|-------|---------------------|---------|------------------------------------------------------|---|---|--------|---------|
|                  | <7>   | <6>                 | 5       | 4                                                    | 3 | 2 | <1>    | <0>     |
| IICFn            | STCFn | IICBSYn             | 0       | 0                                                    | 0 | 0 | STCENn | IICRSVn |

(n = 0 to 2)

| STCFn     | STTn bit clear                                       |                                                                                                                                        |  |  |  |  |
|-----------|------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 0         | Start condition issued                               |                                                                                                                                        |  |  |  |  |
| 1         | Start condition cannot be issued, STTn bit cleared   |                                                                                                                                        |  |  |  |  |
| Condition | for clearing (STCFn bit = 0)                         | Condition for setting (STCFn bit = 1)                                                                                                  |  |  |  |  |
|           | by IICCn.STTn bit = 1<br>e IICCn.IICEn bit = 0<br>et | When start condition is not issued and STTn flag is<br>cleared to 0 during communication reservation is<br>disabled (IICRSVn bit = 1). |  |  |  |  |

| IICBSYn     | l²C0n bus status                                                            |                                                                                       |  |  |  |  |
|-------------|-----------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--|--|--|--|
| 0           | Bus released status (default communication status when STCENn bit = 1)      |                                                                                       |  |  |  |  |
| 1           | Bus communication status (default communication status when STCENn bit = 0) |                                                                                       |  |  |  |  |
| Condition f | for clearing (IICBSYn bit = 0)                                              | Condition for setting (IICBSYn bit = 1)                                               |  |  |  |  |
|             | op condition is detected<br>e IICEn bit = 0<br>et                           | When start condition is detected     By setting the IICEn bit when the STCENn bit = 0 |  |  |  |  |

| STCENn                    | Initial start enable trigger                                                                                           |                                        |  |  |  |  |  |
|---------------------------|------------------------------------------------------------------------------------------------------------------------|----------------------------------------|--|--|--|--|--|
| 0                         | Start conditions cannot be generated until a stop condition is detected following operation enable (IICEn bit = 1).    |                                        |  |  |  |  |  |
| 1                         | Start conditions can be generated even if a stop condition is not detected following operation enable (IICEn bit = 1). |                                        |  |  |  |  |  |
| Condition f               | or clearing (STCENn bit = 0)                                                                                           | Condition for setting (STCENn bit = 1) |  |  |  |  |  |
| When start After research | art condition is detected<br>et                                                                                        | Setting by instruction                 |  |  |  |  |  |

| IICRSVn                 | Communication reservation function disable bit |                                         |  |  |  |  |  |
|-------------------------|------------------------------------------------|-----------------------------------------|--|--|--|--|--|
| 0                       | Communication reservation enabled              |                                         |  |  |  |  |  |
| 1                       | Communication reservation disabled             |                                         |  |  |  |  |  |
| Condition f             | or clearing (IICRSVn bit = 0)                  | Condition for setting (IICRSVn bit = 1) |  |  |  |  |  |
| Clearing     After rese | by instruction<br>et                           | Setting by instruction                  |  |  |  |  |  |

Note Bits 6 and 7 are read-only bits.

- Cautions 1. Write the STCENn bit only when operation is stopped (IICEn bit = 0).
  - 2. When the STCENn bit = 1, the bus released status (IICBSYn bit = 0) is recognized regardless of the actual bus status immediately after the I<sup>2</sup>Cn bus operation is enabled. Therefore, to issue the first start condition (STTn bit = 1), it is necessary to confirm that the bus has been released, so as to not disturb other communications.
  - 3. Write the IICRSVn bit only when operation is stopped (IICEn bit = 0).

## (4) IIC clock select registers 0 to 2 (IICCL0 to IICCL2)

The IICCL0 to IICCL2 registers set the transfer clock for the I<sup>2</sup>C0n bus.

These registers can be read or written in 8-bit or 1-bit units. However, the CLDn and DADn bits are read-only. Set the IICCLn register when the IICCn.IICEn bit = 0.

The SMCn, CLn1, and CLn0 bits are set by the combination of the IICXn.CLXn bit and the OCKSTHm, OCKSm1, and OCKSm0 bits of the OCKSm register (see 17.4 (6)  $I^2$ C0n transfer clock setting method) (n = 0 to 2, m = 0, 1).

Reset input clears these registers to 00H.

| After reset: 00H |   | R/W <sup>Note</sup> Address: IICCL0 FFFF |      | FFFD84H, IICCL1 FFFFFD94I |      | D94H, IICCL | 1H, IICCL2 FFFFFDA4H |      |   |
|------------------|---|------------------------------------------|------|---------------------------|------|-------------|----------------------|------|---|
|                  | 7 | 6                                        | <5>  | <4>                       | 3    | 2           | 1                    | 0    | _ |
| IICCLn           | 0 | 0                                        | CLDn | DADn                      | SMCn | DFCn        | CLn1                 | CLn0 |   |
| (n = 0 to 2)     |   |                                          |      |                           |      |             |                      |      | • |

| CLDn      | Detection of SCL0n pin level (valid only when IICCn.IICEn bit = 1)    |                                      |  |  |  |  |
|-----------|-----------------------------------------------------------------------|--------------------------------------|--|--|--|--|
| 0         | The SCL0n pin was detected at low level.                              |                                      |  |  |  |  |
| 1         | The SCL0n pin was detected at high level.                             |                                      |  |  |  |  |
| Condition | for clearing (CLDn bit = 0)                                           | Condition for setting (CLDn bit = 1) |  |  |  |  |
|           | e SCL0n pin is at low level<br>e IICEn bit = 0 (operation stop)<br>et | When the SCL0n pin is at high level  |  |  |  |  |

| DADn        | Detection of SDA0n pin level (valid only when IICEn bit = 1)          |                                       |  |  |  |  |
|-------------|-----------------------------------------------------------------------|---------------------------------------|--|--|--|--|
| 0           | The SDA0n pin was detected at low level.                              |                                       |  |  |  |  |
| 1           | The SDA0n pin was detected at high level.                             |                                       |  |  |  |  |
| Condition f | or clearing (DADn bit = 0)                                            | Condition for setting (DAD0n bit = 1) |  |  |  |  |
|             | e SDA0n pin is at low level<br>e IICEn bit = 0 (operation stop)<br>et | When the SDA0n pin is at high level   |  |  |  |  |

| SMCn | Operation mode switching      |  |  |  |  |  |
|------|-------------------------------|--|--|--|--|--|
| 0    | Operation in standard mode.   |  |  |  |  |  |
| 1    | Operation in high-speed mode. |  |  |  |  |  |

| DFCn | Digital filter operation control |
|------|----------------------------------|
| 0    | Digital filter off.              |
| 1    | Digital filter on.               |

The digital filter can be used only in high-speed mode.

In high-speed mode, the transfer clock does not vary regardless of the DFCn bit setting (on/off).

The digital filter is used to eliminate noise in high-speed mode.

Note Bits 4 and 5 of IICCLn are read-only bits.

Caution Be sure to clear bits 7 and 6 of IICCLn to 0.

**Remark** When the IICCn.IICEn bit = 0, 0 is read when reading the CLDn and DADn bits.

### (5) IIC function expansion registers 0 to 2 (IICX0 to IICX2)

The IICX0 to IICS2 registers set I<sup>2</sup>C0n function expansion (valid only in the high-speed mode).

These registers can be read or written in 8-bit or 1-bit units.

Setting of the CLXn bit is performed in combination with the SMCn, CLn1, and CLn0 bits of the IICCLn register and the OCKSTHm, OCKSm1, and OCKSm0 bits of the OCKSm register (see 17.4 (6)  $I^2$ C0n transfer clock setting method) (m = 0, 1).

Set the IICXn register when the IICCn.IICEn bit = 0.

Reset input clears these registers to 00H.



### (6) I2COn transfer clock setting method

The  $l^2COn$  transfer clock frequency (fscl) is calculated using the following expression (n = 0 to 2).

$$f_{SCL} = 1/(m \times T + t_R + t_F)$$

m = 12, 18, 24, 36, 44, 48, 54, 60, 66, 72, 86, 88, 96, 132, 172, 176, 198, 220, 258, 344 (see **Table 17-2 Clock Settings**).

T: 1/fxx

tr: SCL0n pin rise time

tr: SCL0n pin fall time

For example, the  $I^2COn$  transfer clock frequency (fscL) when fxx = 19.2 MHz, m = 198, t<sub>R</sub> = 200 ns, and t<sub>F</sub> = 50 ns is calculated using following expression.

$$f_{SCL} = 1/(198 \times 52 \text{ ns} + 200 \text{ ns} + 50 \text{ ns}) \cong 94.7 \text{ kHz}$$



The clock to be selected can be set by the combination of the SMCn, CLn1, and CLn0 bits of the IICCLn register, the CLXn bit of the IICXn register, and the OCKSTHm, OCKSm1, and OCKSm0 bits of the OCKSm register (n = 0 to 2, m = 0, 1).

Table 17-2. Clock Settings (1/2)

|       |           |          |       |                              |          | 1                           |                        |  |
|-------|-----------|----------|-------|------------------------------|----------|-----------------------------|------------------------|--|
| IICX0 |           | IICCL0   | ı     | Selection Clock              | Transfer | Settable Main Clock         | Operating              |  |
| Bit 0 | Bit 3     | Bit 1    | Bit 0 |                              | Clock    | Frequency (fxx) Range       | Mode                   |  |
| CLX0  | SMC0      | CL01     | CL00  |                              |          |                             |                        |  |
| 0     | 0         | 0        | 0     | fxx (when OCKS0 = 18H set)   | fxx/44   | 2.00 MHz ≤ fxx ≤ 4.19 MHz   | Standard               |  |
|       |           |          |       | fxx/2 (when OCKS0 = 10H set) | fxx/88   | 4.00 MHz ≤ fxx ≤ 8.38 MHz   | mode<br>(SMC0 bit = 0) |  |
|       |           |          |       | fxx/3 (when OCKS0 = 11H set) | fxx/132  | 6.00 MHz ≤ fxx ≤ 12.57 MHz  | (ONIOO BIL = 0)        |  |
|       |           |          |       | fxx/4 (when OCKS0 = 12H set) | fxx/176  | 8.00 MHz ≤ fxx ≤ 16.76 MHz  |                        |  |
|       |           |          |       | fxx/5 (when OCKS0 = 13H set) | fxx/220  | 10.00 MHz ≤ fxx ≤ 20.95 MHz |                        |  |
| 0     | 0         | 0        | 1     | fxx (when OCKS0 = 18H set)   | fxx/86   | 4.19 MHz ≤ fxx ≤ 8.38 MHz   |                        |  |
|       |           |          |       | fxx/2 (when OCKS0 = 10H set) | fxx/172  | 8.38 MHz ≤ fxx ≤ 16.76 MHz  |                        |  |
|       |           |          |       | fxx/3 (when OCKS0 = 11H set) | fxx/258  | 12.57 MHz ≤ fxx ≤ 25.14 MHz |                        |  |
|       |           |          |       | fxx/4 (when OCKS0 = 12H set) | fxx/344  | 16.76 MHz ≤ fxx ≤ 32.00 MHz |                        |  |
|       |           |          |       | fxx/5 (when OCKS0 = 13H set) | fxx/430  | 20.95 MHz ≤ fxx ≤ 32.00 MHz |                        |  |
| 0     | 0         | 1        | 0     | fxx <sup>Note</sup>          | fxx/86   | 4.19 MHz ≤ fxx ≤ 8.38 MHz   |                        |  |
| 0     | 0         | 1        | 1     | fxx (when OCKS0 = 18H set)   | fxx/66   | 6.40 MHz                    |                        |  |
|       |           |          |       | fxx/2 (when OCKS0 = 10H set) | fxx/132  | 12.80 MHz                   |                        |  |
|       |           |          |       | fxx/3 (when OCKS0 = 11H set) | fxx/198  | 19.20 MHz                   |                        |  |
|       |           |          |       | fxx/4 (when OCKS0 = 12H set) | fxx/264  | 25.60 MHz                   |                        |  |
|       |           |          |       | fxx/5 (when OCKS0 = 13H set) | fxx/330  | 32.00 MHz                   |                        |  |
| 0     | 1         | 0        | ×     | fxx (when OCKS0 = 18H set)   | fxx/24   | 4.19 MHz ≤ fxx ≤ 8.38 MHz   | High-speed             |  |
|       |           |          |       | fxx/2 (when OCKS0 = 10H set) | fxx/48   | 8.00 MHz ≤ fxx ≤ 16.76 MHz  | mode<br>(SMC0 bit = 1) |  |
|       |           |          |       | fxx/3 (when OCKS0 = 11H set) | fxx/72   | 12.00 MHz ≤ fxx ≤ 25.14 MHz | (Sivico bit = 1)       |  |
|       |           |          |       | fxx/4 (when OCKS0 = 12H set) | fxx/96   | 16.00 MHz ≤ fxx ≤ 32.00 MHz |                        |  |
| 0     | 1         | 1        | 0     | fxx <sup>Note</sup>          | fxx/24   | 4.00 MHz ≤ fxx ≤ 8.38 MHz   |                        |  |
| 0     | 1         | 1        | 1     | fxx (when OCKS0 = 18H set)   | fxx/18   | 6.40 MHz                    |                        |  |
|       |           |          |       | fxx/2 (when OCKS0 = 10H set) | fxx/36   | 12.80 MHz                   | 1                      |  |
|       |           |          |       | fxx/3 (when OCKS0 = 11H set) | fxx/54   | 19.20 MHz                   | 1                      |  |
|       |           |          |       | fxx/4 (when OCKS0 = 12H set) | fxx/72   | 25.60 MHz                   | 1                      |  |
|       |           |          |       | fxx/5 (when OCKS0 = 13H set) | fxx/90   | 32.00 MHz                   | 1                      |  |
| 1     | 1         | 0        | ×     | fxx (when OCKS0 = 18H set)   | fxx/12   | 4.00 MHz ≤ fxx ≤ 4.19 MHz   |                        |  |
|       |           |          |       | fxx/2 (when OCKS0 = 10H set) | fxx/24   | 8.00 MHz ≤ fxx ≤ 8.38 MHz   | 1                      |  |
|       |           |          |       | fxx/3 (when OCKS0 = 11H set) | fxx/36   | 12.00 MHz ≤ fxx ≤ 12.57 MHz | ]                      |  |
|       |           |          |       | fxx/4 (when OCKS0 = 12H set) | fxx/48   | 16.00 MHz ≤ fxx ≤ 16.67 MHz | ]                      |  |
|       |           |          |       | fxx/5 (when OCKS0 = 13H set) | fxx/60   | 20.00 MHz ≤ fxx ≤ 20.95 MHz |                        |  |
| 1     | 1 1 1 0   |          | 0     | fxx <sup>Note</sup>          | fxx/12   | 4.00 MHz ≤ fxx ≤ 4.19 MHz   | 1                      |  |
|       | Other tha | an above | )     | Setting prohibited           | -        | -                           | _                      |  |
|       |           |          | l     | 1                            | 1        | 1                           |                        |  |

**Note** Since the selection clock is fxx regardless of the value set to the OCKS0 register, clear the OCKS0 register to 00H ( $I^2$ C division clock stopped status).

Remark ×: don't care

Table 17-2. Clock Settings (2/2)

|                     | 11001            |        |          | <b>2</b>                     | I                                                       |                                           | 1                     |  |
|---------------------|------------------|--------|----------|------------------------------|---------------------------------------------------------|-------------------------------------------|-----------------------|--|
| IICXm               |                  | IICCLm |          | Selection Clock              | Transfer<br>Clock                                       | Settable Main Clock Frequency (fxx) Range | Operating<br>Mode     |  |
| Bit 0               | Bit 3            | Bit 1  | Bit 0    |                              | CIUCK                                                   | r requericy (ixx) harige                  | IVIOUE                |  |
| CLXm                | SMCm             | CLm1   | CLm0     |                              |                                                         |                                           |                       |  |
| 0                   | 0                | 0      | 0        | fxx (when OCKS1 = 18H set)   | fxx/44                                                  | 2.00 MHz ≤ fxx ≤ 4.19 MHz                 | Standard              |  |
|                     |                  |        |          | fxx/2 (when OCKS1 = 10H set) | fxx/88                                                  | 4.00 MHz ≤ fxx ≤ 8.38 MHz                 | mode $(SMCm bit = 0)$ |  |
|                     |                  |        |          | fxx/3 (when OCKS1 = 11H set) | fxx/132                                                 | 6.00 MHz ≤ fxx ≤ 12.57 MHz                | (,                    |  |
|                     |                  |        |          | fxx/4 (when OCKS1 = 12H set) | fxx/176                                                 | 8.00 MHz ≤ fxx ≤ 16.76 MHz                |                       |  |
|                     |                  |        |          | fxx/5 (when OCKS1 = 13H set) | fxx/220                                                 | 10.00 MHz ≤ fxx ≤ 20.95 MHz               |                       |  |
| 0                   | 0                | 0      | 1        | fxx (when OCKS1 = 18H set)   | fxx/86                                                  | 4.19 MHz ≤ fxx ≤ 8.38 MHz                 |                       |  |
|                     |                  |        |          | fxx/2 (when OCKS1 = 10H set) | fxx/172                                                 | 8.38 MHz ≤ fxx ≤ 16.76 MHz                |                       |  |
|                     |                  |        |          | fxx/3 (when OCKS1 = 11H set) | fxx/258                                                 | 12.57 MHz ≤ fxx ≤ 25.14 MHz               |                       |  |
|                     |                  |        |          | fxx/4 (when OCKS1 = 12H set) | fxx/344                                                 | 16.76 MHz ≤ fxx ≤ 32.00 MHz               |                       |  |
|                     |                  |        |          | fxx/5 (when OCKS1 = 13H set) | fxx/430                                                 | 20.95 MHz ≤ fxx ≤ 32.00 MHz               |                       |  |
| 0                   | 0                | 1      | 0        | fxx <sup>Note</sup>          | fxx/86                                                  | 4.19 MHz ≤ fxx ≤ 8.38 MHz                 |                       |  |
| 0                   | 0                | 1      | 1        | fxx (when OCKS1 = 18H set)   | fxx/66                                                  | 6.40 MHz                                  |                       |  |
|                     |                  |        |          | fxx/2 (when OCKS1 = 10H set) | fxx/132                                                 | 12.80 MHz                                 |                       |  |
|                     |                  |        |          | fxx/3 (when OCKS1 = 11H set) | fxx/198                                                 | 19.20 MHz                                 |                       |  |
|                     |                  |        |          | fxx/4 (when OCKS1 = 12H set) | fxx/264                                                 | 25.60 MHz                                 |                       |  |
|                     |                  |        |          | fxx/5 (when OCKS1 = 13H set) | fxx/330                                                 | 32.00 MHz                                 |                       |  |
| 0                   | 1                | 0      | ×        | fxx (when OCKS1 = 18H set)   | fxx/24                                                  | 4.19 MHz ≤ fxx ≤ 8.38 MHz                 | High-speed            |  |
|                     |                  |        |          | fxx/2 (when OCKS1 = 10H set) | fxx/48                                                  | 8.00 MHz ≤ fxx ≤ 16.76 MHz                | mode                  |  |
|                     |                  |        |          | fxx/3 (when OCKS1 = 11H set) | fxx/72                                                  | 12.00 MHz ≤ fxx ≤ 25.14 MHz               | (SMCm bit = 1)        |  |
|                     |                  |        |          | fxx/4 (when OCKS1 = 12H set) | fxx/4 (when OCKS1 = 12H set) fxx/96 16.00 MHz $\leq$ fx |                                           |                       |  |
| 0                   | 1                | 1      | 0        | fxx <sup>Note</sup>          | fxx/24                                                  | 4.00 MHz ≤ fxx ≤ 8.38 MHz                 |                       |  |
| 0                   | 1                | 1      | 1        | fxx (when OCKS1 = 18H set)   | fxx/18                                                  | 6.40 MHz                                  |                       |  |
|                     |                  |        |          | fxx/2 (when OCKS1 = 10H set) | fxx/36                                                  | 12.80 MHz                                 |                       |  |
|                     |                  |        |          | fxx/3 (when OCKS1 = 11H set) | fxx/54                                                  | 19.20 MHz                                 |                       |  |
|                     |                  |        |          | fxx/4 (when OCKS1 = 12H set) | fxx/72                                                  | 25.60 MHz                                 |                       |  |
|                     |                  |        |          | fxx/5 (when OCKS1 = 13H set) | fxx/90                                                  | 32.00 MHz                                 |                       |  |
| 1                   | 1                | 0      | ×        | fxx (when OCKS1 = 18H set)   | fxx/12                                                  | 4.00 MHz ≤ fxx ≤ 4.19 MHz                 |                       |  |
|                     |                  |        |          | fxx/2 (when OCKS1 = 10H set) | fxx/24                                                  | 8.00 MHz ≤ fxx ≤ 8.38 MHz                 | 1                     |  |
|                     |                  |        |          | fxx/3 (when OCKS1 = 11H set) | fxx/36                                                  | 12.00 MHz ≤ fxx ≤ 12.57 MHz               | 1                     |  |
|                     |                  |        |          | fxx/4 (when OCKS1 = 12H set) | fxx/48                                                  | 16.00 MHz ≤ fxx ≤ 16.67 MHz               | 1                     |  |
|                     |                  |        |          | fxx/5 (when OCKS1 = 13H set) | fxx/60                                                  | 20.00 MHz ≤ fxx ≤ 20.95 MHz               |                       |  |
| 1                   | 1 1 0            |        | 0        | fxx <sup>Note</sup>          | fxx/12                                                  | 4.00 MHz ≤ fxx ≤ 4.19 MHz                 |                       |  |
| ,                   | Other than above |        | )        | Setting prohibited           | _                                                       | _                                         | _                     |  |
| Cirier triair above |                  |        | <u> </u> | L                            | 1                                                       | L                                         |                       |  |

**Note** Since the selection clock is fxx regardless of the value set to the OCKS1 register, clear the OCKS1 register to 00H (I<sup>2</sup>C division clock stopped status).

**Remarks 1.** m = 1, 2

2. ×: don't care

### (7) IIC division clock select registers 0, 1 (OCKS0, OCKS1)

The OCKS0 and OCKS1 registers control the  $I^2$ C0n division clock (n = 0 to 2).

These registers control the I<sup>2</sup>C00 division clock via the OCKS0 register and the I<sup>2</sup>C01 and I<sup>2</sup>C02 division clocks via the OCKS1 register.

These registers can be read or written in 8-bit units.

Reset input clears these registers to 00H.



## (8) IIC shift registers 0 to 2 (IIC0 to IIC2)

The IIC0 to IIC2 registers are used for serial transmission/reception (shift operations) synchronized with the serial clock. These registers can be read or written in 8-bit units, but data should not be written to the IICn register during a data transfer.

Access (read/write) the IICn register only during the wait period. Accessing this register in communication states other than the wait period is prohibited. However, for the master device, the IICn register can be written once only after the transmission trigger bit (IICCn.STTn bit) has been set to 1.

A wait state is released by writing the IICn register during the wait period, and data transfer is started (n = 0 to 2). Reset input clears these registers to 00H.



# (9) Slave address registers 0 to 2 (SVA0 to SVA2)

The SVA0 to SVA2 registers hold the I<sup>2</sup>C bus's slave addresses.

These registers can be read or written in 8-bit units, but bit 0 should be fixed to 0. However, rewriting these registers is prohibited when the IICSn.STDn bit = 1 (start condition detection).

Reset input clears these registers to 00H.



## 17.5 I2C Bus Mode Functions

# 17.5.1 Pin configuration

The serial clock pin (SCL0n) and serial data bus pin (SDA0n) are configured as follows (n = 0 to 2).

SCL0n ......This pin is used for serial clock input and output.

This pin is an N-ch open-drain output for both master and slave devices. Input is Schmitt input.

SDA0n ......This pin is used for serial data input and output.

This pin is an N-ch open-drain output for both master and slave devices. Input is Schmitt input.

Since outputs from the serial clock line and the serial data bus line are N-ch open-drain outputs, an external pull-up resistor is required.



Figure 17-6. Pin Configuration Diagram

#### 17.6 I<sup>2</sup>C Bus Definitions and Control Methods

The following section describes the I<sup>2</sup>C bus's serial data communication format and the signals used by the I<sup>2</sup>C bus. The transfer timing for the "start condition", "address", "transfer direction specification", "data", and "stop condition" generated on the I<sup>2</sup>C bus's serial data bus is shown below.



Figure 17-7. I<sup>2</sup>C Bus Serial Data Transfer Timing

The master device generates the start condition, slave address, and stop condition.

ACK can be generated by either the master or slave device (normally, it is generated by the device that receives 8-bit data).

The serial clock (SCL0n) is continuously output by the master device. However, in the slave device, the SCL0n pin's low-level period can be extended and a wait state can be inserted (n = 0 to 2).

#### 17.6.1 Start condition

A start condition is met when the SCL0n pin is high level and the SDA0n pin changes from high level to low level. The start condition for the SCL0n and SDA0n pins is a signal that the master device outputs to the slave device when starting a serial transfer. The slave device can defect the start condition (n = 0 to 2).



Figure 17-8. Start Condition

A start condition is output when the IICCn.STTn bit is set (1) after a stop condition has been detected (IICSn.SPDn bit = 1). When a start condition is detected, the IICSn.STDn bit is set (1) (n = 0 to 2).

Caution When the IICCn.IICEn bit of the V850ES/SG2 is set to 1 while communications with other devices are in progress, the start condition may be detected depending on the status of the communication line. Be sure to set the IICCn.IICEn bit to 1 when the SCL0n and SDA0n lines are high level.

#### 17.6.2 Addresses

The 7 bits of data that follow the start condition are defined as an address.

An address is a 7-bit data segment that is output in order to select one of the slave devices that are connected to the master device via the bus lines. Therefore, each slave device connected via the bus lines must have a unique address.

The slave devices include hardware that detects the start condition and checks whether or not the 7-bit address data matches the data values stored in the SVAn register. If the address data matches the values of the SVAn register, the slave device is selected and communicates with the master device until the master device generates a start condition or stop condition (n = 0 to 2).

Figure 17-9. Address



The slave address and the eighth bit, which specifies the transfer direction as described in 17.6.3 Transfer direction specification below, are written together to IIC shift register n (IICn) and then output. Received addresses are written to the IICn register (n = 0 to 2).

The slave address is assigned to the higher 7 bits of the IICn register.

## 17.6.3 Transfer direction specification

In addition to the 7-bit address data, the master device sends 1 bit that specifies the transfer direction. When this transfer direction specification bit has a value of 0, it indicates that the master device is transmitting data to a slave device. When the transfer direction specification bit has a value of 1, it indicates that the master device is receiving data from a slave device.

Figure 17-10. Transfer Direction Specification

### 17.6.4 ACK

ACK is used to confirm the serial data status of the transmitting and receiving devices.

The receiving device returns ACK for every 8 bits of data it receives.

The transmitting device normally receives  $\overline{ACK}$  after transmitting 8 bits of data. When  $\overline{ACK}$  is returned from the receiving device, the reception is judged as normal and processing continues. The detection of  $\overline{ACK}$  is confirmed with the IICSn.ACKDn bit.

When the master device is the receiving device, after receiving the final data, it does not return  $\overline{ACK}$  and generates the stop condition. When the slave device is the receiving device and does not return  $\overline{ACK}$ , the master device generates either a stop condition or a restart condition, and then stops the current transmission. Failure to return  $\overline{ACK}$  may be caused by the following factors.

- (a) Reception was not performed normally.
- (b) The final data was received.
- (c) The receiving device (slave) does not exist for the specified address.

When the receiving device sets the SDA0n line to low level during the ninth clock,  $\overline{ACK}$  is generated (normal reception).

When the IICCn.ACKEn bit is set to 1, automatic  $\overline{ACK}$  generation is enabled. Transmission of the eighth bit following the 7 address data bits causes the IICSn.TRCn bit to be set. Normally, set the ACKEn bit to 1 for reception (TRCn bit = 0).

When the slave device is receiving (when TRCn bit = 0), if the slave device cannot receive data or does not need to receive any more data, clear the ACKEn bit to 0 to indicate to the master that no more data can be received.

Similarly, when the master device is receiving (when TRCn bit = 0) and the subsequent data is not needed, clear the ACKEn bit to 0 to prevent  $\overline{ACK}$  from being generated. This notifies the slave device (transmitting device) of the end of the data transmission (transmission stopped).

Figure 17-11. ACK



When the local address is received,  $\overline{ACK}$  is automatically generated regardless of the value of the ACKEn bit. No  $\overline{ACK}$  is generated if the received address is not a local address (NACK).

When receiving the extension code, set the ACKEn bit to 1 in advance to generate ACK.

The ACK generation method during data reception is based on the wait timing setting, as described by the following.

- When 8-clock wait is selected (IICCn.WTIMn bit = 0):
   ACK is generated at the falling edge of the SCL0n pin's eighth clock if the ACKEn bit is set to 1 before the wait state cancellation.
- When 9-clock wait is selected (IICCn.WTIMn bit = 1):
   ACK is generated if the ACKEn bit is set to 1 in advance.

**Remark** n = 0 to 2

## 17.6.5 Stop condition

When the SCL0n pin is high level, changing the SDA0n pin from low level to high level generates a stop condition (n = 0 to 2).

A stop condition is generated when the master device outputs to the slave device when serial transfer has been completed. When used as the slave device, the start condition can be detected.



Figure 17-12. Stop Condition

A stop condition is generated when the IICCn.SPTn bit is set to 1. When the stop condition is detected, the IICSn.SPDn bit is set to 1 and the interrupt request signal (INTIICn) is generated when the IICCn.SPIEn bit is set to 1 (n = 0 to 2).

### 17.6.6 Wait state

A wait state is used to notify the communication partner that a device (master or slave) is preparing to transmit or receive data (i.e., is in a wait state).

Setting the SCL0n pin to low level notifies the communication partner of the wait state. When the wait state has been canceled for both the master and slave devices, the next data transfer can begin (n = 0 to 2).

Figure 17-13. Wait State (1/2)





Figure 17-13. Wait State (2/2)

A wait state may be automatically generated depending on the setting of the IICCn.WTIMn bit (n = 0 to 2).

Normally, when the IICCn.WRELn bit is set to 1 or when FFH is written to the IICn register on the receiving side, the wait state is canceled and the transmitting side writes data to the IICn register to cancel the wait state.

The master device can also cancel the wait state via either of the following methods.

- By setting the IICCn.STTn bit to 1
- By setting the IICCn.SPTn bit to 1

#### 17.6.7 Wait state cancellation method

In the case of  $l^2COn$ , wait state can be canceled normally in the following ways (n = 0 to 2).

- · By writing data to the IICn register
- By setting the IICCn.WRELn bit to 1 (wait state cancellation)
- By setting the IICCn.STTn bit to 1 (start condition generation)
- By setting the IICCn.SPTn bit to 1 (stop condition generation)

If any of these wait state cancellation actions is performed, I<sup>2</sup>C0n will cancel wait state and restart communication.

When canceling wait state and sending data (including address), write data to the IICn register.

To receive data after canceling wait state, or to complete data transmission, set the WRELn bit to 1.

To generate a restart condition after canceling wait state, set the STTn bit to 1.

To generate a stop condition after canceling wait state, set the SPTn bit to 1.

Execute cancellation only once for each wait state.

For example, if data is written to the IICn register following wait state cancellation by setting the WRELn bit to 1, conflict between the SDAn line change timing and IICn register write timing may result in the data output to the SDAn line may be incorrect.

Even in other operations, if communication is stopped halfway, clearing the IICCn.IICEn bit to 0 will stop communication, enabling wait state to be cancelled.

If the I<sup>2</sup>C bus dead-locks due to noise, etc., setting the IICCn.LRELn bit to 1 causes the communication operation to be exited, enabling wait state to be cancelled.

## 17.7 I<sup>2</sup>C Interrupt Request Signals (INTIICn)

The following shows the value of the IICSn register at the INTIICn interrupt request signal generation timing and at the INTIICn signal timing (n = 0 to 2).

## 17.7.1 Master device operation

### (1) Start ~ Address ~ Data ~ Data ~ Stop (normal transmission/reception)



## (2) Start ~ Address ~ Data ~ Start ~ Address ~ Data ~ Stop (restart)



## (3) Start ~ Code ~ Data ~ Data ~ Stop (extension code transmission)

## <1> When WTIMn bit = 0

▲1: IICSn register = 1010X110B

▲2: IICSn register = 1010X000B

▲3: IICSn register = 1010X000B (WTIMn bit = 1)

▲4: IICSn register = 1010XX00B

 $\Delta$  5: IICSn register = 00000001B

### Remarks 1. ▲: Always generated

 $\Delta$ : Generated only when SPIEn bit = 1

X: don't care

**2.** n = 0 to 2

## <2> When WTIMn bit = 1



▲1: IICSn register = 1010X110B

▲2: IICSn register = 1010X100B

▲3: IICSn register = 1010XX00B

 $\Delta$  4: IICSn register = 00000001B

## Remarks 1. ▲: Always generated

 $\Delta$ : Generated only when SPIEn bit = 1

X: don't care

**2.** n = 0 to 2

## 17.7.2 Slave device operation (when receiving slave address data (address match))

# (1) Start ~ Address ~ Data ~ Data ~ Stop



## (2) Start ~ Address ~ Data ~ Start ~ Address ~ Data ~ Stop



## (3) Start ~ Address ~ Data ~ Start ~ Code ~ Data ~ Stop

#### <1> When WTIMn bit = 0 (after restart, extension code reception) ĀCK AD6 to AD0 $R/\overline{W}$ $\overline{\mathsf{ACK}}$ R/W ACK D7 to D0 ĀCK SP ST D7 to D0 ST AD6 to AD0 **▲**2 **▲**3 **4** Δ5 ▲1: IICSn register = 0001X110B ▲2: IICSn register = 0001X000B ▲3: IICSn register = 0010X010B ▲4: IICSn register = 0010X000B $\Delta$ 5: IICSn register = 00000001B Remarks 1. ▲: Always generated $\Delta$ : Generated only when SPIEn bit = 1 X: don't care **2.** n = 0 to 2 <2> When WTIMn bit = 1 (after restart, extension code reception) ST AD6 to AD0 R/W ACK D7 to D0 ACK ST AD6 to AD0 $R/\overline{W}$ ĀCK D7 to D0 $\overline{\mathsf{ACK}}$ SP **▲**2 **▲**4 **▲**5 Δ6 **▲**3 ▲1: IICSn register = 0001X110B ▲2: IICSn register = 0001XX00B ▲3: IICSn register = 0010X010B ▲4: IICSn register = 0010X110B ▲5: IICSn register = 0010XX00B $\Delta$ 6: IICSn register = 00000001B Remarks 1. ▲: Always generated $\Delta$ : Generated only when SPIEn bit = 1 X: don't care **2.** n = 0 to 2

## (4) Start ~ Address ~ Data ~ Start ~ Address ~ Data ~ Stop



## 17.7.3 Slave device operation (when receiving extension code)

(1) Start ~ Code ~ Data ~ Data ~ Stop



## (2) Start ~ Code ~ Data ~ Start ~ Address ~ Data ~ Stop



## (3) Start ~ Code ~ Data ~ Start ~ Code ~ Data ~ Stop



## (4) Start ~ Code ~ Data ~ Start ~ Address ~ Data ~ Stop



## 17.7.4 Operation without communication

# (1) Start ~ Code ~ Data ~ Data ~ Stop

|                                                                |             |                  |     |          |     |          |     |    | - |
|----------------------------------------------------------------|-------------|------------------|-----|----------|-----|----------|-----|----|---|
| ST                                                             | AD6 to AD0  | $R/\overline{W}$ | ĀCK | D7 to D0 | ĀCK | D7 to D0 | ĀCK | SP |   |
|                                                                |             |                  |     |          |     |          |     | Δ  |   |
| $\Delta$ 1: IICSn register = 00000001B                         |             |                  |     |          |     |          |     |    |   |
|                                                                |             |                  |     |          |     |          |     |    |   |
| <b>Remarks 1.</b> $\Delta$ : Generated only when SPIEn bit = 1 |             |                  |     |          |     |          |     |    |   |
|                                                                | <b>2.</b> n | = 0  to  i       | 2   |          |     |          |     |    |   |
|                                                                |             |                  |     |          |     |          |     |    |   |

#### 17.7.5 Arbitration loss operation (operation as slave after arbitration loss)

## (1) When arbitration loss occurs during transmission of slave address data



## (2) When arbitration loss occurs during transmission of extension code

#### <1> When WTIMn bit = 0



▲1: IICSn register = 0110X010B (Example: When ALDn bit is read during interrupt servicing)

▲2: IICSn register = 0010X000B

▲3: IICSn register = 0010X000B

 $\Delta$  4: IICSn register = 00000001B

## Remarks 1. ▲: Always generated

 $\Delta$ : Generated only when SPIEn bit = 1

X: don't care

**2.** n = 0 to 2

#### <2> When WTIMn bit = 1



▲1: IICSn register = 0110X010B (Example: When ALDn bit is read during interrupt servicing)

▲2: IICSn register = 0010X110B

▲3: IICSn register = 0010X100B

▲4: IICSn register = 0010XX00B

 $\Delta$  5: IICSn register = 00000001B

## Remarks 1. ▲: Always generated

 $\Delta$ : Generated only when SPIEn bit = 1

X: don't care

**2.** n = 0 to 2

# 17.7.6 Operation when arbitration loss occurs (no communication after arbitration loss)

# (1) When arbitration loss occurs during transmission of slave address data

| ST                                                                         | AD6 to AD0                                                                                       | R/W     | ĀCK     | D7 to D0 | ĀCK | D7 to D0 | ĀCK | SP |    |
|----------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|---------|---------|----------|-----|----------|-----|----|----|
| <b>Δ</b> 1 Δ2                                                              |                                                                                                  |         |         |          |     |          |     |    | Δ2 |
| <b>▲</b> 1:                                                                | ▲1: IICSn register = 01000110B (Example: When IICSn.ALDn bit is read during interrupt servicing) |         |         |          |     |          |     |    |    |
| $\Delta$ 2: IICSn register = 00000001B                                     |                                                                                                  |         |         |          |     |          |     |    |    |
| D                                                                          | omarke 1 A                                                                                       | · Alsay | ave don | orated   |     |          |     |    |    |
| Remarks 1. ▲: Always generated  Δ: Generated only when IICCn.SPIEn bit = 1 |                                                                                                  |         |         |          |     |          |     |    |    |
| 2. n = 0 to 2                                                              |                                                                                                  |         |         |          |     |          |     |    |    |

## (2) When arbitration loss occurs during transmission of extension code



## (3) When arbitration loss occurs during data transfer

## <1> When IICCn.WTIMn bit = 0



 $\Delta 3$ 

▲1: IICSn register = 10001110B

▲2: IICSn register = 01000000B (Example: When ALDn bit is read during interrupt servicing)

 $\Delta$  3: IICSn register = 00000001B

# Remarks 1. ▲: Always generated

 $\Delta$ : Generated only when SPIEn bit = 1

**2.** n = 0 to 2

## <2> When WTIMn bit = 1



▲1: IICSn register = 10001110B

▲2: IICSn register = 01000100B (Example: When ALDn bit is read during interrupt servicing)

 $\Delta$  3: IICSn register = 00000001B

## Remarks 1. ▲: Always generated

 $\Delta$ : Generated only when SPIEn bit = 1

**2.** n = 0 to 2

## (4) When arbitration loss occurs due to restart condition during data transfer



# (5) When arbitration loss occurs due to stop condition during data transfer

 ST
 AD6 to AD0
 R/W
 ĀCK
 D7 to Dn
 SP

▲1: IICSn register = 1000X110B

 $\Delta$  2: IICSn register = 01000001B

**Remarks 1. ▲**: Always generated

 $\Delta$ : Generated only when SPIEn bit = 1

X: don't care

**2.** Dn = D6 to D0

n = 0 to 2

# (6) When arbitration loss occurs due to low level of SDA0n pin when attempting to generate a restart condition



## (7) When arbitration loss occurs due to a stop condition when attempting to generate a restart condition



# (8) When arbitration loss occurs due to low level of SDA0n pin when attempting to generate a stop condition



## 17.8 Interrupt Request Signal (INTIICn) Generation Timing and Wait Control

The setting of the IICCn.WTIMn bit determines the timing by which the INTIICn register is generated and the corresponding wait control, as shown below (n = 0 to 2).

Table 17-3. INTIICn Generation Timing and Wait Control

| Ī | WTIMn Bit | Durin                   | g Slave Device Ope  | eration             | During Master Device Operation |                |                   |  |
|---|-----------|-------------------------|---------------------|---------------------|--------------------------------|----------------|-------------------|--|
|   |           | Address                 | Data Reception      | Data Transmission   | Address                        | Data Reception | Data Transmission |  |
|   | 0         | 9 <sup>Notes 1, 2</sup> | 8 <sup>Note 2</sup> | 8 <sup>Note 2</sup> | 9                              | 8              | 8                 |  |
| ĺ | 1         | 9 <sup>Notes 1, 2</sup> | 9 <sup>Note 2</sup> | 9 <sup>Note 2</sup> | 9                              | 9              | 9                 |  |

**Notes 1.** The slave device's INTIICn signal and wait period occur at the falling edge of the ninth clock only when there is a match with the address set to the SVAn register.

At this point, the  $\overline{ACK}$  is generated regardless of the value set to the IICCn.ACKEn bit. For a slave device that has received an extension code, the INTIICn signal occurs at the falling edge of the eighth clock.

When the address does not match after restart, the INTIICn signal is generated at the falling edge of the ninth clock, but no wait occurs.

- 2. If the received address does not match the contents of the SVAn register and an extension code is not received, neither the INTIICn signal nor a wait occurs.
- **Remarks 1.** The numbers in the table indicate the number of the serial clock's clock signals. Interrupt requests and wait control are both synchronized with the falling edge of these clock signals.
  - **2.** n = 0 to 2

# (1) During address transmission/reception

- Slave device operation: Interrupt and wait timing are determined regardless of the WTIMn bit.
- Master device operation: Interrupt and wait timing occur at the falling edge of the ninth clock regardless of the WTIMn bit.

#### (2) During data reception

• Master/slave device operation: Interrupt and wait timing is determined according to the WTIMn bit.

## (3) During data transmission

Master/slave device operation: Interrupt and wait timing is determined according to the WTIMn bit.

## (4) Wait cancellation method

The four wait cancellation methods are as follows.

- By setting the IICCn.WRELn bit to 1
- By writing to the IICn register
- By start condition setting (IICCn.STTn bit = 1)<sup>Note</sup>
- By stop condition setting (IICCn.SPTn bit = 1)<sup>Note</sup>

Note Master only

When an 8-clock wait has been selected (WTIMn bit = 0), whether or not the  $\overline{ACK}$  has been generated must be determined prior to wait cancellation.

**Remark** n = 0 to 2

# (5) Stop condition detection

The INTIICn signal is generated when a stop condition is detected.

**Remark** n = 0 to 2

#### 17.9 Address Match Detection Method

In I<sup>2</sup>C bus mode, the master device can select a particular slave device by transmitting the corresponding slave address.

Address match detection is performed automatically by hardware. The INTIICn signal occurs when a local address has been set to the SVAn register and when the address set to the SVAn register matches the slave address sent by the master device, or when an extension code has been received (n = 0 to 2).

#### 17.10 Error Detection

In  $I^2C$  bus mode, the status of the serial data bus pin (SDA0n) during data transmission is captured by the IICn register of the transmitting device, so the data of the IICn register prior to transmission can be compared with the transmitted IICn data to enable detection of transmission errors. A transmission error is judged as having occurred when the compared data values do not match (n = 0 to 2).

#### 17.11 Extension Code

(1) When the higher 4 bits of the receive address are either 0000 or 1111, the extension code flag (IICSn.EXCn bit) is set for extension code reception and an interrupt request signal (INTIICn) is issued at the falling edge of the eighth clock (n = 0 to 2).

The local address stored in the SVAn register is not affected.

- (2) If 11110xx0 is set to the SVAn register by a 10-bit address transfer and 11110xx0 is transferred from the master device, the results are as follows. Note that the INTIICn signal occurs at the falling edge of the eighth clock (n = 0 to 2)
  - Higher four bits of data match: EXCn bit = 1
  - Seven bits of data match: IICSn.COIn bit = 1
- (3) Since the processing after the interrupt request signal occurs differs according to the data that follows the extension code, such processing is performed by software.

For example, when operation as a slave is not desired after the extension code is received, set the IICCn.LRELn bit to 1 and the CPU will enter the next communication wait state.

Table 17-4. Extension Code Bit Definitions

| Slave Address | R/W Bit | Description                                       |
|---------------|---------|---------------------------------------------------|
| 0000 000      | 0       | General call address                              |
| 0000 000      | 1       | Start byte                                        |
| 0000 001      | Х       | CBUS address                                      |
| 0000 010      | Х       | Address that is reserved for different bus format |
| 1111 0xx      | Х       | 10-bit slave address specification                |

#### 17.12 Arbitration

When several master devices simultaneously generate a start condition (when the IICCn.STTn bit is set to 1 before the IICSn.STDn bit is set to 1), communication between the master devices is performed while the number of clocks is adjusted until the data differs. This kind of operation is called arbitration (n = 0 to 2).

When one of the master devices loses in arbitration, an arbitration loss flag (IICSn.ALDn bit) is set to 1 via the timing by which the arbitration loss occurred, and the SCL0n and SDA0n lines are both set to high impedance, which releases the bus (n = 0 to 2).

Arbitration loss is detected based on the timing of the next interrupt request signal (INTIICn) (the eighth or ninth clock, when a stop condition is detected, etc.) and the setting of the ALDn bit to 1, which is made by software (n = 0 to 2).

For details of interrupt request timing, see 17.7 I2C Interrupt Request Signals (INTIICn).



Figure 17-14. Arbitration Timing Example

Table 17-5. Status During Arbitration and Interrupt Request Signal Generation Timing

| Status During Arbitration                                                      | Interrupt Request Generation Timing                                                |
|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------|
| Transmitting address transmission                                              | At falling edge of eighth or ninth clock following byte transfer <sup>Note 1</sup> |
| Read/write data after address transmission                                     |                                                                                    |
| Transmitting extension code                                                    |                                                                                    |
| Read/write data after extension code transmission                              |                                                                                    |
| Transmitting data                                                              |                                                                                    |
| ACK transfer period after data reception                                       |                                                                                    |
| When restart condition is detected during data transfer                        |                                                                                    |
| When stop condition is detected during data transfer                           | When stop condition is generated (when IICCn.SPIEn bit = 1) <sup>Note 2</sup>      |
| When SDA0n pin is low level while attempting to generate restart condition     | At falling edge of eighth or ninth clock following byte transfer <sup>Note 1</sup> |
| When stop condition is detected while attempting to generate restart condition | When stop condition is generated (when IICCn.SPIEn bit = 1) <sup>Note 2</sup>      |
| When DSA0n pin is low level while attempting to generate stop condition        | At falling edge of eighth or ninth clock following byte transfer <sup>Note 1</sup> |
| When SCL0n pin is low level while attempting to generate restart condition     |                                                                                    |

- **Notes 1.** When the IICCn.WTIMn bit = 1, an INTIICn signal occurs at the falling edge of the ninth clock. When the WTIMn bit = 0 and the extension code's slave address is received, an INTIICn signal occurs at the falling edge of the eighth clock (n = 0 to 2).
  - 2. When there is a possibility that arbitration will occur, set the SPIEn bit to 1 for master device operation (n = 0 to 2).

# 17.13 Wakeup Function

The I<sup>2</sup>C bus slave function is a function that generates an interrupt request signal (INTIICn) when a local address and extension code have been received.

This function makes processing more efficient by preventing unnecessary the INTIICn signal from occurring when addresses do not match.

When a start condition is detected, wakeup standby mode is set. This wakeup standby mode is in effect while addresses are transmitted due to the possibility that an arbitration loss may change the master device (which has generated a start condition) to a slave device.

However, when a stop condition is detected, the IICCn.SPIEn bit is set regardless of the wakeup function, and this determines whether INTIICn signal is enabled or disabled (n = 0 to 2).

#### 17.14 Communication Reservation

#### 17.14.1 When communication reservation function is enabled (IICFn.IICRSVn bit = 0)

To start master device communications when not currently using the bus, a communication reservation can be made to enable transmission of a start condition when the bus is released. There are two modes in which the bus is not used.

- When arbitration results in neither master nor slave operation
- When an extension code is received and slave operation is disabled (ACK is not returned and the bus was released when the IICCn.LRELn bit was set to 1) (n = 0 to 2).

If the IICCn.STTn bit is set to 1 while the bus is not used, a start condition is automatically generated and a wait status is set after the bus is released (after a stop condition is detected).

When the bus release is detected (when a stop condition is detected), writing to the IICn register causes master address transfer to start. At this point, the IICCn.SPIEn bit should be set to 1 (n = 0 to 2).

When STTn has been set to 1, the operation mode (as start condition or as communication reservation) is determined according to the bus status (n = 0 to 2).

To detect which operation mode has been determined for the STTn bit, set the STTn bit to 1, wait for the wait period, then check the IICSn.MSTSn bit (n = 0 to 2).

The wait periods, which should be set via software, are listed in Table 17-6. These wait periods can be set by the SMCn, CLn1, and CLn0 bits of the IICCLn register and the IICXn.CLXn bit (n = 0 to 2).

Table 17-6. Wait Periods

| Clock Selection              | CLXn | SMCn | CLn1 | CLn0 | Wait Period |
|------------------------------|------|------|------|------|-------------|
| fxx (when OCKSm = 18H set)   | 0    | 0    | 0    | 0    | 26 clocks   |
| fxx/2 (when OCKSm = 10H set) | 0    | 0    | 0    | 0    | 52 clocks   |
| fxx/3 (when OCKSm = 11H set) | 0    | 0    | 0    | 0    | 78 clocks   |
| fxx/4 (when OCKSm = 12H set) | 0    | 0    | 0    | 0    | 104 clocks  |
| fxx/5 (when OCKSm = 13H set) | 0    | 0    | 0    | 0    | 130 clocks  |
| fxx (when OCKSm = 18H set)   | 0    | 0    | 0    | 1    | 47 clocks   |
| fxx/2 (when OCKSm = 10H set) | 0    | 0    | 0    | 1    | 94 clocks   |
| fxx/3 (when OCKSm = 11H set) | 0    | 0    | 0    | 1    | 141 clocks  |
| fxx/4 (when OCKSm = 12H set) | 0    | 0    | 0    | 1    | 188 clocks  |
| fxx/5 (when OCKSm = 13H set) | 0    | 0    | 0    | 1    | 235 clocks  |
| fxx                          | 0    | 0    | 1    | 0    | 47 clocks   |
| fxx (when OCKSm = 18H set)   | 0    | 1    | 0    | ×    | 16 clocks   |
| fxx/2 (when OCKSm = 10H set) | 0    | 1    | 0    | ×    | 32 clocks   |
| fxx/3 (when OCKSm = 11H set) | 0    | 1    | 0    | ×    | 48 clocks   |
| fxx/4 (when OCKSm = 12H set) | 0    | 1    | 0    | ×    | 64 clocks   |
| fxx/5 (when OCKSm = 13H set) | 0    | 1    | 0    | ×    | 80 clocks   |
| fxx                          | 0    | 1    | 1    | 0    | 16 clocks   |
| fxx (when OCKSm = 18H set)   | 1    | 1    | 0    | ×    | 10 clocks   |
| fxx/2 (when OCKSm = 10H set) | 1    | 1    | 0    | ×    | 20 clocks   |
| fxx/3 (when OCKSm = 11H set) | 1    | 1    | 0    | ×    | 30 clocks   |
| fxx/4 (when OCKSm = 12H set) | 1    | 1    | 0    | ×    | 40 clocks   |
| fxx/5 (when OCKSm = 13H set) | 1    | 1    | 0    | ×    | 50 clocks   |
| fxx                          | 1    | 1    | 1    | 0    | 10 clocks   |

**Remarks 1.** n = 0 to 2 m = 0, 1

2.  $\times$  = don't care

The communication reservation timing is shown below.



Figure 17-15. Communication Reservation Timing

Communication reservations are accepted via the following timing. After the IICSn.STDn bit is set to 1, a communication reservation can be made by setting the IICCn.STTn bit to 1 before a stop condition is detected (n = 0 to 2).



Figure 17-16. Timing for Accepting Communication Reservations

The communication reservation flowchart is illustrated below.

Figure 17-17. Communication Reservation Flowchart



#### 17.14.2 When communication reservation function is disabled (IICFn.IICRSVn bit = 1)

When the IICCn.STTn bit is set when the bus is not used in a communication during bus communication, this request is rejected and a start condition is not generated. There are two modes in which the bus is not used

- When arbitration results in neither master nor slave operation
- When an extension code is received and slave operation is disabled (ACK is not returned and the bus was released when the IICCn.LRELn bit was set to 1) (n = 0 to 2).

To confirm whether the start condition was generated or request was rejected, check the IICFn.STCFn flag. The time shown in Table 17-7 is required until the STCFn flag is set after setting the STTn bit to 1. Therefore, secure the time by software.

Table 17-7. Wait Periods

| OCKSENn | OCKSn1 | OCKSn0 | CLn1 | CLn0 | Wait Period |
|---------|--------|--------|------|------|-------------|
| 1       | 0      | 0      | 0    | ×    | 6 clocks    |
| 1       | 0      | 1      | 0    | ×    | 9 clocks    |
| 1       | 1      | 0      | 0    | ×    | 12 clocks   |
| 1       | 1      | 1      | 0    | ×    | 15 clocks   |
| 0       | 0      | 0      | 1    | 0    | 3 clocks    |

Remarks 1. ×: don't care

**2.** n = 0 to 2

#### 17.15 Cautions

(1) When IICFn.STCENn bit = 0

Immediately after the  $I^2COn$  operation is enabled, the bus communication status (IICFn.IICBSYn bit = 1) is recognized regardless of the actual bus status. To execute master communication in the status where a stop condition has not been detected, generate a stop condition and then release the bus before starting the master communication.

Use the following sequence for generating a stop condition.

<1> Set the IICCLn register.

<2> Set the IICCn.IICEn bit.

<3> Set the IICCn.SPTn bit.

(2) When IICFn.STCENn bit = 1

Immediately after  $l^2$ COn operation is enabled, the bus released status (IICBSYn bit = 0) is recognized regardless of the actual bus status. To generate the first start condition (IICCn.STTn bit = 1), it is necessary to confirm that the bus has been released, so as to not disturb other communications.

- (3) When the IICCn.IICEn bit of the V850ES/SG2 is set to 1 while communications with other devices are in progress, the start condition may be detected depending on the status of the communication line. Be sure to set the IICCn.IICEn bit to 1 when the SCL0n and SDA0n lines are high level.
- (4) Determine the operation clock frequency by the IICCLn, IICXn, and OCKSm registers before enabling the operation (IICCn.IICEn bit = 1). To change the operation clock frequency, clear the IICCn.IICEn bit to 0 once.
- (5) After the IICCn.STTn and IICCn.SPTn bits have been set to 1, they must not be re-set without being cleared to 0 first.
- (6) If transmission has been reserved, set the IICCN.SPIEn bit to 1 so that an interrupt request is generated by the detection of a stop condition. After an interrupt request has been generated, the wait status will be released by writing communication data to I<sup>2</sup>Cn, then transferring will begin. If an interrupt is not generated by the detection of a stop condition, transmission will halt in the wait status because an interrupt request was not generated. However, it is not necessary to set the SPIEn bit to 1 for the software to detect the IICSn.MSTSn bit.

**Remark** n = 0 to 2 m = 0, 1

## 17.16 Communication Operations

**Remark** Set the P38, P39, P40, P41, P90, and P91 pins to I<sup>2</sup>C mode (SDA0n, SCL0n), before starting communication referencing **Table 4-15 Using Port Pin as Alternate-Function Pin** (n = 0 to 2).

#### 17.16.1 Master operation 1

The following shows the flowchart for master communication when the communication reservation function is enabled (IICFn.IICRSVn bit = 0) and the master operation is started after a stop condition is detected (IICFn.STCENn bit = 0).

START  $\mathsf{IICCLn} \leftarrow \times \!\! \times \!\! \mathsf{H}$ Select transfer clock No INTIICn = 1? Yes (stop condition detection) STTn = 1 Wait time is secured by software (see **Table 17-6**) Wait No MSTSn = 1? Communication reservation Yes (start condition generation) INTIICn = 1? Yes Stop condition detection, Start IICn write transfer start condition generation by communication reservation INTIICn = 1? Yes ACKDn = 1? Generate stop condition (no slave with matching address) Yes No (receive) Address transfe TRCn = 1? completion End Start IICn write transfer WTIMn = 0 ACKEn = 1 INTIICn = 1? WRELn = 1 Start reception Data processing INTIICn = 1? T Yes No Data processing Transfer completed? Transfer completed? Generate stop condition SPTn = 1ACKEn = 0 End **Remark** n = 0 to 2

Figure 17-18. Master Operation Flowchart (1)

#### 17.16.2 Master operation 2

The following shows the flowchart for master communication when the communication reservation function is disabled (IICRSVn bit = 1) and the master operation is started without detecting a stop condition (STCENn bit = 1).



Figure 17-19. Master Operation Flowchart (2)

#### 17.16.3 Slave operation

The following shows the processing procedure of the slave operation.

Basically, the operation of the slave device is event-driven. Therefore, processing by an INTIICn interrupt (processing requiring a significant change of the operation status, such as stop condition detection during communication) is necessary.

The following description assumes that data communication does not support extension codes. Also, it is assumed that the INTIICn interrupt servicing performs only status change processing and that the actual data communication is performed during the main processing.

Setting, etc.

INTIICn signal
Setting, etc.

Interrupt servicing

Data
Setting, etc.

Figure 17-20. Software Outline During Slave Operation

Therefore, the following three flags are prepared so that the data transfer processing can be performed by transmitting these flags to the main processing instead of INTIICn signal.

#### (1) Communication mode flag

This flag indicates the following communication statuses.

Clear mode: Data communication not in progress

Communication mode: Data communication in progress (valid address detection stop condition detection, ACK

from master not detected, address mismatch)

## (2) Ready flag

This flag indicates that data communication is enabled. This is the same status as an INTIICn interrupt during normal data transfer. This flag is set in the interrupt processing block and cleared in the main processing block. The ready flag for the first data for transmission is not set in the interrupt processing block, so the first data is transmitted without clear processing (the address match is regarded as a request for the next data).

#### (3) Communication direction flag

This flag indicates the direction of communication and is the same as the value of IICSn.TRCn bit.

The following shows the operation of the main processing block during slave operation.

Start I<sup>2</sup>C0n and wait for the communication enabled status. When communication is enabled, perform transfer using the communication mode flag and ready flag (the processing of the stop condition and start condition is performed by interrupts, conditions are confirmed by flags).

For transmission, repeat the transmission operation until the master device stops returning  $\overline{ACK}$ . When the master device stops returning  $\overline{ACK}$ , transfer is complete.

For reception, receive the required number of data and do not return  $\overline{ACK}$  for the next data immediately after transfer is complete. After that, the master device generates the stop condition or restart condition. This causes exit from communications.



Figure 17-21. Slave Operation Flowchart (1)

The following shows an example of the processing of the slave device by an INTIICn interrupt (it is assumed that no extension codes are used here). During an INTIICn interrupt, the status is confirmed and the following steps are executed.

- <1> When a stop condition is detected, communication is terminated.
- <2> When a start condition is detected, the address is confirmed. If the address does not match, communication is terminated. If the address matches, the communication mode is set and wait is released, and operation returns from the interrupt (the ready flag is cleared).
- <3> For data transmission/reception, when the ready flag is set, operation returns from the interrupt while the  $I^2$ C0n bus remains in the wait status.

Remark <1> to <3> in the above correspond to <1> to <3> in Figure 17-22 Slave Operation Flowchart (2).



Figure 17-22. Slave Operation Flowchart (2)

## 17.17 Timing of Data Communication

When using I<sup>2</sup>C bus mode, the master device outputs an address via the serial bus to select one of several slave devices as its communication partner.

After outputting the slave address, the master device transmits the IICSn.TRCn bit, which specifies the data transfer direction, and then starts serial communication with the slave device.

The shift operation of the IICn register is synchronized with the falling edge of the serial clock pin (SCL0n). The transmit data is transferred to the SO latch and is output (MSB first) via the SDA0n pin.

Data input via the SDA0n pin is captured by the IICn register at the rising edge of the SCL0n pin.

The data communication timing is shown below.

**Remark** n = 0 to 2

Figure 17-23. Example of Master to Slave Communication
(When 9-Clock Wait Is Selected for Both Master and Slave) (1/3)

(a) Start condition ~ Address



Figure 17-23. Example of Master to Slave Communication (When 9-Clock Wait Is Selected for Both Master and Slave) (2/3)







Figure 17-24. Example of Slave to Master Communication (When 9-Clock Wait Is Selected for Both Master and Slave) (1/3)



(b) Data Processing by master device IICn  $\mathsf{IICn} \leftarrow \mathsf{FFH} \; \mathbf{Note}$ IICn ← FFH Note ACKDn STDn SPDn WTIMn ACKEn MSTSn STTn SPTn Note WRELn Note INTIICn TRCn L Receive Transfer lines SCL0n 8 9 1 2 3 4 5 6 7 8 9 2 3 SDA0n D0 \ACK/ D7 X D6 X D5 X D4 X D3 X D2 X D1 X D0 \ACK √ D6 √ D5 Processing by slave device IICn  $IICn \leftarrow data$  $\mathsf{IICn} \leftarrow \mathsf{data}$ ACKDn STDn SPDn WTIMn ACKEn MSTSn STTn SPTn WRELn INTIICn

Figure 17-24. Example of Slave to Master Communication (When 9-Clock Wait Is Selected for Both Master and Slave) (2/3)

Note To cancel master wait, write FFH to IICn or set WRELn.

**Remark** n = 0 to 2

Figure 17-24. Example of Slave to Master Communication (When 9-Clock Wait Is Selected for Both Master and Slave) (3/3)



#### **CHAPTER 18 IEBus CONTROLLER**

IEBus (Inter Equipment Bus) is a small-scale digital data transfer system that transfers data between units. To implement IEBus with the V850ES/SG2, an external IEBus driver and receiver are necessary because they are not provided.

The internal IEBus controller of the V850ES/SG2 is of negative logic.

The following models of the V850ES/SG2 have an on-chip IEBus controller.

• μPD703272HY, 703273HY, 70F3273HY

#### 18.1 Functions

#### 18.1.1 Communication protocol of IEBus

The communication protocol of the IEBus is as follows.

# (1) Multi-task mode

All the units connected to the IEBus can transfer data to the other units.

# (2) Broadcasting communication function

Communication between one unit and multiple units can be performed as follows.

Group-unit broadcast communication:
 All-unit broadcast communication:
 Broadcast communication to group units
 Broadcast communication to all units.

#### (3) Effective transfer rate

The effective transfer rate is in mode 1 or mode 2 (the V850ES/SG2 does not support mode 0 for the effective transfer rate).

Mode 1: Approx. 17 kbps

• Mode 2: Approx. 26 kbps

Caution Different modes must not be mixed on one IEBus.

# (4) Communication mode

Data transfer is executed in half-duplex asynchronous communication mode.

#### (5) Access control: CSMA/CD (Carrier Sense Multiple Access with Collision Detection)

The priority of the IEBus is as follows:

- <1> Broadcast communication takes precedence over individual communication (communication from one unit to another).
- <2> The lower master address takes precedence.

# (6) Communication scale

The communication scale of IEBus is as follows.

- Number of units: 50 MAX.
- Cable length: 150 m MAX. (when twisted pair cable is used)

Caution The communication scale in an actual system differs depending on the characteristics of the cables, etc., constituting the IEBus driver/receiver and IEBus.

## 18.1.2 Determination of bus mastership (arbitration)

An operation to occupy the bus is performed when a unit connected to the IEBus controls the other units. This operation is called arbitration.

When two or more units simultaneously start transmission, arbitration is used to grant one of the units the permission to occupy the bus.

Because only one unit is granted the bus mastership as a result of arbitration, the priority conditions of the bus are predetermined as follows.

#### Caution The bus mastership is released if communication is aborted.

## (1) Priority by communication type

Broadcast communication (communication from one unit to multiple units) takes precedence over normal communication (communication from one unit to another).

## (2) Priority by master address

If the communication type is the same, communication with the lower master address takes precedence.

A master address consists of 12 bits, with unit 000H having the highest priority and unit FFFH having the lowest priority.

#### 18.1.3 Communication mode

The IEBus has three communication modes each having a different transfer rate. The V850ES/SG2 supports communication modes 1 and 2. The transfer rate and the maximum number of transfer bytes in one communication frame in communication modes 1 and 2 are as shown in Table 18-1.

Table 18-1. Transfer Rate and Maximum Number of Transfer Bytes in Each Communication Mode

| Communication Mode | Maximum Number of Transfer Bytes (Bytes/Frame) | Effective Transfer Rate (kbps) <sup>Note</sup> |
|--------------------|------------------------------------------------|------------------------------------------------|
| 1                  | 32                                             | Approx. 17                                     |
| 2                  | 128                                            | Approx. 26                                     |

Note The effective transfer rate when the maximum number of transfer bytes is transmitted.

Select the communication mode for each unit connected to the IEBus before starting communication. If the communication mode of the master unit and that of the partner unit (slave unit) are not the same, communication is not correctly executed.

#### 18.1.4 Communication address

With the IEBus, each unit is assigned a specific 12-bit address. This communication address consists of the following identification numbers.

- Higher 4 bits: Group number (number to identify the group to which each unit belongs)
- Lower 8 bits: Unit number (number to identify each unit in a group)

#### 18.1.5 Broadcast communication

Normally, transmission or reception is performed between the master unit and its partner slave unit on a one-toone basis. During broadcast communication, however, two or more slave units exist and the master unit executes transmission to these slave units. Because two or more slave units exist, the NACK signal is returned by the communicating slave unit as an acknowledge bit.

Whether broadcast communication or normal communication is to be executed is selected by the broadcast bit (for this bit, see **18.1.6 (2) Broadcast bit**).

Broadcast communication is classified into two types: group-unit broadcast communication and all-unit broadcast communication. Group-unit broadcast and all-unit broadcast are identified by the value of the slave address (for the slave address, see **18.1.6** (4) Slave address field).

# (1) Group-unit broadcast communication

Broadcast communication is performed to the units in a group identified by the group number indicated by the higher 4 bits of the communication address.

# (2) All-unit broadcast communication

Broadcast communication is performed to all the units, regardless of the value of the group number.

#### 18.1.6 Transfer format of IEBus

Figure 18-1 shows the transfer signal format of the IEBus.

Figure 18-1. IEBus Transfer Signal Format

|              | Hea   | ader                  | Master<br>address<br>field |   | Slave<br>address<br>field |    | Control fie | eld | Telegraph<br>length<br>field    |             | Data | field       |    |
|--------------|-------|-----------------------|----------------------------|---|---------------------------|----|-------------|-----|---------------------------------|-------------|------|-------------|----|
| Frame format | Start | Broad-<br>cast<br>bit | Master<br>address<br>bit   | Р | Slave<br>address<br>bit   | ΔΙ | Control bit | Α   | Tele-<br>graph<br>length<br>bit | Data<br>bit | РА   | Data<br>bit | PA |

Remarks 1. P: Parity bit

A: Acknowledge (ACK/NACK) bit

2. The master unit ignores the acknowledge bit during broadcast communication.

# (1) Start bit

The start bit is a signal that informs the other units of the start of data transfer. The unit that is to start data transfer outputs a high-level signal (start bit) from the  $\overline{\text{IETX}}$  pin for a specific time, and then starts outputting the broadcast bit.

If another unit has already output its start bit when one unit is to output the start bit, this unit does not output the start bit but waits for completion of output of the start bit by the other unit. When the output of the start bit by the other unit is complete, the unit starts outputting the broadcast bit in synchronization with the completion of the start bit output by the other unit.

The units other than the one that has started communication detect this start bit, and enter the reception status.

#### (2) Broadcast bit

This bit indicates whether the master selects one slave (individual communication) or multiple slaves (broadcast communication) as the other party of communication.

When the broadcast bit is 0, it indicates broadcast communication; when it is 1, individual communication is indicated. Broadcast communication is classified into two types: group-unit communication and all-unit communication. These communication types are identified by the value of the slave address (for the slave address, see 18.1.6 (4) Slave address field).

Because two or more slave units exist as a partner slave unit of communication in the case of broadcast communication, the NACK signal is returned as an acknowledge bit in each field subsequent to the master address field.

If two or more units start transmitting a communication frame at the same time, broadcast communication takes precedence over individual communication, and wins in arbitration.

If one unit occupies the bus as the master, the value set to the broadcast request flag (BCR.ALLRQ bit) is output.

# (3) Master address field

The master address field is output by the master to inform a slave of the master's address.

The configuration of the master address field is as shown in Figure 18-2.

If two or more units start transmitting the broadcast bit at the same time, the master address field makes a judgment of arbitration.

The master address field compares the data it outputs with the data on the bus each time it has output one bit. If the master address output by the master address field is found to be different from the data on the bus as a result of comparison, it is assumed that the master has lost in arbitration. As a result, the master stops transmission and enters the reception status.

Because the IEBus is configured of wired AND, the unit having the minimum master address of the units participating in arbitration (arbitration masters) wins in arbitration.

After a 12-bit master address has been output, only one unit remains in the transmission status as one master unit.

Next, this master unit outputs a parity bit, determines the master address of other unit, and starts outputting a slave address field.

If one unit occupies the bus as the master, the address set by the UAR register is output.

Master address field

Master address (12 bits)

Parity

MSB

LSB

Figure 18-2. Master Address Field

#### (4) Slave address field

The master outputs the address of the unit with which it is to communicate.

Figure 18-3 shows the configuration of the slave address field.

A parity bit is output after a 12-bit slave address has been transmitted in order to prevent a wrong slave address from being received by mistake. Next, the master unit detects an  $\overline{ACK}$  signal from the slave unit to confirm that the slave unit exists on the bus. When the master has detected the  $\overline{ACK}$  signal, it starts outputting the control field. During broadcast communication, however, the master does not confirm the acknowledge bit but starts outputting the control field.

The slave unit outputs the  $\overline{ACK}$  signal if its slave address matches and if the slave detects that the parities of both the master address and slave address are even. The slave unit judges that the master address or slave address has not been correctly received and outputs the NACK signal if the parities are odd. At this time, the master unit is in the standby (monitor) status, and communication ends.

During broadcast communication, the slave address is used to identify group-unit broadcast or all-unit broadcast, as follows:.

If slave address is FFFH: All-unit broadcast communication
If slave address is other than FFFH: Group-unit broadcast communication

**Remark** The group No. during group-unit broadcasting communication is the value of the higher 4 bits of the slave address.

If one unit occupies the bus as the master, the address set by the SAR register is output.

Slave address field

Slave address (12 bits)

Group No.

Unit No.

MSB

LSB

Figure 18-3. Slave Address Field

#### (5) Control field

The master outputs the operation it requires the slave to perform, by using this field.

The configuration of the control field is as shown in Figure 18-4.

If the parity following the control bit is even and if the slave unit can execute the function required by the master unit, the slave unit outputs an  $\overline{ACK}$  signal and starts outputting the telegraph length field. If the slave unit cannot execute the function required by the master unit even if the parity is even, or if the parity is odd, the slave unit outputs the NACK signal, and returns to the standby (monitor) status.

The master unit starts outputting the telegraph field after detecting the ACK signal.

If the master can detect the NACK signal, the master unit enters the standby status, and communication ends. During broadcast communication, however, the master unit does not confirm the acknowledge bit, and starts outputting the telegraph length field.

The contents of the control bits are shown below.

Table 18-2. Contents of Control Bits

| Bit 3 <sup>Note 1</sup> | Bit 2 | Bit 1 | Bit 0 | Function                                            |
|-------------------------|-------|-------|-------|-----------------------------------------------------|
| 0                       | 0     | 0     | 0     | Read slave status                                   |
| 0                       | 0     | 0     | 1     | Undefined                                           |
| 0                       | 0     | 1     | 0     | Undefined                                           |
| 0                       | 0     | 1     | 1     | Read data and lock <sup>Note 2</sup>                |
| 0                       | 1     | 0     | 0     | Read lock address (lower 8 bits) <sup>Note 3</sup>  |
| 0                       | 1     | 0     | 1     | Read lock address (higher 4 bits) <sup>Note 3</sup> |
| 0                       | 1     | 1     | 0     | Read slave status and unlock <sup>Note 2</sup>      |
| 0                       | 1     | 1     | 1     | Read data                                           |
| 1                       | 0     | 0     | 0     | Undefined                                           |
| 1                       | 0     | 0     | 1     | Undefined                                           |
| 1                       | 0     | 1     | 0     | Write command and lock <sup>Note 2</sup>            |
| 1                       | 0     | 1     | 1     | Write data and lock <sup>Note 2</sup>               |
| 1                       | 1     | 0     | 0     | Undefined                                           |
| 1                       | 1     | 0     | 1     | Undefined                                           |
| 1                       | 1     | 1     | 0     | Write command                                       |
| 1                       | 1     | 1     | 1     | Write data                                          |

**Notes 1.** The telegraph length bit of the telegraph length field and data transfer direction of the data field change as follows depending on the value of bit 3 (MSB).

If bit 3 is '1': Transfer from master unit to slave unit

If bit 3 is '0': Transfer from slave unit to master unit

- 2. This is a control bit that specifies locking or unlocking (see 18.1.7 (4) Locking and unlocking).
- 3. The lock address is transferred in 1-byte (8-bit) units and is configured as follows:



If the control bit received from the master unit is not as shown in Table 18-3, the unit locked by the master unit rejects acknowledging the control bit, and outputs the NACK signal.

Table 18-3. Control Field for Locked Slave Unit

| Bit 3 | Bit 2 | Bit 1 | Bit 0 | Function                          |
|-------|-------|-------|-------|-----------------------------------|
| 0     | 0     | 0     | 0     | Read slave status                 |
| 0     | 1     | 0     | 0     | Read lock address (lower 8 bits)  |
| 0     | 0     | 0     | 1     | Read lock address (higher 4 bits) |

Moreover, units for which lock is not set by the master unit reject acknowledgment and output a NACK signal when the control data shown in Table 18-4 is acknowledged.

Table 18-4. Control Field for Unlocked Slave Unit

| Bit 3 | Bit 2 | Bit 1 | Bit 0 | Function                          |
|-------|-------|-------|-------|-----------------------------------|
| 0     | 1     | 0     | 0     | Lock address read (lower 8 bits)  |
| 0     | 1     | 0     | 1     | Lock address read (higher 4 bits) |

If one unit occupies the bus as the master, the value set to the CDR register is output.

Figure 18-4. Control Field



Table 18-5. Acknowledge Signal Output Condition of Control Field

(a) If received control data is AH, BH, EH, or FH

| Communication Type               | Communication Type Communication Target | Lock Status  | Master Unit           | Slave Transmission | Slave Reception   | Received Control Data | d Contro | l Data |
|----------------------------------|-----------------------------------------|--------------|-----------------------|--------------------|-------------------|-----------------------|----------|--------|
| (OSH.ALLI MANS DR)<br>Individual | Slave Specification = 1                 | Lock = 1     | with PAR register)    | (BCR.ENSLVTX bit)  | (BCR.ENSLVRX bit) | AH                    | BH EH    | Ŧ      |
| Communication $= 0$              | No Specification = 0                    | Unlock = $0$ | Lock Request Unit = 1 |                    |                   |                       |          |        |
| Broadcast                        |                                         |              | Other = $0$           |                    |                   |                       |          |        |
| Communication = 1                |                                         |              |                       |                    |                   |                       |          |        |
| 0                                | 1                                       | 0            | don't care            | don't care         | -                 |                       | 0        |        |
|                                  |                                         | -            | -                     |                    |                   |                       |          |        |
|                                  |                                         | Other th     | Other than above      |                    |                   |                       | ×        |        |

(b) If received control data is 0H, 3H, 4H, 5H, 6H, or 7H

|                                                                            |                                                          | ı           |   |                  |                  |         | i —              |
|----------------------------------------------------------------------------|----------------------------------------------------------|-------------|---|------------------|------------------|---------|------------------|
| ata                                                                        | H 2                                                      | ×           | 0 | ×                | ×                | 0       |                  |
| jo.                                                                        | Н9                                                       | 0           | 0 | ×                | 0                | 0       |                  |
| ontr                                                                       | 2H                                                       | ×           | × | 0                | 0                | 0       | ×                |
| ope,                                                                       | <del>1</del>                                             | ×           | × | 0                | 0                | 0       |                  |
| Received Control Data                                                      | HE .                                                     | ×<br>×<br>O | × | 0<br>0<br>×<br>0 | 0<br>0<br>0<br>× | 0 0 0 0 |                  |
| Re                                                                         | 0H 3H 4H 5H 6H 7H                                        | 0           | 0 | 0                | 0                | 0       |                  |
| Slave Reception<br>Enable                                                  | (BCR.ENSLVRX bit)                                        | don't care  |   |                  |                  |         |                  |
| Slave Transmission<br>Enable                                               | (BCR.ENSLVTX bit)                                        | 0           | 1 | don't care       | 0                | 1       |                  |
| Master Unit<br>Identification (Match                                       | with PAR register) Lock Request Unit = 1 Other = 0       | don't care  |   | 0                | 1                |         | Other than above |
| Lock Status<br>(USR.LOCK bit)                                              | Lock = 1<br>Unlock = 0                                   | 0           |   | 1                |                  |         | Other th         |
| Communication Type Communication Target (USR.ALLTRANS bit) (USR.SLVRQ bit) | Slave Specification = 1<br>No Specification = 0          | 1           |   |                  |                  |         |                  |
| Communication Type (USR.ALLTRANS bit)                                      | Individual Communication = 0 Broadcast Communication = 1 | 0           |   |                  |                  |         |                  |

Caution If the received control data is other than the data shown in Table 18-5,  $\times$  (NACK signal is returned) is unconditionally assumed.

Remark O: ACK signal is returned.

x: NACK signal is returned.

#### (6) Telegraph length field

This field is output by the transmission side to inform the reception side of the number of bytes of the transmit data.

The configuration of the telegraph length field is as shown in Figure 18-5.

Table 18-6 shows the relationship between the telegraph length bit and the number of transmit data.

Figure 18-5. Telegraph Length Field



Table 18-6. Contents of Telegraph Length Bit

| Telegraph Length Bit (Hex) | Number of Transmit Data Bytes |
|----------------------------|-------------------------------|
| 01H                        | 1 byte                        |
| 02H                        | 2 bytes                       |
| I                          | I                             |
| FFH                        | 255 bytes                     |
| 00H                        | 256 bytes                     |

The operation of the telegraph length field differs depending on whether the master transmits data (when control bit 3 is 1) or receives data (when control bit 3 is 0).

# (a) When master transmits data

The telegraph length bit and parity bit are output by the master unit and the synchronization signals of bits are output by the master unit. When the slave unit detects that the parity is even, it outputs the  $\overline{ACK}$  signal, and starts outputting the data field. During broadcast communication, however, the slave unit outputs the NACK signal.

If the parity is odd, the slave unit judges that the telegraph length bit has not been correctly received, outputs the NACK signal, and returns to the standby (monitor) status. At this time, the master unit also returns to the standby status, and communication ends.

# (b) When master receives data

The telegraph length bit and parity bit are output by the slave unit and the synchronization signals of bits are output by the master unit. If the master unit detects that the parity bit is even, it outputs the  $\overline{ACK}$  signal.

If the parity bit is odd, the master unit judges that the telegraph length bit has not been correctly received, outputs the NACK signal, and returns to the standby status. At this time, the slave unit also returns to the standby status, and communication ends.

# (7) Data field

This is data output by the transmission side.

The master unit transmits or receives data to or from a slave unit by using the data field.

The configuration of the data field is as shown below.

Figure 18-6. Data Field



Following the data bit, the parity bit and acknowledge bit are respectively output by the master unit and slave

Use broadcast communication only for when the master unit transmits data. At this time, the acknowledge bit is ignored.

The operation differs as follows depending on whether the master transmits or receives data.

# (a) When master transmits data

When the master units writes data to a slave unit, the master unit transmits the data bit and parity bit to the slave unit. If the parity is even and the receive data is not stored in the DR register when the slave unit has received the data bit and parity bit, the slave unit outputs an  $\overline{ACK}$  signal. If the parity is odd or if the receive data is stored in the DR register, the slave unit rejects receiving the data, and outputs the NACK signal.

If the slave unit outputs the NACK signal, the master unit transmits the same data again. This operation continues until the master detects the  $\overline{ACK}$  signal from the slave unit, or the data exceeds the maximum number of transmit bytes.

If there is more data and the maximum number of transmit bytes is not exceeded when the parity is even and when the slave unit outputs the  $\overline{ACK}$  signal, the master unit transmits the next data.

During broadcast communication, the slave unit outputs the NACK signal, and the master unit transfers 1 byte of data at a time. If the parity is odd or the DR register is storing receive data after the slave unit has received the data bit and parity bit during broadcast communication, the slave unit judges that reception has not been performed correctly, and stops reception.

#### (b) When master receives data

When the master unit reads data from a slave unit, the master unit outputs a sync signal corresponding to all the read bits.

The slave unit outputs the contents of the data and parity bits to the bus in response to the sync signal from the master unit.

The master unit reads the data and parity bits output by the slave unit, and checks the parity.

If the parity is odd, or if the DR register is storing a receive data, the master unit rejects accepting the data, and outputs the NACK signal. If the maximum number of transmit bytes is within the value that can be transmitted in one communication frame, the master unit repeats reading the same data.

If the parity is even and the DR register is not storing a receive data, the master unit accepts the data and outputs the  $\overline{ACK}$  signal. If the maximum number of transmit bytes is within the value that can be transmitted in one frame, the master unit reads the next data.

Caution Do not operate master reception in broadcast communication, because the slave unit cannot be defined and data transfer cannot be performed correctly.

#### (8) Parity bit

The parity bit is used to check to see if the transmit data has no error.

The parity bit is appended to each data of the master address, slave address, control, telegraph length, and data bits

The parity is an even parity. If the number of bits in data that are '1' is odd, the parity bit is '1'. If the number of bits in the data that are '1' is even, the parity bit is '0'.

#### (9) Acknowledge bit

During normal communication (communication from one unit to another), an acknowledge bit is appended to the following locations to check if the data has been correctly received.

- · End of slave address field
- End of control field
- End of telegraph length field
- · End of data field

The definition of the acknowledge bit is as follows.

- 0: Indicates that the transmit data is recognized (ACK signal).
- 1: Indicates that the transmit data is not recognized (NACK signal).

During broadcast communication, however, the contents of the acknowledge bit are ignored.

# (a) Last acknowledge bit of slave field

The last acknowledge bit of the slave field serves as a NACK signal in any of the following cases, and transmission is stopped.

- If the parity of the master address bit or slave address bit is incorrect
- If a timing error (error in bit format) occurs
- If a slave unit does not exist

#### (b) Last acknowledge bit of control field

The last acknowledge bit of the control field serves as a NACK signal in any of the following cases, and transmission is stopped.

- · If the parity of the control bit is incorrect
- If control bit 3 is '1' (write operation) when the slave reception enable flag (BCR.ENSLVRX bit) is not set (1)Note
- If the control bit indicates reading of data (3H or 7H) when the slave transmission enable flag (BCR.ENSLVTX bit) is not set (1)
- If a unit other than that has set locking requests 3H, 6H, 7H, AH, BH, EH, or FH of the control bit when locking is set
- If the control bit indicates reading of lock addresses (4H, 5H) even when locking is not set
- · If a timing error occurs
- · If the control bit is undefined

# Cautions 1. The ACK signal is always returned when the control data of the slave status request is received, even if the ENSLVTX bit = 0.

2. The NACK signal is returned by the acknowledge bit in the control field when the control data for data/command writing is received, even if the ENSLVRX bit = 0. Slave reception can be disabled (communication stopped) by ENSLVRX bit only in the case of individual communication. In the case of broadcast communication, communication is maintained and the data request interrupt request signal (INTIE1) or IEBus end interrupt request signal (INTIE2) is generated.

# (c) Last acknowledge bit of telegraph length field

The last acknowledge bit of the telegraph length field serves as a NACK signal in any of the following cases, and transmission is stopped.

- · If the parity of the telegraph length bit is incorrect
- If a timing error occurs

## (d) Last acknowledge bit of data field

The last acknowledge bit of the data field serves as a NACK signal in any of the following cases, and transmission is stopped.

- If the parity of the data bit is incorrect Note
- If a timing error occurs after the preceding acknowledge bit has been transmitted
- If the receive data is stored in the DR register and no more data can be received Note

**Note** In this case, when the communication executed is individual communication, if the maximum number of transmit bytes is within the value that can be transmitted in one frame, the transmission side executes transmission of that data field again. For broadcast communication, the transmission side does not execute transmission again, a communication error occurs on the reception side and reception stops.

# 18.1.7 Transfer data

# (1) Slave status

The master unit can learn why the slave unit did not return the  $\overline{ACK}$  signal by reading the slave status.

The slave status is determined according to the result of the last communication the slave unit has executed.

All the slave units can supply information on the slave status.

The configuration of the slave status is shown below.

Figure 18-7. Bit Configuration of Slave Status

| MSB                     |            |                                           |                      |            |        |      |           | LSB    |  |
|-------------------------|------------|-------------------------------------------|----------------------|------------|--------|------|-----------|--------|--|
| Bit 7                   | Bit 6      | Bit 5                                     | Bit 4                | Bit 3      | В      | it 2 | Bit 1     | Bit 0  |  |
|                         |            |                                           |                      |            |        |      |           |        |  |
| Bit 0 <sup>Note 1</sup> |            | Meaning                                   |                      |            |        |      |           |        |  |
| 0                       | Transmit   | data is not w                             | ritten in D          | R register | •      |      |           |        |  |
| 1                       | Transmit   | ansmit data is written in DR register     |                      |            |        |      |           |        |  |
| Bit 1 <sup>Note 2</sup> |            | Meaning                                   |                      |            |        |      |           |        |  |
| 0                       | Receive    | Receive data is not stored in DR register |                      |            |        |      |           |        |  |
| 1                       |            | data is stored                            |                      |            |        |      |           |        |  |
|                         |            |                                           |                      |            |        |      |           |        |  |
| Bit 2                   |            | Meaning                                   |                      |            |        |      |           |        |  |
| 0                       | Unit is no | ot locked                                 |                      |            |        |      |           |        |  |
| 1                       | Unit is lo | cked                                      |                      |            |        |      |           |        |  |
|                         |            |                                           |                      |            |        |      |           |        |  |
| Bit 3                   |            | Meaning                                   |                      |            |        |      |           |        |  |
| 0                       | Fixed to   | 0                                         |                      |            |        |      |           |        |  |
| Bit 4 <sup>Note 3</sup> |            |                                           |                      | Meaning    | ,      |      |           |        |  |
| 0                       | Slave tra  | nsmission is                              | stonned              | Meaning    | 1      |      |           |        |  |
| 1                       |            | nsmission is                              |                      |            |        |      |           |        |  |
| <u>'</u>                | Olave tra  | 1101111001011110                          | Today                |            |        |      |           |        |  |
| Bit 5                   |            |                                           |                      | Meaning    | 9      |      |           |        |  |
| 0                       | Fixed to   | 0                                         |                      |            |        |      |           |        |  |
|                         |            |                                           |                      |            |        |      |           |        |  |
| Bit 7                   | Bit 6      |                                           |                      | Ме         | eaning |      |           |        |  |
| 0                       | 0          | Mode 0                                    |                      |            | ighest | mode | supported | by the |  |
| 0                       | 1          | Mode 1                                    | unit <sup>Note</sup> | 4.         |        |      |           |        |  |
| 1                       | 0          | Mode 2                                    |                      |            |        |      |           |        |  |
| 1                       | 1          | Not used                                  |                      |            |        |      |           |        |  |

Notes 1. After reset: Bit 0 is set to 1.

- 2. The receive buffer size is 1 byte.
- **3.** When the V850ES/SG2 serves as a slave unit, this bit corresponds to the status indicated by BCR.ENSLVTX bit.
- 4. Bits 7 and 6 are fixed to "10" because the V850ES/SG2 can support modes 1 and 2.

#### (2) Lock address

When the lock address is read (control bit: 4H or 5H), the address (12 bits) of the master unit that has issued the lock instruction is configured in 1-byte units as shown below and read.

Figure 18-8. Configuration of Lock Address



# (3) Data

If the control bit indicates reading of data (3H or 7H), the data in the data buffer of the slave unit is read by the master unit.

If the control bit indicates writing of data (BH or FH), the data received by the slave unit is processed according to the operation rule of that slave unit.

# (4) Locking and unlocking

The lock function is used when a message is transferred in two or more communication frames.

The unit that is locked does not receive data from units other than the one that has locked the unit (does not receive broadcast communication).

A unit is locked or unlocked as follows.

# (a) Locking

If the communication frame is completed without succeeding to transmit or receive data of the number of bytes specified by the telegraph length bit after the telegraph length field has been transmitted or received  $(\overline{ACK} = 0)$  by the control bit that specifies locking (3H, AH, or BH), the slave unit is locked by the master unit. At this time, the bit (bit 2) in the byte indicating the slave status is set to '1'.

#### (b) Unlocking

After transmitting or receiving data of the number of data bytes specified by the telegraph length bit in one communication frame by the control bit that has specified locking (3H, AH, or BH), or the control bit that has specified unlocking (6H), the slave unit is unlocked by the master unit. At this time, the bit related to locking (bit 2) in the byte indicating the slave status is reset to '0'.

Locking or unlocking is not performed during broadcast communication.

Locking and unlocking conditions are shown below.

Table 18-7. Lock Setting Conditions

| Control Data           | Broadcast Co      | ommunication                | Individual Co    | mmunication      |
|------------------------|-------------------|-----------------------------|------------------|------------------|
|                        | Communication End | Communication End Frame End |                  | Frame End        |
| 3H, 6H <sup>Note</sup> |                   |                             | Cannot be locked | Lock set         |
| AH, BH                 | Cannot be locked  | Cannot be locked            | Cannot be locked | Lock set         |
| 0H, 4H, 5H, EH, FH     | Cannot be locked  | Cannot be locked            | Cannot be locked | Cannot be locked |

**Note** The frame end of control data 6H (slave status read/unlock) occurs when the parity in the data field is odd, and when the NACK signal from the IEBus unit is repeated up to the maximum number of transfer bytes with being output.

Table 18-8. Unlock Release Conditions (While Locked)

| Control Data           |                   | munication from<br>Juest Unit |                             | munication from<br>quest Unit |  |
|------------------------|-------------------|-------------------------------|-----------------------------|-------------------------------|--|
|                        | Communication End | Frame End                     | Communication End Frame End |                               |  |
| 3H, 6H <sup>Note</sup> |                   |                               | Unlocked Remains locked     |                               |  |
| AH, BH                 | Unlocked          | Unlocked                      | Unlocked                    | Remains locked                |  |
| 0H, 4H, 5H, EH, FH     | Remains locked    | Remains locked                | Remains locked              | Remains locked                |  |

**Note** The frame end of control data 6H (slave status read/unlock) occurs when the parity in the data field is odd, and when the NACK signal from the IEBus unit is repeated up to the maximum number of transfer bytes with being output.

#### 18.1.8 Bit format

The format of the bits constituting the communication frame of the IEBus is shown below.

Figure 18-9. Bit Format of IEBus



The synchronization period and data period are almost equal to each other in length.

The IEBus synchronizes each bit. The specifications on the time of the entire bit and the time related to the period allocated to that bit differ depending on the type of the transmit bit, or whether the unit is the master unit or a slave unit.

The master and slave units monitor whether each period (preparation period, synchronization period, data period, and stop period) is output for specified time while they are in communication. If a period is not output for the specified time, the master and slave units report a timing error, immediately terminate communication and enter the standby status.

# 18.2 Configuration

The block diagram of the IEBus controller is shown below.

Internal bus 8 SSR, USR, BCR, PSR, ISR RAR, UAR, OCKS2 FSR, SCR, RSA SAR ESR, CDR, DLR, DR CCR Internal register block Prescaler fxx to fxx/5 Prescaler block Transmit shift ĪETX0 ◎register Bit Field processing processing Noise filter block block Receive shift ĪERX0 ⊚ register IEBus interface block Interrupt request signal Interrupt control block IEBus controller

Figure 18-10. IEBus Controller Block Diagram

# (1) Hardware configuration and functions

IEBus mainly consists of the following six internal blocks.

- Interrupt control block
- Internal registers
- Bit processing block
- Field processing block
- IEBus interface block
- Prescaler block

# (a) Interrupt control block

This control block transfers interrupt request signals from the IEBus controller to the CPU.

#### (b) Internal registers

These registers set data to the control registers and fields that control IEBus (for the internal registers, see **18.3 Registers**).

# (c) Bit processing block

This block generates and breaks down bit timing, and mainly consists of a bit sequence ROM, 8-bit preset timer, and comparator.

# (d) Field processing block

This block generates each field in the communication frame, and mainly consists of a field sequence ROM, 4-bit down counter, and comparator.

# (e) IEBus interface block

This is the interface block for an external driver/receiver, and mainly consists of a noise filter, shift register, and transmission/reception block (collision detector, parity detector, parity generator, and  $\overline{ACK}/NACK$  generator).

# (f) Prescaler block

This block selects the clock to be supplied to the IEBus controller.

# 18.3 Registers

The registers that control the IEBus controller are shown below.

Table 18-9. Control Registers of IEBus Controller

| Address   | Function Register Name               | Symbol | R/W | Bit Unit | for Mani | pulation | After Reset |
|-----------|--------------------------------------|--------|-----|----------|----------|----------|-------------|
|           |                                      |        |     | 1        | 8        | 16       |             |
| FFFFF348H | IEBus clock select register          | OCKS2  | R/W |          | √        |          | 00H         |
| FFFFF360H | IEBus control register               | BCR    |     | √        | √        |          |             |
| FFFFF361H | IEBus power save register            | PSR    |     | √        | √        |          |             |
| FFFFF362H | IEBus slave status register          | SSR    | R   | √        | √        |          | 81H         |
| FFFFF363H | IEBus unit status register           | USR    |     | √        | √        |          | 00H         |
| FFFFF364H | IEBus interrupt status register      | ISR    | R/W | √        | √        |          |             |
| FFFFF365H | IEBus error status register          | ESR    |     | √        | √        |          |             |
| FFFFF366H | IEBus unit address register          | UAR    |     |          |          | √        | 0000H       |
| FFFFF368H | IEBus slave address register         | SAR    |     |          |          | √        |             |
| FFFFF36AH | IEBus partner address register       | PAR    | R   |          |          | √        |             |
| FFFFF36CH | IEBus receive slave address register | RSA    |     |          |          | √        |             |
| FFFFF36EH | IEBus control data register          | CDR    | R/W |          | √        |          | 00H         |
| FFFFF36FH | IEBus telegraph length register      | DLR    |     |          | √        |          | 01H         |
| FFFFF370H | IEBus data register                  | DR     |     |          | √        |          | 00H         |
| FFFFF371H | IEBus field status register          | FSR    | R   |          | √        |          |             |
| FFFFF372H | IEBus success count register         | SCR    |     |          | √        |          | 01H         |
| FFFFF373H | IEBus communication count register   | CCR    |     |          | √        |          | 20H         |

# (1) IEBus control register (BCR)

The BCR register is an 8-bit register that controls the operations of the IEBus controller.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

| ENIEBUS | Communication enable flag |
|---------|---------------------------|
| 0       | IEBus unit stopped        |
| 1       | IEBus unit active         |

| MSTRQ | Master request flag                |
|-------|------------------------------------|
| 0     | IEBus unit not requested as master |
| 1     | IEBus unit requested as master     |

| ALLRQ | Broadcast request flag             |
|-------|------------------------------------|
| 0     | Individual communication requested |
| 1     | Broadcast communication requested  |

| ENSLVTX | Slave transmission enable flag |
|---------|--------------------------------|
| 0       | Slave transmission disabled    |
| 1       | Slave transmission enabled     |

| ENSLVRX | Slave reception enable flag |
|---------|-----------------------------|
| 0       | Slave reception disabled    |
| 1       | Slave reception enabled     |

- Cautions 1. While IEBus is operating as the master, writing to the BCR register (including bit manipulation instructions) is disabled until either the end of that communication or frame, or until communication is stopped by the occurrence of an arbitration-loss communication error. Master requests cannot therefore be multiplexed. However, the case when communication has been forcibly stopped (ENIEBUS flag = 0) is not problem.
  - 2. If a bit manipulation instruction for the BCR register conflicts with a hardware reset of the MSTRQ bit, the BCR register may not operate normally. The following countermeasures are recommended in this case.
    - Because the hardware reset is instigated in the acknowledgment period of the slave address field, be sure to observe Caution 1 of (b) Master request flag (MSTRQ) below.
    - Be sure to observe the caution above regarding writing to the BCR register.

# (a) Communication enable flag (ENIEBUS)...Bit 7

<Set/clear conditions>
Set: By software
Clear: By software

The IEBus controller participates in communication differently depending on the timing of setting the ENIEBUS bit (1), as follows.

Table 18-10. Timing of Setting ENIEBUS Bit and Participation in Communication

| Timing of Setting ENIEBUS Bit                                                              | How IEBus Controller Participates in Communication                                                                                                               |
|--------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| If communication is not performed on IEBus                                                 | Participates in communication from the next frame or starts communication.                                                                                       |
| If other bus master is communicating start bit while communication is in progress on IEBus | Participates in communication from that frame if the start bit is detected. If the start bit is not detected, participates in communication from the next frame. |
| If communication is in progress on IEBus after start bit from other bus master is detected | Participates in communication from the next frame.                                                                                                               |

If the ENIEBUS bit is cleared (0), communication is immediately stopped even while it is in progress, and the internal flags and registers are reset, with some exceptions. The registers that are not reset by the ENIEBUS bit are listed in the table below.

The IEBus controller does not respond even if another unit starts communication when the ENIEBUS bit = 0.

Table 18-11. Registers That Are Not Reset by ENIEBUS Bit

| Registers Not Reset by ENIEBUS Bit | Remark                                                                              |
|------------------------------------|-------------------------------------------------------------------------------------|
| UAR                                | Not reset                                                                           |
| SAR                                | Not reset                                                                           |
| CDR                                | Data written from CPU is not reset but data received during communication is reset. |
| DLR                                | Data written from CPU is not reset but data received during communication is reset. |
| DR                                 | Data written from CPU is not reset but data received during communication is reset. |

Caution Before setting the ENIEBUS bit (1), the following registers must be set depending on the mode of communication to be started.

Table 18-12. Registers That Must Be Set Before Each Communication

| Mode of Communication              | Registers That Must Be Set in Advance            |
|------------------------------------|--------------------------------------------------|
| Master transmission                | UAR, SAR, CDR, DLR, DR (first 1-byte data)       |
| Master reception                   | UAR, SAR, CDR                                    |
| Slave transmission <sup>Note</sup> | UAR, DLR, DR (first 1-byte data) <sup>Note</sup> |
| Slave reception                    | UAR                                              |

**Note** When starting slave transmission, information such as the value to be set to the DLR register and which data is to be returned (value to be set to the DR register) must be assigned in advance.

# (b) Master request flag (MSTRQ)...Bit 6

<Set/clear conditions>

Set: By software

Clear: Cleared (0) by hardware when master communication is started and immediately before the start interrupt of the master occurs.

Cleared (0) by hardware before a communication error occurs.

When the ENIEBUS bit is cleared.

When the MSTRQ bit is set (1), the IEBus controller starts communication on IEBus as the master.

If communication is in progress on IEBus (if the start bit cannot be detected while the start bit is being communicated or if communication is in progress after the start bit has been detected), however, the controller waits until the current frame ends (holds the master request pending), outputs the start bit after the frame has ended, and starts communication as the master.

Cautions 1. If the IEBus controller has lost in arbitration, issue the master request again by software.

In doing so, set (1) the MSTRQ bit at a timing other than that illustrated below.

Figure 18-11. Timing at Which MSTRQ Bit Cannot Be Set



2. When a master request has been sent and bus mastership acquired, do not set the MSTRQ, ENSLVTX, or ENSLVRX bit until the end of communication (i.e. the communication end flag (ISR.ENDTRNS bit) or frame end flag (ISR.ENDFRAM bit) is set (1)) as setting these flags disables interrupt request signal generation. However, these flags can be set if communication has been aborted.

# (c) Broadcast request flag (ALLRQ)...Bit 5

<Set/clear conditions>

Set: By software Clear: By software

Caution When requesting broadcast communication, always set (1) the ALLRQ bit, then the MSTRQ bit.

# (d) Slave transmission enable flag (ENSLVTX)...Bit 4

<Set/clear conditions>
Set: By software
Clear: By software

# Cautions 1. The ENSLVTX bit must be set before the parity bit in the control field is received.

- Clear the ENSLVTX bit (0) before setting the MSTRQ bit (1) when making a master request. This is to avoid transmission of the data of the DR register that tries master transmission if the controller loses in arbitration after master operation and if slave transmission is requested by the master.
- 3. When returning to an enabled state from a disabled state, transmission becomes valid from the next frame.
- 4. If control data (3H or 7H) for data/command writing is received when the ENSLVTX bit = 0, the NACK signal is returned by the acknowledge bit in the control field.
- 5. The status interrupt request signals (INTIE2, INTSTA) will be generated and communication continued when the control data of a slave status request is returned, even if the ENSLVTX bit = 0.

# (e) Slave reception enable flag (ENSLVRX)...Bit 3

<Set/clear conditions>
Set: By software
Clear: By software

#### Cautions 1. The ENSLVRX bit must be set before the parity bit in the control field is received.

- 2. While the CPU is busy with other processing, slave reception can be prevented by clearing the ENSLVRX bit (0). During individual communication, the NACK signal is returned in the control field and communication is completed. During broadcast communication, communication cannot be completed because the acknowledge bit is ignored. However, the IEBus controller does not respond to the broadcast communication and does not generate an interrupt request signal.
- 3. When returning to an enabled state from a disabled state, transmission becomes valid from the next frame.

# (2) IEBus power save register (PSR)

The PSR register is an 8-bit register that controls the internal clock and communication mode of the IEBus controller.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.



| ENCLK | Internal clock operation enable flag      |
|-------|-------------------------------------------|
| 0     | Stop internal clock of IEBus controller   |
| 1     | Enable internal clock of IEBus controller |

| IEMODE | IEBus communication mode setting flag |
|--------|---------------------------------------|
| 0      | Set communication mode 1              |
| 1      | Set communication mode 2              |

Cautions 1. Do not set the PSR register while communication is enabled (BCR.ENIEBUS bit = 1).

2. Be sure to clear bits 5 to 0 to 0.

# (3) IEBus slave status register (SSR)

The SSR register is an 8-bit register that indicates the communication status of the slave unit. After receiving a slave status transmission request from the master, read this register by software, and write a slave status to the DR register to transmit the slave status. At this time, the telegraph length is automatically set to "01H", so setting of the DLR register is not required (because it is preset by hardware).

Bits 6 and 7 indicate the highest mode supported by the unit, and are fixed to "10" (mode 2).

This register is read-only, in 8-bit or 1-bit units.

Reset input sets this register to 81H.

| After res | et: 81H R | Addre                                  | ss: FFFF                                | F362H   |   |          |        |        |  |  |  |
|-----------|-----------|----------------------------------------|-----------------------------------------|---------|---|----------|--------|--------|--|--|--|
|           | 7         | 6                                      | 5                                       | <4>     | 3 | <2>      | <1>    | <0>    |  |  |  |
| SSR       | 1         | 0                                      | 0                                       | STATSLV | 0 | STATLOCK | STATRX | STATTX |  |  |  |
|           |           |                                        |                                         |         |   |          |        |        |  |  |  |
|           | STATSLV   |                                        | Slave transmission status flag          |         |   |          |        |        |  |  |  |
|           | 0         | Slave tran                             | smission                                | stops   |   |          |        |        |  |  |  |
|           | 1         | Slave tran                             | smission                                | enabled |   |          |        |        |  |  |  |
|           |           |                                        |                                         |         |   |          |        |        |  |  |  |
|           | STATLOCK  |                                        | Lock status flag                        |         |   |          |        |        |  |  |  |
|           | 0         | Unlock sta                             | Unlock status                           |         |   |          |        |        |  |  |  |
|           | 1         | Lock statu                             | Lock status                             |         |   |          |        |        |  |  |  |
|           |           |                                        |                                         |         |   |          |        |        |  |  |  |
|           | STATRX    | DR register receive status             |                                         |         |   |          |        |        |  |  |  |
|           | 0         | Receive data not stored in DR register |                                         |         |   |          |        |        |  |  |  |
|           | 1         | Receive d                              | Receive data stored in DR register      |         |   |          |        |        |  |  |  |
|           |           |                                        |                                         |         |   |          |        |        |  |  |  |
|           | STATTX    | DR register transmit status            |                                         |         |   |          |        |        |  |  |  |
|           | 0         | Transmit o                             | Transmit data not stored in DR register |         |   |          |        |        |  |  |  |
|           | 1         | Transmit o                             | Transmit data stored in DR register     |         |   |          |        |        |  |  |  |

# (a) Slave transmission status flag (STATSLV)...Bit 4

Reflects the contents of the slave transmission enable flag (BCR.ENSLVTX bit).

# (b) Lock status flag (STATLOCK)...Bit 2

Reflects the contents of the lock flag (USR.LOCK bit).

# (c) DR register reception status (STATRX)...Bit 1

This flag indicates the DR register reception state.

# (d) DR register transmission status (STATTX)...Bit 0

This flag indicates the DR register transmission state.

# (4) IEBus unit status register (USR)

The USR register is an 8-bit register that indicates the IEBus unit status.

This register is read-only, in 8-bit or 1-bit units.

Reset input clears this register to 00H.

| After reset | :: 00H R | Addres                           | s: FFFFF3                       | 363H        |            |         |   |   |  |  |  |
|-------------|----------|----------------------------------|---------------------------------|-------------|------------|---------|---|---|--|--|--|
|             | 7        | <6>                              | <5>                             | <4>         | <3>        | 2       | 1 | 0 |  |  |  |
| USR         | 0        | SLVRQ                            | ARBIT                           | ALLTRNS     | ACK        | LOCK    | 0 | 0 |  |  |  |
|             |          |                                  |                                 |             |            |         |   |   |  |  |  |
|             | SLVRQ    |                                  | Slave request flag              |             |            |         |   |   |  |  |  |
|             | 0        | No reque                         | No request from master to slave |             |            |         |   |   |  |  |  |
|             | 1        | Request t                        | rom maste                       | er to slave |            |         |   |   |  |  |  |
|             |          |                                  |                                 |             |            |         |   |   |  |  |  |
|             | ARBIT    |                                  |                                 | Arbitr      | ation resu | lt flag |   |   |  |  |  |
|             | 0        | Arbitration                      | Arbitration win                 |             |            |         |   |   |  |  |  |
|             | 1        | Arbitration                      | Arbitration loss                |             |            |         |   |   |  |  |  |
|             |          |                                  |                                 |             |            |         |   |   |  |  |  |
|             | ALLTRNS  | Broadcast communication flag     |                                 |             |            |         |   |   |  |  |  |
|             | 0        | Individual communication status  |                                 |             |            |         |   |   |  |  |  |
|             | 1        | 1 Broadcast communication status |                                 |             |            |         |   |   |  |  |  |
|             |          |                                  |                                 |             |            |         |   |   |  |  |  |
|             | ACK      | Acknowledge transmission flag    |                                 |             |            |         |   |   |  |  |  |
|             | 0        |                                  |                                 |             |            |         |   |   |  |  |  |
|             | 1        | 1 ACK signal transmitted         |                                 |             |            |         |   |   |  |  |  |
|             |          |                                  |                                 |             |            |         |   |   |  |  |  |
|             | LOCK     | Lock status flag                 |                                 |             |            |         |   |   |  |  |  |
|             | 0        |                                  | Unit unlocked                   |             |            |         |   |   |  |  |  |
|             | 1        | Unit locke                       | ed                              |             |            |         |   |   |  |  |  |

# (a) Slave request flag (SLVRQ)...Bit 6

A flag indicating whether there has been a slave request from the master.

<Set/clear conditions>

Set: When the unit is requested as a slave (if the condition in Table 18-13 Slave Request Condition (SLVRQ Bit Setting Condition) is satisfied), this flag is set (1) by hardware when the acknowledge period of the slave address field starts.

Clear: This flag is cleared (0) by hardware when the unit is not requested as a slave (if the condition in Table 18-13 Slave Request Condition (SLVRQ Bit Setting Condition) is not satisfied). The reset timing is the same as the set timing. If the unit is requested as a slave immediately after communication has been correctly received (when the SLVRQ bit = 1), and if a parity error occurs in the slave address field for that communication, the flag is not cleared.

| atus of Unit | Received Master<br>Address | Communication Mode | Received Slave Add |
|--------------|----------------------------|--------------------|--------------------|
|              |                            |                    |                    |

Table 18-13. Slave Request Condition (SLVRQ Bit Setting Condition)

Sta ldress Not locked don't care Individual **UAR** register matching Broadcast Group matching **FFFH UAR** register matching Locked Locked master matching Individual Broadcast Group matching **FFFH** 

Caution If a unit other than the locked master communicates with the unit while the unit is locked, the SLVRQ bit is not set but the ACK signal is returned to the slave address field. This is because communication must be continued, even if a unit other than the locked master returns the signal, if the control data is a slave status request.

## (b) Arbitration result flag (ARBIT)...Bit 5

A flag that indicates the result of arbitration.

<Set/clear conditions>

This flag is set (1) when the data output by the IEBus unit during the arbitration period does not match the bus line data.

Clear: This flag is cleared (0) by the start bit timing.

Cautions 1. The timing at which the arbitration result flag (ARBIT bit) is cleared differs depending on whether the unit outputs a start bit.

- If start bit is output: The flag is cleared at the output start timing.
- . If start bit is not output: The flag is cleared at the detection timing of the start bit (approx. 160  $\mu$ s (mode 1, at 6.29 MHz) after output)
- 2. The flag is cleared (0) at the detection timing of the start bit if the other unit outputs the start bit earlier and the unit does not output the start bit after the master request.

## (c) Broadcast communication flag (ALLTRNS)...Bit 4

Flag indicating whether the unit is performing broadcast communication. The contents of the flag are updated in the broadcast field of each frame.

Except for initialization (reset) by system reset, the set/clear conditions vary depending on the receive data of the broadcast field bit.

<Set/clear conditions>

Set: When "broadcast" is received by the broadcast field

Clear: When "individual" is received by the broadcast field, or upon the input of a system reset.

Caution The broadcast flag is updated regardless of whether IEBus is the communication target or not.

Figure 18-12. Example of Broadcast Communication Flag Operation



# (d) Acknowledge transmission flag (ACK)...Bit 3

A flag that indicates whether the ACK signal has been transmitted in the acknowledge bit period of the acknowledge bit field when IEBus is the receiving unit. The contents of the flag are updated in the acknowledge bit period of each frame. However, if the internal circuit is initialized by the occurrence of a parity error, etc., the contents are not updated in the acknowledge bit period of that field.

## (e) Lock status flag (LOCK)...Bit 2

A flag that indicates whether the unit is locked.

<Set/clear conditions>

Set: This flag is set (1) when the communication end flag (ISR.ENDTRNS bit) goes low and the frame end flag (ISR.ENDFRAM bit) goes high after receipt of a lock specification (3H, 6H, AH, BH) in the control field.

Clear: When the communication enable flag (BCR.ENIEBUS bit) is cleared (0).

When the communication end flag (ENDTRNS bit) is set (1) after receipt of a lock release (3H, 6H, AH, BH) in the control field.

Caution Lock specification/release is not possible in broadcast communication. In the lock status, individual communication from a unit other than the one that requests locking is not acknowledged. However, even communication from a unit other than the one that requests locking is acknowledged as long as the communication is a slave status request.

# (5) IEBus interrupt status register (ISR)

The ISR register indicates the interrupt source when IEBus issues an interrupt request signal. This register is read to generate an interrupt request signal, after which the specified interrupt processing is carried out.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.



| IEERR | Communication error flag (during communication) |
|-------|-------------------------------------------------|
| 0     | No communication error                          |
| 1     | Communication error                             |

| STARTF | Start interrupt flag                         |
|--------|----------------------------------------------|
| 0      | Start interrupt request signal did not occur |
| 1      | Start interrupt request signal occurred      |

| STATUSF | Status transmission flag (slave)                                                |
|---------|---------------------------------------------------------------------------------|
| 0       | No slave status/lock address (higher 4 bits, lower 8 bits) transmission request |
| 1       | Slave status/lock address (higher 4 bits, lower 8 bits) transmission request    |

| ENDTRNS | Communication end flag                                                                                       |
|---------|--------------------------------------------------------------------------------------------------------------|
| 0       | Communication does not end after the number of bytes set in the telegraph length field have been transferred |
| 1       | Communication ends after the number of bytes set in the telegraph length field have been transferred         |

| ENDFRAM | Frame end flag                                                   |
|---------|------------------------------------------------------------------|
| 0       | The frame (transfer of the maximum number of bytes) does not end |
| 1       | The frame (transfer of the maximum number of bytes) ends         |

**Notes 1.** Only the IEERR bit can be written, and only to 0 (i.e., the IEERR bit can only be cleared). The IEERR bit is not set (1) even if 1 is written to it.

**2.** Mode 1: 32 bytes Mode 2: 128 bytes

# (a) Communication error flag (IEERR)...Bit 6

A flag that indicates a communication error has occurred. When a communication error occurs, the INTIE2 and INTERR interrupt request signals are generated.

<Set/clear conditions>

Set: The flag is set (1) if a timing error, parity error (except in the data field), NACK reception error (except in the data field), underrun error, overrun error (that occurs during broadcast communication reception), or write error occurs.

Clear: By software

# (b) Start interrupt flag (STARTF)...Bit 5

A flag that indicates the start interrupt. When a start interrupt occurs, the INTIE2 and INTSTA interrupt request signals are generated.

<Set/clear conditions>

Set: This flag is set (1) in the slave address field, upon a master request.

When IEBus is a slave unit, this flag is set (1) upon a request from the master (only if it was a slave request in the locked state from the unit requesting a lock).

Clear: This flag is cleared (0) if the status transmission interrupt, communication end interrupt, frame end interrupt, or INTIE1 interrupt request signal is generated.

## (c) Status transmission flag (STATUSF)...Bit 4

A flag that indicates the master requested transmission of the slave status and lock address (higher 4 bits and lower 8 bits) when the controller was serving as a slave.

<Set/clear conditions>

Set: This flag is set (1) when 0H, 4H, 5H, or 6H is received in the control field from the master when the IEBus is a slave unit.

Clear: This flag is cleared (0) if the start interrupt, communication end interrupt, frame end interrupt, or INTIE1 interrupt request signal is generated.

# (d) Communication end flag (ENDTRANS)...Bit 3

A flag that indicates whether communication ends after the number of bytes set in the telegraph length field have been transferred. When a communication error occurs, the INTIE2 and INTSTA interrupt request signals are generated.

<Set/clear conditions>

Set: This flag is set (1) when the count value of the SCR register is 00H.

Clear: This flag is cleared (0) if the start interrupt, status transmission interrupt, frame end interrupt (if the communication end interrupt does not occur), or INTIE1 interrupt request signal is generated.

# (e) Frame end flag (ENDFRAM)...Bit 2

A flag that indicates whether communication ends after the maximum number of bytes (mode 1: 32 bytes, mode 2: 128 bytes) have been transferred.

<Set/clear conditions>

Set: This flag is set (1) when the count value of the CCR register is 00H.

Clear: This flag is cleared (0) if the start interrupt, status transmission interrupt, communication end interrupt (if the frame end interrupt does not occur), or INTIE1 interrupt request signal is generated

- Cautions 1. If both the CCR and SCR registers are cleared to 00H, the ENDTRNS and ENDFRAM bits are set (1) at the same time.
  - If the last data field is the NACK signal when the maximum number of transmitted bytes is reached as a result of retransmitting the data, the ENDFRAM bit and IEERR (NACK reception error) bit are set at the same time.

# (6) IEBus error status register (ESR)

The ESR register indicates the source of the communication error interrupt request signal of IEBus. Each bit of this register is set (1) as soon as the communication error flag (ISR.IEERR bit) is set (1). The source of a communication error, if any, can be identified by checking the contents of this register.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

| After rese | t: 00H R/ | W Addr | ess: FFFFF | 365H |      |      |   |        |
|------------|-----------|--------|------------|------|------|------|---|--------|
|            | <7>       | <6>    | <5>        | <4>  | <3>  | <2>  | 1 | <0>    |
| ESR        | TERR      | PERR   | NERR       | UERR | OERR | WERR | 0 | DEFLAG |
| •          |           |        |            |      |      |      |   |        |

| TERR | Timing error occurrence flag |
|------|------------------------------|
| 0    | Timing error did not occur   |
| 1    | Timing error occurred        |

| PERR | Parity error occurrence flag |
|------|------------------------------|
| 0    | Parity error did not occur   |
| 1    | Parity error occurred        |

| NERR | NACK reception error occurrence flag |
|------|--------------------------------------|
| 0    | NACK reception error does not occur  |
| 1    | NACK reception error occurred        |

| UERR | Underrun error occurrence flag |
|------|--------------------------------|
| 0    | Underrun error did not occur   |
| 1    | Underrun error occurred        |

| OERR | Overrun error occurrence flag |
|------|-------------------------------|
| 0    | Overrun error did not occur   |
| 1    | Overrun error occurred        |

| WERR | Write error occurrence flag |  |
|------|-----------------------------|--|
| 0    | Write error did not occur   |  |
| 1    | Write error occurred        |  |

| DEFLAG | Third party error occurrence flag                                |  |
|--------|------------------------------------------------------------------|--|
| 0      | Error occurred during communication with unit                    |  |
| 1      | Error occurred during communication with station other than unit |  |

# Cautions 1. Each bit can only be cleared (0). It cannot be set (1) even if 1 is written to it.

- 2. The value of the ESR register is updated when an error occurs. If the ESR register is read at this time, however, an undefined value is read. It is recommended to read the ESR register in error interrupt servicing.
- If a communication error occurs, the IEBus controller returns to the default status and
  makes preparation for communication. If communication is started without the error
  corrected, the error flag accumulates the error. Correct the error before the next
  communication is started.

# (a) Timing error occurrence flag (TERR)...Bit 7

<Set/clear conditions>

Set: This flag is set (1) if a timing error occurs.

Clear: By software

A timing error occurs if the high-/low-level width of the communication bit is not the defined value. The defined value of the high- and low-level width is set to the bit processing block and monitored by the internal timer. If a timing error occurs, the INTERR and INTIE2 interrupt request signals are generated.

# (b) Parity error occurrence flag (PERR)...Bit 6

<Set/clear conditions>

Set: This flag is set (1) if a parity error occurs.

Clear: By software

A parity error occurs if the parity generated in each field does not match the received parity while the controller is serving as a receiver unit. If the parity does not match in the data field during individual communication, however, the NACK signal is returned and retransmission of data is requested. Therefore, the parity error does not occur.

Table 18-14. Operation if Parity Does Not Match

| Field                  | Communication Mode   | Operation if Parity Does Not Match                    |
|------------------------|----------------------|-------------------------------------------------------|
| Master address field   | Individual/broadcast | Parity error occurs.                                  |
| Slave address field    | Individual/broadcast | Parity error occurs.                                  |
| Control data field     | Individual/broadcast | Parity error occurs.                                  |
| Telegraph length field | Individual/broadcast | Parity error occurs.                                  |
| Data field             | Individual           | Retransmission is requested by returning NACK signal. |
|                        | Broadcast            | Parity error occurs.                                  |

#### (c) NACK reception error occurrence flag (NERR)...Bit 5

<Set/clear conditions>

Set: This flag is set (1) if a NACK reception error occurs.

Clear: By software

A NACK reception error occurs if the NACK signal is received during the acknowledge bit period of the slave address field, control data field, or telegraph length field during individual communication, regardless of whether the controller is operating as the master or a slave. If the NACK signal is received during the acknowledge bit period of the data field, a NACK reception error does not occur because data is retransmitted. If the NACK signal is received during the acknowledge period of the last data field when the maximum number of transfer bytes is reached, the NACK reception error occurs.

The NACK reception error does not occur during broadcast communication because the  $\overline{ACK}/NACK$  signal is not identified.

The NACK reception error does not occur during third-party communication because only the timing/parity error is detected as an error.

# (d) Underrun error occurrence flag (UERR) ... Bit 4

<Set/clear conditions>

Set: This flag is set (1) if an underrun error occurs.

Clear: By software

An underrun error occurs if the next data is not transmitted to the DR register in time before the  $\overline{ACK}$  signal is received. If the NACK signal is received during individual communication and during the acknowledge bit period, the underrun error does not occur because the data is retransmitted.

Figure 18-13. Timing of Underrun Error Occurrence



### (e) Overrun error occurrence flag (OERR) ... Bit 3

<Set/clear conditions>

Set: This flag is set (1) if an overrun error occurs.

Clear: By software

If 1-byte data is stored in the DR register while the IEBus controller serves as a receiver unit, the data request interrupt request signal (INTIE1) is generated, and the DR register is read by means of DMA or by software. If this reading is delayed and the next data is received, an overrun error occurs.

- Cautions 1. If the DR register is not read and the number of retransmitted data reaches the maximum number of transmitted bytes (32 bytes) after the overrun error has occurred, the frame end interrupt request signal (INTSTA or INTIE2) occurs. The overrun status is maintained until the DR register is read, even after the frame has ended.
  - 2. The overrun status is cleared only when the DR register is read and when the system is reset. Therefore, be sure to read the DR register in the communication error interrupt processing program.
  - 3. The next data cannot be transmitted in the overrun status if it is 2 bytes or more. Because the data request interrupt request signal (INTIE1) does not occur, the transmit data cannot be set and an underrun error occurs. Therefore, be sure to execute transmission after clearing the overrun status.

Remark

During individual communication reception, the NACK signal is returned during the acknowledge bit period of the next data. In response, the transmitter unit retransmits data. Therefore, the CCR register is decremented but the SCR register is not decremented.

During broadcast communication reception, the communication error interrupt request signal (INTIE2) is generated and reception is stopped. At this time, the DR register is not updated. The INTIE1 signal is not generated. The STATRX bit of the SSR register is held set (to 1). The overrun status is cleared when data is received after the DR register has been read.

Figure 18-14. Timing of Overrun Error Occurrence



### (f) Write error occurrence flag (WERR) ... Bit 2

<Set/clear conditions>

Set: This flag is set (1) if a write error occurs.

Clear: By software

A write error occurs if the data written to the DR register is not transmitted in the data field during unit transmission. The timing of occurrence of a write error is illustrated below.

Figure 18-15. Timing of Write Error Occurrence



### (g) Third-party error occurrence flag (DEFLAG)...Bit 0

<Set/clear conditions>

Set: This flag is set (1) if a timing error or parity error occurs during communication regardless of the unit (during communication between third parties).

Clear: By software

Caution If an error occurs before the third-party communication starts even when the slave address field does not match that of the unit (for example, if the NACK signal is received when the received address does not match that of the unit in the slave address field (if the NERR bit is set (1))), the DEFLAG bit is not set (1).

**Remark** Communication between third parties may take place in the following two cases.

- <1> If the received address in the slave address field does not match that of the unit (during individual communication: Matching with UAR register, during broadcast communication: Matching with group or FFFH) and if communication continues after the ACK signal has been received, the unit monitors that communication.
- <2> If the unit cannot respond to the received control data in the control field during broadcast communication and if communication continues, the unit monitors that communication. For example, this happens when the unit receives control data FH from master during broadcast communication but the slave reception enable flag of the unit is disabled (BCR.ENSLVRX bit = 0) (the NACK signal is returned and communication ends during individual communication).

### (7) IEBus unit address register (UAR)

The UAR register sets the unit address of an IEBus unit. This register must always be set before starting communication.

Sets the unit address (12 bits) to bits 11 to 0.

This register can be read or written in 16-bit units.

Reset input clears this register to 0000H.



Caution Do not set the UAR register while communication is enabled (BCR.ENIEBUS bit = 1).

### (8) IEBus slave address register (SAR)

During a master request, the value of this register is reflected in the value of the transmit data in the slave address field. The SAR register must always be set before starting communication.

The SAR register sets the slave address (12 bits) to bits 11 to 0.

This register can be read or written in 16-bit units.

Reset input clears this register to 0000H.



Caution Do not set the SAR register while communication is enabled (BCR.ENIEBUS bit = 1).

#### (9) IEBus partner address register (PAR)

The PAR register stores the master address value received in the master address field regardless of whether the unit is operating as the master or a slave.

If a request "4H" to read the lock address (lower 8 bits) is received from the master, read the value of this register by software, and write the data of the lower 8 bits to the DR register.

If a request "5H" to read the lock address (higher 4 bits) is received from the master, read the value of this register by software and write the data of bits 11 to 8 to the higher 4 bits of the DR register.

The PAR register sets the partner address (12 bits) to bits 11 to 0.

This register is read-only, in 16-bit units.

Reset input clears this register to 0000H.



Caution The PAR register stores an address value if the parity is correct and the unit is not locked when the parity period of the master address field expires. If the PAR register is read at this time, an undefined value is read.

### (10) IEBus receive slave address register (RSA)

The RSA register stores the slave address value received in the slave address field regardless of whether the unit is operating as the master or a slave.

This register is read-only, in 16-bit units.

Reset input clears this register to 0000H.



Caution The RSA register stores an address value if the parity is correct and the unit is not locked when the parity period of the slave address field expires. If the RSA register is read at this time, an undefined value is read.

# (11) IEBus control data register (CDR)

The CDR register can be read or written in 8-bit units.

Reset input clears this register to 00H.

**Remark** The CDR register consists of a write register and a read register and data written to the CDR register cannot be read as is. The data read from this register is the data received by IEBus communication.

#### (a) When master unit

The data of the lower 4 bits is reflected in the data transmitted in the control field. During a master request, the CDR register must be set in advance before starting communication.

#### (b) When slave unit

The data received in the control field is written to the lower 4 bits.

When the status transmission flag (ISR.STATUSF bit) is set (1), an interrupt request signal (INTIE2) is issued, and each processing should be performed by software, according to the value of the lower 4 bits of the CDR register.

| After rese | t: 00H | R/V | V Addre | ess: FFFFF | 36EH |     |        |        |        |
|------------|--------|-----|---------|------------|------|-----|--------|--------|--------|
|            | 7      |     | 6       | 5          | 4    | 3   | 2      | 1      | 0      |
| CDR        | 0      |     | 0       | 0          | 0    | MOD | SELCL2 | SELCL1 | SELCL0 |

| MOD | SELCL2 | SELCL1 | SELCL0 | Function                         |
|-----|--------|--------|--------|----------------------------------|
| 0   | 0      | 0      | 0      | Read slave status                |
| 0   | 0      | 0      | 1      | Undefined                        |
| 0   | 0      | 1      | 0      | Undefined                        |
| 0   | 0      | 1      | 1      | Read data and lock               |
| 0   | 1      | 0      | 0      | Read lock address (lower 8 bits) |
| 0   | 1      | 0      | 1      | Read lock address (lower 4 bits) |
| 0   | 1      | 1      | 0      | Read slave status and unlock     |
| 0   | 1      | 1      | 1      | Read data                        |
| 1   | 0      | 0      | 0      | Undefined                        |
| 1   | 0      | 0      | 1      | Undefined                        |
| 1   | 0      | 1      | 0      | Write command and lock           |
| 1   | 0      | 1      | 1      | Write data and lock              |
| 1   | 1      | 0      | 0      | Undefined                        |
| 1   | 1      | 0      | 1      | Undefined                        |
| 1   | 1      | 1      | 0      | Write command                    |
| 1   | 1      | 1      | 1      | Write data                       |

- Cautions 1. Because the slave unit must judge whether the received data is a "command" or "data", read the value of the CDR register after completing communication.
  - 2. If the master unit sets an undefined value, the slave unit returns the NACK signal and communication is aborted. During broadcast communication, the master unit ignores the acknowledge bit and continues communication. Therefore, do not set an undefined value.

#### (c) Slave status return operation

When IEBus receives a request to transfer from master to slave status or a lock address request (control data: 0H, 6H), whether the  $\overline{ACK}/NACK$  signal in the control field is returned or not depends on the status of the IEBus unit.

- (1) If 0H or 6H control data was received in the unlocked state
- (2) If 4H or 5H control data was received in the unlocked state
- (3) If 0H, 4H, 5H or 6H control data was received in the locked state from the unit that sent the lock request
- (4) If 0H, 4H, or 5H control data was received in the locked state from other than the unit that sent the lock request
- (5) If 6H control data was received in the locked state from other than the unit that sent the lock request
- $\rightarrow \overline{ACK}$  signal returned
- → NACK signal returned
- $\rightarrow \overline{ACK}$  signal returned
- $\rightarrow \overline{ACK}$  signal returned
- → NACK signal returned

In all of the above cases, the acknowledgment of a slave status or lock request will cause the STATUSF bit to be set (1) and the status interrupt signal (INTIE2, INTSTA) to be generated. The generation timing is at the end of the control field parity bit (at the start of the acknowledge bit). However, if NACK is returned, a NACK receive error is generated after the acknowledge bit, and communication is terminated.

Figure 18-16. Interrupt Request Signal Generation Timing (for (1), (3), and (4))





Figure 18-17. Interrupt Request Signal Generation Timing (for (2) and (5))

Because in (4) and (5) the communication was from other than the unit that sent the lock request while IEBus was in the locked state, the start or communication end interrupt request signals (INTIE2, INTSTA) are not generated, even if the IEBus unit is the communication target. The STATUSF bit is set (1) and the status interrupt request signals (INTIE2, INTSTA) are generated, however, if a slave status or lock address request is acknowledged. Note that even if the same control data is received while IEBus is in the locked state, the interrupt generation timing for INTIE2 and INTSTA differs depending on whether the master unit (3) or another unit (4) is requesting the locked state.

Figure 18-18. Timing of INTIE2 and INTSTA Interrupt Request Signal Generation in Locked State (for (4) and (5))



Figure 18-19. Timing of INTIE2 and INTSTA Interrupt Request Signal Generation in Locked State (for (3))



### (12) IEBus telegraph length register (DLR)

The DLR register can be read or written in 8-bit units.

Reset input sets this register to 01H.

### (a) When transmission unit ... Master transmission, slave transmission

The data of this register is reflected in the data transmitted in the telegraph length field and indicates the number of bytes of the transmit data. The DLR register must be set in advance before transmission.

### (b) When reception unit ... Master reception, slave reception

The receive data in the telegraph length field transmitted from the transmission unit is written to this register.

**Remark** The DLR register consists of a write register and a read register. Consequently, data written to this register cannot be read as is. The data that can be read is the data received during IEBus communication.



|   | Bit |   |    |   |   |   |   | Setting | Remaining number of      |
|---|-----|---|----|---|---|---|---|---------|--------------------------|
| 7 | 6   | 5 | 4  | 3 | 2 | 1 | 0 | value   | communication data bytes |
| 0 | 0   | 0 | 0  | 0 | 0 | 0 | 1 | 01H     | 1 byte                   |
| 0 | 0   | 0 | 0  | 0 | 0 | 1 | 0 | 02H     | 2 bytes                  |
| : | :   |   | •• |   |   | : |   |         | :                        |
| 0 | 0   | 1 | 0  | 0 | 0 | 0 | 0 | 20H     | 32 bytes                 |
| : | :   |   | •• |   |   | : |   |         | :                        |
| 1 | 1   | 1 | 1  | 1 | 1 | 1 | 1 | FFH     | 255 bytes                |
| 0 | 0   | 0 | 0  | 0 | 0 | 0 | 0 | 00H     | 256 bytes                |

- Cautions 1. When the master issues a request (0H, 4H, 5H, or 6H) for transmission of a slave status or a lock address (higher 4 bits and lower 8 bits), 01H is transmitted as the telegraph length regardless of the contents of the DLR register. It is therefore not necessary to set the DLR register by software.
  - 2. When the IEBus controller serves as a receiver unit, the DLR register stores a telegraph length if the value of the parity bit of the telegraph length field is correct. If the DLR register is read at this time, an undefined value is read.

### (13) IEBus data register (DR)

The DR register sets the communication data (8 bits) to bits 7 to 0.

This register can be read or written in 8-bit units.

Reset input clears this register to 00H.

**Remark** The DR register consists of a write register and a read register. Consequently, data written to this register cannot be read as is. The data that can be read is the data received during IEBus communication.

#### (a) When transmission unit

The data (1 byte) written to the DR register is stored in the transmit shift register of the IEBus interface block. It is then output from the most significant bit, and an interrupt request signal (INTIE1) is generated each time 1 byte has been transmitted. If the NACK signal is received after 1-byte data has been transferred during individual transfer, data is not transferred from the DR register to the transmit shift register, and the same data is retransmitted. At this time, INTIE1 signal is not generated.

INTIE1 signal is generated when the transmit shift register stores the DR register value. However, when the last byte and 32nd byte (the last byte of 1 communication frame) is stored in the transmit shift register, the INTIE1 signal is not generated.

### (b) When reception unit

One byte of the data received by the receive shift register of the IEBus interface block is stored in this register.

Each time 1 byte has been correctly received, an interrupt request signal (INTIE1) is generated.

When transmit/receive data is transferred to and from the DR register, using DMA can reduce the CPU processing load.



- Cautions 1. If the next data is not in time while the transmission unit is set, an underrun occurs, and a communication error interrupt request signal (INTIE2, INTERR) occurs, stopping transmission.
  - 2. If data is not read in time before the next data is read when the IEBus controller functions as a receiver unit during individual communication reception, the NACK signal is returned by the acknowledge bit of the data field, requesting the master to retransmit the data. If the DR register is not read after the data has reached the maximum number of transmit bytes, however, the frame end interrupt request signal (INTIE2, INTSTA) and NACK reception error interrupt request signal (INTIE2, INTERR) are generated at the same time.
  - If data is not read in time before the next data is received when the IEBus controller functions as a receiver unit during broadcast communication reception, an overrun error occurs and the communication error interrupt request signal (INTIE2, INTERR) is generated.
  - 4. When the IEBus controller serves as a receiver unit, the DR register stores receive data if the value of the parity bit of the data field is correct. If the DR register is read at this time, an undefined value is read.

### (14) IEBus field status register (FSR)

The FSR register stores the status of the field status of the IEBus controller if an interrupt request signal (INTIE1, INTIE2, INTSTA, or INTERR) is generated.

This register is read-only, in 8-bit units.

Reset input clears this register to 00H.

- Cautions 1. If an interrupt request signal is generated during communication between third parties, the FSR register is cleared to 00H. However, because only an interrupt request signal that is generated if an error occurs is generated during communication between third parties, the error can be identified as that during communication between third parties, by reading third-party error flag (ESR.DEFLAG bit).
  - 2. The FSR register updates the status information when an interrupt request signal is generated. If the FSR register is read at this time, however, an undefined value is read.
  - 3. If another interrupt request signal is generated before the FSR register is read, the status information when the preceding interrupt occurred is updated by the status information when the new interrupt occurs.
  - 4. Use the FSR register only for problem analysis; do not use it with the actual software.



Remark For the explanation of the FSTATE1 and FSTATE0 bits, see Table 18-15 Field Status.

Table 18-15. Field Status

| Field Status               |                  | Explanation            |                        |  |
|----------------------------|------------------|------------------------|------------------------|--|
|                            | Master/Slave     | Field                  | Transmission/Reception |  |
| Slave transmission status  | Slave operation  | Start field            | Reception              |  |
| FSR = 00H                  |                  | Master address field   |                        |  |
|                            |                  | Slave address field    |                        |  |
|                            |                  | Control data field     |                        |  |
|                            |                  | Telegraph length field |                        |  |
|                            |                  | Data field             |                        |  |
| Slave transmission status  | Slave operation  | Telegraph length field | Transmission           |  |
| FSR = 01H                  |                  | Data field             |                        |  |
| Master reception status    | Master operation | Telegraph length field | Reception              |  |
| FSR = 02H                  |                  | Data field             |                        |  |
| Master transmission status | Master operation | Start field            | Transmission           |  |
| FSR = 03H                  |                  | Master address field   |                        |  |
|                            |                  | Slave address field    |                        |  |
|                            |                  | Control data field     |                        |  |
|                            |                  | Telegraph length field |                        |  |
|                            |                  | Data field             |                        |  |

### (15) IEBus success count register (SCR)

The SCR register indicates the number of remaining communication bytes.

The count value of the counter in which the value set by the DLR register is decremented by the  $\overline{ACK}$  signal in the data field is read from this register. When the count value has reached "00H", the communication end flag (ISR.ENDTRNS bit) is set (1). This register is read-only, in 8-bit units. Reset input clears this register to 00H.



|   | Bit |   |   |   |   |   |   | Setting | Remaining number of                                               |
|---|-----|---|---|---|---|---|---|---------|-------------------------------------------------------------------|
| 7 | 6   | 5 | 4 | 3 | 2 | 1 | 0 | value   | communication data bytes                                          |
| 0 | 0   | 0 | 0 | 0 | 0 | 0 | 1 | 01H     | 1 byte                                                            |
| 0 | 0   | 0 | 0 | 0 | 0 | 1 | 0 | 02H     | 2 bytes                                                           |
| : | :   | : | : | : | : | : | : | :       | :                                                                 |
| 0 | 0   | 1 | 0 | 0 | 0 | 0 | 0 | 20H     | 32 bytes                                                          |
| : | :   | : | : | : | : | : | : | :       | :                                                                 |
| 1 | 1   | 1 | 1 | 1 | 1 | 1 | 1 | FFH     | 255 bytes                                                         |
| 0 | 0   | 0 | 0 | 0 | 0 | 0 | 0 | 00H     | 0 bytes (end of<br>communication) or 256<br>bytes <sup>Note</sup> |

**Note** The actual counter consists of 9 bits. When "00H" is read, it cannot be judged whether the remaining number of communication data bytes is 0 (end of communication) or 256. Therefore, either the communication end flag (ENDTRNS bit) is used, or if "00H" is read when the first interrupt occurs at the beginning of communication, the remaining number of communication data bytes is judged to be 256.

Caution The SCR register is updated when the parity period of the telegraph field expires and when the  $\overline{ACK}$  signal of the data field is received. If the SCR register is read at this time, however, an undefined value is read.

### (16) IEBus communication count register (CCR)

The CCR register indicates the number of bytes remaining from the communication byte number specified by the communication mode.

This register indicates the number of transfer bytes.

The maximum number of transmitted bytes per frame defined in each mode (mode 1: 32 bytes, mode 2: 128 bytes) is preset to this register. The count value of the counter that is decremented during the acknowledge bit period of the data field regardless of the  $\overline{ACK}/NACK$  signal is read from this register. Whereas the SCR register is decremented during normal communication ( $\overline{ACK}$  signal), the CCR register is decremented when 1 byte has been communicated, regardless of whether the signal is  $\overline{ACK}$  or NACK. When the count value has reached "00H", the frame end flag (ISR.ENDFRAM bit) is set (1).

The preset value of the maximum number of transmitted bytes per frame is 20H (32 bytes) in mode 1 and 80H (128 bytes) in mode 2.

This register is read-only, in 8-bit units.

Reset input sets this register to 20H.

| After rese | t: 20H R | Addr | ess: FFFFF | -373H |   |   |   |   |
|------------|----------|------|------------|-------|---|---|---|---|
| _          | 7        | 6    | 5          | 4     | 3 | 2 | 1 | 0 |
| CCR        |          |      |            |       |   |   |   |   |

Caution The maximum number of transmit bytes is preset to the CCR register when the start bit is transmitted or received, and the register is decremented when the parity period of the data

# (17) IEBus clock select register (OCKS2)

The OCKS2 register selects the clock of IEBus. The main clock frequencies that can be used are shown below. No other main clock frequencies can be used.

This register can be read or written in 8-bit units.

Reset input clears this register to 00H.

- 6.0 MHz/6.291456 MHz (6.29 MHz)
- 12.0 MHz/12.582912 MHz (12.58 MHz)
- 18.0 MHz/18.874368 MHz (18.87 MHz)
- 24.0 MHz/25.165824 MHz (25.16 MHz)
- 30.0 MHz/31.457280 MHz (31.45 MHz)

| After res | et: 00H | R/W | Address: F | FFFF348H | 1       |   |        |        |
|-----------|---------|-----|------------|----------|---------|---|--------|--------|
|           | 7       | 6   | 5          | 4        | 3       | 2 | 1      | 0      |
| OCKS2     | 0       | 0   | 0          | OCKSEN2  | OCKSTH2 | 0 | OCKS21 | OCKS20 |
|           |         |     |            |          |         |   |        |        |

|   | OCKSEN2 IEBus clock operation specification |                               |  |  |  |  |
|---|---------------------------------------------|-------------------------------|--|--|--|--|
| ſ | 0                                           | IEBus clock operation stops   |  |  |  |  |
|   | 1                                           | IEBus clock operation enabled |  |  |  |  |

| OCKSTH2          | OCKS21 | OCKS20 | IEBus clock selection                                           |  |  |
|------------------|--------|--------|-----------------------------------------------------------------|--|--|
| 0                | 0      | 0      | fxx/2 (when fxx = 12.0 MHz or fxx = 12.58 MHz)                  |  |  |
| 0                | 0      | 1      | fxx/3 (when fxx = 18.0 MHz or fxx = 18.87 MHz)                  |  |  |
| 1                | 1      | 0      | fxx/4 (when fxx = 24.0 MHz or fxx = 25.16 MHz)                  |  |  |
| 0                | 1      | 1      | fxx/5 (when fxx = 30.0 MHz or fxx = 31.45 MHz)                  |  |  |
| 1                | 0      | 0      | fxx (when fxx = $6.0 \text{ MHz}$ or fxx = $6.29 \text{ MHz}$ ) |  |  |
| Other than above |        |        | Setting prohibited                                              |  |  |

# 18.4 Interrupt Operations of IEBus Controller

# 18.4.1 Interrupt control block

Interrupt request signal

<1> Communication error **IEERR** (i) Timing error: **TERR** (ii) Parity error: **PERR** (iii) NACK receive error: **NERR** (iv) Underrun error: **UERR** (v) Overrun error: **OERR** (vi) Write error: **WERR** <2> Start interrupt **STARTF** <3> Status communication **STATUSF** <4> End of communication **ENDTRNS ENDFRAM** <5> End of frame **STATTX** <6> Transmit data write request <7> Receive data read request **STATRX** 

A communication error <1> occurs if any of the above error sources (i) to (vi) is generated.

These error sources are assigned to the error status register (ESR) (see **Table 18-18 Communication Error Source Processing List**).

The above interrupt signals <1> to <5> are assigned to the ISR register (see **Table 18-17 Interrupt Source List**). The configuration of the interrupt control block is illustrated below.



Figure 18-20. Configuration of Interrupt Control Block

- Cautions 1. The logical sum (OR) output of the STATRX and STATTX signals is treated as an interrupt request signal (INTIE1).
  - 2. The logical sum (OR) output of the TERR, PERR, NERR, UERR, OERR, and WERR signals is treated as a communication error (IEERR) or an interrupt request signal (INTERR).
  - 3. The logical sum (OR) output of the STARTF, STATUSF, ENDTRNS, and ENDFRAM signals is treated as an interrupt request signal (INTSTA).
  - 4. The logical sum (OR) output of the IEERR, STARTF, STATUSF, ENDTRNS, and ENDFRAM signals (logical sum (OR) output of INTSTA and INTERR signals) is treated as an interrupt request signal (INTIE2).

| Table 10 16  | Intervient Degrees | Cianal Canavatia  | · Course List |
|--------------|--------------------|-------------------|---------------|
| Table 18-16. | Interrupt Request  | Sidnai Generatioi | 1 Source List |

|     | Interrupt Source            | Symbol  |        | Interrupt Re | quest Signal |        |
|-----|-----------------------------|---------|--------|--------------|--------------|--------|
|     |                             |         | INTIE1 | INTIE2       | INTERR       | INTSTA |
| Со  | mmunication error interrupt | IEERR   |        | √            | √            |        |
|     | Timing error                | TERR    |        |              |              |        |
|     | Parity error                | PERR    |        |              |              |        |
|     | NACK reception error        | NERR    |        |              |              |        |
|     | Underrun error              | UERR    |        |              |              |        |
|     | Overrun error               | OERR    |        |              |              |        |
|     | Write error                 | WERR    |        |              |              |        |
| Sta | art interrupt               | STARTF  |        | √            |              | √      |
| Sta | atus transmission           | STATUSF |        | √            |              | √      |
| En  | d of Communication          | ENDTRNS |        | √            |              | √      |
| En  | d of frame                  | ENDFRAM |        | √            |              | √      |
| Tra | ansmit data write request   | STATTX  | √      |              |              |        |
| Re  | ceive data write request    | STATRX  | √      |              |              |        |

### 18.4.2 Example of identifying interrupt

The IEBus controller processes interrupts in the following two ways.

- Using three interrupt request signals: INTIE1, INTERR, and INTSTA
- Using two interrupt request signals: INTIE1 and INTIE2

Caution Mask the interrupt sources that are not used so that the interrupts do not occur.

How an interrupt is identified in each of the above cases is explained below.

### (1) When INTIE1, INTERR, and INTSTA signals are used

Figure 18-21. Example of Identifying INTIE1 Signal Interrupt (When INTIE1, INTERR, and INTSTA Signals Are Used)



Figure 18-22. Example of Identifying INTERR Signal Interrupt (When INTIE1, INTERR, and INTSTA Signals Are Used)





Figure 18-23. Example of Identifying INTSTA Signal Interrupt (When INTIE1, INTERR, and INTSTA Signals Are Used)

### (2) When INTIE1 and INTIE2 signals are used

Figure 18-24. Example of Identifying INTIE1 Signal Interrupt (When INTIE1 and INTIE2 Signals Are Used)



INTIE2 signal generated ISR register IEERR bit Communication error identification Error source identification ESR register TEER bit PEER bit NEER bit **UEER** bit OEER bit WEER bit STARTF bit Start interrupt occurs SSR register Arbitration loss detection ARBIT bit Remaster processing SLVRQ bit Slave request identification STATUSF bit Status transmission identification Status transmission processing CDR register 00H, 06H Writing SSR register to DR register 04H Writing lower 8 bits of PAR register to DR register 05H Writing higher 4 bits of PAR register to DR register **ENDTRNS** bit Communication end identification **ENDFRAM** bit Frame end identification

Figure 18-25. Example of Identifying INTIE2 Signal Interrupt (When INTIE1 and INTIE2 Signals Are Used)

# 18.4.3 Interrupt source list

The interrupt request signals of the internal IEBus controller in the V850ES/SG2 can be classified into vector interrupts and DMA transfer interrupts. These interrupt request signals can be specified via software manipulation.

The interrupt sources are listed below.

Table 18-17. Interrupt Source List

| I                   | nterrupt Source  | Condition o                 | f Generation                 | Software Processing After                                                                                       | Remark                                                                                                                   |  |
|---------------------|------------------|-----------------------------|------------------------------|-----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|--|
|                     |                  | Unit                        | Field                        | Generation of Interrupt Request<br>Signal                                                                       |                                                                                                                          |  |
|                     | Timing error     | Master/slave                | All fields                   | Undo communication processing                                                                                   | Communication error is logical                                                                                           |  |
| _                   | Parity error     | Reception                   | Other than data (individual) |                                                                                                                 | sum (OR) output of timing<br>error, parity error, NACK<br>reception error, underrun error,                               |  |
| tion erro           |                  |                             | All fields<br>(broadcast)    |                                                                                                                 | overrun error, and write error.                                                                                          |  |
| Communication error | NACK reception   | Reception<br>(Transmission) | Other than data (individual) |                                                                                                                 |                                                                                                                          |  |
| Com                 | Underrun error   | Transmission                | Data                         |                                                                                                                 |                                                                                                                          |  |
|                     | Overrun error    | Reception                   | Data<br>(broadcast)          |                                                                                                                 |                                                                                                                          |  |
|                     | Write error      | Transmission                | Data                         |                                                                                                                 |                                                                                                                          |  |
| Star                | rt interrupt     | Master                      | Slave/address                | Slave request judgment Arbitration judgment (If lost, remaster processing) Communication preparation processing | Interrupt always occurs if lost in arbitration during master request                                                     |  |
|                     |                  | Slave                       |                              | Slave request judgment Communication preparation processing                                                     | Generated only during slave request                                                                                      |  |
| Stat                | tus transmission | Slave                       | Control                      | Refer to transmission processing example such as slave status.                                                  | Interrupt occurs regardless of slave transmission enable flag Interrupt occurs if NACK is returned in the control field. |  |
| End                 | of communication | Transmission                | Data                         | DMA transfer end processing                                                                                     | Set if SCR register is cleared to                                                                                        |  |
|                     |                  | Reception                   | Data                         | DMA transfer end processing<br>Receive data processing                                                          | 00Н                                                                                                                      |  |
| End                 | l of frame       | Transmission                | Data                         | Retransmission preparation processing                                                                           | Set if CCR register is cleared to 00H                                                                                    |  |
|                     |                  | Reception                   | Data                         | Re-reception preparation processing                                                                             |                                                                                                                          |  |
| Transmit data write |                  | Transmission                | Data                         | Reading of transmit data <sup>Note</sup>                                                                        | Set after transfer transmission data to internal shift register This does not occur when the last data is transferred.   |  |
| Rec                 | eive data read   | Reception                   | Data                         | Reading of received data <sup>Note</sup>                                                                        | Set after normal data reception                                                                                          |  |
|                     |                  |                             |                              |                                                                                                                 |                                                                                                                          |  |

Note If DMA transfer or software manipulation is not executed.

# 18.4.4 Communication error source processing list

The following table shows the occurrence conditions of the communication errors (timing error, NACK reception error, overrun error, underrun error, parity error, and write error), error processing by the IEBus controller, and examples of processing by software.

Table 18-18. Communication Error Source Processing List (1/2)

|                          |                        | Timing Error                                                                                                                      |            |                                                                      |            |  |  |
|--------------------------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------|------------|----------------------------------------------------------------------|------------|--|--|
| Occurrence               | Unit status            | Reception                                                                                                                         |            | Transmission                                                         |            |  |  |
| condition                | Occurrence condition   | If bit specification timing is not correct                                                                                        |            |                                                                      |            |  |  |
|                          | Location of occurrence | Other than data field                                                                                                             | Data field | Other than data field                                                | Data field |  |  |
| Broadcast communication  | Hardware processing    | Reception stops.     INTIE2 signal occurs     To start bit waiting status  Remark Communication between other units does not end. |            | Transmission stops. INTIE2 signal occurs To start bit waiting status |            |  |  |
|                          | Software processing    | Error processing (such as retransmission request)                                                                                 |            | Error processing (such as retransmission request)                    |            |  |  |
| Individual communication | Hardware processing    | Reception stops.     INTIE2 signal occurs     NACK signal is returned.     To start bit waiting status                            |            | Transmission stops. INTIE2 signal occurs To start bit waiting status |            |  |  |
|                          | Software processing    | Error processing (such as retransmission request)                                                                                 |            | Error processing (such as retransmission request)                    |            |  |  |

|                          |                        | NACK Reception Error                                                       |                                                                                                                          |                                                                    |                                                             |                                                               |  |
|--------------------------|------------------------|----------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|-------------------------------------------------------------|---------------------------------------------------------------|--|
| Occurrence condition     | Unit status            | Reception                                                                  |                                                                                                                          | Transmission                                                       |                                                             |                                                               |  |
|                          | Occurrence condition   | Unit NACK signal transmission                                              |                                                                                                                          | Unit NACK signal transmission                                      |                                                             |                                                               |  |
|                          | Location of occurrence | Other than data field                                                      | Data field                                                                                                               | Other than data field                                              | Data field                                                  | NACK signal<br>reception of data<br>of 32nd byte              |  |
| Broadcast communication  | Hardware processing    | -                                                                          | _                                                                                                                        | _                                                                  | _                                                           | -                                                             |  |
|                          | Software processing    | _                                                                          | _                                                                                                                        | _                                                                  | _                                                           | _                                                             |  |
| Individual communication | Hardware processing    | Reception stops.     INTIE2 signal occurs.     To start bit waiting status | <ul> <li>INTIE2 signal<br/>does not occur.</li> <li>Data<br/>retransmitted<br/>by other unit is<br/>received.</li> </ul> | Reception stops. INTIE2 signal occurs. To start bit waiting status | INTIE2 signal does not occur.     Retransmission processing | INTIE2 signal occurs.     To start bit waiting status         |  |
|                          | Software processing    | Error<br>processing<br>(such as<br>retransmission<br>request)              | -                                                                                                                        | Error<br>processing<br>(such as<br>retransmission<br>request)      | -                                                           | Error<br>processing<br>(such as<br>retransmission<br>request) |  |

Table 18-18. Communication Error Source Processing List (2/2)

|                             |                        |                                                                      | Overrun Error                                                                                                                             | U                                                                          | nderrun Error/Write Error                                             |  |  |
|-----------------------------|------------------------|----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|-----------------------------------------------------------------------|--|--|
| Occurrence                  | Unit status            | Reception                                                            | Reception                                                                                                                                 |                                                                            | Transmission                                                          |  |  |
| condition                   | Occurrence condition   | DR register cannot be read in time before the next data is received. |                                                                                                                                           | DR register cannot be written in time before the next data is transmitted. |                                                                       |  |  |
|                             | Location of occurrence | Other than data field                                                | Data field                                                                                                                                | Other than data field                                                      | Data field                                                            |  |  |
| Broadcast<br>communication  | Hardware<br>processing | -                                                                    | Reception stops.     INTIE2 signal occurs.     To start bit waiting status  Remarks 1. Communication between other units does not end.    | -                                                                          | Transmission stops. INTIE2 signal occurs. To start bit waiting status |  |  |
|                             |                        |                                                                      | 2. Data cannot be received until the overrun status is cleared.                                                                           |                                                                            |                                                                       |  |  |
|                             | Software processing    | -                                                                    | <ul> <li>DR register is read and overrun<br/>status is cleared.</li> <li>Error processing (such as<br/>retransmission request)</li> </ul> | _                                                                          | Error processing (such as retransmission request)                     |  |  |
| Individual<br>communication | Hardware processing    | -                                                                    | INTIE2 signal does not occur.     NACK signal is returned.     Data is retransmitted from other unit.                                     | _                                                                          | Transmission stops. INTIE2 signal occurs. To start bit waiting status |  |  |
|                             |                        |                                                                      | Remark Data cannot be received until overrun status is cleared.                                                                           |                                                                            |                                                                       |  |  |
|                             | Software processing    | -                                                                    | <ul> <li>DR register is read and overrun<br/>status is cleared.</li> <li>Error processing (such as<br/>retransmission request)</li> </ul> | _                                                                          | Error processing (such as<br>retransmission request)                  |  |  |

|                             |                        | Parity Error                                                                                                                     |                                                                                                                               |                       |            |  |  |
|-----------------------------|------------------------|----------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|-----------------------|------------|--|--|
| Occurrence                  | Unit status            | Reception                                                                                                                        | Transmission                                                                                                                  |                       |            |  |  |
| condition                   | Occurrence condition   | Received data and received p                                                                                                     | -                                                                                                                             |                       |            |  |  |
|                             | Location of occurrence | Other than data field                                                                                                            | Data field                                                                                                                    | Other than data field | Data field |  |  |
| Broadcast<br>communication  | Hardware processing    | <ul> <li>Reception stops.</li> <li>INTIE2 signal occurs.</li> <li>To start bit waiting status</li> </ul> Remark Communication be | _                                                                                                                             | _                     |            |  |  |
|                             | Software processing    | Error processing (such as re                                                                                                     | -                                                                                                                             | -                     |            |  |  |
| Individual<br>communication | Hardware processing    | Reception stops.     INTIE2 signal occurs.     To start bit waiting status                                                       | Reception does not stop. INTIE2 signal does not occur. NACK signal is returned. Data retransmitted by other unit is received. | -                     | -          |  |  |
|                             | Software processing    | Error processing (such as retransmission request)                                                                                | -                                                                                                                             | -                     | -          |  |  |

# 18.5 Interrupt Request Signal Generation Timing and Main CPU Processing

# 18.5.1 Master transmission

Initial preparation processing:

Sets a unit address, slave address, control data, telegraph length, and the first byte of the transmit data.

Communication start processing:

Set the BCR register (enable communication, master request, and slave reception).

Figure 18-26. Master Transmission



**Note** This processing is necessary only when the INTIE2 interrupt request signal is used as the start interrupt, and is not necessary when the INTSTA interrupt request signal is used (in this case, the error processing is performed by using the INTERR interrupt request signal).

Remarks 1. ∇: Interrupt request signal (INTIE1) occurrence (See 18.5.1 (2) Interrupt request signal (INTIE1) occurrence)

The transmit data of the second and subsequent bytes is written to the DR register by DMA transfer.

At this time, the data transfer direction is RAM  $\rightarrow$  on-chip peripheral I/O

- 2. ▼: An interrupt request signal (INTIE1) does not occur.
- **3.** n = Final number of data bytes

### (1) Slave reception processing

If a slave reception request is confirmed during vector interrupt servicing, the data transfer direction of the macro service must change from RAM  $\rightarrow$  on-chip peripheral I/O to on-chip peripheral I/O  $\rightarrow$  RAM until the first data is received. The maximum pending period of this data transfer direction changing processing is about 1,040  $\mu$ s in communication mode 1 (at 6.29 MHz).

### (2) Interrupt request signal (INTIE1) occurrence

If the NACK signal is received from the slave in the data field, an interrupt request signal (INTIE1) is not issued to the interrupt controller (INTC), and the same data is retransmitted by hardware.

If the transmit data is not written in time during the period of writing the next data, a communication error interrupt request signal (INTERR) occurs due to occurrence of underrun, and communication ends midway.

#### (3) Recommunication processing

In the vector interrupt servicing in <2> in Figure 18-26, it is judged whether the data has been correctly transmitted within one frame. If the data has not been correctly transmitted (if the number of data to be transmitted in one frame could not be transmitted), the data must be retransmitted in the next frame, or the remainder of the data must be transmitted.

#### 18.5.2 Master reception

Before performing master reception, it is necessary to notify the unit that will be the slave of slave transmission. Therefore, more than two communication frames are necessary for master reception.

The slave unit prepares the transmit data, sets (1) the slave transmission enable flag (BCR.ENSLVTX bit), and waits.

Initial preparation processing:

Set a unit address, slave address, and control data.

Communication start processing:

Set the BCR register (enable communication and master request).

Figure 18-27. Master Reception



Remarks 1. ∇: Interrupt request signal (INTIE1) occurrence (See 18.5.2 (1) Interrupt request signal (INTIE1) occurrence)

The receive data stored in the DR register is read by DMA transfer.

At this time, the data transfer direction is on-chip peripheral I/O  $\rightarrow$  RAM.

**2.** n = Final number of data bytes

# (1) Interrupt request signal (INTIE1) occurrence

If the NACK signal is transmitted (hardware processing) in the data field, an interrupt request signal (INTIE1) is not issued to the INTC, and the same data is retransmitted from the slave.

If the receive data is not read by the time the next data is received, the hardware automatically transmits the NACK signal.

### (2) Frame end processing

In the vector interrupt servicing in <2> in Figure 18-27, it is judged whether the data has been correctly received within one frame. If the data has not been correctly received (if the number of data to be received in one frame could not be received), a request to retransmit the data must be made to the slave in the next communication frame.

#### 18.5.3 Slave transmission

Initial preparation processing:

Set a unit address, telegraph length, and the first byte of the transmit data.

Communication start processing:

Set the BCR register (enable communication, slave transmission, and slave reception).

Figure 18-28. Slave Transmission



The transmit data of the second and subsequent bytes is written to the DR register by DMA

At this time, the data transfer direction is RAM  $\rightarrow$  on-chip peripheral I/O.

- 2. ▼: An interrupt request signal (INTIE1) does not occur.
- 3. (a): Interrupt request signal (INTIE2) occurrence An interrupt request signal occurs only when 0H, 4H, 5H, or 6H is received in the control field in the slave status (for the slave status response operation during the locked status, see 18.3 (11) IEBus control data register (CDR)).
- **4.** n = Final number of data bytes

### (1) Interrupt request signal (INTIE1) occurrence

If the NACK signal is received from the master in the data field, an interrupt request signal (INTIE1) is not issued to the INTC, and the same data is retransmitted by hardware.

If the transmit data is not written in time during the period of writing the next data, a communication error interrupt request signal (INTERR) occurs due to occurrence of underrun, and communication is abnormally ended.

# (2) Frame end processing

In the vector interrupt servicing in <2> in Figure 18-28, it is judged whether the data has been correctly transmitted within one frame. If the data has not been correctly transmitted (if the number of data to be transmitted in one frame could not be transmitted), the data must be retransmitted in the next frame, or the remaining data must be transmitted.

#### 18.5.4 Slave reception

Initial preparation processing:

Set a unit address.

Communication start processing:

Set the BCR register (enable communication, disables slave transmission, and enables slave reception).

Figure 18-29. Slave Reception



# (1) Interrupt request signal (INTIE1) occurrence

If the NACK signal is transmitted in the data field, an interrupt request signal (INTIE1) is not issued to the INTC, and the same data is retransmitted from the master.

If the receive data is not read by the time the next data is received, the NACK signal is automatically transmitted.

# (2) Frame end processing

In the vector interrupt servicing in <2> in Figure 18-29, it is judged whether the data has been correctly received within one frame.

### 18.5.5 Interval of occurrence of interrupt request signal for IEBus control

Each control interrupt request signal must occur at each point of communication and perform the necessary processing until the next interrupt request signal occurs. Therefore, the IEBus control block is controlled by software, taking the shortest time of this interrupt request signal occurrence interval into consideration.

The locations at which the following interrupt request signals may occur are indicated by  $\uparrow$  in the field where it may occur.  $\uparrow$  does not mean that the interrupt request signal occurs at each of the points indicated by  $\uparrow$ . If an error interrupt request signal (timing error, parity error, or NACK receive error) occurs, the IEBus internal circuit is initialized. As a result, the following interrupt request signal does not occur in that communication frame.

### (1) Master transmission

Figure 18-30. Master Transmission (Interval of Interrupt Request Signal Occurrence)



# (2) Master reception

Figure 18-31. Master Reception (Interval of Interrupt Request Signal Occurrence)



### (3) Slave transmission

Figure 18-32. Slave Transmission (Interval of Interrupt Request Signal Occurrence)



# (4) Slave reception

Figure 18-33. Slave Reception (Interval of Interrupt Request Signal Occurrence)



# **CHAPTER 19 CAN CONTROLLER**

### 19.1 Overview

The V850ES/SG2 features an on-chip 1-channel CAN (Controller Area Network) controller that complies with the CAN protocol as standardized in ISO 11898.

The V850ES/SG2 products with an on-chip CAN controller are as follows.

• μPD703282HY, 703283HY, 70F3283HY

#### 19.1.1 Features

- Compliant with ISO 11898 and tested according to ISO/DIS 16845 (CAN conformance test)
- Standard frame and extended frame transmission/reception enabled
- Transfer rate: 1 Mbps max. (CAN clock input ≥ 8 MHz)
- 32 message buffers/channels
- Receive/transmit history list function
- Automatic block transmission function
- Multi-buffer receive block function
- Mask setting of four patterns is possible for each channel

# 19.1.2 Overview of functions

Table 19-1 presents an overview of the CAN controller functions.

**Table 19-1. Overview of Functions** 

| Function                          | Details                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Protocol                          | CAN protocol ISO 11898 (standard and extended frame transmission/reception)                                                                                                                                                                                                                                                                                                                                                |
| Baud rate                         | Maximum 1 Mbps (CAN clock input ≥ 8 MHz)                                                                                                                                                                                                                                                                                                                                                                                   |
| Data storage                      | Storing messages in the CAN RAM                                                                                                                                                                                                                                                                                                                                                                                            |
| Number of messages                | <ul> <li>32 message buffers/channels</li> <li>Each message buffer can be set to be either a transmit message buffer or a receive message buffer.</li> </ul>                                                                                                                                                                                                                                                                |
| Message reception                 | <ul> <li>Unique ID can be set to each message buffer.</li> <li>Mask setting of four patterns is possible for each channel.</li> <li>A receive completion interrupt is generated each time a message is received and stored in a message buffer.</li> <li>Two or more receive message buffers can be used as a FIFO receive buffer (multi-buffer receive block function).</li> <li>Receive history list function</li> </ul> |
| Message transmission              | <ul> <li>Unique ID can be set to each message buffer.</li> <li>Transmit completion interrupt for each message buffer</li> <li>Message buffer numbers 0 to 7 specified as transmit message buffers can be used for automatic block transfer. Message transmission interval is programmable (automatic block transmission function (hereafter referred to as "ABT")).</li> <li>Transmission history list function</li> </ul> |
| Remote frame processing           | Remote frame processing by transmit message buffer                                                                                                                                                                                                                                                                                                                                                                         |
| Time stamp function               | <ul> <li>The time stamp function can be set for a receive message when a 16-bit timer is used in combination.         The time stamp capture trigger can be selected (SOF or EOF in a CAN message frame can be detected).     </li> <li>The time stamp function can be set for a transmit message.         Specific bytes in data field can be replaced with the capture time stamp<sup>Note</sup>.     </li> </ul>        |
| Diagnostic function               | <ul> <li>Readable error counters</li> <li>"Valid protocol operation flag" for verification of bus connections</li> <li>Receive-only mode</li> <li>Single-shot mode</li> <li>CAN protocol error type decoding</li> <li>Self-test mode</li> </ul>                                                                                                                                                                            |
| Forced release from bus-off state | Default mode can be set while bus is off, so that bus can be forcibly released from bus-off state.                                                                                                                                                                                                                                                                                                                         |
| Power save mode                   | <ul><li>CAN sleep mode (can be woken up by CAN bus)</li><li>CAN stop mode (cannot be woken up by CAN bus)</li></ul>                                                                                                                                                                                                                                                                                                        |

Note Valid only for the macro with advanced time stamp function

## 19.1.3 Configuration

The CAN controller is composed of the following four blocks.

#### (1) NPB interface

This functional block provides an NPB (NEC Peripheral I/O Bus) interface and means of transmitting and receiving signals between the CAN module and the host CPU.

## (2) MAC (Memory Access Controller)

This functional block controls access to the CAN protocol layer and to the CAN RAM within the CAN module.

## (3) CAN protocol layer

This functional block is involved in the operation of the CAN protocol and its related settings.

# (4) CAN RAM

This is the CAN memory functional block, which is used to store message IDs, message data, etc.



Figure 19-1. Block Diagram of CAN Module

## 19.2 CAN Protocol

CAN (Controller Area Network) is a high-speed multiplex communication protocol for real-time communication in automotive applications (class C). CAN is prescribed by ISO 11898. For details, refer to the ISO 11898 specifications.

The CAN specification is generally divided into two layers: a physical layer and a data link layer. In turn, the data link layer includes logical link and medium access control. The composition of these layers is illustrated below.

Higher Logical link control (LLC) · Acceptance filtering · Overload report Data link · Recovery management laver<sup>Note</sup> · Data capsuled/not capsuled Medium access control (MAC) Frame coding (stuffing/no stuffing) · Medium access management · Error detection · Error report · Acknowledgement · Seriated/not seriated Prescription of signal level and bit description Physical layer Lower Note CAN controller specification

Figure 19-2. Composition of Layers

#### 19.2.1 Frame format

## (1) Standard format frame

• The standard format frame uses 11-bit identifiers, which means that it can handle up to 2,048 messages.

## (2) Extended format frame

- The extended format frame uses 29-bit (11 bits + 18 bits) identifiers, which increases the number of messages that can be handled to 2,048 × 2<sup>18</sup> messages.
- An extended format frame is set when "recessive level" (CMOS level of "1") is set for both the SRR and IDE bits in the arbitration field.

# 19.2.2 Frame types

The following four types of frames are used in the CAN protocol.

Table 19-2. Frame Types

| Frame Type     | Description                                             |
|----------------|---------------------------------------------------------|
| Data frame     | Frame used to transmit data                             |
| Remote frame   | Frame used to request a data frame                      |
| Error frame    | Frame used to report error detection                    |
| Overload frame | Frame used to delay the next data frame or remote frame |

## (1) Bus value

The bus values are divided into dominant and recessive.

- Dominant level is indicated by logical 0.
- Recessive level is indicated by logical 1.
- When a dominant level and a recessive level are transmitted simultaneously, the bus value becomes dominant level.

#### 19.2.3 Data frame and remote frame

## (1) Data frame

A data frame is composed of seven fields.

Figure 19-3. Data Frame



## (2) Remote frame

A remote frame is composed of six fields.

Figure 19-4. Remote Frame



#### (3) Description of fields

## <1> Start of frame (SOF)

The start of frame field is located at the start of a data frame or remote frame.

Figure 19-5. Start of Frame (SOF)



- If a dominant level is detected in the bus idle state, a hardware synchronization is performed (the current TQ is assigned to be the SYNC segment).
- If a dominant level is sampled at the sample point following such a hardware synchronization, the bit
  is assigned to be a SOF. If a recessive level is detected, the protocol layer returns to the bus idle
  state and regards the preceding dominant pulse as a noise only. In this case an error frame is not
  generated.

## <2> Arbitration field

The arbitration field is used to set the priority, data frame/remote frame, and frame format.

Figure 19-6. Arbitration Field (in Standard Format Mode)



Figure 19-7. Arbitration Field (in Extended Format Mode)



Table 19-3. RTR Frame Settings

| Frame Type   | RTR Bit |  |  |
|--------------|---------|--|--|
| Data frame   | 0 (D)   |  |  |
| Remote frame | 1 (R)   |  |  |

Table 19-4. Frame Format Setting (IDE Bit) and Number of Identifier (ID) Bits

| Frame Format         | SRR Bit | IDE Bit | Number of Bits |
|----------------------|---------|---------|----------------|
| Standard format mode | None    | 0 (D)   | 11 bits        |
| Extended format mode | 1 (R)   | 1 (R)   | 29 bits        |

# <3> Control field

The control field sets "N" as the number of data bytes in the data field (N = 0 to 8).

Figure 19-8. Control Field



In a standard format frame, the control field's IDE bit is the same as the r1 bit.

Table 19-5. Data Length Setting

| Data Length Code |      |      | Data Byte Count                                 |         |
|------------------|------|------|-------------------------------------------------|---------|
| DLC3             | DLC2 | DLC1 | DLC0                                            |         |
| 0                | 0    | 0    | 0                                               | 0 bytes |
| 0                | 0    | 0    | 1                                               | 1 byte  |
| 0                | 0    | 1    | 0                                               | 2 bytes |
| 0                | 0    | 1    | 1                                               | 3 bytes |
| 0                | 1    | 0    | 0                                               | 4 bytes |
| 0                | 1    | 0    | 1                                               | 5 bytes |
| 0                | 1    | 1    | 0                                               | 6 bytes |
| 0                | 1    | 1    | 1                                               | 7 bytes |
| 1                | 0    | 0    | 0                                               | 8 bytes |
| Other than above |      |      | 8 bytes regardless of the value of DLC3 to DLC0 |         |

Caution In the remote frame, there is no data field even if the data length code is not 0000B.

## <4> Data field

The data field contains the amount of data (byte units) set by the control field. Up to 8 units of data can be set.

Figure 19-9. Data Field



#### <5> CRC field

The CRC field is a 16-bit field that is used to check for errors in transmit data.

Figure 19-10. CRC Field



- The polynomial P(X) used to generate the 15-bit CRC sequence is expressed as follows.
  - $P(X) = X^{15} + X^{14} + X^{10} + X^{8} + X^{7} + X^{4} + X^{3} + 1$
- Transmitting node: Transmits the CRC sequence calculated from the data (before bit stuffing) in the start of frame, arbitration field, control field, and data field.
- Receiving node: Compares the CRC sequence calculated using data bits that exclude the stuffing bits in the receive data with the CRC sequence in the CRC field. If the two CRC sequences do not match, the node issues an error frame.

# <6> ACK field

The ACK field is used to acknowledge normal reception.

Figure 19-11. ACK Field



- If no CRC error is detected, the receiving node sets the ACK slot to the dominant level.
- The transmitting node outputs two recessive-level bits.

# <7> End of frame (EOF)

The end of frame field indicates the end of data frame/remote frame.

Figure 19-12. End of Frame (EOF)



## <8> Interframe space

The interframe space is inserted after a data frame, remote frame, error frame, or overload frame to separate one frame from the next.

• The bus state differs depending on the error status.

#### (a) Error active node

The interframe space consists of a 3-bit intermission field and a bus idle field.

Figure 19-13. Interframe Space (Error Active Node)



# (b) Error passive node

The interframe space consists of an intermission field, a suspend transmission field, and a bus idle field.

Figure 19-14. Interframe Space (Error Passive Node)



Usually, the intermission field is 3 bits. If the transmitting node detects a dominant level at the third bit of the intermission field, however, it executes transmission.

• Operation in error status

Table 19-6. Operation in Error Status

| Error Status  | Operation                                                                  |
|---------------|----------------------------------------------------------------------------|
| Error active  | A node in this status can transmit immediately after a 3-bit intermission. |
| Error passive | A node in this status can transmit 8 bits after the intermission.          |

# 19.2.4 Error frame

An error frame is output by a node that has detected an error.

Figure 19-15. Error Frame



**Table 19-7. Definition of Error Frame Fields** 

| No. | Name                            | Bit Count | Definition                                                                                                                                                                                                                                                                                                              |  |  |
|-----|---------------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| <1> | Error flag 1                    | 6         | Error active node: Outputs 6 dominant-level bits consecutively.  Error passive node: Outputs 6 recessive-level bits consecutively.  If another node outputs a dominant level while one node is outputting a passive error flag, the passive error flag is not cleared until the same level is detected 6 bits in a row. |  |  |
| <2> | Error flag 2                    | 0 to 6    | Nodes receiving error flag 1 detect bit stuff errors and issues this error flag.                                                                                                                                                                                                                                        |  |  |
| <3> | Error delimiter                 | 8         | Outputs 8 recessive-level bits consecutively.  If a dominant level is detected at the 8th bit, an overload frame is transmitted from the next bit.                                                                                                                                                                      |  |  |
| <4> | Error bit                       | -         | The bit at which the error was detected.  The error flag is output from the bit next to the error bit.  In the case of a CRC error, this bit is output following the ACK delimiter.                                                                                                                                     |  |  |
| <5> | Interframe space/overload frame | _         | An interframe space or overload frame starts from here.                                                                                                                                                                                                                                                                 |  |  |

## 19.2.5 Overload frame

An overload frame is transmitted under the following conditions.

- When the receiving node has not completed the reception operation Note
- If a dominant level is detected at the first two bits during intermission
- If a dominant level is detected at the last bit (7th bit) of the end of frame or at the last bit (8th bit) of the error delimiter/overload delimiter

**Note** In this CAN controller, all reception frames can be loaded without outputting an overload frame because of the high-speed internal processing.



Figure 19-16. Overload Frame

Table 19-8. Definition of Overload Frame Fields

| No  | Name                            | Bit Count | Definition                                                                                                                                         |
|-----|---------------------------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| <1> | Overload flag                   | 6         | Outputs 6 dominant-level bits consecutively.                                                                                                       |
| <2> | Overload flag from other node   | 0 to 6    | The node that received an overload flag in the interframe space outputs an overload flag.                                                          |
| <3> | Overload delimiter              | 8         | Outputs 8 recessive-level bits consecutively.  If a dominant level is detected at the 8th bit, an overload frame is transmitted from the next bit. |
| <4> | Frame                           | -         | Output following an end of frame, error delimiter, or overload delimiter.                                                                          |
| <5> | Interframe space/overload frame | _         | An interframe space or overload frame starts from here.                                                                                            |

#### 19.3 Functions

## 19.3.1 Determining bus priority

## (1) When a node starts transmission:

• During bus idle, the node that output data first transmits the data.

#### (2) When more than one node starts transmission:

- The node that consecutively outputs the dominant level for the longest from the first bit of the arbitration field has the bus priority (if a dominant level and a recessive level are simultaneously transmitted, the dominant level is taken as the bus value).
- The transmitting node compares its output arbitration field and the data level on the bus.

## Table 19-9. Determining Bus Priority

| Level match    | Continuous transmission |
|----------------|-------------------------|
| Level mismatch | Continuous transmission |

## (3) Priority of data frame and remote frame

• When a data frame and a remote frame are on the bus, the data frame has priority because its RTR bit, the last bit in the arbitration field, carries a dominant level.

**Remark** If the extended-format data frame and the standard-format remote frame conflict on the bus (if ID28 to ID18 of both of them are the same), the standard-format remote frame takes priority.

## 19.3.2 Bit stuffing

Bit stuffing is used to establish synchronization by appending 1 bit of inverted-level data if the same level continues for 5 bits, in order to prevent a burst error.

# Table 19-10. Bit Stuffing

|     | During the transmission of a data frame or remote frame, when the same level continues for 5 bits in the data between the start of frame and the ACK field, 1 inverted-level bit of data is inserted before the following bit. |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| · · | During the reception of a data frame or remote frame, when the same level continues for 5 bits in the data between the start of frame and the ACK field, reception is continued after deleting the next bit.                   |

#### 19.3.3 Multi masters

As the bus priority (a node which acquires transmission rights) is determined by the identifier, any node can be the bus master.

## 19.3.4 Multi cast

Although there is one transmitting node, two or more nodes can receive the same data at the same time because the same identifier can be set to two or more nodes.

# 19.3.5 CAN sleep mode/CAN stop mode function

The CAN sleep mode/CAN stop mode function puts the CAN controller in waiting mode to achieve low power consumption.

The controller is woken up from the CAN sleep mode by bus operation but it is not woken up from the CAN stop mode by bus operation (the CAN stop mode is controlled by CPU access).

# 19.3.6 Error control function

# (1) Error types

Table 19-11. Error Types

| Туре        | Description of                                                                               | f Error                                     | Detection State                 |                                                                                                               |  |
|-------------|----------------------------------------------------------------------------------------------|---------------------------------------------|---------------------------------|---------------------------------------------------------------------------------------------------------------|--|
|             | Detection Method                                                                             | Detection<br>Condition                      | Transmission/<br>Reception      | Field/Frame                                                                                                   |  |
| Bit error   | Comparison of the output level and level on the bus (except stuff bit)                       | Mismatch of levels                          | Transmitting/<br>receiving node | Bit that is outputting data on the bus at the start of frame to end of frame, error frame and overload frame. |  |
| Stuff error | Check of the receive data at the stuff bit                                                   | 6 consecutive bits of the same output level | Receiving node                  | Start of frame to CRC sequence                                                                                |  |
| CRC error   | Comparison of the CRC sequence generated from the receive data and the received CRC sequence | Mismatch of CRC                             | Receiving node                  | CRC field                                                                                                     |  |
| Form error  | Field/frame check of the fixed format                                                        | Detection of fixed format violation         | Receiving node                  | CRC delimiter ACK field End of frame Error frame Overload frame                                               |  |
| ACK error   | Check of the ACK slot by the transmitting node                                               | Detection of recessive level in ACK slot    | Transmitting node               | ACK slot                                                                                                      |  |

# (2) Output timing of error frame

Table 19-12. Output Timing of Error Frame

| Туре                                          | Output Timing                                                                        |
|-----------------------------------------------|--------------------------------------------------------------------------------------|
| Bit error, stuff error, form error, ACK error | Error frame output is started at the timing of the bit following the detected error. |
| CEC error                                     | Error frame output is started at the timing of the bit following the ACK delimiter.  |

# (3) Processing in case of error

The transmission node re-transmits the data frame or remote frame after the error frame. (However, it does not re-transmit the frame in the single-shot mode.)

## (4) Error state

## (a) Types of error states

The following three types of error states are defined by the CAN specification.

- · Error active
- · Error passive
- Bus-off

These types of error states are classified by the values of the C0ERC.TEC7 to C0ERC.TEC0 bits (transmission error counter bits) and the C0ERC.REC6 to C0ERC.REC0 bits (reception error counter bits) as shown in Table 19-13.

The present error state is indicated by the C0INFO register.

When each error counter value becomes equal to or greater than the error warning level (96), the C0INFO.TECS0 or C0INFO.RECS0 bit is set to 1. In this case, the bus state must be tested because it is considered that the bus has a serious fault. An error counter value of 128 or more indicates an error passive state and the TECS1 or RECS1 bit is set to 1.

- If the value of the transmission error counter is greater than or equal to 256 (actually, the transmission error counter does not indicate a value greater than or equal to 256), the bus-off state is reached and the C0INFO.BOFF bit is set to 1.
- If only one node is active on the bus at startup (i.e., when the bus is connected only to the local station),
   ACK is not returned even if data is transmitted. Consequently, re-transmission of the error frame and data is repeated. In the error passive state, however, the transmission error counter is not incremented and the bus-off state is not reached.

Table 19-13. Types of Error States

| Туре          | Operation    | Value of Error<br>Counter                      | Indication of C0INFO<br>Register | Operation Specific to Error State                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------|--------------|------------------------------------------------|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Error active  | Transmission | 0 to 95                                        | TECS1, TECS0 = 00                | Outputs an active error flag (6 consecutive dominant-                                                                                                                                                                                                                                                                                                                                                                                                                   |
|               | Reception    | 0 to 95                                        | RECS1, RECS0 = 00                | level bits) on detection of the error.                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|               | Transmission | 96 to 127                                      | TECS1, TECS0 = 01                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|               | Reception    | 96 to 127                                      | RECS1, RECS0 = 01                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Error passive | Transmission | 128 to 255                                     | TECS1, TECS0 = 11                | Outputs a passive error flag (6 consecutive                                                                                                                                                                                                                                                                                                                                                                                                                             |
|               | Reception    | 128 or more                                    | RECS1, RECS0 = 11                | <ul> <li>recessive-level bits) on detection of the error.</li> <li>Transmits 8 recessive-level bits, in between transmissions, following an intermission (suspend transmission).</li> </ul>                                                                                                                                                                                                                                                                             |
| Bus-off       | Transmission | 256 or more<br>(not indicated) <sup>Note</sup> | BOFF = 1,<br>TECS1, TECS0 = 11   | Communication is not possible.     When the frame is received, no messages are stored and the following operations are performed.     <1> TSOUT toggles.     <2> REC is incremented/decremented.     <3> VALID bit is set.     If the initialization mode is set and then 11 recessive-level bits are generated 128 times in a row in an operation mode other than the initialization mode, the error counter is reset to 0 and the error active state can be restored. |

**Note** The value of the transmit error counter (TEC) does not carry any meaning if BOFF has been set. If an error that increments the value of the transmission error counter by 8 while the counter value is in a range of 248 to 255 occurs, the counter is not incremented and the bus-off state is assumed.

# (b) Error counter

The error counter counts up when an error has occurred, and counts down upon successful transmission and reception. The error counter is updated during the first bit of the error delimiter.

Table 19-14. Error Counter

| State                                                                                                                                                                                                                                                                                                                                                                                                 | Transmission Error Counter (TEC7 to TEC0 Bits) | Reception Error Counter<br>(REC6 to REC0 Bits)                                                                                                                    |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Receiving node detects an error (except bit error in the active error flag or overload flag).                                                                                                                                                                                                                                                                                                         | No change                                      | +1 (REPS bit = 0)                                                                                                                                                 |
| Receiving node detects dominant level following error flag of error frame.                                                                                                                                                                                                                                                                                                                            | No change                                      | +8 (REPS bit = 0)                                                                                                                                                 |
| Transmitting node transmits an error flag.  [As exceptions, the error counter does not change in the following cases.]  <1> ACK error is detected in error passive state and dominant level is not detected while the passive error flag is being output.  <2> A stuff error is detected in an arbitration field that transmitted a recessive level as a stuff bit, but a dominant level is detected. | +8                                             | No change                                                                                                                                                         |
| Bit error detection while active error flag or overload flag is being output (error-active transmitting node)                                                                                                                                                                                                                                                                                         | +8                                             | No change                                                                                                                                                         |
| Bit error detection while active error flag or overload flag is being output (error-active receiving node)                                                                                                                                                                                                                                                                                            | No change                                      | +8 (REPS bit = 0)                                                                                                                                                 |
| When the node detects 14 consecutive dominant-level bits from the beginning of the active error flag or overload flag, and then subsequently detects 8 consecutive dominant-level bits.  When the node detects 8 consecutive dominant levels after a passive error flag                                                                                                                               | +8 (transmitting)                              | +8 (receiving, REPS bit = 0)                                                                                                                                      |
| When the transmitting node has completed transmission without error (±0 if error counter = 0)                                                                                                                                                                                                                                                                                                         | -1                                             | No change                                                                                                                                                         |
| When the receiving node has completed reception without error                                                                                                                                                                                                                                                                                                                                         | No change                                      | <ul> <li>-1 (1 ≤ REC6 to REC0 ≤ 127, REPS bit = 0)</li> <li>±0 (REC6 to REC0 = 0, REPS bit = 0)</li> <li>Any value of 119 to 127 is set (REPS bit = 1)</li> </ul> |

## (c) Occurrence of bit error in intermission

An overload frame is generated.

Caution If an error occurs, it is controlled according to the contents of the transmission error counter and reception error counter before the error occurred. The value of the error counter is incremented after the error flag has been output.

#### (5) Recovery from bus-off state

When the CAN module is in the bus-off state, the transmission pins (CTXD0) cut off from the CAN bus always output the recessive level.

The CAN module recovers from the bus-off state in the following bus-off recovery sequence.

- <1> Request to enter the CAN initialization mode
- <2> Request to enter a CAN operation mode
  - (a) Recovery operation through normal recovery sequence
  - (b) Forced recovery operation that skips recovery sequence

#### (a) Recovery from bus-off state through normal recovery sequence

The CAN module first issues a request to enter the initialization mode (see timing <1> in Figure 19-17). This request will be immediately acknowledged, and the C0CTRL.OPMODE bit is cleared to 000B. Processing such as analyzing the fault that has caused the bus-off state, re-defining the CAN module and message buffer using application software, or stopping the operation of the CAN module can be performed by clearing the C0GMCTRL.GOM bit to 0.

Next, the module requests to change the mode from the initialization mode to an operation mode (see timing <2> in Figure 19-17). This starts an operation to recover the CAN module from the bus-off state. The conditions under which the module can recover from the bus-off state are defined by the CAN protocol ISO 11898, and it is necessary to detect 11 consecutive recessive-level bits 128 times. At this time, the request to change the mode to an operation mode is held pending until the recovery conditions are satisfied. When the recovery conditions are satisfied (see timing <3> in Figure 19-17), the CAN module can enter the operation mode it has requested. Until the CAN module enters this operation mode, it stays in the initialization mode. Whether the CAN module has entered the operation mode can be confirmed by reading OPMODE.

During the bus-off period and bus-off recovery sequence, the C0INFO.BOFF bit stays set (to 1). In the bus-off recovery sequence, the reception error counter (C0ERC.REC0 to C0ERC.REC6) counts the number of times 11 consecutive recessive-level bits have been detected on the bus. Therefore, the recovery state can be checked by reading the REC0 to REC6 bits.

Caution In the bus-off recovery sequence, the REC0 to REC6 bits counts up (+1) each time 11 consecutive recessive-level bits have been detected. Even during the bus-off period, the CAN module can enter the CAN sleep mode or CAN stop mode. To be released from the bus-off state, the module must enter the initialization mode once. If the module is in the CAN sleep mode or CAN stop mode, however, it cannot directly enter the initialization mode. In this case, the bus off recovery sequence is started at the same time as the CAN sleep mode is released even without shifting to the initialization mode. In addition to clearing the C0CTRL.PSMODE1 and C0CTRL.PSMODE0 bits by software, the bus off recovery sequence is also started due to wakeup by dominant edge detection on the CAN bus.



Figure 19-17. Recovery from Bus-off State Through Normal Recovery Sequence

## (b) Forced recovery operation that skips bus-off recovery sequence

The CAN module can be forcibly released from the bus-off state, regardless of the bus state, by skipping the bus-off recovery sequence. Here is the procedure.

First, the CAN module requests to enter the initialization mode. For the operation and points to be noted at this time, see 19.3.6 (5) (a) Recovery from bus-off state through normal recovery sequence.

Next, the module requests to enter an operation mode. At the same time, the C0CTRL.CCERC bit must be set to 1.

As a result, the bus-off recovery sequence defined by the CAN protocol ISO 11898 is skipped, and the module immediately enters the operation mode. In this case, the module is connected to the CAN bus after it has monitored 11 consecutive recessive-level bits. For details, see the processing in Figure 19-53.

Caution This function is not defined by the CAN protocol ISO 11898. When using this function, thoroughly evaluate its effect on the network system.

# (6) Initializing CAN module error counter register (C0ERC) in initialization mode

If it is necessary to initialize the C0ERC and C0INFO registers for debugging or evaluating a program, they can be initialized to the default value by setting the C0CTRL.CCERC bit in the initialization mode. When initialization has been completed, the CCERC bit is automatically cleared to 0.

- Cautions 1. This function is enabled only in the initialization mode. Even if the CCERC bit is set to 1 in a CAN operation mode, the C0ERC and C0INFO registers are not initialized.
  - 2. The CCERC bit can be set at the same time as the request to enter a CAN operation mode.

## 19.3.7 Baud rate control function

# (1) Prescaler

The CAN controller has a prescaler that divides the clock (fcan) supplied to CAN. This prescaler generates a CAN protocol layer base clock (fta) that is the CAN module system clock (fcanmod) divided by 1 to 256 (see 19.6 (12) CAN0 module bit rate prescaler register (C0BRP)).

#### (2) Data bit time (8 to 25 time quanta)

One data bit time is defined as shown in **Figure 19-18**. The CAN controller sets time segment 1, time segment 2, and reSynchronization Jump Width (SJW) as the data bit time, as shown in Figure 19-18. Time segment 1 is equivalent to the total of the propagation (prop) segment and phase segment 1 that are defined by the CAN protocol specification. Time segment 2 is equivalent to phase segment 2.

Figure 19-18. Segment Setting



| Segment name                       | Settable range | Notes on setting to conform to CAN specification                                                                                                                                                                                                                     |
|------------------------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Time segment 1 (TSEG1)             | 2TQ to 16TQ    | -                                                                                                                                                                                                                                                                    |
| Time segment 2 (TSEG2)             | 1TQ to 8TQ     | IPT <sup>Note</sup> of the CAN controller is 0TQ. To conform to the CAN protocol specification, therefore, a length equal to phase segment 1 must be set here. This means that the length of time segment 1 minus 1TQ is the settable upper limit of time segment 2. |
| reSynchronization Jump Width (SJW) | 1TQ to 4TQ     | The length of time segment 1 minus 1TQ or 4TQ, whichever smaller.                                                                                                                                                                                                    |

Note IPT: Information Processing Time

**Remark** The CAN protocol specification defines the segments constituting the data bit time as shown in Figure 19-19.

Figure 19-19. Configuration of Data Bit Time Defined by CAN Specification



| Segment name                                | Segment length                                                                   | Description                                                                                                                                                   |
|---------------------------------------------|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Sync segment (Synchronization segment)      | 1                                                                                | This segment starts at the edge where the level changes from recessive to dominant when hardware synchronization is established.                              |
| Prop segment<br>(Propagation segment)       | Programmable to 1 to 8, or greater                                               | This segment absorbs the delay of the output buffer, CAN bus, and input buffer.  The length of this segment is set so that ACK is returned                    |
| Phase segment 1<br>(Phase buffer segment 1) | Programmable to 1 to 8                                                           | before the start of phase segment 1.  Time of prop segment ≥ (Delay of output buffer) + 2 ×  (Delay of CAN bus) + (Delay of input buffer)                     |
| Phase segment 2<br>(Phase buffer segment 2) | Phase segment 1 or IPT <sup>Note</sup> , whichever greater                       | This segment compensates for an error in the data bit time.  The longer this segment, the wider the permissible range but the slower the communication speed. |
| SJW<br>(reSynchronization Jump<br>Width)    | Programmable from 1TQ<br>to phase segment 1TQ to<br>4TQ, whichever is<br>smaller | This width sets the upper limit of expansion or contraction of the phase segment during resynchronization.                                                    |

Note IPT: Information Processing Time

## (3) Synchronizing data bit

- The receiving node establishes synchronization by a level change on the bus because it does not have a sync signal.
- The transmitting node transmits data in synchronization with the bit timing of the transmitting node.

# (a) Hardware synchronization

This synchronization is established when the receiving node detects the start of frame in the interframe space.

• When a falling edge is detected on the bus, that TQ means the sync segment and the next segment is the prop segment. In this case, synchronization is established regardless of SJW.

Figure 19-20. Adjusting Synchronization of Data Bit



## (b) Resynchronization

Synchronization is established again if a level change is detected on the bus during reception (only if a recessive level was sampled previously).

• The phase error of the edge is given by the relative position of the detected edge and sync segment. <Sign of phase error>

0: If the edge is within the sync segment

Positive: If the edge is before the sample point (phase error)

Negative: If the edge is after the sample point (phase error)

If phase error is positive: Phase segment 1 is longer by specified SJW.

If phase error is negative: Phase segment 2 is shorter by specified SJW.

• The sample point of the data of the receiving node moves relatively due to the "discrepancy" in the baud rate between the transmitting node and receiving node.



Figure 19-21. Resynchronization

# 19.4 Connection with Target System

The CAN module has to be connected to the CAN bus using an external transceiver.

Figure 19-22. Connection to CAN Bus



# 19.5 Internal Registers of CAN Controller

# 19.5.1 CAN controller configuration

Table 19-15. List of CAN Controller Registers

| Item                     | Register Name                                                              |
|--------------------------|----------------------------------------------------------------------------|
| CAN global registers     | CAN0 global control register (C0GMCTRL)                                    |
|                          | CAN0 global clock selection register (C0GMCS)                              |
|                          | CAN0 global automatic block transmission control register (C0GMABT)        |
|                          | CAN0 global automatic block transmission delay setting register (C0GMABTD) |
| CAN module registers     | CAN0 module mask 1 register (C0MASK1L, C0MASK1H)                           |
|                          | CAN0 module mask 2 register (C0MASK2L, C0MASK2H)                           |
|                          | CAN0 module mask 3 register (C0MASK3L, C0MASK3H)                           |
|                          | CAN0 module mask 4 registers (C0MASK4L, C0MASK4H)                          |
|                          | CAN0 module control register (C0CTRL)                                      |
|                          | CAN0 module last error information register (C0LEC)                        |
|                          | CAN0 module information register (C0INFO)                                  |
|                          | CAN0 module error counter register (C0ERC)                                 |
|                          | CAN0 module interrupt enable register (C0IE)                               |
|                          | CAN0 module interrupt status register (C0INTS)                             |
|                          | CAN0 module bit rate prescaler register (C0BRP)                            |
|                          | CAN0 module bit rate register (C0BTR)                                      |
|                          | CAN0 module last in-pointer register (C0LIPT)                              |
|                          | CAN0 module receive history list register (C0RGPT)                         |
|                          | CAN0 module last out-pointer register (C0LOPT)                             |
|                          | CAN0 module transmit history list register (C0TGPT)                        |
|                          | CAN0 module time stamp register (C0TS)                                     |
| Message buffer registers | CAN0 message data byte 01 register m (C0MDATA01m)                          |
|                          | CAN0 message data byte 0 register m (C0MDATA0m)                            |
|                          | CAN0 message data byte 1 register m (C0MDATA1m)                            |
|                          | CAN0 message data byte 23 register m (C0MDATA23m)                          |
|                          | CAN0 message data byte 2 register m (C0MDATA2m)                            |
|                          | CAN0 message data byte 3 register m (C0MDATA3m)                            |
|                          | CAN0 message data byte 45 register m (C0MDATA45m)                          |
|                          | CAN0 message data byte 4 register m (C0MDATA4m)                            |
|                          | CAN0 message data byte 5 register m (C0MDATA5m)                            |
|                          | CAN0 message data byte 67 register m (C0MDATA67m)                          |
|                          | CAN0 message data byte 6 register m (C0MDATA6m)                            |
|                          | CAN0 message data byte 7 register m (C0MDATA7m)                            |
|                          | CAN0 message data length register m (C0MDLCm)                              |
|                          | CAN0 message configuration register m (C0MCONFm)                           |
|                          | CAN0 message ID register m (C0MIDLm, C0MIDHm)                              |
|                          | CAN0 message control register m (C0MCTRLm)                                 |

Remarks 1. The CAN global register is defined as C0GM <register function>.

The CAN module register is defined as C0 <register function>.

The message buffer register is defined as C0M <register function>.

**2.** m = 00 to 31

# 19.5.2 Register access type

Table 19-16. Register Access Types (1/17)

| Address   | Register Name                                           | Symbol   | R/W | Bit Ma | anipulation | n Units | After Reset |
|-----------|---------------------------------------------------------|----------|-----|--------|-------------|---------|-------------|
|           |                                                         |          |     | 1 Bit  | 8 Bits      | 16 Bits |             |
| 03FEC000H | CAN0 global control register                            | COGMCTRL | R/W |        |             | √       | 0000H       |
| 03FEC002H | CAN0 global clock selection register                    | COGMCS   |     |        | √           |         | 0FH         |
| 03FEC006H | CAN0 global automatic block transmission register       | COGMABT  |     |        |             | √       | H0000       |
| 03FEC008H | CAN0 global automatic block transmission delay register | C0GMABTD |     |        | √           |         | 00H         |
| 03FEC040H | CAN0 module mask 1 register                             | C0MASK1L |     |        |             | √       | Undefined   |
| 03FEC042H |                                                         | C0MASK1H |     |        |             | √       | Undefined   |
| 03FEC044H | CAN0 module mask 2 register                             | C0MASK2L |     |        |             | √       | Undefined   |
| 03FEC046H |                                                         | C0MASK2H |     |        |             | √       | Undefined   |
| 03FEC048H | CAN0 module mask 3 register                             | C0MASK3L |     |        |             | √       | Undefined   |
| 03FEC04AH |                                                         | C0MASK3H |     |        |             | √       | Undefined   |
| 03FEC04CH | CAN0 module mask 4 register                             | C0MASK4L |     |        |             | √       | Undefined   |
| 03FEC04EH |                                                         | C0MASK4H |     |        |             | √       | Undefined   |
| 03FEC050H | CAN0 module control register                            | C0CTRL   |     |        |             | √       | 0000H       |
| 03FEC052H | CAN0 module last error code register                    | COLEC    |     |        | √           |         | 00H         |
| 03FEC053H | CAN0 module information register                        | COINFO   | R   |        | √           |         | 00H         |
| 03FEC054H | CAN0 module error counter register                      | C0ERC    |     |        |             | √       | 0000H       |
| 03FEC056H | CAN0 module interrupt enable register                   | COIE     | R/W |        |             | √       | 0000H       |
| 03FEC058H | CAN0 module interrupt status register                   | COINTS   |     |        |             | √       | 0000H       |
| 03FEC05AH | CAN0 module bit-rate prescaler register                 | C0BRP    |     |        | √           |         | FFH         |
| 03FEC05CH | CAN0 module bit-rate register                           | C0BTR    |     |        |             | √       | 370FH       |
| 03FEC05EH | CAN0 module last in-pointer register                    | COLIPT   | R   |        | √           |         | Undefined   |
| 03FEC060H | CAN0 module receive history list register               | C0RGPT   | R/W |        |             | √       | xx02H       |
| 03FEC062H | CAN0 module last out-pointer register                   | COLOPT   | R   |        | √           |         | Undefined   |
| 03FEC064H | CAN0 module transmit history list register              | C0TGPT   | R/W |        |             | √       | xx02H       |
| 03FEC066H | CAN0 module time stamp register                         | COTS     |     |        |             | √       | 0000H       |

Table 19-16. Register Access Types (2/17)

| Г | Address   | Register Name                          | Symbol      | R/W | Bit Ma | nipulatio | n Units | After Reset           |
|---|-----------|----------------------------------------|-------------|-----|--------|-----------|---------|-----------------------|
|   |           |                                        |             |     | 1 Bit  | 8 Bits    | 16 Bits |                       |
| ( | 3FEC100H  | CAN0 message data byte 01 register 00  | C0MDATA0100 | R/W |        |           | √       | Undefined             |
|   | 03FEC100H | CAN0 message data byte 0 register 00   | C0MDATA000  |     |        | √         |         | Undefined             |
|   | 03FEC101H | CAN0 message data byte 1 register 00   | C0MDATA100  |     |        | √         |         | Undefined             |
| ( | 3FEC102H  | CAN0 message data byte 23 register 00  | C0MDATA2300 |     |        |           | √       | Undefined             |
|   | 03FEC102H | CAN0 message data byte 2 register 00   | C0MDATA200  |     |        | √         |         | Undefined             |
|   | 03FEC103H | CAN0 message data byte 3 register 00   | C0MDATA300  |     |        | √         |         | Undefined             |
| ( | 3FEC104H  | CAN0 message data byte 45 register 00  | C0MDATA4500 |     |        |           | √       | Undefined             |
|   | 03FEC104H | CAN0 message data byte 4 register 00   | C0MDATA400  |     |        | √         |         | Undefined             |
|   | 03FEC105H | CAN0 message data byte 5 register 00   | C0MDATA500  |     |        | √         |         | Undefined             |
| ( | 3FEC106H  | CAN0 message data byte 67 register 00  | C0MDATA6700 |     |        |           | √       | Undefined             |
|   | 03FEC106H | CAN0 message data byte 6 register 00   | C0MDATA600  |     |        | √         |         | Undefined             |
|   | 03FEC107H | CAN0 message data byte 7 register 00   | C0MDATA700  |     |        | √         |         | Undefined             |
| ( | 3FEC108H  | CAN0 message data length register 00   | C0MDLC00    |     |        | √         |         | 0000xxxxB             |
| ( | 3FEC109H  | CAN0 message configuration register 00 | C0MCONF00   |     |        | √         |         | Undefined             |
| ( | 3FEC10AH  | CAN0 message identifier register 00    | C0MIDL00    |     |        |           | √       | Undefined             |
| ( | 3FEC10CH  |                                        | C0MIDH00    |     |        |           | √       | Undefined             |
| ( | 3FEC10EH  | CAN0 message control register 00       | COMCTRL00   |     |        |           | √       | 00x00000<br>000xx000B |
| ( | 3FEC120H  | CAN0 message data byte 01 register 01  | C0MDATA0101 |     |        |           | √       | Undefined             |
|   | 03FEC120H | CAN0 message data byte 0 register 01   | C0MDATA001  |     |        | √         |         | Undefined             |
|   | 03FEC121H | CAN0 message data byte 1 register 01   | C0MDATA101  |     |        | √         |         | Undefined             |
| ( | 3FEC122H  | CAN0 message data byte 23 register 01  | C0MDATA2301 |     |        |           | √       | Undefined             |
|   | 03FEC122H | CAN0 message data byte 2 register 01   | C0MDATA201  |     |        | √         |         | Undefined             |
|   | 03FEC123H | CAN0 message data byte 3 register 01   | C0MDATA301  |     |        | √         |         | Undefined             |
| ( | 3FEC124H  | CAN0 message data byte 45 register 01  | C0MDATA4501 |     |        |           | √       | Undefined             |
|   | 03FEC124H | CAN0 message data byte 4 register 01   | C0MDATA401  |     |        | √         |         | Undefined             |
|   | 03FEC125H | CAN0 message data byte 5 register 01   | C0MDATA501  |     |        | √         |         | Undefined             |
| ( | 3FEC126H  | CAN0 message data byte 67 register 01  | C0MDATA6701 |     |        |           | √       | Undefined             |
|   | 03FEC126H | CAN0 message data byte 6 register 01   | C0MDATA601  |     |        | √         |         | Undefined             |
|   | 03FEC127H | CAN0 message data byte 7 register 01   | C0MDATA701  |     |        | √         |         | Undefined             |
| ( | 3FEC128H  | CAN0 message data length register 01   | C0MDLC01    |     |        | <b>V</b>  |         | 0000xxxxB             |
| ( | 3FEC129H  | CAN0 message configuration register 01 | C0MCONF01   |     |        | √         |         | Undefined             |
| ( | 3FEC12AH  | CAN0 message identifier register 01    | C0MIDL01    |     |        |           | √       | Undefined             |
| ( | 3FEC12CH  |                                        | C0MIDH01    |     |        |           | √       | Undefined             |
| ( | 3FEC12EH  | CAN0 message control register 01       | C0MCTRL01   |     |        |           | √       | 00x00000<br>000xx000B |

Table 19-16. Register Access Types (3/17)

| Address   | Register Name                          | Symbol      | R/W | Bit Ma | nipulatio    | n Units | After Reset |
|-----------|----------------------------------------|-------------|-----|--------|--------------|---------|-------------|
|           |                                        |             |     | 1 Bit  | 8 Bits       | 16 Bits |             |
| 03FEC140H | CAN0 message data byte 01 register 02  | C0MDATA0102 | R/W |        |              | √       | Undefined   |
| 03FEC140H | CAN0 message data byte 0 register 02   | C0MDATA002  |     |        | $\checkmark$ |         | Undefined   |
| 03FEC141H | CAN0 message data byte 1 register 02   | C0MDATA102  |     |        | √            |         | Undefined   |
| 03FEC142H | CAN0 message data byte 23 register 02  | C0MDATA2302 |     |        |              | √       | Undefined   |
| 03FEC142H | CAN0 message data byte 2 register 02   | C0MDATA202  |     |        | √            |         | Undefined   |
| 03FEC143H | CAN0 message data byte 3 register 02   | C0MDATA302  |     |        | $\checkmark$ |         | Undefined   |
| 03FEC144H | CAN0 message data byte 45 register 02  | C0MDATA4502 |     |        |              | √       | Undefined   |
| 03FEC144H | CAN0 message data byte 4 register 02   | C0MDATA402  |     |        | √            |         | Undefined   |
| 03FEC145H | CAN0 message data byte 5 register 02   | C0MDATA502  |     |        | $\checkmark$ |         | Undefined   |
| 03FEC146H | CAN0 message data byte 67 register 02  | C0MDATA6702 |     |        |              | √       | Undefined   |
| 03FEC146H | CAN0 message data byte 6 register 02   | C0MDATA602  |     |        | √            |         | Undefined   |
| 03FEC147H | CAN0 message data byte 7 register 02   | C0MDATA702  |     |        | √            |         | Undefined   |
| 03FEC148H | CAN0 message data length register 02   | C0MDLC02    |     |        | √            |         | 0000xxxxB   |
| 03FEC149H | CAN0 message configuration register 02 | C0MCONF02   |     |        | <b>√</b>     |         | Undefined   |
| 03FEC14AH | CAN0 message identifier register 02    | C0MIDL02    |     |        |              | √       | Undefined   |
| 03FEC14CH |                                        | C0MIDH02    |     |        |              | √       | Undefined   |
| 03FEC14EH | CAN0 message control register 02       | C0MCTRL02   |     |        |              | √       | 00x00000    |
|           |                                        |             |     |        |              |         | 000xx000B   |
| 03FEC160H | CAN0 message data byte 01 register 03  | C0MDATA0103 |     |        |              | √       | Undefined   |
| 03FEC160H | CAN0 message data byte 0 register 03   | C0MDATA003  |     |        | √            |         | Undefined   |
| 03FEC161H | CAN0 message data byte 1 register 03   | C0MDATA103  |     |        | √            |         | Undefined   |
| 03FEC162H | CAN0 message data byte 23 register 03  | C0MDATA2303 |     |        |              | √       | Undefined   |
| 03FEC162H | CAN0 message data byte 2 register 03   | C0MDATA203  |     |        | √            |         | Undefined   |
| 03FEC163H | CAN0 message data byte 3 register 03   | C0MDATA303  |     |        | √            |         | Undefined   |
| 03FEC164H | CAN0 message data byte 45 register 03  | C0MDATA4503 |     |        |              | √       | Undefined   |
| 03FEC164H | CAN0 message data byte 4 register 03   | C0MDATA403  |     |        | √            |         | Undefined   |
| 03FEC165H | CAN0 message data byte 5 register 03   | C0MDATA503  |     |        | √            |         | Undefined   |
| 03FEC166H | CAN0 message data byte 67 register 03  | C0MDATA6703 |     |        |              | √       | Undefined   |
| 03FEC166H | CAN0 message data byte 6 register 03   | C0MDATA603  |     |        | √            |         | Undefined   |
| 03FEC167H | CAN0 message data byte 7 register 03   | C0MDATA703  |     |        | $\sqrt{}$    |         | Undefined   |
| 03FEC168H | CAN0 message data length register 03   | C0MDLC03    |     |        | $\sqrt{}$    |         | 0000xxxxB   |
| 03FEC169H | CAN0 message configuration register 03 | C0MCONF03   |     |        | $\sqrt{}$    |         | Undefined   |
| 03FEC16AH | CAN0 message identifier register 03    | C0MIDL03    |     |        |              | √       | Undefined   |
| 03FEC16CH |                                        | C0MIDH03    |     |        |              | √       | Undefined   |
| 03FEC16EH | CAN0 message control register 03       | C0MCTRL03   |     |        |              | √       | 00x00000    |
|           |                                        |             |     |        |              |         | 000xx000B   |

Table 19-16. Register Access Types (4/17)

|   | Address   | Register Name                          | Symbol      | R/W | Bit Ma | nipulatio | n Units      | After Reset |
|---|-----------|----------------------------------------|-------------|-----|--------|-----------|--------------|-------------|
|   |           |                                        |             |     | 1 Bit  | 8 Bits    | 16 Bits      |             |
| ( | 03FEC180H | CAN0 message data byte 01 register 04  | C0MDATA0104 | R/W |        |           | <b>√</b>     | Undefined   |
|   | 03FEC180H | CAN0 message data byte 0 register 04   | C0MDATA004  |     |        | $\sqrt{}$ |              | Undefined   |
|   | 03FEC181H | CAN0 message data byte 1 register 04   | C0MDATA104  |     |        | √         |              | Undefined   |
| ( | 03FEC182H | CAN0 message data byte 23 register 04  | C0MDATA2304 |     |        |           | <b>√</b>     | Undefined   |
|   | 03FEC182H | CAN0 message data byte 2 register 04   | C0MDATA204  |     |        | √         |              | Undefined   |
|   | 03FEC183H | CAN0 message data byte 3 register 04   | C0MDATA304  |     |        | <b>√</b>  |              | Undefined   |
| ( | 3FEC184H  | CAN0 message data byte 45 register 04  | C0MDATA4504 |     |        |           | <b>√</b>     | Undefined   |
|   | 03FEC184H | CAN0 message data byte 4 register 04   | C0MDATA404  |     |        | <b>V</b>  |              | Undefined   |
|   | 03FEC185H | CAN0 message data byte 5 register 04   | C0MDATA504  |     |        | $\sqrt{}$ |              | Undefined   |
| ( | 3FEC186H  | CAN0 message data byte 67 register 04  | C0MDATA6704 |     |        |           | <b>√</b>     | Undefined   |
|   | 03FEC186H | CAN0 message data byte 6 register 04   | C0MDATA604  |     |        | <b>V</b>  |              | Undefined   |
|   | 03FEC187H | CAN0 message data byte 7 register 04   | C0MDATA704  |     |        | <b>√</b>  |              | Undefined   |
| ( | 03FEC188H | CAN0 message data length register 04   | C0MDLC04    |     |        | <b>√</b>  |              | 0000xxxxB   |
| ( | 03FEC189H | CAN0 message configuration register 04 | C0MCONF04   |     |        | <b>√</b>  |              | Undefined   |
| ( | 3FEC18AH  | CAN0 message identifier register 04    | C0MIDL04    |     |        |           | <b>√</b>     | Undefined   |
| ( | 3FEC18CH  |                                        | C0MIDH04    |     |        |           | <b>√</b>     | Undefined   |
| ( | 3FEC18EH  | CAN0 message control register 04       | C0MCTRL04   |     |        |           | <b>√</b>     | 00x00000    |
|   |           |                                        |             |     |        |           |              | 000xx000B   |
| ( | 03FEC1A0H | CAN0 message data byte 01 register 05  | C0MDATA0105 |     |        |           | V            | Undefined   |
|   | 03FEC1A0H | CAN0 message data byte 0 register 05   | C0MDATA005  |     |        | √         |              | Undefined   |
|   | 03FEC1A1H | CAN0 message data byte 1 register 05   | C0MDATA105  |     |        | √         |              | Undefined   |
| ( | 3FEC1A2H  | CAN0 message data byte 23 register 05  | C0MDATA2305 |     |        |           | √            | Undefined   |
|   | 03FEC1A2H | CAN0 message data byte 2 register 05   | C0MDATA205  |     |        | √         |              | Undefined   |
|   | 03FEC1A3H | CAN0 message data byte 3 register 05   | C0MDATA305  |     |        | √         |              | Undefined   |
| ( | 3FEC1A4H  | CAN0 message data byte 45 register 05  | C0MDATA4505 |     |        |           | √            | Undefined   |
|   | 03FEC1A4H | CAN0 message data byte 4 register 05   | C0MDATA405  |     |        | √         |              | Undefined   |
| L | 03FEC1A5H | CAN0 message data byte 5 register 05   | C0MDATA505  |     |        | √         |              | Undefined   |
| ( | 3FEC1A6H  | CAN0 message data byte 67 register 05  | C0MDATA6705 |     |        |           | √            | Undefined   |
|   | 03FEC1A6H | CAN0 message data byte 6 register 05   | C0MDATA605  |     |        | √         |              | Undefined   |
|   | 03FEC1A7H | CAN0 message data byte 7 register 05   | C0MDATA705  |     |        | √         |              | Undefined   |
| ( | 03FEC1A8H | CAN0 message data length register 05   | C0MDLC05    |     |        | √         |              | 0000xxxxB   |
| ( | 03FEC1A9H | CAN0 message configuration register 05 | C0MCONF05   |     |        | √         |              | Undefined   |
| ( | 03FEC1AAH | CAN0 message identifier register 05    | C0MIDL05    |     |        |           | $\sqrt{}$    | Undefined   |
| ( | 03FEC1ACH |                                        | C0MIDH05    |     |        |           | $\sqrt{}$    | Undefined   |
| ( | 03FEC1AEH | CAN0 message control register 05       | C0MCTRL05   |     |        |           | $\checkmark$ | 00x00000    |
| L |           |                                        |             |     |        |           |              | 000xx000B   |

Table 19-16. Register Access Types (5/17)

| Address   | Register Name                          | Symbol      | R/W | Bit Manipulation Units |          | After Reset |           |
|-----------|----------------------------------------|-------------|-----|------------------------|----------|-------------|-----------|
|           |                                        |             |     | 1 Bit                  | 8 Bits   | 16 Bits     |           |
| 03FEC1C0H | CAN0 message data byte 01 register 06  | C0MDATA0106 | R/W |                        |          | √           | Undefined |
| 03FEC1C0H | CAN0 message data byte 0 register 06   | C0MDATA006  |     |                        | √        |             | Undefined |
| 03FEC1C1H | CAN0 message data byte 1 register 06   | C0MDATA106  |     |                        | <b>√</b> |             | Undefined |
| 03FEC1C2H | CAN0 message data byte 23 register 06  | C0MDATA2306 |     |                        |          | <b>V</b>    | Undefined |
| 03FEC1C2H | CAN0 message data byte 2 register 06   | C0MDATA206  |     |                        | √        |             | Undefined |
| 03FEC1C3H | CAN0 message data byte 3 register 06   | C0MDATA306  |     |                        | <b>√</b> |             | Undefined |
| 03FEC1C4H | CAN0 message data byte 45 register 06  | C0MDATA4506 |     |                        |          | <b>√</b>    | Undefined |
| 03FEC1C4H | CAN0 message data byte 4 register 06   | C0MDATA406  |     |                        | <b>V</b> |             | Undefined |
| 03FEC1C5H | CAN0 message data byte 5 register 06   | C0MDATA506  |     |                        | <b>√</b> |             | Undefined |
| 03FEC1C6H | CAN0 message data byte 67 register 06  | C0MDATA6706 |     |                        |          | <b>V</b>    | Undefined |
| 03FEC1C6H | CAN0 message data byte 6 register 06   | C0MDATA606  |     |                        | √        |             | Undefined |
| 03FEC1C7H | CAN0 message data byte 7 register 06   | C0MDATA706  |     |                        | <b>√</b> |             | Undefined |
| 03FEC1C8H | CAN0 message data length register 06   | C0MDLC06    |     |                        | √        |             | 0000xxxxB |
| 03FEC1C9H | CAN0 message configuration register 06 | C0MCONF06   |     |                        | √        |             | Undefined |
| 03FEC1CAH | CAN0 message identifier register 06    | C0MIDL06    |     |                        |          | √           | Undefined |
| 03FEC1CCH |                                        | C0MIDH06    |     |                        |          | <b>√</b>    | Undefined |
| 03FEC1CEH | CAN0 message control register 06       | C0MCTRL06   |     |                        |          | √           | 00x00000  |
|           |                                        |             |     |                        |          |             | 000xx000B |
| 03FEC1E0H | CAN0 message data byte 01 register 07  | C0MDATA0107 | -   |                        |          | √           | Undefined |
| 03FEC1E0H | CAN0 message data byte 0 register 07   | C0MDATA007  | -   |                        | √        |             | Undefined |
| 03FEC1E1H | CAN0 message data byte 1 register 07   | C0MDATA107  |     |                        | √        |             | Undefined |
| 03FEC1E2H | CAN0 message data byte 23 register 07  | C0MDATA2307 |     |                        |          | √           | Undefined |
| 03FEC1E2H | CAN0 message data byte 2 register 07   | C0MDATA207  |     |                        | √        |             | Undefined |
| 03FEC1E3H | CAN0 message data byte 3 register 07   | C0MDATA307  |     |                        | √        |             | Undefined |
| 03FEC1E4H | CAN0 message data byte 45 register 07  | C0MDATA4507 |     |                        |          | √           | Undefined |
| 03FEC1E4H | CAN0 message data byte 4 register 07   | C0MDATA407  |     |                        | √        |             | Undefined |
| 03FEC1E5H | CAN0 message data byte 5 register 07   | C0MDATA507  |     |                        | √        |             | Undefined |
| 03FEC1E6H | CAN0 message data byte 67 register 07  | C0MDATA6707 |     |                        |          | $\sqrt{}$   | Undefined |
| 03FEC1E6H | CAN0 message data byte 6 register 07   | C0MDATA607  |     |                        | √        |             | Undefined |
| 03FEC1E7H | CAN0 message data byte 7 register 07   | C0MDATA707  |     |                        | √        |             | Undefined |
| 03FEC1E8H | CAN0 message data length register 07   | C0MDLC07    |     |                        | √        |             | 0000xxxxB |
| 03FEC1E9H | CAN0 message configuration register 07 | C0MCONF07   |     |                        | √        |             | Undefined |
| 03FEC1EAH | CAN0 message identifier register 07    | C0MIDL07    |     |                        |          | <b>V</b>    | Undefined |
| 03FEC1ECH |                                        | C0MIDH07    |     |                        |          | √           | Undefined |
| 03FEC1EEH | CAN0 message control register 07       | C0MCTRL07   |     |                        |          | √           | 00x00000  |
|           |                                        |             |     |                        |          |             | 000xx000B |

Table 19-16. Register Access Types (6/17)

| Address   | Register Name                          | Symbol      | R/W | Bit Ma | nipulatio | n Units | After Reset |
|-----------|----------------------------------------|-------------|-----|--------|-----------|---------|-------------|
|           |                                        |             |     | 1 Bit  | 8 Bits    | 16 Bits |             |
| 03FEC200H | CAN0 message data byte 01 register 08  | C0MDATA0108 | R/W |        |           | √       | Undefined   |
| 03FEC200H | CAN0 message data byte 0 register 08   | C0MDATA008  |     |        | √         |         | Undefined   |
| 03FEC201H | CAN0 message data byte 1 register 08   | C0MDATA108  |     |        | √         |         | Undefined   |
| 03FEC202H | CAN0 message data byte 23 register 08  | C0MDATA2308 |     |        |           | √       | Undefined   |
| 03FEC202H | CAN0 message data byte 2 register 08   | C0MDATA208  |     |        | √         |         | Undefined   |
| 03FEC203H | CAN0 message data byte 3 register 08   | C0MDATA308  |     |        | √         |         | Undefined   |
| 03FEC204H | CAN0 message data byte 45 register 08  | C0MDATA4508 |     |        |           | √       | Undefined   |
| 03FEC204H | CAN0 message data byte 4 register 08   | C0MDATA408  |     |        | √         |         | Undefined   |
| 03FEC205H | CAN0 message data byte 5 register 08   | C0MDATA508  |     |        | √         |         | Undefined   |
| 03FEC206H | CAN0 message data byte 67 register 08  | C0MDATA6708 |     |        |           | √       | Undefined   |
| 03FEC206H | CAN0 message data byte 6 register 08   | C0MDATA608  |     |        | √         |         | Undefined   |
| 03FEC207H | CAN0 message data byte 7 register 08   | C0MDATA708  |     |        | √         |         | Undefined   |
| 03FEC208H | CAN0 message data length register 08   | C0MDLC08    |     |        | √         |         | 0000xxxxB   |
| 03FEC209H | CAN0 message configuration register 08 | C0MCONF08   |     |        | √         |         | Undefined   |
| 03FEC20AH | CAN0 message identifier register 08    | C0MIDL08    |     |        |           | √       | Undefined   |
| 03FEC20CH |                                        | C0MIDH08    |     |        |           | √       | Undefined   |
| 03FEC20EH | CAN0 message control register 08       | C0MCTRL08   |     |        |           | √       | 00x00000    |
|           |                                        |             |     |        |           |         | 000xx000B   |
| 03FEC220H | CAN0 message data byte 01 register 09  | C0MDATA0109 |     |        |           | √       | Undefined   |
| 03FEC220H | CAN0 message data byte 0 register 09   | C0MDATA009  |     |        | √         |         | Undefined   |
| 03FEC221H | CAN0 message data byte 1 register 09   | C0MDATA109  |     |        | √         |         | Undefined   |
| 03FEC222H | CAN0 message data byte 23 register 09  | C0MDATA2309 |     |        |           | √       | Undefined   |
| 03FEC222H | CAN0 message data byte 2 register 09   | C0MDATA209  |     |        | √         |         | Undefined   |
| 03FEC223H | CAN0 message data byte 3 register 09   | C0MDATA309  |     |        | √         |         | Undefined   |
| 03FEC224H | CAN0 message data byte 45 register 09  | C0MDATA4509 |     |        |           | √       | Undefined   |
| 03FEC224H | CAN0 message data byte 4 register 09   | C0MDATA409  |     |        | √         |         | Undefined   |
| 03FEC225H | CAN0 message data byte 5 register 09   | C0MDATA509  |     |        | √         |         | Undefined   |
| 03FEC226H | CAN0 message data byte 67 register 09  | C0MDATA6709 |     |        |           | √       | Undefined   |
| 03FEC226H | CAN0 message data byte 6 register 09   | C0MDATA609  |     |        | √         |         | Undefined   |
| 03FEC227H | CAN0 message data byte 7 register 09   | C0MDATA709  |     |        | √         |         | Undefined   |
| 03FEC228H | CAN0 message data length register 09   | C0MDLC09    |     |        | √         |         | 0000xxxxB   |
| 03FEC229H | CAN0 message configuration register 09 | C0MCONF09   |     |        | √         |         | Undefined   |
| 03FEC22AH | CAN0 message identifier register 09    | C0MIDL09    |     |        |           | √       | Undefined   |
| 03FEC22CH |                                        | C0MIDH09    |     |        |           | √       | Undefined   |
| 03FEC22EH | CAN0 message control register 09       | C0MCTRL09   |     |        |           | √       | 00x00000    |
|           |                                        |             |     |        |           |         | 000xx000B   |

Table 19-16. Register Access Types (7/17)

| Address   | Register Name                          | Symbol      | R/W | Bit Ma | Bit Manipulation Units  1 Bit 8 Bits 16 Bits |          | After Reset           |
|-----------|----------------------------------------|-------------|-----|--------|----------------------------------------------|----------|-----------------------|
|           |                                        |             |     | 1 Bit  |                                              |          |                       |
| 03FEC240H | CAN0 message data byte 01 register 10  | C0MDATA0110 | R/W |        |                                              | √        | Undefined             |
| 03FEC240H | CAN0 message data byte 0 register 10   | C0MDATA010  |     |        | √                                            |          | Undefined             |
| 03FEC241H | CAN0 message data byte 1 register 10   | C0MDATA110  |     |        | <b>V</b>                                     |          | Undefined             |
| 03FEC242H | CAN0 message data byte 23 register 10  | C0MDATA2310 |     |        |                                              | √        | Undefined             |
| 03FEC242H | CAN0 message data byte 2 register 10   | C0MDATA210  |     |        | √                                            |          | Undefined             |
| 03FEC243H | CAN0 message data byte 3 register 10   | C0MDATA310  |     |        | <b>V</b>                                     |          | Undefined             |
| 03FEC244H | CAN0 message data byte 45 register 10  | C0MDATA4510 |     |        |                                              | √        | Undefined             |
| 03FEC244H | CAN0 message data byte 4 register 10   | C0MDATA410  |     |        | <b>V</b>                                     |          | Undefined             |
| 03FEC245H | CAN0 message data byte 5 register 10   | C0MDATA510  |     |        | √                                            |          | Undefined             |
| 03FEC246H | CAN0 message data byte 67 register 10  | C0MDATA6710 |     |        |                                              | √        | Undefined             |
| 03FEC246H | CAN0 message data byte 6 register 10   | C0MDATA610  |     |        | <b>V</b>                                     |          | Undefined             |
| 03FEC247H | CAN0 message data byte 7 register 10   | C0MDATA710  |     |        | <b>V</b>                                     |          | Undefined             |
| 03FEC248H | CAN0 message data length register 10   | C0MDLC10    |     |        | √                                            |          | 0000xxxxB             |
| 03FEC249H | CAN0 message configuration register 10 | C0MCONF10   |     |        | √                                            |          | Undefined             |
| 03FEC24AH | CAN0 message identifier register 10    | C0MIDL10    |     |        |                                              | √        | Undefined             |
| 03FEC24CH |                                        | C0MIDH10    |     |        |                                              | √        | Undefined             |
| 03FEC24EH | CAN0 message control register 10       | C0MCTRL10   |     |        |                                              | √        | 00x00000<br>000xx000B |
| 03FEC260H | CAN0 message data byte 01 register 11  | C0MDATA0111 |     |        |                                              | √        | Undefined             |
| 03FEC260H | CAN0 message data byte 0 register 11   | C0MDATA011  |     |        | √                                            |          | Undefined             |
| 03FEC261H | CAN0 message data byte 1 register 11   | C0MDATA111  |     |        | <b>V</b>                                     |          | Undefined             |
| 03FEC262H | CAN0 message data byte 23 register 11  | C0MDATA2311 |     |        |                                              | √        | Undefined             |
| 03FEC262H | CAN0 message data byte 2 register 11   | C0MDATA211  |     |        | √                                            |          | Undefined             |
| 03FEC263H | CAN0 message data byte 3 register 11   | C0MDATA311  |     |        | <b>V</b>                                     |          | Undefined             |
| 03FEC264H | CAN0 message data byte 45 register 11  | C0MDATA4511 |     |        |                                              | √        | Undefined             |
| 03FEC264H | CAN0 message data byte 4 register 11   | C0MDATA411  | 1   |        | √                                            |          | Undefined             |
| 03FEC265H | CAN0 message data byte 5 register 11   | C0MDATA511  | 1   |        | √                                            |          | Undefined             |
| 03FEC266H | CAN0 message data byte 67 register 11  | C0MDATA6711 | 1   |        |                                              | √        | Undefined             |
| 03FEC266H | CAN0 message data byte 6 register 11   | C0MDATA611  | 1   |        | √                                            |          | Undefined             |
| 03FEC267H | CAN0 message data byte 7 register 11   | C0MDATA711  | 1   |        | √                                            |          | Undefined             |
| 03FEC268H | CAN0 message data length register 11   | C0MDLC11    | 1   |        | √                                            |          | 0000xxxxB             |
| 03FEC269H | CAN0 message configuration register 11 | C0MCONF11   | 1   |        | √                                            |          | Undefined             |
| 03FEC26AH | CAN0 message identifier register 11    | C0MIDL11    | 1   |        |                                              | √        | Undefined             |
| 03FEC26CH | 1                                      | C0MIDH11    | 1   |        |                                              | √        | Undefined             |
| 03FEC26EH | CAN0 message control register 11       | C0MCTRL11   |     |        |                                              | <b>V</b> | 00x00000<br>000xx000B |

Table 19-16. Register Access Types (8/17)

| Address   | Register Name                          | Symbol      | R/W | Bit Manipulation Units |        | After Reset |           |
|-----------|----------------------------------------|-------------|-----|------------------------|--------|-------------|-----------|
|           |                                        |             |     | 1 Bit                  | 8 Bits | 16 Bits     |           |
| 03FEC280H | CAN0 message data byte 01 register 12  | C0MDATA0112 | R/W |                        |        | √           | Undefined |
| 03FEC280H | CAN0 message data byte 0 register 12   | C0MDATA012  |     |                        | √      |             | Undefined |
| 03FEC281H | CAN0 message data byte 1 register 12   | C0MDATA112  |     |                        | √      |             | Undefined |
| 03FEC282H | CAN0 message data byte 23 register 12  | C0MDATA2312 |     |                        |        | √           | Undefined |
| 03FEC282H | CAN0 message data byte 2 register 12   | C0MDATA212  |     |                        | √      |             | Undefined |
| 03FEC283H | CAN0 message data byte 3 register 12   | C0MDATA312  |     |                        | √      |             | Undefined |
| 03FEC284H | CAN0 message data byte 45 register 12  | C0MDATA4512 |     |                        |        | √           | Undefined |
| 03FEC284H | CAN0 message data byte 4 register 12   | C0MDATA412  |     |                        | √      |             | Undefined |
| 03FEC285H | CAN0 message data byte 5 register 12   | C0MDATA512  |     |                        | √      |             | Undefined |
| 03FEC286H | CAN0 message data byte 67 register 12  | C0MDATA6712 |     |                        |        | √           | Undefined |
| 03FEC286H | CAN0 message data byte 6 register 12   | C0MDATA612  |     |                        | √      |             | Undefined |
| 03FEC287H | CAN0 message data byte 7 register 12   | C0MDATA712  |     |                        | √      |             | Undefined |
| 03FEC288H | CAN0 message data length register 12   | C0MDLC12    |     |                        | √      |             | 0000xxxxB |
| 03FEC289H | CAN0 message configuration register 12 | C0MCONF12   |     |                        | √      |             | Undefined |
| 03FEC28AH | CAN0 message identifier register 12    | C0MIDL12    |     |                        |        | √           | Undefined |
| 03FEC28CH |                                        | C0MIDH12    |     |                        |        | √           | Undefined |
| 03FEC28EH | CAN0 message control register 12       | C0MCTRL12   |     |                        |        | √           | 00x00000  |
|           |                                        |             |     |                        |        |             | 000xx000B |
| 03FEC2A0H | CAN0 message data byte 01 register 13  | C0MDATA0113 |     |                        |        | √           | Undefined |
| 03FEC2A0H | CAN0 message data byte 0 register 13   | C0MDATA013  |     |                        | √      |             | Undefined |
| 03FEC2A1H | CAN0 message data byte 1 register 13   | C0MDATA113  |     |                        | √      |             | Undefined |
| 03FEC2A2H | CAN0 message data byte 23 register 13  | C0MDATA2313 |     |                        |        | √           | Undefined |
| 03FEC2A2H | CAN0 message data byte 2 register 13   | C0MDATA213  |     |                        | √      |             | Undefined |
| 03FEC2A3H | CAN0 message data byte 3 register 13   | C0MDATA313  |     |                        | √      |             | Undefined |
| 03FEC2A4H | CAN0 message data byte 45 register 13  | C0MDATA4513 |     |                        |        | √           | Undefined |
| 03FEC2A4H | CAN0 message data byte 4 register 13   | C0MDATA413  |     |                        | √      |             | Undefined |
| 03FEC2A5H | CAN0 message data byte 5 register 13   | C0MDATA513  |     |                        | √      |             | Undefined |
| 03FEC2A6H | CAN0 message data byte 67 register 13  | C0MDATA6713 |     |                        |        | √           | Undefined |
| 03FEC2A6H | CAN0 message data byte 6 register 13   | C0MDATA613  |     |                        | √      |             | Undefined |
| 03FEC2A7H | CAN0 message data byte 7 register 13   | C0MDATA713  |     |                        | √      |             | Undefined |
| 03FEC2A8H | CAN0 message data length register 13   | C0MDLC13    |     |                        | √      |             | 0000xxxxB |
| 03FEC2A9H | CAN0 message configuration register 13 | C0MCONF13   |     |                        | √      |             | Undefined |
| 03FEC2AAH | CAN0 message identifier register 13    | C0MIDL13    |     |                        |        | √           | Undefined |
| 03FEC2ACH |                                        | C0MIDH13    |     |                        |        | √           | Undefined |
| 03FEC2AEH | CAN0 message control register 13       | C0MCTRL13   |     |                        |        | √           | 00x00000  |
|           |                                        |             |     |                        |        |             | 000xx000B |

Table 19-16. Register Access Types (9/17)

| Address   | Register Name                          | Symbol      | R/W | Bit Manipulation Units |          | After Reset  |           |
|-----------|----------------------------------------|-------------|-----|------------------------|----------|--------------|-----------|
|           |                                        |             |     | 1 Bit                  | 8 Bits   | 16 Bits      |           |
| 03FEC2C0H | CAN0 message data byte 01 register 14  | C0MDATA0114 | R/W |                        |          | $\checkmark$ | Undefined |
| 03FEC2C0H | CAN0 message data byte 0 register 14   | C0MDATA014  |     |                        | √        |              | Undefined |
| 03FEC2C1H | CAN0 message data byte 1 register 14   | C0MDATA114  |     |                        | <b>√</b> |              | Undefined |
| 03FEC2C2H | CAN0 message data byte 23 register 14  | C0MDATA2314 |     |                        |          | <b>V</b>     | Undefined |
| 03FEC2C2H | CAN0 message data byte 2 register 14   | C0MDATA214  |     |                        | <b>V</b> |              | Undefined |
| 03FEC2C3H | CAN0 message data byte 3 register 14   | C0MDATA314  |     |                        | <b>√</b> |              | Undefined |
| 03FEC2C4H | CAN0 message data byte 45 register 14  | C0MDATA4514 |     |                        |          | √            | Undefined |
| 03FEC2C4H | CAN0 message data byte 4 register 14   | C0MDATA414  |     |                        | <b>V</b> |              | Undefined |
| 03FEC2C5H | CAN0 message data byte 5 register 14   | C0MDATA514  |     |                        | <b>√</b> |              | Undefined |
| 03FEC2C6H | CAN0 message data byte 67 register 14  | C0MDATA6714 |     |                        |          | √            | Undefined |
| 03FEC2C6H | CAN0 message data byte 6 register 14   | C0MDATA614  |     |                        | <b>V</b> |              | Undefined |
| 03FEC2C7H | CAN0 message data byte 7 register 14   | C0MDATA714  |     |                        | <b>√</b> |              | Undefined |
| 03FEC2C8H | CAN0 message data length register 14   | C0MDLC14    |     |                        | √        |              | 0000xxxxB |
| 03FEC2C9H | CAN0 message configuration register 14 | C0MCONF14   |     |                        | √        |              | Undefined |
| 03FEC2CAH | CAN0 message identifier register 14    | C0MIDL14    |     |                        |          | √            | Undefined |
| 03FEC2CCH |                                        | C0MIDH14    |     |                        |          | <b>√</b>     | Undefined |
| 03FEC2CEH | CAN0 message control register 14       | C0MCTRL14   |     |                        |          | √            | 00x00000  |
|           |                                        |             |     |                        |          |              | 000xx000B |
| 03FEC2E0H | CAN0 message data byte 01 register 15  | C0MDATA0115 | -   |                        |          | √            | Undefined |
| 03FEC2E0H | CAN0 message data byte 0 register 15   | C0MDATA015  | -   |                        | √        |              | Undefined |
| 03FEC2E1H | CAN0 message data byte 1 register 15   | C0MDATA115  | -   |                        | √        |              | Undefined |
| 03FEC2E2H | CAN0 message data byte 23 register 15  | C0MDATA2315 |     |                        |          | $\sqrt{}$    | Undefined |
| 03FEC2E2H | CAN0 message data byte 2 register 15   | C0MDATA215  |     |                        | √        |              | Undefined |
| 03FEC2E3H | CAN0 message data byte 3 register 15   | C0MDATA315  |     |                        | √        |              | Undefined |
| 03FEC2E4H | CAN0 message data byte 45 register 15  | C0MDATA4515 |     |                        |          | √            | Undefined |
| 03FEC2E4H | CAN0 message data byte 4 register 15   | C0MDATA415  |     |                        | √        |              | Undefined |
| 03FEC2E5H | CAN0 message data byte 5 register 15   | C0MDATA515  |     |                        | √        |              | Undefined |
| 03FEC2E6H | CAN0 message data byte 67 register 15  | C0MDATA6715 |     |                        |          | √            | Undefined |
| 03FEC2E6H | CAN0 message data byte 6 register 15   | C0MDATA615  |     |                        | √        |              | Undefined |
| 03FEC2E7H | CAN0 message data byte 7 register 15   | C0MDATA715  |     |                        | √        |              | Undefined |
| 03FEC2E8H | CAN0 message data length register 15   | C0MDLC15    |     |                        | √        |              | 0000xxxxB |
| 03FEC2E9H | CAN0 message configuration register 15 | C0MCONF15   |     |                        | √        |              | Undefined |
| 03FEC2EAH | CAN0 message identifier register 15    | C0MIDL15    |     |                        |          | √            | Undefined |
| 03FEC2ECH |                                        | C0MIDH15    |     |                        |          | √            | Undefined |
| 03FEC2EEH | CAN0 message control register 15       | C0MCTRL15   |     |                        |          | √            | 00x00000  |
|           |                                        |             |     |                        |          |              | 000xx000B |

Table 19-16. Register Access Types (10/17)

| Address   | Register Name                          | Symbol      | R/W | Bit Manipulation Units |        | After Reset |           |
|-----------|----------------------------------------|-------------|-----|------------------------|--------|-------------|-----------|
|           |                                        |             |     | 1 Bit                  | 8 Bits | 16 Bits     |           |
| 03FEC300H | CAN0 message data byte 01 register 16  | C0MDATA0116 | R/W |                        |        | √           | Undefined |
| 03FEC300H | CAN0 message data byte 0 register 16   | C0MDATA016  |     |                        | √      |             | Undefined |
| 03FEC301H | CAN0 message data byte 1 register 16   | C0MDATA116  |     |                        | √      |             | Undefined |
| 03FEC302H | CAN0 message data byte 23 register 16  | C0MDATA2316 |     |                        |        | √           | Undefined |
| 03FEC302H | CAN0 message data byte 2 register 16   | C0MDATA216  |     |                        | √      |             | Undefined |
| 03FEC303H | CAN0 message data byte 3 register 16   | C0MDATA316  |     |                        | √      |             | Undefined |
| 03FEC304H | CAN0 message data byte 45 register 16  | C0MDATA4516 |     |                        |        | √           | Undefined |
| 03FEC304H | CAN0 message data byte 4 register 16   | C0MDATA416  |     |                        | √      |             | Undefined |
| 03FEC305H | CAN0 message data byte 5 register 16   | C0MDATA516  |     |                        | √      |             | Undefined |
| 03FEC306H | CAN0 message data byte 67 register 16  | C0MDATA6716 |     |                        |        | √           | Undefined |
| 03FEC306H | CAN0 message data byte 6 register 16   | C0MDATA616  |     |                        | √      |             | Undefined |
| 03FEC307H | CAN0 message data byte 7 register 16   | C0MDATA716  |     |                        | √      |             | Undefined |
| 03FEC308H | CAN0 message data length register 16   | C0MDLC16    |     |                        | √      |             | 0000xxxxB |
| 03FEC309H | CAN0 message configuration register 16 | C0MCONF16   |     |                        | √      |             | Undefined |
| 03FEC30AH | CAN0 message identifier register 16    | C0MIDL16    |     |                        |        | √           | Undefined |
| 03FEC30CH | ]                                      | C0MIDH16    |     |                        |        | √           | Undefined |
| 03FEC30EH | CAN0 message control register 16       | C0MCTRL16   |     |                        |        | √           | 00x00000  |
|           |                                        |             |     |                        |        |             | 000xx000B |
| 03FEC320H | CAN0 message data byte 01 register 17  | C0MDATA0117 |     |                        |        | √           | Undefined |
| 03FEC320H | CAN0 message data byte 0 register 17   | C0MDATA017  |     |                        | √      |             | Undefined |
| 03FEC321H | CAN0 message data byte 1 register 17   | C0MDATA117  |     |                        | √      |             | Undefined |
| 03FEC322H | CAN0 message data byte 23 register 17  | C0MDATA2317 |     |                        |        | √           | Undefined |
| 03FEC322H | CAN0 message data byte 2 register 17   | C0MDATA217  |     |                        | √      |             | Undefined |
| 03FEC323H | CAN0 message data byte 3 register 17   | C0MDATA317  |     |                        | √      |             | Undefined |
| 03FEC324H | CAN0 message data byte 45 register 17  | C0MDATA4517 |     |                        |        | √           | Undefined |
| 03FEC324H | CAN0 message data byte 4 register 17   | C0MDATA417  |     |                        | √      |             | Undefined |
| 03FEC325H | CAN0 message data byte 5 register 17   | C0MDATA517  |     |                        | √      |             | Undefined |
| 03FEC326H | CAN0 message data byte 67 register 17  | C0MDATA6717 |     |                        |        | √           | Undefined |
| 03FEC326H | CAN0 message data byte 6 register 17   | C0MDATA617  |     |                        | √      |             | Undefined |
| 03FEC327H | CAN0 message data byte 7 register 17   | C0MDATA717  |     |                        | √      |             | Undefined |
| 03FEC328H | CAN0 message data length register 17   | C0MDLC17    |     |                        | √      |             | 0000xxxxB |
| 03FEC329H | CAN0 message configuration register 17 | C0MCONF17   |     |                        | √      |             | Undefined |
| 03FEC32AH | CAN0 message identifier register 17    | C0MIDL17    |     |                        |        | √           | Undefined |
| 03FEC32CH |                                        | C0MIDH17    |     |                        |        | √           | Undefined |
| 03FEC32EH | CAN0 message control register 17       | C0MCTRL17   |     |                        |        | √           | 00x00000  |
|           |                                        |             |     |                        |        |             | 000xx000B |

Table 19-16. Register Access Types (11/17)

| Address   | Register Name                          | Symbol      | R/W | Bit Manipulation Units |           | After Reset |           |
|-----------|----------------------------------------|-------------|-----|------------------------|-----------|-------------|-----------|
|           |                                        |             |     | 1 Bit                  | 8 Bits    | 16 Bits     |           |
| 03FEC340H | CAN0 message data byte 01 register 18  | C0MDATA0118 | R/W |                        |           | √           | Undefined |
| 03FEC340H | CAN0 message data byte 0 register 18   | C0MDATA018  |     |                        | √         |             | Undefined |
| 03FEC341H | CAN0 message data byte 1 register 18   | C0MDATA118  |     |                        | √         |             | Undefined |
| 03FEC342H | CAN0 message data byte 23 register 18  | C0MDATA2318 |     |                        |           | √           | Undefined |
| 03FEC342H | CAN0 message data byte 2 register 18   | C0MDATA218  |     |                        | √         |             | Undefined |
| 03FEC343H | CAN0 message data byte 3 register 18   | C0MDATA318  |     |                        | √         |             | Undefined |
| 03FEC344H | CAN0 message data byte 45 register 18  | C0MDATA4518 |     |                        |           | √           | Undefined |
| 03FEC344H | CAN0 message data byte 4 register 18   | C0MDATA418  |     |                        | √         |             | Undefined |
| 03FEC345H | CAN0 message data byte 5 register 18   | C0MDATA518  |     |                        | √         |             | Undefined |
| 03FEC346H | CAN0 message data byte 67 register 18  | C0MDATA6718 |     |                        |           | √           | Undefined |
| 03FEC346H | CAN0 message data byte 6 register 18   | C0MDATA618  |     |                        | √         |             | Undefined |
| 03FEC347H | CAN0 message data byte 7 register 18   | C0MDATA718  |     |                        | √         |             | Undefined |
| 03FEC348H | CAN0 message data length register 18   | C0MDLC18    |     |                        | √         |             | 0000xxxxB |
| 03FEC349H | CAN0 message configuration register 18 | C0MCONF18   |     |                        | √         |             | Undefined |
| 03FEC34AH | CAN0 message identifier register 18    | C0MIDL18    |     |                        |           | √           | Undefined |
| 03FEC34CH |                                        | C0MIDH18    |     |                        |           | √           | Undefined |
| 03FEC34EH | CAN0 message control register 18       | C0MCTRL18   |     |                        |           | √           | 00x00000  |
|           |                                        |             |     |                        |           |             | 000xx000B |
| 03FEC360H | CAN0 message data byte 01 register 19  | C0MDATA0119 | -   |                        |           | √           | Undefined |
| 03FEC360H | CAN0 message data byte 0 register 19   | C0MDATA019  | -   |                        | √         |             | Undefined |
| 03FEC361H | CAN0 message data byte 1 register 19   | C0MDATA119  |     |                        | √         |             | Undefined |
| 03FEC362H | CAN0 message data byte 23 register 19  | C0MDATA2319 |     |                        |           | √           | Undefined |
| 03FEC362H | CAN0 message data byte 2 register 19   | C0MDATA219  |     |                        | √         |             | Undefined |
| 03FEC363H | CAN0 message data byte 3 register 19   | C0MDATA319  |     |                        | √         |             | Undefined |
| 03FEC364H | CAN0 message data byte 45 register 19  | C0MDATA4519 |     |                        |           | √           | Undefined |
| 03FEC364H | CAN0 message data byte 4 register 19   | C0MDATA419  |     |                        | √         |             | Undefined |
| 03FEC365H | CAN0 message data byte 5 register 19   | C0MDATA519  |     |                        | √         |             | Undefined |
| 03FEC366H | CAN0 message data byte 67 register 19  | C0MDATA6719 |     |                        |           | $\sqrt{}$   | Undefined |
| 03FEC366H | CAN0 message data byte 6 register 19   | C0MDATA619  |     |                        | $\sqrt{}$ |             | Undefined |
| 03FEC367H | CAN0 message data byte 7 register 19   | C0MDATA719  |     |                        | √         |             | Undefined |
| 03FEC368H | CAN0 message data length register 19   | C0MDLC19    |     |                        | √         |             | 0000xxxxB |
| 03FEC369H | CAN0 message configuration register 19 | C0MCONF19   |     |                        | √         |             | Undefined |
| 03FEC36AH | CAN0 message identifier register 19    | C0MIDL19    |     |                        |           | √           | Undefined |
| 03FEC36CH |                                        | C0MIDH19    |     |                        |           | √           | Undefined |
| 03FEC36EH | CAN0 message control register 19       | C0MCTRL19   |     |                        |           | √           | 00x00000  |
|           |                                        |             |     |                        |           |             | 000xx000B |

Table 19-16. Register Access Types (12/17)

| Address   | Register Name                          | Symbol      | R/W | Bit Manipulation Units |        | After Reset |           |
|-----------|----------------------------------------|-------------|-----|------------------------|--------|-------------|-----------|
|           |                                        |             |     | 1 Bit                  | 8 Bits | 16 Bits     |           |
| 03FEC380H | CAN0 message data byte 01 register 20  | C0MDATA0120 | R/W |                        |        | √           | Undefined |
| 03FEC380H | CAN0 message data byte 0 register 20   | C0MDATA020  |     |                        | √      |             | Undefined |
| 03FEC381H | CAN0 message data byte 1 register 20   | C0MDATA120  |     |                        | √      |             | Undefined |
| 03FEC382H | CAN0 message data byte 23 register 20  | C0MDATA2320 |     |                        |        | √           | Undefined |
| 03FEC382H | CAN0 message data byte 2 register 20   | C0MDATA220  |     |                        | √      |             | Undefined |
| 03FEC383H | CAN0 message data byte 3 register 20   | C0MDATA320  |     |                        | √      |             | Undefined |
| 03FEC384H | CAN0 message data byte 45 register 20  | C0MDATA4520 |     |                        |        | √           | Undefined |
| 03FEC384H | CAN0 message data byte 4 register 20   | C0MDATA420  |     |                        | √      |             | Undefined |
| 03FEC385H | CAN0 message data byte 5 register 20   | C0MDATA520  |     |                        | √      |             | Undefined |
| 03FEC386H | CAN0 message data byte 67 register 20  | C0MDATA6720 |     |                        |        | √           | Undefined |
| 03FEC386H | CAN0 message data byte 6 register 20   | C0MDATA620  |     |                        | √      |             | Undefined |
| 03FEC387H | CAN0 message data byte 7 register 20   | C0MDATA720  |     |                        | √      |             | Undefined |
| 03FEC388H | CAN0 message data length register 20   | C0MDLC20    |     |                        | √      |             | 0000xxxxB |
| 03FEC389H | CAN0 message configuration register 20 | C0MCONF20   |     |                        | √      |             | Undefined |
| 03FEC38AH | CAN0 message identifier register 20    | C0MIDL20    |     |                        |        | √           | Undefined |
| 03FEC38CH |                                        | C0MIDH20    |     |                        |        | <b>V</b>    | Undefined |
| 03FEC38EH | CAN0 message control register 20       | C0MCTRL20   |     |                        |        | √           | 00x00000  |
|           |                                        |             |     |                        |        |             | 000xx000B |
| 03FEC3A0H | CAN0 message data byte 01 register 21  | C0MDATA0121 |     |                        |        | √           | Undefined |
| 03FEC3A0H | CAN0 message data byte 0 register 21   | C0MDATA021  | =   |                        | √      |             | Undefined |
| 03FEC3A1H | CAN0 message data byte 1 register 21   | C0MDATA121  |     |                        | √      |             | Undefined |
| 03FEC3A2H | CAN0 message data byte 23 register 21  | C0MDATA2321 |     |                        |        | √           | Undefined |
| 03FEC3A2H | CAN0 message data byte 2 register 21   | C0MDATA221  |     |                        | √      |             | Undefined |
| 03FEC3A3H | CAN0 message data byte 3 register 21   | C0MDATA321  |     |                        | √      |             | Undefined |
| 03FEC3A4H | CAN0 message data byte 45 register 21  | C0MDATA4521 |     |                        |        | √           | Undefined |
| 03FEC3A4H | CAN0 message data byte 4 register 21   | C0MDATA421  |     |                        | √      |             | Undefined |
| 03FEC3A5H | CAN0 message data byte 5 register 21   | C0MDATA521  |     |                        | √      |             | Undefined |
| 03FEC3A6H | CAN0 message data byte 67 register 21  | C0MDATA6721 |     |                        |        | √           | Undefined |
| 03FEC3A6H | CAN0 message data byte 6 register 21   | C0MDATA621  |     |                        | √      |             | Undefined |
| 03FEC3A7H | CAN0 message data byte 7 register 21   | C0MDATA721  |     |                        | √      |             | Undefined |
| 03FEC3A8H | CAN0 message data length register 21   | C0MDLC21    |     |                        | √      |             | 0000xxxxB |
| 03FEC3A9H | CAN0 message configuration register 21 | C0MCONF21   |     |                        | √      |             | Undefined |
| 03FEC3AAH | CAN0 message identifier register 21    | C0MIDL21    |     |                        |        | √           | Undefined |
| 03FEC3ACH |                                        | C0MIDH21    |     |                        |        | √           | Undefined |
| 03FEC3AEH | CAN0 message control register 21       | C0MCTRL21   |     |                        |        | √           | 00x00000  |
|           |                                        |             |     |                        |        |             | 000xx000B |

Table 19-16. Register Access Types (13/17)

| Address   | Register Name                          | Symbol      | R/W | Bit Ma | nipulatio | n Units   | After Reset |
|-----------|----------------------------------------|-------------|-----|--------|-----------|-----------|-------------|
|           |                                        |             |     | 1 Bit  | 8 Bits    | 16 Bits   |             |
| 03FEC3C0H | CAN0 message data byte 01 register 22  | C0MDATA0122 | R/W |        |           | √         | Undefined   |
| 03FEC3C0H | CAN0 message data byte 0 register 22   | C0MDATA022  |     |        | √         |           | Undefined   |
| 03FEC3C1H | CAN0 message data byte 1 register 22   | C0MDATA122  |     |        | √         |           | Undefined   |
| 03FEC3C2H | CAN0 message data byte 23 register 22  | C0MDATA2322 |     |        |           | √         | Undefined   |
| 03FEC3C2H | CAN0 message data byte 2 register 22   | C0MDATA222  |     |        | √         |           | Undefined   |
| 03FEC3C3H | CAN0 message data byte 3 register 22   | C0MDATA322  |     |        | √         |           | Undefined   |
| 03FEC3C4H | CAN0 message data byte 45 register 22  | C0MDATA4522 |     |        |           | √         | Undefined   |
| 03FEC3C4H | CAN0 message data byte 4 register 22   | C0MDATA422  |     |        | √         |           | Undefined   |
| 03FEC3C5H | CAN0 message data byte 5 register 22   | C0MDATA522  |     |        | √         |           | Undefined   |
| 03FEC3C6H | CAN0 message data byte 67 register 22  | C0MDATA6722 |     |        |           | √         | Undefined   |
| 03FEC3C6H | CAN0 message data byte 6 register 22   | C0MDATA622  |     |        | √         |           | Undefined   |
| 03FEC3C7H | CAN0 message data byte 7 register 22   | C0MDATA722  |     |        | √         |           | Undefined   |
| 03FEC3C8H | CAN0 message data length register 22   | C0MDLC22    |     |        | √         |           | 0000xxxxB   |
| 03FEC3C9H | CAN0 message configuration register 22 | C0MCONF22   |     |        | √         |           | Undefined   |
| 03FEC3CAH | CAN0 message identifier register 22    | C0MIDL22    |     |        |           | √         | Undefined   |
| 03FEC3CCH |                                        | C0MIDH22    |     |        |           | √         | Undefined   |
| 03FEC3CEH | CAN0 message control register 22       | C0MCTRL22   |     |        |           | √         | 00x00000    |
|           |                                        |             |     |        |           |           | 000xx000B   |
| 03FEC3E0H | CAN0 message data byte 01 register 23  | C0MDATA0123 |     |        |           | √         | Undefined   |
| 03FEC3E0H | CAN0 message data byte 0 register 23   | C0MDATA023  |     |        | √         |           | Undefined   |
| 03FEC3E1H | CAN0 message data byte 1 register 23   | C0MDATA123  |     |        | √         |           | Undefined   |
| 03FEC3E2H | CAN0 message data byte 23 register 23  | C0MDATA2323 |     |        |           | √         | Undefined   |
| 03FEC3E2H | CAN0 message data byte 2 register 23   | C0MDATA223  |     |        | √         |           | Undefined   |
| 03FEC3E3H | CAN0 message data byte 3 register 23   | C0MDATA323  |     |        | √         |           | Undefined   |
| 03FEC3E4H | CAN0 message data byte 45 register 23  | C0MDATA4523 |     |        |           | √         | Undefined   |
| 03FEC3E4H | CAN0 message data byte 4 register 23   | C0MDATA423  |     |        | √         |           | Undefined   |
| 03FEC3E5H | CAN0 message data byte 5 register 23   | C0MDATA523  |     |        | √         |           | Undefined   |
| 03FEC3E6H | CAN0 message data byte 67 register 23  | C0MDATA6723 |     |        |           | $\sqrt{}$ | Undefined   |
| 03FEC3E6H | CAN0 message data byte 6 register 23   | C0MDATA623  |     |        | $\sqrt{}$ |           | Undefined   |
| 03FEC3E7H | CAN0 message data byte 7 register 23   | C0MDATA723  |     |        | √         |           | Undefined   |
| 03FEC3E8H | CAN0 message data length register 23   | C0MDLC23    |     |        | √         |           | 0000xxxxB   |
| 03FEC3E9H | CAN0 message configuration register 23 | C0MCONF23   |     |        | √         |           | Undefined   |
| 03FEC3EAH | CAN0 message identifier register 23    | C0MIDL23    |     |        |           | √         | Undefined   |
| 03FEC3ECH |                                        | C0MIDH23    |     |        |           | √         | Undefined   |
| 03FEC3EEH | CAN0 message control register 23       | C0MCTRL23   |     |        |           | √         | 00x00000    |
|           |                                        |             |     |        |           |           | 000xx000B   |

Table 19-16. Register Access Types (14/17)

| Γ | Address   | Register Name                          | Symbol      | R/W | Bit Mai | nipulatio    | n Units      | After Reset |
|---|-----------|----------------------------------------|-------------|-----|---------|--------------|--------------|-------------|
|   |           |                                        |             |     | 1 Bit   | 8 Bits       | 16 Bits      |             |
| ( | O3FEC400H | CAN0 message data byte 01 register 24  | C0MDATA0124 | R/W |         |              | <b>V</b>     | Undefined   |
|   | 03FEC400H | CAN0 message data byte 0 register 24   | C0MDATA024  |     |         | $\checkmark$ |              | Undefined   |
|   | 03FEC401H | CAN0 message data byte 1 register 24   | C0MDATA124  |     |         | √            |              | Undefined   |
| ( | 03FEC402H | CAN0 message data byte 23 register 24  | C0MDATA2324 |     |         |              | <b>V</b>     | Undefined   |
|   | 03FEC402H | CAN0 message data byte 2 register 24   | C0MDATA224  |     |         | √            |              | Undefined   |
|   | 03FEC403H | CAN0 message data byte 3 register 24   | C0MDATA324  |     |         | $\checkmark$ |              | Undefined   |
| ( | 03FEC404H | CAN0 message data byte 45 register 24  | C0MDATA4524 |     |         |              | $\checkmark$ | Undefined   |
|   | 03FEC404H | CAN0 message data byte 4 register 24   | C0MDATA424  |     |         | √            |              | Undefined   |
|   | 03FEC405H | CAN0 message data byte 5 register 24   | C0MDATA524  |     |         | $\checkmark$ |              | Undefined   |
| ( | 03FEC406H | CAN0 message data byte 67 register 24  | C0MDATA6724 |     |         |              | <b>V</b>     | Undefined   |
|   | 03FEC406H | CAN0 message data byte 6 register 24   | C0MDATA624  |     |         | <b>√</b>     |              | Undefined   |
|   | 03FEC407H | CAN0 message data byte 7 register 24   | C0MDATA724  |     |         | $\checkmark$ |              | Undefined   |
| ( | 03FEC408H | CAN0 message data length register 24   | C0MDLC24    |     |         | √            |              | 0000xxxxB   |
| ( | 03FEC409H | CAN0 message configuration register 24 | C0MCONF24   |     |         | √            |              | Undefined   |
| ( | 03FEC40AH | CAN0 message identifier register 24    | C0MIDL24    |     |         |              | <b>V</b>     | Undefined   |
| ( | 03FEC40CH |                                        | C0MIDH24    |     |         |              | <b>V</b>     | Undefined   |
| ( | 03FEC40EH | CAN0 message control register 24       | C0MCTRL24   |     |         |              | <b>V</b>     | 00x00000    |
|   |           |                                        |             |     |         |              |              | 000xx000B   |
| ľ | 03FEC420H | CAN0 message data byte 01 register 25  | C0MDATA0125 |     |         |              | √            | Undefined   |
|   | 03FEC420H | CAN0 message data byte 0 register 25   | C0MDATA025  |     |         | √            |              | Undefined   |
|   | 03FEC421H | CAN0 message data byte 1 register 25   | C0MDATA125  |     |         | √            |              | Undefined   |
| ( | 03FEC422H | CAN0 message data byte 23 register 25  | C0MDATA2325 |     |         |              | √            | Undefined   |
|   | 03FEC422H | CAN0 message data byte 2 register 25   | C0MDATA225  |     |         | √            |              | Undefined   |
|   | 03FEC423H | CAN0 message data byte 3 register 25   | C0MDATA325  |     |         | √            |              | Undefined   |
| ( | 03FEC424H | CAN0 message data byte 45 register 25  | C0MDATA4525 |     |         |              | √            | Undefined   |
|   | 03FEC424H | CAN0 message data byte 4 register 25   | C0MDATA425  |     |         | √            |              | Undefined   |
|   | 03FEC425H | CAN0 message data byte 5 register 25   | C0MDATA525  |     |         | √            |              | Undefined   |
| ( | 03FEC426H | CAN0 message data byte 67 register 25  | C0MDATA6725 |     |         |              | √            | Undefined   |
|   | 03FEC426H | CAN0 message data byte 6 register 25   | C0MDATA625  |     |         | √            |              | Undefined   |
|   | 03FEC427H | CAN0 message data byte 7 register 25   | C0MDATA725  |     |         | $\sqrt{}$    |              | Undefined   |
| ( | 03FEC428H | CAN0 message data length register 25   | C0MDLC25    |     |         | $\checkmark$ |              | 0000xxxxB   |
| ( | 03FEC429H | CAN0 message configuration register 25 | C0MCONF25   |     |         | $\sqrt{}$    |              | Undefined   |
| ( | 03FEC42AH | CAN0 message identifier register 25    | C0MIDL25    |     |         |              | $\sqrt{}$    | Undefined   |
| Ĺ | 03FEC42CH |                                        | C0MIDH25    |     |         |              | $\sqrt{}$    | Undefined   |
| ( | 03FEC42EH | CAN0 message control register 25       | C0MCTRL25   |     |         |              | <b>√</b>     | 00x00000    |
| L |           |                                        |             |     |         |              |              | 000xx000B   |

Table 19-16. Register Access Types (15/17)

| Address   | Register Name                          | Symbol      | R/W | Bit Ma | nipulatio | n Units   | After Reset |
|-----------|----------------------------------------|-------------|-----|--------|-----------|-----------|-------------|
|           |                                        |             |     | 1 Bit  | 8 Bits    | 16 Bits   |             |
| 03FEC440H | CAN0 message data byte 01 register 26  | C0MDATA0126 | R/W |        |           | √         | Undefined   |
| 03FEC440H | CAN0 message data byte 0 register 26   | C0MDATA026  |     |        | √         |           | Undefined   |
| 03FEC441H | CAN0 message data byte 1 register 26   | C0MDATA126  |     |        | <b>√</b>  |           | Undefined   |
| 03FEC442H | CAN0 message data byte 23 register 26  | C0MDATA2326 |     |        |           | √         | Undefined   |
| 03FEC442H | CAN0 message data byte 2 register 26   | C0MDATA226  |     |        | √         |           | Undefined   |
| 03FEC443H | CAN0 message data byte 3 register 26   | C0MDATA326  |     |        | <b>√</b>  |           | Undefined   |
| 03FEC444H | CAN0 message data byte 45 register 26  | C0MDATA4526 |     |        |           | √         | Undefined   |
| 03FEC444H | CAN0 message data byte 4 register 26   | C0MDATA426  |     |        | <b>√</b>  |           | Undefined   |
| 03FEC445H | CAN0 message data byte 5 register 26   | C0MDATA526  |     |        | <b>√</b>  |           | Undefined   |
| 03FEC446H | CAN0 message data byte 67 register 26  | C0MDATA6726 |     |        |           | √         | Undefined   |
| 03FEC446H | CAN0 message data byte 6 register 26   | C0MDATA626  |     |        | √         |           | Undefined   |
| 03FEC447H | CAN0 message data byte 7 register 26   | C0MDATA726  |     |        | <b>√</b>  |           | Undefined   |
| 03FEC448H | CAN0 message data length register 26   | C0MDLC26    |     |        | √         |           | 0000xxxxB   |
| 03FEC449H | CAN0 message configuration register 26 | C0MCONF26   |     |        | √         |           | Undefined   |
| 03FEC44AH | CAN0 message identifier register 26    | C0MIDL26    |     |        |           | √         | Undefined   |
| 03FEC44CH |                                        | C0MIDH26    |     |        |           | √         | Undefined   |
| 03FEC44EH | CAN0 message control register 26       | C0MCTRL26   |     |        |           | <b>V</b>  | 00x00000    |
|           |                                        |             |     |        |           |           | 000xx000B   |
| 03FEC460H | CAN0 message data byte 01 register 27  | C0MDATA0127 | -   |        |           | √         | Undefined   |
| 03FEC460H | CAN0 message data byte 0 register 27   | C0MDATA027  | -   |        | √         |           | Undefined   |
| 03FEC461H | CAN0 message data byte 1 register 27   | C0MDATA127  |     |        | √         |           | Undefined   |
| 03FEC462H | CAN0 message data byte 23 register 27  | C0MDATA2327 |     |        |           | √         | Undefined   |
| 03FEC462H | CAN0 message data byte 2 register 27   | C0MDATA227  |     |        | √         |           | Undefined   |
| 03FEC463H | CAN0 message data byte 3 register 27   | C0MDATA327  |     |        | √         |           | Undefined   |
| 03FEC464H | CAN0 message data byte 45 register 27  | C0MDATA4527 |     |        |           | √         | Undefined   |
| 03FEC464H | CAN0 message data byte 4 register 27   | C0MDATA427  |     |        | √         |           | Undefined   |
| 03FEC465H | CAN0 message data byte 5 register 27   | C0MDATA527  |     |        | √         |           | Undefined   |
| 03FEC466H | CAN0 message data byte 67 register 27  | C0MDATA6727 |     |        |           | $\sqrt{}$ | Undefined   |
| 03FEC466H | CAN0 message data byte 6 register 27   | C0MDATA627  |     |        | √         |           | Undefined   |
| 03FEC467H | CAN0 message data byte 7 register 27   | C0MDATA727  |     |        | √         |           | Undefined   |
| 03FEC468H | CAN0 message data length register 27   | C0MDLC27    |     |        | √         |           | 0000xxxxB   |
| 03FEC469H | CAN0 message configuration register 27 | C0MCONF27   |     |        | √         |           | Undefined   |
| 03FEC46AH | CAN0 message identifier register 27    | C0MIDL27    |     |        |           | √         | Undefined   |
| 03FEC46CH |                                        | C0MIDH27    |     |        |           | √         | Undefined   |
| 03FEC46EH | CAN0 message control register 27       | C0MCTRL27   |     |        |           | √         | 00x00000    |
|           |                                        |             |     |        |           |           | 000xx000B   |

Table 19-16. Register Access Types (16/17)

|   | Address   | Register Name                          | Symbol      | R/W | Bit Mai | nipulatio    | n Units      | After Reset |
|---|-----------|----------------------------------------|-------------|-----|---------|--------------|--------------|-------------|
|   |           |                                        |             |     | 1 Bit   | 8 Bits       | 16 Bits      |             |
| ( | 3FEC480H  | CAN0 message data byte 01 register 28  | C0MDATA0128 | R/W |         |              | <b>V</b>     | Undefined   |
|   | 03FEC480H | CAN0 message data byte 0 register 28   | C0MDATA028  |     |         | $\checkmark$ |              | Undefined   |
|   | 03FEC481H | CAN0 message data byte 1 register 28   | C0MDATA128  |     |         | √            |              | Undefined   |
| ( | 03FEC482H | CAN0 message data byte 23 register 28  | C0MDATA2328 |     |         |              | <b>V</b>     | Undefined   |
|   | 03FEC482H | CAN0 message data byte 2 register 28   | C0MDATA228  |     |         | <b>√</b>     |              | Undefined   |
|   | 03FEC483H | CAN0 message data byte 3 register 28   | C0MDATA328  |     |         | √            |              | Undefined   |
| ( | O3FEC484H | CAN0 message data byte 45 register 28  | C0MDATA4528 |     |         |              | $\checkmark$ | Undefined   |
|   | 03FEC484H | CAN0 message data byte 4 register 28   | C0MDATA428  |     |         | $\checkmark$ |              | Undefined   |
|   | 03FEC485H | CAN0 message data byte 5 register 28   | C0MDATA528  |     |         | $\checkmark$ |              | Undefined   |
| ( | O3FEC486H | CAN0 message data byte 67 register 28  | C0MDATA6728 |     |         |              | <b>V</b>     | Undefined   |
|   | 03FEC486H | CAN0 message data byte 6 register 28   | C0MDATA628  |     |         | $\checkmark$ |              | Undefined   |
|   | 03FEC487H | CAN0 message data byte 7 register 28   | C0MDATA728  |     |         | $\checkmark$ |              | Undefined   |
| ( | O3FEC488H | CAN0 message data length register 28   | C0MDLC28    |     |         | $\checkmark$ |              | 0000xxxxB   |
| ( | O3FEC489H | CAN0 message configuration register 28 | C0MCONF28   |     |         | √            |              | Undefined   |
| ( | 3FEC48AH  | CAN0 message identifier register 28    | C0MIDL28    |     |         |              | <b>V</b>     | Undefined   |
| ( | 03FEC48CH |                                        | C0MIDH28    |     |         |              | <b>V</b>     | Undefined   |
| ( | 3FEC48EH  | CAN0 message control register 28       | C0MCTRL28   |     |         |              | <b>V</b>     | 00x00000    |
|   |           |                                        |             |     |         |              |              | 000xx000B   |
| ( | 3FEC4A0H  | CAN0 message data byte 01 register 29  | C0MDATA0129 |     |         |              | √            | Undefined   |
|   | 03FEC4A0H | CAN0 message data byte 0 register 29   | C0MDATA029  |     |         | √            |              | Undefined   |
|   | 03FEC4A1H | CAN0 message data byte 1 register 29   | C0MDATA129  |     |         | √            |              | Undefined   |
| ( | 3FEC4A2H  | CAN0 message data byte 23 register 29  | C0MDATA2329 |     |         |              | √            | Undefined   |
|   | 03FEC4A2H | CAN0 message data byte 2 register 29   | C0MDATA229  |     |         | √            |              | Undefined   |
|   | 03FEC4A3H | CAN0 message data byte 3 register 29   | C0MDATA329  |     |         | √            |              | Undefined   |
| ( | 3FEC4A4H  | CAN0 message data byte 45 register 29  | C0MDATA4529 |     |         |              | √            | Undefined   |
|   | 03FEC4A4H | CAN0 message data byte 4 register 29   | C0MDATA429  |     |         | √            |              | Undefined   |
| L | 03FEC4A5H | CAN0 message data byte 5 register 29   | C0MDATA529  |     |         | √            |              | Undefined   |
| ( | 3FEC4A6H  | CAN0 message data byte 67 register 29  | C0MDATA6729 |     |         |              | √            | Undefined   |
|   | 03FEC4A6H | CAN0 message data byte 6 register 29   | C0MDATA629  |     |         | √            |              | Undefined   |
|   | 03FEC4A7H | CAN0 message data byte 7 register 29   | C0MDATA729  |     |         | $\sqrt{}$    |              | Undefined   |
| ( | O3FEC4A8H | CAN0 message data length register 29   | C0MDLC29    |     |         | √            |              | 0000xxxxB   |
| ( | 3FEC4A9H  | CAN0 message configuration register 29 | C0MCONF29   |     |         | $\sqrt{}$    |              | Undefined   |
| ( | 3FEC4AAH  | CAN0 message identifier register 29    | C0MIDL29    |     |         |              | $\sqrt{}$    | Undefined   |
| ( | 3FEC4ACH  |                                        | C0MIDH29    |     |         |              | $\sqrt{}$    | Undefined   |
| ( | 3FEC4AEH  | CAN0 message control register 29       | C0MCTRL29   |     |         |              | <b>√</b>     | 00x00000    |
| L |           |                                        |             |     |         |              |              | 000xx000B   |

Table 19-16. Register Access Types (17/17)

| Address   | Register Name                          | Symbol      | R/W | Bit Ma | nipulatio | n Units   | After Reset |
|-----------|----------------------------------------|-------------|-----|--------|-----------|-----------|-------------|
|           |                                        |             |     | 1 Bit  | 8 Bits    | 16 Bits   |             |
| 03FEC4C0H | CAN0 message data byte 01 register 30  | C0MDATA0130 | R/W |        |           | √         | Undefined   |
| 03FEC4C0H | CAN0 message data byte 0 register 30   | C0MDATA030  |     |        | √         |           | Undefined   |
| 03FEC4C1H | CAN0 message data byte 1 register 30   | C0MDATA130  |     |        | <b>√</b>  |           | Undefined   |
| 03FEC4C2H | CAN0 message data byte 23 register 30  | C0MDATA2330 |     |        |           | √         | Undefined   |
| 03FEC4C2H | CAN0 message data byte 2 register 30   | C0MDATA230  |     |        | <b>V</b>  |           | Undefined   |
| 03FEC4C3H | CAN0 message data byte 3 register 30   | C0MDATA330  |     |        | <b>√</b>  |           | Undefined   |
| 03FEC4C4H | CAN0 message data byte 45 register 30  | C0MDATA4530 |     |        |           | √         | Undefined   |
| 03FEC4C4H | CAN0 message data byte 4 register 30   | C0MDATA430  |     |        | <b>V</b>  |           | Undefined   |
| 03FEC4C5H | CAN0 message data byte 5 register 30   | C0MDATA530  |     |        | <b>√</b>  |           | Undefined   |
| 03FEC4C6H | CAN0 message data byte 67 register 30  | C0MDATA6730 |     |        |           | √         | Undefined   |
| 03FEC4C6H | CAN0 message data byte 6 register 30   | C0MDATA630  |     |        | <b>V</b>  |           | Undefined   |
| 03FEC4C7H | CAN0 message data byte 7 register 30   | C0MDATA730  |     |        | <b>√</b>  |           | Undefined   |
| 03FEC4C8H | CAN0 message data length register 30   | C0MDLC30    |     |        | √         |           | 0000xxxxB   |
| 03FEC4C9H | CAN0 message configuration register 30 | C0MCONF30   |     |        | √         |           | Undefined   |
| 03FEC4CAH | CAN0 message identifier register 30    | C0MIDL30    |     |        |           | √         | Undefined   |
| 03FEC4CCH |                                        | C0MIDH30    |     |        |           | √         | Undefined   |
| 03FEC4CEH | CAN0 message control register 30       | C0MCTRL30   |     |        |           | <b>V</b>  | 00x00000    |
|           |                                        |             |     |        |           |           | 000xx000B   |
| 03FEC4E0H | CAN0 message data byte 01 register 31  | C0MDATA0131 |     |        |           | √         | Undefined   |
| 03FEC4E0H | CAN0 message data byte 0 register 31   | C0MDATA031  |     |        | √         |           | Undefined   |
| 03FEC4E1H | CAN0 message data byte 1 register 31   | C0MDATA131  |     |        | √         |           | Undefined   |
| 03FEC4E2H | CAN0 message data byte 23 register 31  | C0MDATA2331 |     |        |           | √         | Undefined   |
| 03FEC4E2H | CAN0 message data byte 2 register 31   | C0MDATA231  |     |        | √         |           | Undefined   |
| 03FEC4E3H | CAN0 message data byte 3 register 31   | C0MDATA331  |     |        | √         |           | Undefined   |
| 03FEC4E4H | CAN0 message data byte 45 register 31  | C0MDATA4531 |     |        |           | √         | Undefined   |
| 03FEC4E4H | CAN0 message data byte 4 register 31   | C0MDATA431  |     |        | √         |           | Undefined   |
| 03FEC4E5H | CAN0 message data byte 5 register 31   | C0MDATA531  |     |        | √         |           | Undefined   |
| 03FEC4E6H | CAN0 message data byte 67 register 31  | C0MDATA6731 |     |        |           | $\sqrt{}$ | Undefined   |
| 03FEC4E6H | CAN0 message data byte 6 register 31   | C0MDATA631  |     |        | $\sqrt{}$ |           | Undefined   |
| 03FEC4E7H | CAN0 message data byte 7 register 31   | C0MDATA731  |     |        | <b>V</b>  |           | Undefined   |
| 03FEC4E8H | CAN0 message data length register 31   | C0MDLC31    |     |        | √         |           | 0000xxxxB   |
| 03FEC4E9H | CAN0 message configuration register 31 | C0MCONF31   |     |        | √         |           | Undefined   |
| 03FEC4EAH | CAN0 message identifier register 31    | C0MIDL31    |     |        |           | √         | Undefined   |
| 03FEC4ECH |                                        | C0MIDH31    |     |        |           | √         | Undefined   |
| 03FEC4EEH | CAN0 message control register 31       | C0MCTRL31   |     |        |           | √         | 00x00000    |
|           |                                        |             |     |        |           |           | 000xx000B   |

# 19.5.3 Register bit configuration

Table 19-17. CAN Global Register Bit Configuration

| Address   | Symbol       | Bit 7/15 | Bit 6/14 | Bit 5/13 | Bit 4/12 | Bit 3/11 | Bit 2/10 | Bit 1/9       | Bit 0/8         |
|-----------|--------------|----------|----------|----------|----------|----------|----------|---------------|-----------------|
| 03FEC000H | C0GMCTRL (W) | 0        | 0        | 0        | 0        | 0        | 0        | 0             | Clear GOM       |
| 03FEC001H |              | 0        | 0        | 0        | 0        | 0        | 0        | Set EFSD      | Set GOM         |
| 03FEC000H | C0GMCTRL (R) | 0        | 0        | 0        | 0        | 0        | 0        | EFSD          | GOM             |
| 03FEC001H |              | MBON     | 0        | 0        | 0        | 0        | 0        | 0             | 0               |
| 03FEC002H | COGMCS       | 0        | 0        | 0        | 0        | CCP3     | CCP2     | CCP1          | CCP0            |
| 03FEC006H | COGMABT (W)  | 0        | 0        | 0        | 0        | 0        | 0        | 0             | Clear<br>ABTTRG |
| 03FEC007H |              | 0        | 0        | 0        | 0        | 0        | 0        | Set<br>ABTCLR | Set<br>ABTTRG   |
| 03FEC006H | C0GMABT (R)  | 0        | 0        | 0        | 0        | 0        | 0        | ABTCLR        | ABTTRG          |
| 03FEC007H |              | 0        | 0        | 0        | 0        | 0        | 0        | 0             | 0               |
| 03FEC008H | C0GMABTD     | 0        | 0        | 0        | 0        | ABTD3    | ABTD2    | ABTD1         | ABTD0           |

Table 19-18. CAN Module Register Bit Configuration (1/2)

| Address   | Symbol     | Bit 7/15     | Bit 6/14  | Bit 5/13        | Bit 4/12                                      | Bit 3/11         | Bit 2/10         | Bit 1/9          | Bit 0/8          |  |
|-----------|------------|--------------|-----------|-----------------|-----------------------------------------------|------------------|------------------|------------------|------------------|--|
| 03FEC040H | C0MASK1L   |              |           |                 | L                                             | o CMID0          |                  |                  |                  |  |
| 03FEC041H |            |              |           |                 | CMID15                                        | to CMID8         |                  |                  |                  |  |
| 03FEC042H | C0MASK1H   |              |           |                 | CMID23 t                                      | o CMID16         |                  |                  |                  |  |
| 03FEC043H |            | 0            | 0         | 0               |                                               | СМІ              | D28 to CMI       | D24              |                  |  |
| 03FEC044H | C0MASK2L   |              |           | Į.              | CMID7 t                                       | o CMID0          |                  |                  |                  |  |
| 03FEC045H |            |              |           |                 | CMID15                                        | to CMID8         |                  |                  |                  |  |
| 03FEC046H | C0MASK2H   |              |           |                 | CMID23 t                                      | o CMID16         |                  |                  |                  |  |
| 03FEC047H |            | 0            | 0         | 0               |                                               | СМІ              | D28 to CMII      | D24              |                  |  |
| 03FEC048H | C0MASK3L   |              |           |                 | CMID7 t                                       | o CMID0          |                  |                  |                  |  |
| 03FEC049H |            |              |           |                 | CMID15                                        | to CMID8         |                  |                  |                  |  |
| 03FEC04AH | C0MASK3H   |              |           |                 | CMID23 t                                      | o CMID16         |                  |                  |                  |  |
| 03FEC04BH |            | 0            | 0         | 0               |                                               | СМІ              | D28 to CMI       | D24              |                  |  |
| 03FEC04CH | C0MASK4L   |              |           |                 | CMID7 t                                       | o CMID0          |                  |                  |                  |  |
| 03FEC04DH |            |              |           |                 | CMID15                                        | to CMID8         |                  |                  |                  |  |
| 03FEC04EH | C0MASK4H   |              |           |                 | CMID23 t                                      | o CMID16         |                  |                  |                  |  |
| 03FEC04FH |            | 0            | 0         | 0               |                                               | СМ               | ID28 to CMI      | D24              |                  |  |
| 03FEC050H | COCTRL (W) | 0            | Clear AL  | Clear<br>VALID  | Clear<br>PSMODE1                              | Clear<br>PSMODE0 | Clear<br>OPMODE2 | Clear<br>OPMODE1 | Clear<br>OPMODE0 |  |
| 03FEC051H |            | Set<br>CCERC | Set<br>AL | 0               | Set<br>PSMODE1                                | Set<br>PSMODE0   | Set<br>OPMODE2   | Set<br>OPMODE1   | Set<br>OPMODE0   |  |
| 03FEC050H | COCTRL (R) | CCERC        | AL        | VALID           | PS<br>MODE1                                   | PS<br>MODE0      | OP<br>MODE2      | OP<br>MODE1      | OP<br>MODE0      |  |
| 03FEC051H |            | 0            | 0         | 0               | 0                                             | 0                | 0                | RSTAT            | TSTAT            |  |
| 03FEC052H | C0LEC (W)  | 0            | 0         | 0               | 0                                             | 0                | 0                | 0                | 0                |  |
| 03FEC052H | C0LEC (R)  | 0            | 0         | 0               | 0                                             | 0                | LEC2             | LEC1             | LEC0             |  |
| 03FEC053H | COINFO     | 0            | 0         | 0               | BOFF                                          | TECS1            | TECS0            | RECS1            | RECS0            |  |
| 03FEC054H | C0ERC      |              |           |                 | TEC7 t                                        | o TEC0           |                  |                  |                  |  |
| 03FEC055H |            |              |           |                 | REC7 t                                        | o REC0           |                  |                  |                  |  |
| 03FEC056H | C0IE (W)   | 0            | 0         | Clear CIE5      | Clear CIE4                                    | Clear CIE3       | Clear CIE2       | Clear CIE1       | Clear CIE0       |  |
| 03FEC057H |            | 0            | 0         | Set CIE5        | IE5 Set CIE4 Set CIE3 Set CIE2 Set CIE1 Set C |                  |                  |                  |                  |  |
| 03FEC056H | C0IE (R)   | 0            | 0         | CIE5            | CIE4                                          | CIE3             | CIE2             | CIE1             | CIE0             |  |
| 03FEC057H |            | 0            | 0         | 0               | 0                                             | 0                | 0                | 0                | 0                |  |
| 03FEC058H | COINTS (W) | 0            | 0         | Clear<br>CINTS5 | Clear<br>CINTS4                               | Clear<br>CINTS3  | Clear<br>CINTS2  | Clear<br>CINTS1  | Clear<br>CINTS0  |  |
| 03FEC059H |            | 0            | 0         | 0               | 0                                             | 0                | 0                | 0                | 0                |  |
| 03FEC058H | COINTS (R) | 0            | 0         | CINTS5          | CINTS4                                        | CINTS3           | CINTS2           | CINTS1           | CINTS0           |  |
| 03FEC059H |            | 0            | 0         | 0               | 0                                             | 0                | 0                | 0                | 0                |  |

Table 19-18. CAN Module Register Bit Configuration (2/2)

| Address                      | Symbol     | Bit 7/15 | Bit 6/14 | Bit 5/13 | Bit 4/12      | Bit 3/11      | Bit 2/10        | Bit 1/9        | Bit 0/8       |
|------------------------------|------------|----------|----------|----------|---------------|---------------|-----------------|----------------|---------------|
| 03FEC05AH                    | C0BRP      |          |          |          | TQPRS7 to     | o TQPRS0      |                 |                |               |
| 03FEC05CH                    | C0BTR      | 0        | 0        | 0        | 0             |               | TSEG13 to       | o TSEG10       |               |
| 03FEC05DH                    |            | 0        | 0        | SJW1,    | SJW0          | 0             | TSE             | G22 to TSE     | G20           |
| 03FEC05EH                    | COLIPT     |          |          |          | LIPT7 to      | o LIPT0       |                 |                |               |
| 03FEC060H                    | CORGPT (W) | 0        | 0        | 0        | 0             | 0             | 0               | 0              | Clear<br>ROVF |
| 03FEC061H                    |            | 0        | 0        | 0        | 0             | 0             | 0               | 0              | 0             |
| 03FEC060H                    | C0RGPT (R) | 0        | 0        | 0        | 0             | 0             | 0               | RHPM           | ROVF          |
| 03FEC061H                    |            |          |          |          | RGPT7 to      | o RGPT0       |                 |                |               |
| 03FEC062H                    | C0LOPT     |          |          |          | LOPT7 to      | o LOPT0       |                 |                |               |
| 03FEC064H                    | COTGPT (W) | 0        | 0        | 0        | 0             | 0             | 0               | 0              | Clear<br>TOVF |
| 03FEC065H                    |            | 0        | 0        | 0        | 0             | 0             | 0               | 0              | 0             |
| 03FEC064H                    | C0TGPT (R) | 0        | 0        | 0        | 0             | 0             | 0               | THPM           | TOVF          |
| 03FEC065H                    |            |          |          |          | TGPT7 to      | o TGPT0       |                 |                |               |
| 03FEC066H                    | COTS (W)   | 0        | 0        | 0        | 0             | 0             | Clear<br>TSLOCK | Clear<br>TSSEL | Clear<br>TSEN |
| 03FEC067H                    |            | 0        | 0        | 0        | 0             | 0             | Set<br>TSLOCK   | Set<br>TSSEL   | Set<br>TSEN   |
| 03FEC066H                    | C0TS (R)   | 0        | 0        | 0        | 0             | 0             | TSLOCK          | TSSEL          | TSEN          |
| 03FEC067H                    | 1          | 0        | 0        | 0        | 0             | 0             | 0               | 0              | 0             |
| 03FEC068H<br>to<br>03FEC0FFH | -          |          |          | Access p | rohibited (re | served for fu | ture use)       |                |               |

Table 19-19. Message Buffer Register Bit Configuration

| Address                     | Symbol       | Bit 7/15  | Bit 6/14            | Bit 5/13 | Bit 4/12      | Bit 3/11      | Bit 2/10    | Bit 1/9   | Bit 0/8   |  |
|-----------------------------|--------------|-----------|---------------------|----------|---------------|---------------|-------------|-----------|-----------|--|
| 03FECxx0H                   | C0MDATA01m   | Message d | ata (byte 0)        |          |               |               |             |           |           |  |
| 03FECxx1H                   |              | Message d | ata (byte 1)        |          |               |               |             |           |           |  |
| 03FECxx0H                   | C0MDATA0m    | Message d | ssage data (byte 0) |          |               |               |             |           |           |  |
| 03FECxx1H                   | C0MDATA1m    | Message d | ata (byte 1)        |          |               |               |             |           |           |  |
| 03FECxx2H                   | C0MDATA23m   | Message d | ata (byte 2)        |          |               |               |             |           |           |  |
| 03FECxx3H                   |              | Message d | ata (byte 3)        |          |               |               |             |           |           |  |
| 03FECxx2H                   | C0MDATA2m    | Message d | ata (byte 2)        |          |               |               |             |           |           |  |
| 03FECxx3H                   | C0MDATA3m    | Message d | ata (byte 3)        |          |               |               |             |           |           |  |
| 03FECxx4H                   | C0MDATA45m   | Message d | ata (byte 4)        |          |               |               |             |           |           |  |
| 03FECxx5H                   |              | Message d | ata (byte 5)        |          |               |               |             |           |           |  |
| 03FECxx4H                   | C0MDATA4m    | Message d | ata (byte 4)        |          |               |               |             |           |           |  |
| 03FECxx5H                   | C0MDATA5m    | Message d | ata (byte 5)        |          |               |               |             |           |           |  |
| 03FECxx6H                   | C0MDATA67m   | Message d | ata (byte 6)        |          |               |               |             |           |           |  |
| 03FECxx7H                   |              | Message d | ata (byte 7)        |          |               |               |             |           |           |  |
| 03FECxx6H                   | C0MDATA6m    | Message d | ata (byte 6)        |          |               |               |             |           |           |  |
| 03FECxx7H                   | C0MDATA7m    | Message d | ata (byte 7)        |          |               |               |             |           |           |  |
| 03FECxx8H                   | C0MDLCm      |           | C                   | )        |               | MDLC3         | MDLC2       | MDLC1     | MDLC0     |  |
| 03FECxx9H                   | C0MCONFm     | ows       | RTR                 | MT2      | MT1           | MT0           | 0           | 0         | MA0       |  |
| 03FECxxAH                   | C0MIDLm      | ID7       | ID6                 | ID5      | ID4           | ID3           | ID2         | ID1       | ID0       |  |
| 03FECxxBH                   |              | ID15      | ID14                | ID13     | ID12          | ID11          | ID10        | ID9       | ID8       |  |
| 03FECxxCH                   | C0MIDHm      | ID23      | ID22                | ID21     | ID20          | ID19          | ID18        | ID17      | ID16      |  |
| 03FECxxDH                   |              | IDE       | 0                   | 0        | ID28          | ID27          | ID26        | ID25      | ID24      |  |
| 03FECxxEH                   | C0MCTRLm (W) | 0         | 0                   | 0        | Clear<br>MOW  | Clear<br>IE   | Clear<br>DN | Clear TRQ | Clear RDY |  |
| 03FECxxFH                   |              | 0         | 0                   | 0        | 0             | Set IE        | 0           | Set TRQ   | Set RDY   |  |
| 03FECxxEH                   | C0MCTRLm (R) | 0         | 0                   | 0        | MOW           | ΙE            | DN          | TRQ       | RDY       |  |
| 03FECxxFH                   |              | 0         | 0                   | MUC      | 0             | 0             | 0           | 0         | 0         |  |
| 03FECxx0<br>to<br>03FECxxFH | _            |           |                     | Access p | rohibited (re | served for fu | iture use)  |           |           |  |

**Remark** m = 00 to 31

xx = 10, 12, 14, 16, 18, 1A, 1C, 1E, 20, 22, 24, 26, 28, 2A, 2C, 2E, 30, 32, 34, 36, 38, 3A, 3C, 3E, 40, 42, 44, 46, 48, 4A, 4C, 4E

#### 19.6 Registers

Caution Accessing the CAN controller registers is prohibited in the following statuses. For details, see 3.4.9 (2) Accessing specific on-chip peripheral I/O registers.

- . When the CPU operates with the subclock and the main clock oscillation is stopped
- When the CPU operates with the internal oscillation clock

**Remark** m = 00 to 31

#### (1) CAN0 global control register (C0GMCTRL)

The COGMCTRL register is used to control the operation of the CAN module.

(1/2)

| After reset: 000 | 00H R/W | 7 taarese | s: 03FEC00 |    |    |    |             |              |
|------------------|---------|-----------|------------|----|----|----|-------------|--------------|
| (a) Read         |         |           |            |    |    |    |             |              |
|                  | 15      | 14        | 13         | 12 | 11 | 10 | 9           | 8            |
| C0GMCTRL         | MBON    | 0         | 0          | 0  | 0  | 0  | 0           | 0            |
|                  | 7       | 6         | 5          | 4  | 3  | 2  | 1           | 0            |
|                  | 0       | 0         | 0          | 0  | 0  | 0  | EFSD        | GOM          |
| (b) Write        |         |           |            |    |    |    |             |              |
|                  | 15      | 14        | 13         | 12 | 11 | 10 | 9           | 8            |
| COGMCTRL         | 0       | 0         | 0          | 0  | 0  | 0  | Set<br>EFSD | Set<br>GOM   |
|                  | 7       | 6         | 5          | 4  | 3  | 2  | 1           | 0            |
|                  | 0       | 0         | 0          | 0  | 0  | 0  | 0           | Clear<br>GOM |

#### (a) Read

| MBON | Bit enabling access to message buffer register, transmit/receive history registers                                       |
|------|--------------------------------------------------------------------------------------------------------------------------|
| 0    | Write access and read access to the message buffer register and the transmit/receive history list registers is disabled. |
| 1    | Write access and read access to the message buffer register and the transmit/receive history list registers is enabled.  |

- Cautions 1. While the MBON bit is cleared (to 0), software access to the message buffers (C0MDATA0m, C0MDATA1m, C0MDATA01m, C0MDATA2m, C0MDATA3m, C0MDATA23m, C0MDATA4m, C0MDATA5m, C0MDATA45m, C0MDATA6m, C0MDATA7m, C0MDATA67m, C0MDLCm, C0MCONFm, C0MIDLm, C0MIDHm, and C0MCTRLm), or registers related to transmit history or receive history (C0LOPT, C0TGPT, C0LIPT, and C0RGPT) is disabled.
  - This bit is read-only. Even if 1 is written to the MBON bit while it is 0, the value of the MBON bit does not change, and access to the message buffer registers, or registers related to transmit history or receive history remains disabled.

**Remark** When the CAN sleep mode/CAN stop mode is entered, or when the GOM bit is cleared to 0, the MBON bit is cleared to 0. When the CAN sleep mode/CAN stop mode is released, or when the GOM bit is set to 1, the MBON bit is set to 1.

(2/2)

| EFSD | Bit enabling forced shut down             |
|------|-------------------------------------------|
| 0    | Forced shut down by GOM bit = 0 disabled. |
| 1    | Forced shut down by GOM bit = 0 enabled.  |

Caution To request forced shut down, the GOM bit must be cleared to 0 immediately after the EFSD bit has been set to 1. If access to another register (including reading the C0GMCTRL register) is executed without clearing the GOM bit immediately after the EFSD bit has been set to 1, the EFSD bit is forcibly cleared to 0, and the forced shut down request is invalid.

| G | MOE | Global operation mode bit              |
|---|-----|----------------------------------------|
|   | 0   | CAN module is disabled from operating. |
|   | 1   | CAN module is enabled to operate.      |

Caution The GOM bit is cleared to 0 only in the initialization mode or immediately after the EFSD bit is set to 1.

| Set EFSD | EFSD bit setting       |
|----------|------------------------|
| 0        | No change in EFSD bit. |
| 1        | EFSD bit set to 1.     |

| Set GOM   | Clear GOM | GOM bit setting       |
|-----------|-----------|-----------------------|
| 0         | 1         | GOM bit cleared to 0. |
| 1         | 0         | GOM bit set to 1.     |
| Other tha | an above  | No change in GOM bit. |

# (2) CAN0 global clock selection register (C0GMCS)

The C0GMCS register is used to select the CAN module system clock.

After reset: 0FH R/W Address: 03FEC002H

7 6 5 4 3 2 1 0

C0GMCS 0 0 0 0 CCP3 CCP2 CCP1 CCP0

| ССРЗ | CCP2 | CCP1 | CCP1 | CAN module system clock (fcanmod) |
|------|------|------|------|-----------------------------------|
| 0    | 0    | 0    | 0    | fcan/1                            |
| 0    | 0    | 0    | 1    | fcan/2                            |
| 0    | 0    | 1    | 0    | fcan/3                            |
| 0    | 0    | 1    | 1    | fcan/4                            |
| 0    | 1    | 0    | 0    | fcan/5                            |
| 0    | 1    | 0    | 1    | fcan/6                            |
| 0    | 1    | 1    | 0    | fcan/7                            |
| 0    | 1    | 1    | 1    | fcan/8                            |
| 1    | 0    | 0    | 0    | fcan/9                            |
| 1    | 0    | 0    | 1    | fcan/10                           |
| 1    | 0    | 1    | 0    | fcan/11                           |
| 1    | 0    | 1    | 1    | fcan/12                           |
| 1    | 1    | 0    | 0    | fcan/13                           |
| 1    | 1    | 0    | 1    | fcan/14                           |
| 1    | 1    | 1    | 0    | fcan/15                           |
| 1    | 1    | 1    | 1    | fcan/16 (default value)           |

**Remark** fcan = Clock supplied to CAN = fxx

#### (3) CANO global automatic block transmission control register (C0GMABT)

The COGMABT register is used to control the automatic block transmission (ABT) operation.

(1/2)

| After reset: 000 | 00H R/W | Address | s: 03FEC00 | 6H |    |    |               |                 |
|------------------|---------|---------|------------|----|----|----|---------------|-----------------|
| (a) Read         |         |         |            |    |    |    |               |                 |
|                  | 15      | 14      | 13         | 12 | 11 | 10 | 9             | 8               |
| COGMABT          | 0       | 0       | 0          | 0  | 0  | 0  | 0             | 0               |
|                  | 7       | 6       | 5          | 4  | 3  | 2  | 1             | 0               |
|                  | 0       | 0       | 0          | 0  | 0  | 0  | ABTCLR        | ABTTRG          |
| (a) Write        | 15      | 14      | 13         | 12 | 11 | 10 | 9             | 8               |
| COGMABT          | 0       | 0       | 0          | 0  | 0  | 0  | Set<br>ABTCLR | Set<br>ABTTRG   |
|                  | 7       | 6       | 5          | 4  | 3  | 2  | 1             | 0               |
|                  | 0       | 0       | 0          | 0  | 0  | 0  | 0             | Clear<br>ABTTRG |

Caution Before changing the normal operation mode with ABT to the initialization mode, be sure to set the C0GMABT register to the default value (0000H). After setting, confirm that the C0GMABT register is initialized to 0000H.

#### (a) Read

| ABTCLR | Automatic block transmission engine clear status bit     |
|--------|----------------------------------------------------------|
| 0      | Clearing the automatic transmission engine is completed. |
| 1      | The automatic transmission engine is being cleared.      |

# Remarks 1. Set the ABTCLR bit to 1 while the ABTTRG bit is cleared to 0. The operation is not guaranteed if the ABTCLR bit is set to 1 while the ABTTRG bit is set to 1.

2. When the automatic block transmission engine is cleared by setting the ABTCLR bit to 1, the ABTCLR bit is automatically cleared to 0 as soon as the requested clearing processing is complete.

| ABTTRG | Automatic block transmission status bit          |
|--------|--------------------------------------------------|
| 0      | Automatic block transmission is stopped.         |
| 1      | Automatic block transmission is under execution. |

# Cautions 1. Do not set the ABTTRG bit to 1 in the initialization mode. If the ABTTRG bit is set to 1 in the initialization mode, the operation is not guaranteed after the CAN module has entered the normal operation mode with ABT.

2. Do not set the ABTTRG bit to 1 while the C0CTRL.TSTAT bit is set to 1. Confirm that the TSTAT bit = 0 before setting the ABTTRG bit to 1.

(2/2)

| Set ABTCLR | Automatic block transmission engine clear request bit                                                                                                                                                                   |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | The automatic block transmission engine is in idle status or under operation.                                                                                                                                           |
| 1          | Request to clear the automatic block transmission engine. After the automatic block transmission engine has been cleared, automatic block transmission is started from message buffer 0 by setting the ABTTRG bit to 1. |

| Set ABTTRG | Clear ABTTRG | Automatic block transmission start bit         |
|------------|--------------|------------------------------------------------|
| 0          | 1            | Request to stop automatic block transmission.  |
| 1          | 0            | Request to start automatic block transmission. |
| Other tha  | an above     | No change in ABTTRG bit.                       |

## (4) CAN0 global automatic block transmission delay register (C0GMABTD)

The COGMABTD register is used to set the interval at which the data of the message buffer assigned to ABT is to be transmitted in the normal operation mode with ABT.

| After reset: 00H | H R/W | Address | s: 03FEC008 | sH |       |       |       |       |
|------------------|-------|---------|-------------|----|-------|-------|-------|-------|
|                  | 7     | 6       | 5           | 4  | 3     | 2     | 1     | 0     |
| COGMABTD         | 0     | 0       | 0           | 0  | ABTD3 | ABTD2 | ABTD1 | ABTD0 |

| ABTD3 | ABTD2     | ABTD1    | ABTD0 | Data frame interval during automatic block transmission (Unit: Data bit time (DBT)) |
|-------|-----------|----------|-------|-------------------------------------------------------------------------------------|
| 0     | 0         | 0        | 0     | 0 DBT (default value)                                                               |
| 0     | 0         | 0        | 1     | 2º DBT                                                                              |
| 0     | 0         | 1        | 0     | 2º DBT                                                                              |
| 0     | 0         | 1        | 1     | 2 <sup>7</sup> DBT                                                                  |
| 0     | 1         | 0        | 0     | 2º DBT                                                                              |
| 0     | 1         | 0        | 1     | 2º DBT                                                                              |
| 0     | 1         | 1        | 0     | 2 <sup>10</sup> DBT                                                                 |
| 0     | 1         | 1        | 1     | 2 <sup>11</sup> DBT                                                                 |
| 1     | 0         | 0        | 0     | 2 <sup>12</sup> DBT                                                                 |
|       | Other tha | an above |       | Setting prohibited                                                                  |

Cautions 1. Do not change the contents of the COGMABTD register while the ABTTRG bit is set to 1.

2. The timing at which the ABT message is actually transmitted onto the CAN bus differs depending on the status of transmission from the other station or how a request to transmit a message other than an ABT message (message buffers 8 to 31) is made.

# (5) CANO module mask control register (C0MASKaL, C0MASKaH) (a = 1, 2, 3, or 4)

The C0MASKaL and C0MASKaH registers are used to extend the number of receivable messages by masking part of the identifier (ID) of a message and invalidating the ID of the masked part.

(1/2)

| After reset: Un                  | defined                                      | R/W A                                             | Address: C0                                       | MASK1L 03F                                     | EC040H, C0                                | MASK1H 03                                      | BFEC042H                      |                     |
|----------------------------------|----------------------------------------------|---------------------------------------------------|---------------------------------------------------|------------------------------------------------|-------------------------------------------|------------------------------------------------|-------------------------------|---------------------|
|                                  |                                              |                                                   |                                                   |                                                |                                           |                                                |                               |                     |
|                                  | 15                                           | 14                                                | 13                                                | 12                                             | 11                                        | 10                                             | 9                             | 8                   |
| C0MASK1L                         | CMID15                                       | CMID14                                            | CMID13                                            | CMID12                                         | CMID11                                    | CMID10                                         | CMID9                         | CMID8               |
|                                  | 7                                            | 6                                                 | 5                                                 | 4                                              | 3                                         | 2                                              | 1                             | 0                   |
|                                  | CMID7                                        | CMID6                                             | CMID5                                             | CMID4                                          | CMID3                                     | CMID2                                          | CMID1                         | CMID0               |
|                                  | 15                                           | 14                                                | 13                                                | 12                                             | 11                                        | 10                                             | 9                             | 8                   |
| C0MASK1H                         | 0                                            | 0                                                 | 0                                                 | CMID28                                         | CMID27                                    | CMID26                                         | CMID25                        | CMID24              |
|                                  | 7                                            | 6                                                 | 5                                                 | 4                                              | 3                                         | 2                                              | 1                             | 0                   |
|                                  |                                              |                                                   | OMIDOA                                            | CMIDOO                                         | CMID19                                    | CMID18                                         | CMID17                        | CMID4               |
| CAN0 module m                    | CMID23<br>ask 2 registe                      | CMID22<br>er (C0MASh                              | CMID21                                            | CMID20<br>SK2H)                                | CMID19                                    | CMID18                                         | CMID17                        | CIVIID 16           |
| CAN0 module m<br>After reset: Un | ask 2 registe                                | er (COMASh<br>R/W                                 | K2L, C0MAS                                        | SK2H)<br>MASK2L 03                             | FEC044H, C0                               | OMASK2H 03                                     | 3FEC046H                      |                     |
|                                  | ask 2 registed defined                       | er (C0MASk                                        | K2L, COMAS                                        | SK2H)                                          |                                           |                                                |                               | 8 8                 |
|                                  | ask 2 registe                                | er (COMASh<br>R/W                                 | K2L, C0MAS                                        | SK2H)<br>MASK2L 03                             | FEC044H, C0                               | OMASK2H 03                                     | 3FEC046H                      | 8                   |
| After reset: Un                  | ask 2 registed defined                       | er (C0MASk<br>R/W A                               | X2L, COMAS Address: CO                            | 6K2H)<br>MASK2L 031                            | FEC044H, C0                               | 0MASK2H 03                                     | 3FEC046H<br>9                 | 8                   |
| After reset: Un                  | ask 2 registed defined 15 CMID15             | er (COMASh<br>R/W A<br>14<br>CMID14               | K2L, C0MAS Address: C0 13 CMID13                  | SK2H)<br>MASK2L 03l<br>12<br>CMID12            | FEC044H, C0<br>11<br>CMID11               | 0MASK2H 03<br>10<br>CMID10                     | 3FEC046H<br>9<br>CMID9        | 8<br>CMID8<br>0     |
| After reset: Un                  | ask 2 registed defined 15 CMID15             | er (COMASh<br>R/W A<br>14<br>CMID14               | Address: C0  13  CMID13                           | 6K2H)  MASK2L 03I  12  CMID12  4               | FEC044H, C0<br>11<br>CMID11<br>3          | 0MASK2H 03<br>10<br>CMID10<br>2                | 3FEC046H<br>9<br>CMID9        | 8<br>CMID8<br>0     |
| After reset: Un                  | ask 2 registed defined  15  CMID15  7  CMID7 | er (COMASh<br>R/W A<br>14<br>CMID14<br>6<br>CMID6 | X2L, COMAS  Address: CO  13  CMID13  5  CMID5     | SK2H)  MASK2L 03I  12  CMID12  4  CMID4        | TEC044H, C0<br>11<br>CMID11<br>3<br>CMID3 | 0MASK2H 03<br>10<br>CMID10<br>2<br>CMID2       | 3FEC046H 9 CMID9 1 CMID1      | 8 CMID8 0 CMID0 8   |
| After reset: Un                  | ask 2 registed defined 15 CMID15 7 CMID7     | er (COMASh<br>R/W A<br>14<br>CMID14<br>6<br>CMID6 | CAL, COMAS  Address: CO  13  CMID13  5  CMID5  13 | MASK2L 03l<br>12<br>CMID12<br>4<br>CMID4<br>12 | FEC044H, C0<br>11<br>CMID11<br>3<br>CMID3 | 0MASK2H 03<br>10<br>CMID10<br>2<br>CMID2<br>10 | 9<br>CMID9<br>1<br>CMID1<br>9 | CMID8<br>0<br>CMID0 |

(2/2)

• CAN0 module mask 3 register (C0MASK3L, C0MASK3H)

After reset: Undefined R/W Address: C0MASK3L 03FEC048H, C0MASK3H 03FEC04AH

C0MASK3L

| 15     | 14     | 13     | 12     | 11     | 10     | 9      | 8      |
|--------|--------|--------|--------|--------|--------|--------|--------|
| CMID15 | CMID14 | CMID13 | CMID12 | CMID11 | CMID10 | CMID9  | CMID8  |
| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| CMID7  | CMID6  | CMID5  | CMID4  | CMID3  | CMID2  | CMID1  | CMID0  |
| 15     | 14     | 13     | 12     | 11     | 10     | 9      | 8      |
| 0      | 0      | 0      | CMID28 | CMID27 | CMID26 | CMID25 | CMID24 |
| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| CMID23 | CMID22 | CMID21 | CMID20 | CMID19 | CMID18 | CMID17 | CMID16 |

C0MASK3H

• CAN0 module mask 4 register (C0MASK4L, C0MASK4H)

After reset: Undefined R/W Address: C0MASK4L 03FEC04CH, C0MASK4H 03FEC04EH

C0MASK4L

| 15     | 14     | 13     | 12     | 11     | 10     | 9      | 8      |
|--------|--------|--------|--------|--------|--------|--------|--------|
| CMID15 | CMID14 | CMID13 | CMID12 | CMID11 | CMID10 | CMID9  | CMID8  |
| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| CMID7  | CMID6  | CMID5  | CMID4  | CMID3  | CMID2  | CMID1  | CMID0  |
| 15     | 14     | 13     | 12     | 11     | 10     | 9      | 8      |
| 0      | 0      | 0      | CMID28 | CMID27 | CMID26 | CMID25 | CMID24 |
| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| CMID23 | CMID22 | CMID21 | CMID20 | CMID19 | CMID18 | CMID17 | CMID16 |

C0MASK4H

| CMID28 to CMID0 | Mask pattern setting of ID bit                                                                                                                       |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0               | The ID bits of the message buffer set by the CMID28 to CMID0 bits are compared with the ID bits of the received message frame.                       |
| 1               | The ID bits of the message buffer set by the CMID28 to CMID0 bits are not compared with the ID bits of the received message frame (they are masked). |

**Remark** Masking is always defined by an ID length of 29 bits. If a mask is assigned to a message with a standard ID, the CMID17 to CMID0 bits are ignored. Therefore, only the CMID28 to CMID18 bits of the received ID are masked. The same mask can be used for both the standard and extended IDs.

#### (6) CAN0 module control register (C0CTRL)

The COCTRL register is used to control the operation mode of the CAN module.

(1/4)

| After reset: 000 | 00H R/W      | Address     | s: 03FEC05     | 0H                   |                      |                      |                      |                      |
|------------------|--------------|-------------|----------------|----------------------|----------------------|----------------------|----------------------|----------------------|
| (a) Read         |              |             |                |                      |                      |                      |                      |                      |
|                  | 15           | 14          | 13             | 12                   | 11                   | 10                   | 9                    | 8                    |
| C0CTRL           | 0            | 0           | 0              | 0                    | 0                    | 0                    | RSTAT                | TSTAT                |
|                  | 7            | 6           | 5              | 4                    | 3                    | 2                    | 1                    | 0                    |
|                  | CCERC        | AL          | VALID          | PSMODE<br>1          | PSMODE<br>0          | OPMODE<br>2          | OPMODE<br>1          | OPMODE<br>0          |
| (a) Write        |              |             |                |                      |                      |                      |                      |                      |
|                  | 15           | 14          | 13             | 12                   | 11                   | 10                   | 9                    | 8                    |
| COCTRL           | Set<br>CCERC | Set<br>AL   | 0              | Set<br>PSMODE<br>1   | Set<br>PSMODE<br>0   | Set<br>OPMODE<br>2   | Set<br>OPMODE<br>1   | Set<br>OPMODE<br>0   |
|                  | 7            | 6           | 5              | 4                    | 3                    | 2                    | 1                    | 0                    |
|                  | 0            | Clear<br>AL | Clear<br>VALID | Clear<br>PSMODE<br>1 | Clear<br>PSMODE<br>0 | Clear<br>OPMODE<br>2 | Clear<br>OPMODE<br>1 | Clear<br>OPMODE<br>0 |

#### (a) Read

| RSTAT | Reception status bit      |  |  |  |
|-------|---------------------------|--|--|--|
| 0     | eception is stopped.      |  |  |  |
| 1     | Reception is in progress. |  |  |  |

Remark The RSTAT bit is set to 1 under the following conditions (timing)

- · The SOF bit of a receive frame is detected
- On occurrence of arbitration loss during a transmit frame

The RSTAT bit is cleared to 0 under the following conditions (timing)

- When a recessive level is detected at the second bit of the interframe space
- On transition to the initialization mode at the first bit of the interframe space

| TSTAT | Transmission status bit      |  |  |  |
|-------|------------------------------|--|--|--|
| 0     | Transmission is stopped.     |  |  |  |
| 1     | Transmission is in progress. |  |  |  |

**Remark** The TSTAT bit is set to 1 under the following conditions (timing)

- The SOF bit of a transmit frame is detected
- The first bit of an error flag is detected during a transmit frame

The TSTAT bit is cleared to 0 under the following conditions (timing)

- During transition to bus-off status
- On occurrence of arbitration loss in transmit frame
- On detection of recessive level at the second bit of the interframe space
- On transition to the initialization mode at the first bit of the interframe space

(2/4)

| CCERC | Error counter clear bit                                                   |  |  |  |  |
|-------|---------------------------------------------------------------------------|--|--|--|--|
| 0     | ne C0ERC and C0INFO registers are not cleared in the initialization mode. |  |  |  |  |
| 1     | The C0ERC and C0INFO registers are cleared in the initialization mode.    |  |  |  |  |

- Remarks 1. The CCERC bit is used to clear the C0ERC and C0INFO registers for re-initialization or forced recovery from the bus-off status. This bit can be set to 1 only in the initialization mode.
  - 2. When the C0ERC and C0INFO registers have been cleared, the CCERC bit is also cleared to 0 automatically.
  - **3.** The CCERC bit can be set to 1 at the same time as a request to change the initialization mode to an operation mode is made.
  - **4.** If the CCERC bit is set to 1 immediately after the INIT mode is entered in the self test mode, the receive data may be corrupted.

| AL | Bit to set operation in case of arbitration loss                                        |  |  |  |
|----|-----------------------------------------------------------------------------------------|--|--|--|
| 0  | Re-transmission is not executed in case of an arbitration loss in the single-shot mode. |  |  |  |
| 1  | Re-transmission is executed in case of an arbitration loss in the single-shot mode.     |  |  |  |

**Remark** The AL bit is valid only in the single-shot mode.

| VALID | Valid receive message frame detection bit                                              |
|-------|----------------------------------------------------------------------------------------|
| 0     | A valid message frame has not been received since the VALID bit was last cleared to 0. |
| 1     | A valid message frame has been received since the VALID bit was last cleared to 0.     |

- **Remarks 1**. Detection of a valid receive message frame is not dependent upon storage in the receive message buffer (data frame) or transmit message buffer (remote frame).
  - 2. Clear the VALID bit (0) before changing the initialization mode to an operation mode.
  - 3. If only two CAN nodes are connected to the CAN bus with one transmitting a message frame in the normal mode and the other in the reception mode, the VALID bit is not set to 1 before the transmitting node enters the error passive status.
  - **4**. To clear the VALID bit, set the Clear VALID bit to 1 first and confirm that the VALID bit is cleared. If it is not cleared, perform clearing processing again.

| PSMODE1 | PSMODE0 | Power save mode                |  |  |
|---------|---------|--------------------------------|--|--|
| 0       | 0       | o power save mode is selected. |  |  |
| 0       | 1       | CAN sleep mode                 |  |  |
| 1       | 0       | etting prohibited              |  |  |
| 1       | 1       | CAN stop mode                  |  |  |

Caution Transition to and from the CAN stop mode must be made via CAN sleep mode. A request for direct transition to and from the CAN stop mode is ignored.

(3/4)

| OPMODE2 | OPMODE1         | OPMODE0 | Operation mode                                                                                    |
|---------|-----------------|---------|---------------------------------------------------------------------------------------------------|
| 0       | 0               | 0       | No operation mode is selected (CAN module is in the initialization mode).                         |
| 0       | 0               | 1       | Normal operation mode                                                                             |
| 0       | 1               | 0       | Normal operation mode with automatic block transmission function (normal operation mode with ABT) |
| 0       | 1               | 1       | Receive-only mode                                                                                 |
| 1       | 0               | 0       | Single-shot mode                                                                                  |
| 1       | 0               | 1       | Self-test mode                                                                                    |
| (       | Other than abov | е       | Setting prohibited                                                                                |

**Remark** The OPMODE0 to OPMODE2 bits are read-only in the CAN sleep mode or CAN stop mode.

| Set CCERC        | Setting of CCERC bit      |
|------------------|---------------------------|
| 1                | CCERC bit is set to 1.    |
| Other than above | CCERC bit is not changed. |

| Set AL           | Clear AL | Setting of AL bit       |
|------------------|----------|-------------------------|
| 0                | 1        | AL bit is cleared to 0. |
| 1                | 0        | AL bit is set to 1.     |
| Other than above |          | AL bit is not changed.  |

| Clear VALID | Setting of VALID bit       |
|-------------|----------------------------|
| 0           | VALID bit is not changed.  |
| 1           | VALID bit is cleared to 0. |

| Set PSMODE0      | Clear PSMODE0 | Setting of PSMODE0 bit       |
|------------------|---------------|------------------------------|
| 0                | 1             | PSMODE0 bit is cleared to 0. |
| 1                | 0             | PSMODE bit is set to 1.      |
| Other than above |               | PSMODE0 bit is not changed.  |

| Set PSMODE1      | Clear PSMODE1 | Setting of PSMODE1 bit       |
|------------------|---------------|------------------------------|
| 0                | 1             | PSMODE1 bit is cleared to 0. |
| 1                | 0             | PSMODE1 bit is set to 1.     |
| Other than above |               | PSMODE1 bit is not changed.  |

(4/4)

| Set OPMODE0      | Clear OPMODE0 | Setting of OPMODE0 bit       |
|------------------|---------------|------------------------------|
| 0                | 1             | OPMODE0 bit is cleared to 0. |
| 1                | 0             | OPMODE0 bit is set to 1.     |
| Other than above |               | OPMODE0 bit is not changed.  |

| Set OPMODE1      | Clear OPMODE1 | Setting of OPMODE1 bit       |
|------------------|---------------|------------------------------|
| 0                | 1             | OPMODE1 bit is cleared to 0. |
| 1                | 0             | OPMODE1 bit is set to 1.     |
| Other than above |               | OPMODE1 bit is not changed.  |

| Set OPMODE2      | Clear OPMODE2 | Setting of OPMODE2 bit       |
|------------------|---------------|------------------------------|
| 0                | 1             | OPMODE2 bit is cleared to 0. |
| 1                | 0             | OPMODE2 bit is set to 1.     |
| Other than above |               | OPMODE2 bit is not changed.  |

## (7) CAN0 module last error information register (C0LEC)

The C0LEC register provides the error information of the CAN protocol.



- **Remarks 1.** The contents of the COLEC register are not cleared when the CAN module changes from an operation mode to the initialization mode.
  - 2. If an attempt is made to write a value other than 00H to the C0LEC register by software, the access is ignored.

| LEC2 | LEC1 | LEC0 | Last CAN protocol error information                                                                                                                                                               |
|------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | 0    | 0    | No error                                                                                                                                                                                          |
| 0    | 0    | 1    | Stuff error                                                                                                                                                                                       |
| 0    | 1    | 0    | Form error                                                                                                                                                                                        |
| 0    | 1    | 1    | ACK error                                                                                                                                                                                         |
| 1    | 0    | 0    | Bit error. (The CAN module tried to transmit a recessive-level bit as part of a transmit message (except the arbitration field), but the value on the CAN bus is a dominant-level bit.)           |
| 1    | 0    | 1    | Bit error. (The CAN module tried to transmit a dominant-level bit as part of a transmit message, ACK bit, error frame, or overload frame, but the value on the CAN bus is a recessive-level bit.) |
| 1    | 1    | 0    | CRC error                                                                                                                                                                                         |
| 1    | 1    | 1    | Undefined                                                                                                                                                                                         |

# (8) CAN0 module information register (C0INFO)

The C0INFO register indicates the status of the CAN module.



| BOFF | Bus-off status bit                                                                                       |
|------|----------------------------------------------------------------------------------------------------------|
| 0    | Not bus-off status (transmit error counter ≤ 255). (The value of the transmit counter is less than 256.) |
| 1    | Bus-off status (transmit error counter > 255). (The value of the transmit error counter is 256 or more.) |

| TECS1 | TECS0 | Transmission error counter status bit                                                                       |
|-------|-------|-------------------------------------------------------------------------------------------------------------|
| 0     | 0     | The value of the transmission error counter is less than that of the warning level (< 96).                  |
| 0     | 1     | The value of the transmission error counter is in the range of the warning level (96 to 127).               |
| 1     | 0     | Undefined                                                                                                   |
| 1     | 1     | The value of the transmission error counter is in the range of the error passive or bus-off status (≥ 128). |

| RECS1 | RECS0 | Reception error counter status bit                                                         |
|-------|-------|--------------------------------------------------------------------------------------------|
| 0     | 0     | The value of the reception error counter is less than that of the warning level (< 96).    |
| 0     | 1     | The value of the reception error counter is in the range of the warning level (96 to 127). |
| 1     | 0     | Undefined                                                                                  |
| 1     | 1     | The value of the reception error counter is in the error passive range (≥ 128).            |

## (9) CAN0 module error counter register (C0ERC)

The C0ERC register indicates the count value of the transmission/reception error counter.

After reset: 0000H R Address: 03FEC054H 15 14 12 9 13 11 10 C0ERC **REPS** REC6 REC5 REC4 REC3 REC2 REC1 REC0 7 6 5 4 3 2 0 1 TEC7 TEC6 TEC5 TEC4 TEC3 TEC2 TEC1 TEC0

| REPS | Reception error passive status bit                                             |
|------|--------------------------------------------------------------------------------|
| 0    | The value of the reception error counter is not error passive (< 128)          |
| 1    | The value of the reception error counter is in the error passive range (≥ 128) |

| REC6 to REC0 | Reception error counter bit                                                                   |
|--------------|-----------------------------------------------------------------------------------------------|
| 0 to 127     | Number of reception errors. These bits reflect the status of the reception error counter. The |
|              | number of errors is defined by the CAN protocol.                                              |

**Remark** The REC6 to REC0 bits of the reception error counter are invalid in the reception error passive status (C0INFO.RECS1, C0INFO.RECS0 bit = 11B).

| TEC7 to TEC0 | Transmission error counter bit                                                                  |  |  |  |  |
|--------------|-------------------------------------------------------------------------------------------------|--|--|--|--|
| 0 to 255     | Number of transmission errors. These bits reflect the status of the transmission error counter. |  |  |  |  |
|              | The number of errors is defined by the CAN protocol.                                            |  |  |  |  |

**Remark** The TEC7 to TEC0 bits of the transmission error counter are invalid in the bus-off status (C0INFO.BOFF bit = 1).

# (10) CAN0 module interrupt enable register (C0IE)

The C0IE register is used to enable or disable the interrupts of the CAN module.

(1/2)

| After reset: | 0000H R/W    | Addres                                                                                 | s: 03FEC05    | 6H              |                |               |               |               |
|--------------|--------------|----------------------------------------------------------------------------------------|---------------|-----------------|----------------|---------------|---------------|---------------|
| (a) Read     |              |                                                                                        |               |                 |                |               |               |               |
|              | 15           | 14                                                                                     | 13            | 12              | 11             | 10            | 9             | 8             |
| COIE         | 0            | 0                                                                                      | 0             | 0               | 0              | 0             | 0             | 0             |
|              | 7            | 6                                                                                      | 5             | 4               | 3              | 2             | 1             | 0             |
|              | 0            | 0                                                                                      | CIE5          | CIE4            | CIE3           | CIE2          | CIE1          | CIE0          |
| (b) Write    | 15           | 14                                                                                     | 13            | 12              | 11             | 10            | 9             | 8             |
| COIE         | 0            | 0                                                                                      | Set<br>CIE5   | Set<br>CIE4     | Set<br>CIE3    | Set<br>CIE2   | Set<br>CIE1   | Set<br>CIE0   |
|              | 7            | 6                                                                                      | 5             | 4               | 3              | 2             | 1             | 0             |
|              | 0            | 0                                                                                      | Clear<br>CIE5 | Clear<br>CIE4   | Clear<br>CIE3  | Clear<br>CIE2 | Clear<br>CIE1 | Clear<br>CIE0 |
| (a) Read     |              |                                                                                        |               |                 |                |               |               |               |
| CIE5 to CII  | E0           | CAN module interrupt enable bit                                                        |               |                 |                |               |               |               |
| 0            | Output of th | Output of the interrupt corresponding to interrupt status register CINTSx is disabled. |               |                 |                |               |               |               |
| 1            | Output of th | e interrupt co                                                                         | rresponding   | to interrupt st | tatus register | CINTSx is er  | nabled.       |               |

(2/2)

| Set CIE5         | Clear CIE5 | Setting of CIE5 bit       |  |  |  |
|------------------|------------|---------------------------|--|--|--|
| 0                | 1          | CIE5 bit is cleared to 0. |  |  |  |
| 1                | 0          | CIE5 bit is set to 1.     |  |  |  |
| Other than above |            | CIE5 bit is not changed.  |  |  |  |

| Set CIE4         | Clear CIE4 | Setting of CIE4 bit       |  |  |  |
|------------------|------------|---------------------------|--|--|--|
| 0                | 1          | CIE4 bit is cleared to 0. |  |  |  |
| 1                | 0          | CIE4 bit is set to 1.     |  |  |  |
| Other than above |            | CIE4 bit is not changed.  |  |  |  |

| Set CIE3         | Clear CIE3 | Setting of CIE3 bit       |
|------------------|------------|---------------------------|
| 0                | 1          | CIE3 bit is cleared to 0. |
| 1                | 0          | CIE3 bit is set to 1.     |
| Other than above |            | CIE3 bit is not changed.  |

| Set CIE2         | Clear CIE2 | Setting of CIE2 bit       |  |  |  |
|------------------|------------|---------------------------|--|--|--|
| 0                | 1          | CIE2 bit is cleared to 0. |  |  |  |
| 1                | 0          | CIE2 bit is set to 1.     |  |  |  |
| Other than above |            | CIE2 bit is not changed.  |  |  |  |

| Set CIE1  | Clear CIE1 | Setting of CIE1 bit       |  |  |  |
|-----------|------------|---------------------------|--|--|--|
| 0         | 1          | CIE1 bit is cleared to 0. |  |  |  |
| 1         | 0          | CIE1 bit is set to 1.     |  |  |  |
| Other tha | an above   | CIE1 bit is not changed.  |  |  |  |

| Set CIE0         | Clear CIE0 | Setting of CIE0 bit       |  |  |  |
|------------------|------------|---------------------------|--|--|--|
| 0                | 1          | CIE0 bit is cleared to 0. |  |  |  |
| 1                | 0          | CIE0 bit is set to 1.     |  |  |  |
| Other than above |            | CIE0 bit is not changed.  |  |  |  |

## (11) CAN0 module interrupt status register (C0INTS)

The C0INTS register indicates the interrupt status of the CAN module.

| After reset: 000 | 00H R/W | Address | s: 03FEC05      | 8H              |                 |                 |                 |                 |
|------------------|---------|---------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|
| (a) Read         |         |         |                 |                 |                 |                 |                 |                 |
|                  | 15      | 14      | 13              | 12              | 11              | 10              | 9               | 8               |
| COINTS           | 0       | 0       | 0               | 0               | 0               | 0               | 0               | 0               |
|                  | 7       | 6       | 5               | 4               | 3               | 2               | 1               | 0               |
|                  | 0       | 0       | CINTS5          | CINTS4          | CINTS3          | CINTS2          | CINTS1          | CINTS0          |
| (b) Write        |         |         |                 |                 |                 |                 |                 |                 |
|                  | 15      | 14      | 13              | 12              | 11              | 10              | 9               | 8               |
| COINTS           | 0       | 0       | 0               | 0               | 0               | 0               | 0               | 0               |
|                  | 7       | 6       | 5               | 4               | 3               | 2               | 1               | 0               |
|                  | 0       | 0       | Clear<br>CINTS5 | Clear<br>CINTS4 | Clear<br>CINTS3 | Clear<br>CINTS2 | Clear<br>CINTS1 | Clear<br>CINTS0 |

#### (a) Read

| CINTS5 to CINTS0 | CAN interrupt status bit                        |  |  |  |
|------------------|-------------------------------------------------|--|--|--|
| 0                | lo related interrupt source event is generated. |  |  |  |
| 1                | A related interrupt source event is generated.  |  |  |  |

| Interrupt status bit | Related interrupt source event                                                        |
|----------------------|---------------------------------------------------------------------------------------|
| CINTS5               | Wakeup interrupt from CAN sleep mode <sup>Note</sup>                                  |
| CINTS4               | Arbitration loss interrupt                                                            |
| CINTS3               | CAN protocol error interrupt                                                          |
| CINTS2               | CAN error status interrupt                                                            |
| CINTS1               | Interrupt on completion of reception of valid message frame to message buffer m       |
| CINTS0               | Interrupt on normal completion of transmission of message frame from message buffer m |

Note The CINTS5 bit is set only when the CAN module is woken up from the CAN sleep mode by a CAN bus operation. The CINTS5 bit is not set when the CAN sleep mode has been released by software.

| Clear CINTS5 to CINTS0 | Setting of CINTS5 to CINTS0 bits        |
|------------------------|-----------------------------------------|
| 0                      | CINTS5 to CINTS0 bits are not changed.  |
| 1                      | CINTS5 to CINTS0 bits are cleared to 0. |

#### (12) CAN0 module bit rate prescaler register (C0BRP)

The C0BRP register is used to select the CAN protocol layer base clock ( $f_{TQ}$ ). The communication baud rate is set to the C0BTR register.



Figure 19-23. CAN Module Clock



Caution The C0BRP register can be write-accessed only in the initialization mode.

## (13) CAN0 module bit rate register (C0BTR)

The C0BTR register is used to control the data bit time of the communication baud rate.

Figure 19-24. Data Bit Time



| After reset: 370 | )FH R/W | Address | s: 03FEC05 | СН   |        |        |        |        |
|------------------|---------|---------|------------|------|--------|--------|--------|--------|
|                  | 15      | 14      | 13         | 12   | 11     | 10     | 9      | 8      |
| C0BTR            | 0       | 0       | SJW1       | SJW0 | 0      | TSEG22 | TSEG21 | TSEG20 |
|                  | 7       | 6       | 5          | 4    | 3      | 2      | 1      | 0      |
|                  | 0       | 0       | 0          | 0    | TSEG13 | TSEG12 | TSEG11 | TSEG10 |

| SJW1 | SJW0 | Length of synchronization jump width |
|------|------|--------------------------------------|
| 0    | 0    | 1TQ                                  |
| 0    | 1    | 2TQ                                  |
| 1    | 0    | 3TQ                                  |
| 1    | 1    | 4TQ (default value)                  |

| TSEG22 | TSEG21 | TSEG20 | Length of time segment 2 |
|--------|--------|--------|--------------------------|
| 0      | 0      | 0      | 1TQ                      |
| 0      | 0      | 1      | 2TQ                      |
| 0      | 1      | 0      | зто                      |
| 0      | 1      | 1      | 4TQ                      |
| 1      | 0      | 0      | 5TQ                      |
| 1      | 0      | 1      | 6TQ                      |
| 1      | 1      | 0      | 7TQ                      |
| 1      | 1      | 1      | 8TQ (default value)      |

| TSEG13 | TSEG12 | TSEG11 | TSEG10 | Length of time segment 1 |
|--------|--------|--------|--------|--------------------------|
| 0      | 0      | 0      | 0      | Setting prohibited       |
| 0      | 0      | 0      | 1      | 2TQ <sup>Note</sup>      |
| 0      | 0      | 1      | 0      | 3TQ <sup>Note</sup>      |
| 0      | 0      | 1      | 1      | 4TQ                      |
| 0      | 1      | 0      | 0      | 5TQ                      |
| 0      | 1      | 0      | 1      | 6TQ                      |
| 0      | 1      | 1      | 0      | 7TQ                      |
| 0      | 1      | 1      | 1      | 8TQ                      |
| 1      | 0      | 0      | 0      | 9TQ                      |
| 1      | 0      | 0      | 1      | 10TQ                     |
| 1      | 0      | 1      | 0      | 11TQ                     |
| 1      | 0      | 1      | 1      | 12TQ                     |
| 1      | 1      | 0      | 0      | 13TQ                     |
| 1      | 1      | 0      | 1      | 14TQ                     |
| 1      | 1      | 1      | 0      | 15TQ                     |
| 1      | 1      | 1      | 1      | 16TQ (default value)     |

**Note** This setting must not be made when the C0BRP register = 00H.

**Remark**  $TQ = 1/f_{TQ}$  ( $f_{TQ}$ : CAN protocol layer basic system clock)

## (14) CAN0 module last in-pointer register (C0LIPT)

The C0LIPT register indicates the number of the message buffer in which a data frame or a remote frame was last stored.



| LIPT7 to LIPT0 | Last in-pointer register (C0LIPT)                                                              |
|----------------|------------------------------------------------------------------------------------------------|
| 0 to 31        | When the C0LIPT register is read, the contents of the element indexed by the last in-pointer   |
|                | (LIPT) of the receive history list are read. These contents indicate the number of the message |
|                | buffer in which a data frame or a remote frame was last stored.                                |

**Remark** The read value of the C0LIPT register is undefined if a data frame or a remote frame has never been stored in the message buffer. If the C0RGPT.RHPM bit is set to 1 after the CAN module has changed from the initialization mode to an operation mode, therefore, the read value of the C0LIPT register is undefined.

# (15) CAN0 module receive history list register (C0RGPT)

The CORGPT register is used to read the receive history list.

| After reset: xx0 | 2H R/W | Address | s: 03FEC06 | 0H    |       |       |       |               |
|------------------|--------|---------|------------|-------|-------|-------|-------|---------------|
| (a) Read         |        |         |            |       |       |       |       |               |
|                  | 15     | 14      | 13         | 12    | 11    | 10    | 9     | 8             |
| CORGPT           | RGPT7  | RGPT6   | RGPT5      | RGPT4 | RGPT3 | RGPT2 | RGPT1 | RGPT0         |
|                  | 7      | 6       | 5          | 4     | 3     | 2     | 1     | 0             |
|                  | 0      | 0       | 0          | 0     | 0     | 0     | RHPM  | ROVF          |
| (b) Write        |        |         |            |       |       |       |       |               |
|                  | 15     | 14      | 13         | 12    | 11    | 10    | 9     | 8             |
| CORGPT           | 0      | 0       | 0          | 0     | 0     | 0     | 0     | 0             |
|                  | 7      | 6       | 5          | 4     | 3     | 2     | 1     | 0             |
|                  | 0      | 0       | 0          | 0     | 0     | 0     | 0     | Clear<br>ROVF |

#### (a) Read

| RGPT7 to RGPT0 | Receive history list read pointer                                                                                                                                                                                                                                            |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 to 31        | When the C0RGPT register is read, the contents of the element indexed by the receive history list get pointer (RGPT) of the receive history list are read. These contents indicate the number of the message buffer in which a data frame or a remote frame has been stored. |

| RHPM <sup>Note</sup> | Receive history list pointer match                                                      |
|----------------------|-----------------------------------------------------------------------------------------|
| 0                    | The receive history list has at least one message buffer number that has not been read. |
| 1                    | The receive history list has no message buffer numbers that have not been read.         |

| ROVF | Receive history list overflow bit                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | All the message buffer numbers that have not been read are preserved. All the numbers of the message buffers in which a new data frame or remote frame has been received and stored are recorded to the receive history list (the receive history list has a vacant element).                                                                                                                                                                      |
| 1    | At least 23 entries have been stored since the host processor serviced the RHL last time (i.e. read C0RGPT). The first 22 entries are sequentially stored whereas the last entry might have been overwritten by newly received messages a number of times because all buffer numbers are stored at position LIPT-1 when the ROVF bit is set to 1. As a consequence receptions cannot be completely recovered in the order that they were received. |

**Note** The read value of the RGPT0 to RGPT7 bits is invalid when the RHPM bit = 1.

| Clear ROVF | Setting of ROVF bit       |
|------------|---------------------------|
| 0          | ROVF bit is not changed.  |
| 1          | ROVF bit is cleared to 0. |

## (16) CAN0 module last out-pointer register (C0LOPT)

The C0LOPT register indicates the number of the message buffer to which a data frame or a remote frame was transmitted last.



| LOPT7 to LOPT0 | Last out-pointer of transmit history list (LOPT)                                               |
|----------------|------------------------------------------------------------------------------------------------|
| 0 to 31        | When the C0LOPT register is read, the contents of the element indexed by the last out-pointer  |
|                | (LOPT) of the receive history list are read. These contents indicate the number of the message |
|                | buffer to which a data frame or a remote frame was transmitted last.                           |

**Remark** The value read from the C0LOPT register is undefined if a data frame or remote frame has never been transmitted from a message buffer. If the C0TGPT.THPM bit is set to 1 after the CAN module has changed from the initialization mode to an operation mode, therefore, the read value of the C0LOPT register is undefined.

## (17) CAN0 module transmit history list register (C0TGPT)

The C0TGPT register is used to read the transmit history list.

After reset: xx02H R/W Address: 03FEC064H

(a) Read

(b) Write

C0TGPT

**COTGPT** 

|   | 15    | 14    | 13    | 12    | 11    | 10    | 9     | 8             |
|---|-------|-------|-------|-------|-------|-------|-------|---------------|
|   | TGPT7 | TGPT6 | TGPT5 | TGPT4 | TGPT3 | TGPT2 | TGPT1 | TGPT0         |
|   | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0             |
|   | 0     | 0     | 0     | 0     | 0     | 0     | THPM  | TOVF          |
|   |       |       |       |       |       |       |       |               |
| , | 15    | 14    | 13    | 12    | 11    | 10    | 9     | 8             |
|   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0             |
|   | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0             |
|   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | Clear<br>TOVF |

#### (a) Read

| TGPT7 to TGPT0 | Transmit history list read pointer                                                                                                                                                                                                                             |  |  |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0 to 31        | When the C0TGPT register is read, the contents of the element indexed by the read pointer (TGPT) of the transmit history list are read. These contents indicate the number of the message buffer to which a data frame or a remote frame was transmitted last. |  |  |

| THPM <sup>Note</sup> Transmit history pointer match                                      |  |
|------------------------------------------------------------------------------------------|--|
| The transmit history list has at least one message buffer number that has not been read. |  |
| 1 The transmit history list has no message buffer numbers that have not been read.       |  |

| TOVF | Transmit history list overflow bit                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | All the message buffer numbers that have not been read are preserved. All the numbers of the message buffers to which a new data frame or remote frame has been transmitted are recorded to the transmit history list (the transmit history list has a vacant element).                                                                                                                                                                         |
| 1    | At least 7 entries have been stored since the host processor serviced the THL last time (i.e. read C0TGPT). The first 6 entries are sequentially stored whereas the last entry might have been overwritten by newly transmitted messages a number of times because all buffer numbers are stored at position LOPT-1 when TOVF bit is set to 1. As a consequence receptions cannot be completely recovered in the order that they were received. |

**Note** The read value of the TGPT0 to TGPT7 bits is invalid when the THPM bit = 1.

**Remark** Transmission from message buffers 0 to 7 is not recorded to the transmit history list in the normal operation mode with ABT.

| Clear TOVF | Setting of TOVF bit       |  |  |
|------------|---------------------------|--|--|
| 0          | TOVF bit is not changed.  |  |  |
| 1          | TOVF bit is cleared to 0. |  |  |

## (18) CAN0 module time stamp register (C0TS)

The C0TS register is used to control the time stamp function.

(1/2)

| After reset: 000 | 00H R/V | V Addre | ss: 03FEC0 | 66H |    |                 |                |               |
|------------------|---------|---------|------------|-----|----|-----------------|----------------|---------------|
| (a) Read         |         |         |            |     |    |                 |                |               |
|                  | 15      | 14      | 13         | 12  | 11 | 10              | 9              | 8             |
| COTS             | 0       | 0       | 0          | 0   | 0  | 0               | 0              | 0             |
|                  | 7       | 6       | 5          | 4   | 3  | 2               | 1              | 0             |
|                  | 0       | 0       | 0          | 0   | 0  | TSLOCK          | TSSEL          | TSEN          |
| (b) Write        | 15      | 14      | 13         | 12  | 11 | 10              | 9              | 8             |
| COTS             | 0       | 0       | 0          | 0   | 0  | Set<br>TSLOCK   | Set<br>TSSEL   | Set<br>TSEN   |
|                  | 7       | 6       | 5          | 4   | 3  | 2               | 1              | 0             |
|                  | 0       | 0       | 0          | 0   | 0  | Clear<br>TSLOCK | Clear<br>TSSEL | Clear<br>TSEN |

**Remark** The lock function of the time stamp functions must not be used when the CAN module is in the normal operation mode with ABT.

## (a) Read

| TSLOCK | Time stamp lock function enable bit                                                                                                                                                                                                                  |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | Time stamp lock function stopped.  The TSOUT signal is toggled each time the selected time stamp capture event occurs.                                                                                                                               |
| 1      | Time stamp lock function enabled.  The TSOUT signal toggled each time the selected time stamp capture event occurred. However, the TSOUT output signal is locked when a data frame has been correctly received to message buffer 0 <sup>Note</sup> . |

Note The TSEN bit is automatically cleared to 0.

| TSSEL | Time stamp capture event selection bit               |  |  |
|-------|------------------------------------------------------|--|--|
| 0     | The time capture event is SOF.                       |  |  |
| 1     | The time stamp capture event is the last bit of EOF. |  |  |

| TSEN | TSOUT operation setting bit        |  |  |
|------|------------------------------------|--|--|
| 0    | SOUT toggle operation is disabled. |  |  |
| 1    | TSOUT toggle operation is enabled. |  |  |

(2/2)

| Set TSLOCK       | Clear TSLOCK | Setting of TSLOCK bit       |
|------------------|--------------|-----------------------------|
| 0                | 1            | TSLOCK bit is cleared to 0. |
| 1                | 0            | TSLOCK bit is set to 1.     |
| Other than above |              | TSLOCK bit is not changed.  |

| Set TSSEL        | Clear TSSEL | Setting of TSSEL bit      |  |  |
|------------------|-------------|---------------------------|--|--|
| 0                | 1           | SSEL bit is cleared to 0. |  |  |
| 1                | 0           | SSEL bit is set to 1.     |  |  |
| Other than above |             | TSSEL bit is not changed. |  |  |

| Set TSEN         | Clear TSEN | Setting of TSEN bit      |  |  |
|------------------|------------|--------------------------|--|--|
| 0                | 1          | SEN bit is cleared to 0. |  |  |
| 1                | 0          | SEN bit is set to 1.     |  |  |
| Other than above |            | TSEN bit is not changed. |  |  |

# (19) CANO message data byte register (COMDATAxm, COMDATAym) (x = 0 to 7, y = 01, 23, 45, 67)

The C0MDATAxm and C0MDATAym registers are used to store the data of a transmit/receive message. The C0MDATAxm register can be accessed in 16-bit units by the C0MDATAym register.

(1/2)

|            | 15      | 14          | 13          | 12          | 11          | 10          | 9            | 8         |
|------------|---------|-------------|-------------|-------------|-------------|-------------|--------------|-----------|
| C0MDATA01m | MDATA01 | MDATA01     | MDATA01     | MDATA01     | MDATA01     | MDATA01     | MDATA01      | MDAT      |
|            | 15      | 14          | 13          | 12          | 11          | 10          | 9            | 8         |
|            | 7       | 6           | 5           | 4           | 3           | 2           | 1            | 0         |
|            | MDATA01 | MDATA01     | MDATA01     | MDATA01     | MDATA01     | MDATA01     | MDATA01      | MDAT      |
|            | 7       | 6           | 5           | 4           | 3           | 2           | 1            | 0         |
|            | 7       | 6           | 5           | 4           | 3           | 2           | 1            | 0         |
| C0MDATA0m  | MDATA0  | MDATA0      | MDATA0      | MDATA0      | MDATA0      | MDATA0      | MDATA0       | MDAT      |
|            | 7       | 6           | 5           | 4           | 3           | 2           | 1            | 0         |
|            |         |             |             |             |             |             |              |           |
|            | 7       | 6           | 5           | 4           | 3           | 2           | 1            | 0         |
| C0MDATA1m  | MDATA1  | MDATA1      | MDATA1      | MDATA1      | MDATA1      | MDATA1      | MDATA1       | MDAT      |
|            | 7       | 6           | 5           | 4           | 3           | 2           | 1            | 0         |
|            | 15      | 14          | 13          | 12          | 11          | 10          | 9            | 8         |
| 0014547400 |         |             | 1           |             |             | 1           | 1            |           |
| C0MDATA23m | MDATA23 | MDATA23     | MDATA23     | MDATA23     | MDATA23     | MDATA23     | MDATA23<br>9 | MDAT.     |
|            | 7       | 6           | 5           | 4           | 3           | 2           | 1            | 0         |
|            | MDATA23 | MDATA23     | MDATA23     | MDATA23     | MDATA23     | MDATA23     | MDATA23      | MDAT      |
|            | 7       | 6           | 5           | 4           | 3           | 2           | 1            | 0         |
|            | 7       |             | F           | 4           | 0           | 0           | 4            | 0         |
| COMPATAG   | 7       | 6           | 5           | 4           | 3           | 2           | 1            | 0         |
| C0MDATA2m  | MDATA2  | MDATA2<br>6 | MDATA2<br>5 | MDATA2<br>4 | MDATA2<br>3 | MDATA2<br>2 | MDATA2<br>1  | MDAT<br>0 |
|            |         |             |             | _т          |             |             | '            |           |
|            | 7       | 6           | 5           | 4           | 3           | 2           | 1            | 0         |
| C0MDATA3m  | MDATA3  | MDATA3      | MDATA3      | MDATA3      | MDATA3      | MDATA3      | MDATA3       | MDAT      |
| COMPATAGIN | 7       | 6           | 5           | 4           | 3           | 2           | 1            | IVIL      |

(2/2)

|            | 15      | 14          | 13      | 12      | 11      | 10      | 9       | 8      |
|------------|---------|-------------|---------|---------|---------|---------|---------|--------|
| C0MDATA45m | MDATA45 | MDATA45     | MDATA45 | MDATA45 | MDATA45 | MDATA45 | MDATA45 | MDATA4 |
|            | 15      | 14          | 13      | 12      | 11      | 10      | 9       | 8      |
|            | 7       | 6           | 5       | 4       | 3       | 2       | 1       | 0      |
|            | MDATA45 | MDATA45     | MDATA45 | MDATA45 | MDATA45 | MDATA45 | MDATA45 | MDATA4 |
|            | 7       | 6           | 5       | 4       | 3       | 2       | 1       | 0      |
|            |         |             |         |         |         |         |         |        |
|            | 7       | 6           | 5       | 4       | 3       | 2       | 1       | 0      |
| C0MDATA4m  | MDATA4  | MDATA4      | MDATA4  | MDATA4  | MDATA4  | MDATA4  | MDATA4  | MDATA4 |
|            | 7       | 6           | 5       | 4       | 3       | 2       | 1       | 0      |
|            |         |             |         |         |         |         |         |        |
|            | 7       | 6           | 5       | 4       | 3       | 2       | 1       | 0      |
| C0MDATA5m  | MDATA5  | MDATA5      | MDATA5  | MDATA5  | MDATA5  | MDATA5  | MDATA5  | MDATA5 |
|            | 7       | 6           | 5       | 4       | 3       | 2       | 1       | 0      |
|            |         |             |         |         |         |         |         |        |
|            | 15      | 14          | 13      | 12      | 11      | 10      | 9       | 8      |
| C0MDATA67m | MDATA67 | MDATA67     | MDATA67 | MDATA67 | MDATA67 | MDATA67 | MDATA67 | MDATA6 |
|            | 15      | 14          | 13      | 12      | 11      | 10      | 9       | 8      |
|            | 7       | 6           | 5       | 4       | 3       | 2       | 1       | 0      |
|            | MDATA67 | MDATA67     | MDATA67 | MDATA67 | MDATA67 | MDATA67 | MDATA67 | MDATA6 |
|            | 7       | 6           | 5       | 4       | 3       | 2       | 1       | 0      |
|            |         |             |         |         |         |         |         |        |
|            | 7       | 6           | 5       | 4       | 3       | 2       | 1       | 0      |
| C0MDATA6m  | MDATA6  | MDATA6      | MDATA6  | MDATA6  | MDATA6  | MDATA6  | MDATA6  | MDATA6 |
|            | 7       | 6           | 5       | 4       | 3       | 2       | 1       | 0      |
|            |         |             |         |         |         |         |         |        |
|            | 7       | 6           | 5       | 4       | 3       | 2       | 1       | 0      |
| C0MDATA7m  | MDATA7  | MDATA7<br>6 | MDATA7  | MDATA7  | MDATA7  | MDATA7  | MDATA7  | MDATA7 |
|            | 7       |             | 5       | 4       | 3       | 2       | 1       | 0      |

# (20) CAN0 message data length register m (C0MDLCm)

The COMDLCm register is used to set the number of bytes of the data field of a message buffer.

 After reset: 0000xxxxB
 R/W
 Address: See **Table 19-16**.

 7
 6
 5
 4
 3
 2
 1
 0

 COMDLCm
 0
 0
 0
 MDLC3
 MDLC2
 MDLC1
 MDLC0

| MDLC3 | MDLC2 | MDLC1 | MDLC0 | Data length of transmit/receive message                                                                                            |
|-------|-------|-------|-------|------------------------------------------------------------------------------------------------------------------------------------|
| 0     | 0     | 0     | 0     | 0 bytes                                                                                                                            |
| 0     | 0     | 0     | 1     | 1 byte                                                                                                                             |
| 0     | 0     | 1     | 0     | 2 bytes                                                                                                                            |
| 0     | 0     | 1     | 1     | 3 bytes                                                                                                                            |
| 0     | 1     | 0     | 0     | 4 bytes                                                                                                                            |
| 0     | 1     | 0     | 1     | 5 bytes                                                                                                                            |
| 0     | 1     | 1     | 0     | 6 bytes                                                                                                                            |
| 0     | 1     | 1     | 1     | 7 bytes                                                                                                                            |
| 1     | 0     | 0     | 0     | 8 bytes                                                                                                                            |
| 1     | 0     | 0     | 1     | Setting prohibited                                                                                                                 |
| 1     | 0     | 1     | 0     | (If these bits are set during transmission, 8-byte data is transmitted                                                             |
| 1     | 0     | 1     | 1     | regardless of the set DLC value when a data frame is transmitted.  However, the DLC actually transmitted to the CAN bus is the DLC |
| 1     | 1     | 0     | 0     | value set to this register.) Note                                                                                                  |
| 1     | 1     | 0     | 1     |                                                                                                                                    |
| 1     | 1     | 1     | 0     |                                                                                                                                    |
| 1     | 1     | 1     | 1     |                                                                                                                                    |

**Note** The data and DLC value actually transmitted to CAN bus are as follows.

| Type of transmit frame | Length of transmit data                                        | DLC transmitted     |
|------------------------|----------------------------------------------------------------|---------------------|
| Data frame             | Number of bytes specified by DLC (However, 8 bytes if DLC ≥ 8) | MDLC3 to MDLC0 bits |
| Remote frame           | 0 bytes                                                        |                     |

# Cautions 1. Be sure to set bits 7 to 4 to 0000B.

2. Receive data is stored in as many C0MDATAxm register as the number of bytes (however, the upper limit is 8) corresponding to DLC. The C0MDATAxm register in which no data is stored is undefined.

#### (21) CAN0 message configuration register m (C0MCONFm)

The COMCONFm register is used to specify the type of the message buffer and to set a mask.

(1/2)

| After reset: Undefined R/W |     | R/W Ad | dress: See <b>1</b> | Table 19-16. |     |   |   |     |
|----------------------------|-----|--------|---------------------|--------------|-----|---|---|-----|
|                            | 7   | 6      | 5                   | 4            | 3   | 2 | 1 | 0   |
| C0MCONFm                   | ows | RTR    | MT2                 | MT1          | MT0 | 0 | 0 | MA0 |

| ows | Overwrite control bit                                                                                                                                                    |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | The message buffer <sup>Note</sup> that has already received a data frame is not overwritten by a newly received data frame. The newly received data frame is discarded. |
| 1   | The message buffer that has already received a data frame is overwritten by a newly received data frame.                                                                 |

**Note** The "message buffer that has already received a data frame" is a receive message buffer whose the COMCTRLm.DN bit has been set to 1.

**Remark** A remote frame is received and stored, regardless of the setting of the OWS and DN bits. A remote frame that satisfies the other conditions (ID matches, the RTR bit = 0, the C0MCTRLm.TRQ bit = 0) is always received and stored in the corresponding message buffer (interrupt generated, DN flag set, the C0MDLCm.MDLC0 to C0MDLCm.MDLC3 bits updated, and recorded to the receive history list).

| RTR | Remote frame request bit <sup>Note</sup> |
|-----|------------------------------------------|
| 0   | Transmit a data frame.                   |
| 1   | Transmit a remote frame.                 |

Note The RTR bit specifies the type of message frame that is transmitted from a message buffer defined as a transmit message buffer. Even if a valid remote frame has been received, the RTR bit of the transmit message buffer that has received the frame remains cleared to 0. Even if a remote frame whose ID matches has been received from the CAN bus with the RTR bit of the transmit message buffer set to 1 to transmit a remote frame, that remote frame is not received or stored (interrupt generated, DN flag set, the MDLC0 to MDLC3 bits updated, and recorded to the receive history list).

| MT2 | MT1              | MT0 | Message buffer type setting bit          |
|-----|------------------|-----|------------------------------------------|
| 0   | 0                | 0   | Transmit message buffer                  |
| 0   | 0                | 1   | Receive message buffer (no mask setting) |
| 0   | 1                | 0   | Receive message buffer (mask 1 set)      |
| 0   | 1                | 1   | Receive message buffer (mask 2 set)      |
| 1   | 0                | 0   | Receive message buffer (mask 3 set)      |
| 1   | 0                | 1   | Receive message buffer (mask 4 set)      |
| 0   | Other than above |     | Setting prohibited                       |

(2/2)

| MA0 | Message buffer assignment bit |
|-----|-------------------------------|
| 0   | Message buffer not used.      |
| 1   | Message buffer used.          |

Caution Be sure to write 0 to bits 2 and 1.

# (22) CAN0 message ID register m (C0MIDLm, C0MIDHm)

The C0MIDLm and C0MIDHm registers are used to set an identifier (ID).

| After reset: Und | defined | R/W Ad | ldress: See 1 | Гable 19-16. |      |      |      |      |
|------------------|---------|--------|---------------|--------------|------|------|------|------|
|                  | 15      | 14     | 13            | 12           | 11   | 10   | 9    | 8    |
| C0MIDLm          | ID15    | ID14   | ID13          | ID12         | ID11 | ID10 | ID9  | ID8  |
|                  | 7       | 6      | 5             | 4            | 3    | 2    | 1    | 0    |
|                  | ID7     | ID6    | ID5           | ID4          | ID3  | ID2  | ID1  | ID0  |
|                  |         |        |               |              |      |      |      |      |
|                  | 15      | 14     | 13            | 12           | 11   | 10   | 9    | 8    |
| C0MIDHm          | IDE     | 0      | 0             | ID28         | ID27 | ID26 | ID25 | ID24 |
|                  | 7       | 6      | 5             | 4            | 3    | 2    | 1    | 0    |
|                  | ID23    | ID22   | ID21          | ID20         | ID19 | ID18 | ID17 | ID16 |

| IDE | Format mode specification bit                                |
|-----|--------------------------------------------------------------|
| 0   | Standard format mode (ID28 to ID18: 11 bits) <sup>Note</sup> |
| 1   | Extended format mode (ID28 to ID0: 29 bits)                  |

**Note** The ID17 to ID0 bits are not used.

| ID28 to ID0  | Message ID                                  |
|--------------|---------------------------------------------|
| ID28 to ID18 | Standard ID value of 11 bits (when IDE = 0) |
| ID28 to ID0  | Extended ID value of 29 bits (when IDE = 1) |

Caution Be sure to write 0 to bits 14 and 13 of the C0MIDHm register.

# (23) CAN0 message control register m (C0MCTRLm)

The COMCTRLm register is used to control the operation of the message buffer.

(1/2)

TRQ

**RDY** 

|                  |                    |     |              |               |           |       |            | •          |
|------------------|--------------------|-----|--------------|---------------|-----------|-------|------------|------------|
| After reset: 000 | x000000<br>0xx000B | R/W | Address: See | e Table 19-16 |           |       |            |            |
| (a) Read         |                    |     |              |               |           |       |            |            |
|                  | 15                 | 14  | 13           | 12            | 11        | 10    | 9          | 8          |
| C0MCTRLm         | 0                  | 0   | MUC          | 0             | 0         | 0     | 0          | 0          |
|                  | 7                  | 6   | 5            | 4             | 3         | 2     | 1          | 0          |
|                  | 0                  | 0   | 0            | MOW           | ΙE        | DN    | TRQ        | RDY        |
| (b) Write        |                    |     |              |               |           |       |            |            |
|                  | 15                 | 14  | 13           | 12            | 11        | 10    | 9          | 8          |
| C0MCTRLm         | 0                  | 0   | 0            | 0             | Set<br>IE | 0     | Set<br>TRQ | Set<br>RDY |
|                  | 7                  | 6   | 5            | 4             | 3         | 2     | 1          | 0          |
|                  | 0                  | 0   | 0            | Clear         | Clear     | Clear | Clear      | Clear      |

# (a) Read

|                                                                                                                                                    | MUC <sup>Note</sup> | Bit indicating that message buffer data is being updated                   |
|----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|----------------------------------------------------------------------------|
| The CAN module is not updating the message buffer (reception and storage).  The CAN module is updating the message buffer (reception and storage). |                     | The CAN module is not updating the message buffer (reception and storage). |
|                                                                                                                                                    |                     | The CAN module is updating the message buffer (reception and storage).     |

MOW

ΙE

DN

**Note** The MUC bit is undefined until the first reception and storage is performed.

| MOW Message buffer overwrite status bit |   | Message buffer overwrite status bit                                   |
|-----------------------------------------|---|-----------------------------------------------------------------------|
|                                         | 0 | The message buffer is not overwritten by a newly received data frame. |
|                                         | 1 | The message buffer is overwritten by a newly received data frame.     |

**Remark** The MOW bit is not set to 1 even if a remote frame is received and stored in the transmit message buffer with the DN bit = 1.

| IE | Message buffer interrupt request enable bit                                                                                                                         |
|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0  | Receive message buffer: Valid message reception completion interrupt disabled.  Transmit message buffer: Normal message transmission completion interrupt disabled. |
| 1  | Receive message buffer: Valid message reception completion interrupt enabled.  Transmit message buffer: Normal message transmission completion interrupt enabled.   |

| DN                                                                  | Message buffer data update bit                                |
|---------------------------------------------------------------------|---------------------------------------------------------------|
| O A data frame or remote frame is not stored in the message buffer. |                                                               |
| 1                                                                   | A data frame or remote frame is stored in the message buffer. |

(2/2)

| TRQ | Message buffer transmission request bit                                                              |  |
|-----|------------------------------------------------------------------------------------------------------|--|
| 0   | No message frame transmitting request that is pending or being transmitted is in the message buffer. |  |
| 1   | The message buffer is holding transmission of a message frame pending or is transmitting a message   |  |
|     | frame.                                                                                               |  |

# Caution Do not set the TRQ bit and RDY bit to 1 at the same time. Be sure to set the RDY bit to 1 before setting the TRQ bit to 1.

| RDY | Message buffer ready bit                                                                              |
|-----|-------------------------------------------------------------------------------------------------------|
| 0   | The message buffer can be written by software. The CAN module cannot write to the message buffer.     |
| 1   | Writing the message buffer by software is ignored (except a write access to the RDY, TRQ, DN, and MOW |
|     | bits). The CAN module can write to the message buffer.                                                |

# Caution Do not clear the RDY bit (0) during message transmission. Follow transmission abort procedures in order to clear the RDY bit for redefinition.

# (b) Write

| Clear MOW | Setting of MOW bit       |  |
|-----------|--------------------------|--|
| 0         | MOW bit is not changed.  |  |
| 1         | MOW bit is cleared to 0. |  |

|   | Set IE           | Clear IE | Setting of IE bit       |
|---|------------------|----------|-------------------------|
|   | 0                | 1        | IE bit is cleared to 0. |
|   | 1                | 0        | IE bit is set to 1.     |
| Ī | Other than above |          | IE bit is not changed.  |

| Clear DN | Setting of DN bit       |
|----------|-------------------------|
| 1        | DN bit is cleared to 0. |
| 0        | DN bit is not changed.  |

# Caution Do not set the DN bit to 1 by software. Be sure to write 0 to bit 10.

| Set TRQ          | Clear TRQ | Setting of TRQ bit       |
|------------------|-----------|--------------------------|
| 0                | 1         | TRQ bit is cleared to 0. |
| 1                | 0         | TRQ bit is set to 1.     |
| Other than above |           | TRQ bit is not changed.  |

| Set RDY          | Clear RDY | Setting of RDY bit       |
|------------------|-----------|--------------------------|
| 0                | 1         | RDY bit is cleared to 0. |
| 1                | 0         | RDY bit is set to 1.     |
| Other than above |           | RDY bit is not changed.  |

#### 19.7 Bit Set/Clear Function

The CAN control registers include registers whose bits can be set or cleared via the CPU and via the CAN interface. An operation error occurs if the following registers are written directly. Do not write any values directly via bit manipulation, read/modify/write, or direct writing of target values.

- CAN0 global control register (C0GMCTRL)
- CANO global automatic block transmission control register (COGMABT)
- CAN0 module control register (C0CTRL)
- CAN0 module interrupt enable register (C0IE)
- CAN0 module interrupt status register (C0INTS)
- CAN0 module receive history list register (C0RGPT)
- CAN0 module transmit history list register (C0TGPT)
- CAN0 module time stamp register (C0TS)
- CAN0 message control register (C0MCTRLm)

**Remark** m = 00 to 31

All the 16 bits in the above registers can be read via the usual method. Use the procedure described in Figure 19-25 below to set or clear the lower 8 bits in these registers.

Setting or clearing of lower 8 bits in the above registers is performed in combination with the higher 8 bits (see the bit status after set/clear operation is specified in Figure 19-26). Figure 19-25 shows how the values of set bits or clear bits relate to set/clear/no change operations in the corresponding register.

Register's current value Write value set clear No change No change No change status Clear Set Set Register's value after write operation

Figure 19-25. Example of Bit Setting/Clearing Operations

Figure 19-26. Bit Status After Bit Setting/Clearing Operations

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
Set 7 Set 6 Set 5 Set 4 Set 3 Set 2 Set 1 Set 0 Clear 7 Clear 6 Clear 5 Clear 4 Clear 3 Clear 2 Clear 1 Clear 0

| Set n | Clear n | Status of bit n after bit set/clear operation |
|-------|---------|-----------------------------------------------|
| 0     | 0       | No change                                     |
| 0     | 1       | 0                                             |
| 1     | 0       | 1                                             |
| 1     | 1       | No change                                     |

**Remark** n = 0 to 7

#### 19.8 CAN Controller Initialization

#### 19.8.1 Initialization of CAN module

Before CAN module operation is enabled, the CAN module system clock needs to be determined by setting the C0GMCS.CCP0 to C0GMCS.CCP3 bits by software. Do not change the setting of the CAN module system clock after CAN module operation is enabled.

The CAN module is enabled by setting the COGMCTRL.GOM bit.

For the procedure of initializing the CAN module, see 19.16 Operation of CAN Controller.

#### 19.8.2 Initialization of message buffer

After the CAN module is enabled, the message buffers contain undefined values. A minimum initialization for all the message buffers, even for those not used in the application, is necessary before switching the CAN module from the initialization mode to one of the operation modes.

- Clear the C0MCTRLm.RDY, C0MCTRLm.TRQ, and C0MCTRLm.DN bits to 0.
- Clear the C0MCONFm.MA0 bit to 0.

**Remark** m = 00 to 31

#### 19.8.3 Redefinition of message buffer

Redefining a message buffer means changing the ID and control information of the message buffer while a message is being received or transmitted, without affecting other transmission/reception operations.

### (1) To redefine message buffer in initialization mode

Place the CAN module in the initialization mode once and then change the ID and control information of the message buffer in the initialization mode. After changing the ID and control information, set the CAN module to an operation mode.

### (2) To redefine message buffer during reception

Perform redefinition as shown in Figure 19-38.

#### (3) To redefine message buffer during transmission

To rewrite the contents of a transmit message buffer to which a transmission request has been set, perform transmission abort processing (see 19.10.4 (1) Transmission abort in normal operation mode, 19.10.4 (2) Transmission abort process except for ABT transmission in normal operation mode with automatic block transmission (ABT), and 19.10.4 (3) Transmission abort in normal operation mode with automatic block transmission (ABT)). Confirm that transmission has been aborted or completed, and then redefine the message buffer. After redefining the transmit message buffer, set a transmission request using the procedure described below. When setting a transmission request to a message buffer that has been redefined without aborting the transmission in progress, however, the 1-bit wait time is not necessary.



Figure 19-27. Setting Transmission Request (TRQ) to Transmit Message Buffer After Redefinition

- Cautions 1. When a message is received, reception filtering is performed in accordance with the ID and mask set to each receive message buffer. If the procedure in Figure 19-39 is not observed, the contents of the message buffer after it has been redefined may contradict the result of reception (result of reception filtering). If this happens, check that the ID and IDE received first and stored in the message buffer following redefinition are those stored after the message buffer has been redefined. If no ID and IDE are stored after redefinition, redefine the message buffer again.
  - 2. When a message is transmitted, the transmission priority is checked in accordance with the ID, IDE, and RTR bits set to each transmit message buffer to which a transmission request was set. The transmit message buffer having the highest priority is selected for transmission. If the procedure in Figure 19-27 is not observed, a message with an ID not having the highest priority may be transmitted after redefinition.

#### 19.8.4 Transition from initialization mode to operation mode

The CAN module can be switched to the following operation modes.

- · Normal operation mode
- · Normal operation mode with ABT
- · Receive-only mode
- · Single-shot mode
- · Self-test mode

OPMODE[2:0] = 00H and CAN bus is busy Receive-only mode DPMODE[2:0]=03H OPMODE[2:0] = 00H OPMODE[2:0] = 00H and CAN bus is busy. and CAN bus is busy Normal operation mode with ABT] OPMODE[2:0]=02H OPMODE[2:0] = 03H [Single-shot mode] OPMODE[2:0]=04H OPMODE[2:0] = 00H OPMODE[2:0] = 00H OPMODE[2:0] \_ 04H OPMODE[2:0] = 02H OPMODE[2:0] = 00H OPMODE[2:0] = 00H OPMODE[2:0] = 00H and CAN bus is busy OPMODE[2:0] = 00H [Normal operation INIT mode OPMODE[2:0] = 00H OPMODE[2:0] = 05H [Self-test mode] OPMODE[2:0]=05 mode] OPMODE[2:0]=01H OPMODE[2:0] = 01H OPMODE[2:0] = 00H GOM = 1All CAN modules a in INIT mode and GOM and GOM = 0

Figure 19-28. Transition to Operation Modes

The transition from the initialization mode to an operation mode is controlled by the C0CTRL.OPMODE2 to C0CTRL.OPMODE0 bits.

CAN module channel invalid

RESET

Changing from one operation mode into another requires shifting to the initialization mode in between. Do not change one operation mode to another directly; otherwise the operation will not be guaranteed.

Requests for transition from an operation mode to the initialization mode are held pending when the CAN bus is not in the interframe space (i.e., frame reception or transmission is in progress), and the CAN module enters the initialization mode at the first bit in the interframe space (the values of the OPMODE2 to OPMODE0 bits are changed to 00H). After issuing a request to change the mode to the initialization mode, read the OPMODE2 to OPMODE0 bits until their values become 000B to confirm that the module has entered the initialization mode (see **Figure 19-36**).

# 19.8.5 Resetting error counter C0ERC of CAN module

If it is necessary to reset the C0ERC and C0INFO registers when re-initialization or forced recovery from the busoff status is made, set the C0CTRL.CCERC bit to 1 in the initialization mode. When this bit is set to 1, the C0ERC and C0INFO registers are cleared to their default values.

#### 19.9 Message Reception

# 19.9.1 Message reception

In all the operation modes, when a message is received, a message buffer that is to store the message is searched from all the message buffers satisfying the following conditions.

- Used as a message buffer (C0MCONFm.MA0 bit is set to 1.)
- Set as a receive message buffer (C0MCONFm.MT2 to C0MCONFm.MT0 bits are set to 001B, 010B, 011B, 100B, or 101B.)
- Ready for reception (C0MCTRLm.RDY bit is set to 1.)

**Remark** m = 00 to 31

When two or more message buffers of the CAN module receive a message, the message is stored according to the priority explained below. The message is always stored in the message buffer with the highest priority, not in a message buffer with a low priority. For example, when an unmasked receive message buffer and a receive message buffer linked to mask 1 have the same ID, the received message is not stored in the message buffer linked to mask 1 that has not received a message, even if a message has already been received in the unmasked receive message buffer. In other words, when a condition has been set to store a message in two or more message buffers with different priorities, the message buffer with the highest priority always stores the message; the message is not stored in message buffers with a lower priority. This also applies when the message buffer with the highest priority is unable to receive and store a message (i.e., when the DN bit = 1 indicating that a message has already been received, but rewriting is disabled because the OWS bit = 0). In this case, the message is not actually received and stored in the candidate message buffer with the highest priority, but neither is it stored in a message buffer with a lower priority.

| Priority | Storing Condition If Same ID Is Set |                            |  |  |
|----------|-------------------------------------|----------------------------|--|--|
| 1 (high) | Unmasked message buffer             | DN bit = 0                 |  |  |
|          |                                     | DN bit = 1 and OWS bit = 1 |  |  |
| 2        | Message buffer linked to mask 1     | DN bit = 0                 |  |  |
|          |                                     | DN bit = 1 and OWS bit = 1 |  |  |
| 3        | Message buffer linked to mask 2     | DN bit = 0                 |  |  |
|          |                                     | DN bit = 1 and OWS bit = 1 |  |  |
| 4        | Message buffer linked to mask 3     | DN bit = 0                 |  |  |
|          |                                     | DN bit = 1 and OWS bit = 1 |  |  |
| 5 (low)  | Message buffer linked to mask 4     | DN bit = 0                 |  |  |
|          |                                     | DN bit = 1 and OWS bit = 1 |  |  |

#### 19.9.2 Receive history list function

The receive history list (RHL) function records in the receive history list the number of the receive message buffer in which each data frame or remote frame was received and stored. The RHL consists of storage elements equivalent to up to 23 messages, the last in-message pointer (LIPT) with the corresponding C0LIPT register and the receive history list get pointer (RGPT) with the corresponding C0RGPT register.

The RHL is undefined immediately after the transition of the CAN module from the initialization mode to one of the operation modes.

The COLIPT register holds the contents of the RHL element indicated by the value of the LIPT pointer minus 1. By reading the COLIPT register, therefore, the number of the message buffer that received and stored a data frame or remote frame first can be checked. The LIPT pointer is utilized as a write pointer that indicates to what part of the RHL a message buffer number is recorded. Any time a data frame or remote frame is received and stored, the corresponding message buffer number is recorded to the RHL element indicated by the LIPT pointer. Each time recording to the RHL has been completed, the LIPT pointer is automatically incremented. In this way, the number of the message buffer that has received and stored a frame will be recorded chronologically.

The RGPT pointer is utilized as a read pointer that reads a recorded message buffer number from the RHL. This pointer indicates the first RHL element that the CPU has not read yet. By reading the C0RGPT register by software, the number of a message buffer that has received and stored a data frame or remote frame can be read. Each time a message buffer number is read from the C0RGPT register, the RGPT pointer is automatically incremented.

If the value of the RGPT pointer matches the value of the LIPT pointer, the C0RGPT.RHPM bit (receive history list pointer match) is set to 1. This indicates that no message buffer number that has not been read remains in the RHL. If a new message buffer number is recorded, the LIPT pointer is incremented and because its value no longer matches the value of the RGPT pointer, the RHPM bit is cleared. In other words, the numbers of the unread message buffers exist in the RHL.

If the LIPT pointer is incremented and matches the value of the RGPT pointer minus 1, the C0RGPT.ROVF bit (receive history list overflow) is set to 1. This indicates that the RHL is full of numbers of message buffers that have not been read. When further message reception and storing occur, the last recorded message buffer number is overwritten by the number of the message buffer that received and stored the new message. After the ROVF bit has been set to 1, the recorded message buffer numbers in the RHL do not completely reflect chronological order. However the messages themselves are not lost and can be located by a CPU search in the message buffer memory with the help of the DN bit.

As long as the RHL contains 23 or less entries the sequence of occurrence is maintained. If more receptions occur without the RHL being read by the host processor, a complete sequence of receptions can not be recovered.

**Remark** m = 00 to 31



Figure 19-29. Receive History List

#### 19.9.3 Mask function

It can be defined whether masking of the identifier that is set to a message buffer is linked with another message buffer.

By using the mask function, the identifier of a message received from the CAN bus can be compared with the identifier set to a message buffer in advance. Regardless of whether the masked ID is set to 0 or 1, the received message can be stored in the defined message buffer.

While the mask function is in effect, an identifier bit that is defined to be 1 by a mask in the received message is not compared with the corresponding identifier bit in the message buffer.

However, this comparison is performed for any bit whose value is defined as 0 by the mask.

For example, let us assume that all messages that have a standard-format ID, in which bits ID27 to ID25 are 0 and bits ID24 and ID22 are 1, are to be stored in message buffer 14. The procedure for this example is shown below.

<1> Identifier to be stored in message buffer

| ID28 | ID27 | ID26 | ID25 | ID24 | ID23 | ID22 | ID21 | ID20 | ID19 | ID18 |
|------|------|------|------|------|------|------|------|------|------|------|
| х    | 0    | 0    | 0    | 1    | x    | 1    | x    | х    | x    | х    |

**Remark** x = don't care

<2> Identifier to be configured in message buffer 14 (example) (Using C0MIDL14 and C0MIDH14 registers)

| ID28 | ID27 | ID26 | ID25 | ID24 | ID23 | ID22 | ID21 | ID20 | ID19 | ID18 |
|------|------|------|------|------|------|------|------|------|------|------|
| х    | 0    | 0    | 0    | 1    | х    | 1    | х    | х    | х    | х    |
| ID17 | ID16 | ID15 | ID14 | ID13 | ID12 | ID11 | ID10 | ID9  | ID8  | ID7  |
| х    | х    | х    | х    | х    | х    | х    | х    | х    | х    | х    |
| ID6  | ID5  | ID4  | ID3  | ID2  | ID1  | ID0  |      |      |      |      |
| х    | х    | х    | х    | х    | х    | х    |      |      |      |      |

ID with the ID27 to ID25 bits cleared to 0 and the ID24 and ID22 bits set to 1 is registered (initialized) to message buffer 14.

**Remark** x = don't care

**Remark** Message buffer 14 is set as a standard format identifier that is linked to mask 1 (C0MCONF14.MT2 to C0MCONF14.MT0 bits are set to 010B).

<3> Mask setting for CAN module 0 (mask 0) (Example)
(Using CAN0 module mask 1 registers L and H (C0MASKL1 and C0MASKH1))

| CMID28 | CMID27 | CMID26 | CMID25 | CMID24 | CMID23 | CMID22 | CMID21 | CMID20 | CMID19 | CMID18 |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 1      | 0      | 0      | 0      | 0      | 1      | 0      | 1      | 1      | 1      | 1      |
| CMID17 | CMID16 | CMID15 | CMID14 | CMID13 | CMID12 | CMID11 | CMID10 | CMID9  | CMID8  | CMID7  |
| 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      |
| CMID6  | CMID5  | CMID4  | CMID3  | CMID2  | CMID1  | CMID0  |        |        |        |        |
| 1      | 1      | 1      | 1      | 1      | 1      | 1      |        |        |        |        |

- 1: Not compared (masked)
- 0: Compared

The CMID27 to CMID24 and CMID22 bits are cleared to 0, and the CMID28, CMID23, and CMID21 to CMID0 bits are set to 1.

#### 19.9.4 Multi buffer receive block function

The multi buffer receive block (MBRB) function is used to store a block of data in two or more message buffers sequentially with no CPU interaction, by setting the same ID to two or more message buffers with the same message buffer type.

Suppose, for example, the same message buffer type is set to 10 message buffers, message buffers 10 to 19, and the same ID is set to each message buffer. If the first message whose ID matches an ID of the message buffers is received, it is stored in message buffer 10. At this point, the DN bit of message buffer 10 is set, prohibiting overwriting the message buffer.

When the next message with a matching ID is received, it is received and stored in message buffer 11. Each time a message with a matching ID is received, it is sequentially (in the ascending order) stored in message buffers 12, 13, and so on. Even when a data block consisting of multiple messages is received, the messages can be stored and received without overwriting the previously received matching-ID data.

Whether a data block has been received and stored can be checked by setting the C0MCTRLm.IE bit of each message buffer. For example, if a data block consists of k messages, k message buffers are initialized for reception of the data block. The IE bit in message buffers 0 to (k-2) is cleared to 0 (interrupts disabled), and the IE bit in message buffer k-1 is set to 1 (interrupts enabled). In this case, a reception completion interrupt occurs when a message has been received and stored in message buffer k-1, indicating that MBRB has become full. Alternatively, by clearing the IE bit of message buffers 0 to (k-3) and setting the IE bit of message buffer k-2, a warning that MBRB is about to overflow can be issued.

The basic conditions of storing receive data in each message buffer for the MBRB are the same as the conditions of storing data in a single message buffer.

- Cautions 1. MBRB can be configured for each of the same message buffer types. Therefore, even if a message buffer of another MBRB whose ID matches but whose message buffer type is different has a vacancy, the received message is not stored in that message buffer, but instead discarded.
  - 2. MBRB does not have a ring buffer structure. Therefore, after a message is stored in the message buffer having the highest number in the MBRB configuration, a newly received message will not be stored in the message buffer having the lowest message buffer number.
  - 3. MBRB operates based on the reception and storage conditions; there are no settings dedicated to MBRB, such as function enable bits. By setting the same message buffer type and ID to two or more message buffers, MBRB is automatically configured.
  - 4. With MBRB, "matching ID" means "matching ID after mask". Even if the ID set to each message buffer is not the same, if the ID that is masked by the mask register matches, it is considered a matching ID and the buffer that has this ID is treated as the storage destination of a message.
  - 5. Priority among each MBRB conforms to the priority shown in 19.9.1 Message reception.

**Remark** m = 00 to 31

#### 19.9.5 Remote frame reception

In all the operation modes, when a remote frame is received, the message buffer that is to store the remote frame is searched from all the message buffers satisfying the following conditions.

- Used as a message buffer (C0MCONFm.MA0 bit set to 1.)
- Set as a transmit message buffer (C0MCONFm.MT2 to C0MCONFm.MT0 bits set to 000B)
- Ready for reception (C0MCTRLm.RDY bit set to 1.)
- Set to transmit message (C0MCONFm.RTR bit is cleared to 0.)
- Transmission request is not set. (C0MCTRLm.TRQ bit is set to 1.)

Upon acceptance of a remote frame, the following actions are executed if the ID of the received remote frame matches the ID of a message buffer that satisfies the above conditions.

- The C0MDLCm.DLC3 to C0MDLCm.DLC0 bits store the received DLC value.
- The C0MDATA0m to C0MDATA7m registers in the data area are not updated (data before reception is saved).
- The COMCTRLm.DN bit is set to 1.
- The C0INTS.CINTS1 bit is set to 1 (if the C0MCTRLm.IE bit of the message buffer that receives and stores the frame is set to 1).
- The receive completion interrupt (INTCORE) is output (if the IE bit of the message buffer that receives and stores the frame is set to 1 and if the CoIE.CIE1 bit is set to 1).
- The message buffer number is recorded in the receive history list.

Caution When a message buffer is searched for receiving and storing a remote frame, overwrite control by the COMCONFm.OWS bit of the message buffer and the DN bit are not affected.

If more than one transmit message buffer has the same ID and the ID of the received remote frame matches that ID, the remote frame is stored in the transmit message buffer with the lowest message buffer number.

**Remark** m = 00 to 31

#### 19.10 Message Transmission

### 19.10.1 Message transmission

In all the operation modes, if the COMCTRLm.TRQ bit is set to 1 in a message buffer that satisfies the following conditions, the message buffer that is to transmit a message is searched.

- Used as a message buffer (C0MCONFm.MA0 bit set to 1.)
- Set as a transmit message buffer (COMCONFm.MT2 to COMCONFm.MT0 bits set to 000B.)
- Ready for transmission (C0MCTRLm.RDY bit is set to 1.)

**Remark** m = 00 to 31

The CAN system is a multi-master communication system. In a system like this, the priority of message transmission is determined based on message identifiers (IDs). To facilitate transmission processing by software when there are several messages awaiting transmission, the CAN module uses hardware to check the ID of the message with the highest priority and automatically identifies that message. This eliminates the need for software-based priority control.

Transmission priority is controlled by the identifier (ID).

Message No. Message waiting to be transmitted 0 ID = 120H 1 2 ID = 229H The CAN module transmits messages in the following sequence. 3 1. Message 6 4 2. Message 1 ID = 223H3. Message 8 5 4. Message 5 ID = 023H6 5. Message 2 7 ID = 123H 8 9

Figure 19-30. Message Processing Example

After the transmit message search, the transmit message with the highest priority of the transmit message buffers that have a pending transmission request (message buffers with the TRQ bit set to 1 in advance) is transmitted.

If a new transmission request is set, the transmit message buffer with the new transmission request is compared with the transmit message buffer with a pending transmission request. If the new transmission request has a higher priority, it is transmitted, unless transmission of a message with a low priority has already started. If transmission of a message with a low priority has already started, however, the new transmission request is transmitted later. The highest priority is determined according to the following rules.

| Priority | Conditions                                   | Description                                                                                                                                                                                                                                                                                                        |
|----------|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 (high) | Value of first 11 bits of ID [ID28 to ID18]: | The message frame with the lowest value represented by the first 11 bits of the ID is transmitted first. If the value of an 11-bit standard ID is equal to or smaller than the first 11 bits of a 29-bit extended ID, the 11-bit standard ID has a higher priority than a message frame with a 29-bit extended ID. |
| 2        | Frame type                                   | A data frame with an 11-bit standard ID (C0MCONFm.RTR bit is cleared to 0) has a higher priority than a remote frame with a standard ID and a message frame with an extended ID.                                                                                                                                   |
| 3        | ID type                                      | A message frame with a standard ID (C0MIDHm.IDE bit is cleared to 0) has a higher priority than a message frame with an extended ID.                                                                                                                                                                               |
| 4        | Value of lower 18 bits of ID [ID17 to ID0]:  | If one or more transmission-pending extended ID message frame has equal values in the first 11 bits of the ID and the same frame type (equal RTR bit values), the message frame with the lowest value in the lower 18 bits of its extended ID is transmitted first.                                                |
| 5 (low)  | Message buffer number                        | If two or more message buffers request transmission of message frames with the same ID, the message from the message buffer with the lowest message buffer number is transmitted first.                                                                                                                            |

Remark If the automatic block transmission request bit COGMABT.ABTTRG bit is set to 1 in the normal operation mode with ABT, the TRQ bit is set to 1 only for one message buffer in the ABT message buffer group. If the ABT mode was triggered by the ABTTRG bit (1), one TRQ bit is set to 1 in the ABT area (buffers 0 to 7). In addition to this TRQ bit, the application can request transmissions (set TRQ bit to 1) for other TX-message buffers that do not belong to the ABT area. In that case an internal arbitration process (TXsearch) evaluates all of the TX-message buffers with the TRQ bit set to 1 and chooses the message buffer that contains the highest prioritized identifier for the next transmission. If there are 2 or more identifiers that have the highest priority (i.e. identical identifiers), the message located at the lowest message buffer number is transmitted first.

Upon successful transmission of a message frame, the following operations are performed.

- The TRQ bit of the corresponding transmit message buffer is automatically cleared to 0.
- The transmission completion status bit CINTS0 of the C0INTS register is set to 1 (if the interrupt enable bit (IE) of the corresponding transmit message buffer is set to 1).
- · An interrupt request signal INTRRX1 is output (if the C0IE.CIE0 bit is set to 1 and if the interrupt enable bit (IE) of the corresponding transmit message buffer is set to 1).

#### 19.10.2 Transmit history list function

The transmit history list (THL) function records in the transmit history list the number of the transmit message buffer in which each data frame or remote frame was received and stored. The THL consists of storage elements equivalent to up to seven messages, the last out-message pointer (LOPT) with the corresponding C0LOPT register, and the transmit history list get pointer (TGPT) with the corresponding C0TGPT register.

The THL is undefined immediately after the transition of the CAN module from the initialization mode to one of the operation modes.

The C0LOPT register holds the contents of the THL element indicated by the value of the LOPT pointer minus 1. By reading the C0LOPT register, therefore, the number of the message buffer that transmitted a data frame or remote frame first can be checked. The LOPT pointer is utilized as a write pointer that indicates to what part of the THL a message buffer number is recorded. Any time a data frame or remote frame is transmitted, the corresponding message buffer number is recorded to the THL element indicated by the LOPT pointer. Each time recording to the THL has been completed, the LOPT pointer is automatically incremented. In this way, the number of the message buffer that has received and stored a frame will be recorded chronologically.

The TGPT pointer is utilized as a read pointer that reads a recorded message buffer number from the THL. This pointer indicates the first THL element that the CPU has not yet read. By reading the C0TGPT register by software, the number of a message buffer that has completed transmission can be read. Each time a message buffer number is read from the C0TGPT register, the TGPT pointer is automatically incremented.

If the value of the TGPT pointer matches the value of the LOPT pointer, the C0TGPT.THPM bit (transmit history list pointer match) is set to 1. This indicates that no message buffer numbers that have not been read remain in the THL. If a new message buffer number is recorded, the LOPT pointer is incremented and because its value no longer matches the value of the TGPT pointer, the THPM bit is cleared. In other words, the numbers of the unread message buffers exist in the THL.

If the LOPT pointer is incremented and matches the value of the TGPT pointer minus 1, the TOVF bit (transmit history list overflow) of the C0TGPT register is set to 1. This indicates that the THL is full of message buffer numbers that have not been read. If a new message is received and stored, the message buffer number recorded last is overwritten by the number of the message buffer that received and stored the new message. After the TOVF bit has been set (1), therefore, the recorded message buffer numbers in the THL do not completely reflect chronological order. However the transmitted messages can be found by a CPU search applied to all transmit message buffers unless the CPU has not overwritten a transmit object in one of these buffers beforehand. In total up to six transmission completions can occur without overflowing the THL.

Transmit history list (THL) Transmit history list (THL) 6 6 Event: Message buffer 4 5 5 - CPU confirms Tx completion Message buffer 3 4 of message buffer 6, 9, and 2. Message buffer 7 Last out-Last out-Message buffer 7 - Tx completion of message 3 3 message message Transmit buffer 3, and 4. Message buffer 2 2 pointer pointer history list Message buffer 9 1 (LOPT) (LOPT) get pointer Message buffer 6 0 (TGPT) Transmit history list get pointer (TGPT) - Message buffer 8, 5, 6, and 10 completes transmission. - THL is full. - TOVF bit is set to 1. Transmit history list (THL) Transmit history list (THL) Message buffer 5 Message buffer 5 Event: Message buffer 8 Message buffer 8 6 6 Message buffer 4 - Message buffer11, 13, and 14 Message buffer 4 5 5 completes transmission. Message buffer 3 Message buffer 3 - Overflow situation occurs. Message buffer 7 Message buffer 7 3 3 Transmit Transmit 2 history list history list Last out-Message buffer 10 Last out-Message buffer 14 message get pointer get pointer message Message buffer 6 Message buffer 6 (TGPT) (TGPT) pointer pointer (LOPT) (LOPT) TOVF bit = 1 TOVF bit = 1LOPT is blocked LOPT is blocked TOVF bit = 1 denotes that LOPT equals TGPT - 1 while message buffer number stored to element indicated by LOPT - 1.

Figure 19-31. Transmit History List

#### 19.10.3 Automatic block transmission (ABT)

The automatic block transmission (ABT) function is used to transmit two or more data frames successively with no CPU interaction. The maximum number of transmit message buffers assigned to the ABT function is eight (message buffer numbers 0 to 7).

By setting the C0CTRL.OPMODE2 to C0CTRL.OPMODE0 bits to 010B, "normal operation mode with automatic block transmission function" (hereafter referred to as ABT mode) can be selected.

To issue an ABT transmission request, define the message buffers by software first. Set the COMCONFm.MA0 bit (1) in all the message buffers used for ABT, and define all the buffers as transmit message buffers by setting the COMCONFm.MA2 to COMCONFm.MA0 bits to 000B. Be sure to set the same ID for the message buffers for ATB even when that ID is being used for all the message buffers. To use two or more IDs, set the ID of each message buffer by using the COMIDLm and COMIDHm registers. Set the COMDLCm and COMDATA0m to COMDATA7m registers before issuing a transmission request for the ABT function.

After initialization of message buffers for ABT is finished, the C0MCTRLm.RDY bit needs to be set (1). In the ABT mode, the C0MCTRLm.TRQ bit does not have to be manipulated by software.

After the data for the ABT message buffers has been prepared, set the C0GMABT.ABTTRG bit to 1. Automatic block transmission is then started. When ABT is started, the TRQ bit in the first message buffer (message buffer 0) is automatically set to 1. After transmission of the data of message buffer 0 is finished, the TRQ bit of the next message buffer, message buffer 1, is set automatically. In this way, transmission is executed successively.

A delay time can be inserted by program in the interval in which the transmission request (TRQ bit) is automatically set while successive transmission is being executed. The delay time to be inserted is defined by the COGMABTD register. The unit of the delay time is DBT (data bit time). DBT depends on the setting of the COBRP and COBTR registers.

During ABT, the priority of the ABT transmission ID is not searched. The data of message buffers 0 to 7 is sequentially transmitted. When transmission of the data frame from message buffer 7 has been completed, the ABTTRG bit is automatically cleared to 0 and the ABT operation is finished.

If the RDY bit of an ABT message buffer is cleared during ABT, no data frame is transmitted from that buffer, ABT is stopped, and the ABTTRG bit is cleared. After that, transmission can be resumed from the message buffer where ABT stopped, by setting the RDY and ABTTRG bits to 1 by software. To not resume transmission from the message buffer where ABT stopped, the internal ABT engine can be reset by setting the COGMABT.ABTCLR bit to 1 while ABT mode is stopped and the ABTTRG bit is cleared to 0. In this case, transmission is started from message buffer 0 if the ABTCLR bit is cleared to 0 and then the ABTTRG bit is set to 1.

An interrupt can be used to check if data frames have been transmitted from all the message buffers for ABT. To do so, the COMCTRLm.IE bit of each message buffer except the last message buffer needs to be cleared (0).

If a transmit message buffer other than those used by the ABT function (message buffers 8 to 31) is assigned to a transmit message buffer, the priority of the message to be transmitted is determined by the priority of the transmission ID of the ABT message buffer whose transmission is currently held pending and the transmission ID of the message buffers other than those used by the ABT function.

Transmission of a data frame from an ABT message buffer is not recorded in the transmit history list (THL).

- Cautions 1. To resume the normal operation mode with ABT from the message buffer 0, set the ABTCLR bit to 1 while the ABTTRG bit is cleared to 0. If the ABTCLR bit is set to 1 while the ABTTRG bit is set to 1, the subsequent operation is not guaranteed.
  - If the automatic block transmission engine is cleared by setting the ABTCLR bit to 1, the ABTCLR bit is automatically cleared immediately after the processing of the clearing request is completed.
  - 3. Do not set the ABTTRG bit in the initialization mode. If the ABTTRG bit is set in the initialization mode, the proper operation is not guaranteed after the mode is changed from the initialization mode to the ABT mode.
  - 4. Do not set the TRQ bit of the ABT message buffers to 1 by software in the normal operation mode with ABT. Otherwise, the operation is not guaranteed.
  - 5. The COGMABTD register is used to set the delay time that is inserted in the period from completion of the preceding ABT message to setting of the TRQ bit for the next ABT message when the transmission requests are set in the order of message numbers for each message for ABT that is successively transmitted in the ABT mode. The timing at which the messages are actually transmitted onto the CAN bus varies depending on the status of transmission from other stations and the status of the setting of the transmission request for messages other than the ABT messages (message buffers 8 to 31).
  - 6. If a transmission request is made for a message other than an ABT message and if no delay time is inserted in the interval in which transmission requests for ABT are automatically set (COGMABTD register = 00H), messages other than ABT messages may be transmitted regardless of their priority in regards to the ABT message.
  - 7. Do not clear the RDY bit to 0 when the ABTTRG bit = 1.
  - If a message is received from another node in the normal operation mode with ABT, the message may be transmitted after the time of one frame has elapsed even when COGMABTD register = 00H.

**Remark** m = 00 to 31

#### 19.10.4 Transmission abort process

**Remark** m = 00 to 31

# (1) Transmission abort in normal operation mode

The user can clear the C0MCTRLm.TRQ bit to 0 to abort a transmission request. The TRQ bit will be cleared immediately if the abort was successful. Whether the transmission was successfully aborted or not can be checked using the C0CTRL.TSTAT bit and the C0TGPT register, which indicate the transmission status on the CAN bus (for details, see the processing in Figure 19-45).

# (2) Transmission abort process except for ABT transmission in normal operation mode with automatic block transmission (ABT)

The user can clear the C0GMABT.ABTTRG bit to 0 to abort a transmission request. After checking the ABTTRG bit of the C0GMABT register = 0, clear the C0MCTRLm.TRQ bit to 0. The TRQ bit will be cleared immediately if the abort was successful. Whether the transmission was successfully aborted or not can be checked by using the C0CTRL.TSTAT bit and the C0TGPT register, which indicate the transmission status on the CAN bus (for details, see the process in Figure 19-46).

#### (3) Transmission abort in normal operation mode with automatic block transmission (ABT)

To abort ABT that is already started, clear the COGMABT.ABTTRG bit to 0. In this case, the ABTTRG bit remains 1 if an ABT message is currently being transmitted and until the transmission is completed (successfully or not), and is cleared to 0 as soon as transmission is finished. This aborts ABT.

If the last transmission (before ABT) was successful, the normal operation mode with ABT is left with the internal ABT pointer pointing to the next message buffer to be transmitted.

In the case of an erroneous transmission, the position of the internal ABT pointer depends on the status of the TRQ bit in the last transmitted message buffer. If the TRQ bit is set to 1 when clearing the ABTTRG bit is requested, the internal ABT pointer points to the last transmitted message buffer (for details, see the process in Figure 19-47). If the TRQ bit is cleared to 0 when clearing the ABTTRG bit is requested, the internal ABT pointer is increased in increments of 1 and indicates the next message buffer in the ABT area (for details, see the process in Figure 19-47).

Caution Be sure to abort ABT by clearing the ABTTRG bit to 0. The operation is not guaranteed if aborting transmission is requested by clearing RDY.

When the normal operation mode with ABT is resumed after ABT has been aborted and the ABTTRG bit is set to 1, the next ABT message buffer to be transmitted can be determined from the following table.

| Status of TRQ of ABT Message Buffer | Abort After Successful Transmission      | Abort After Erroneous Transmission                  |  |  |
|-------------------------------------|------------------------------------------|-----------------------------------------------------|--|--|
| Set (1)                             | Next message buffer in the ABT area Note | Same message buffer in the ABT area                 |  |  |
| Cleared (0)                         | Next message buffer in the ABT area Note | Next message buffer in the ABT area <sup>Note</sup> |  |  |

Note The above resumption operation can be performed only if a message buffer ready for ABT exists in the ABT area. For example, an abort request that is issued while ABT of message buffer 7 is in progress is regarded as completion of ABT, rather than abort, if transmission of message buffer 7 has been successfully completed, even if the ABTTRG bit is cleared to 0. If the C0MCTRLm.RDY bit in the next message buffer in the ABT area is cleared to 0, the internal ABT pointer is retained, but the resumption operation is not performed even if the ABTTRG bit is set to 1, and ABT ends immediately.

**Remark** m = 00 to 31

#### 19.10.5 Remote frame transmission

Remote frames can be transmitted only from transmit message buffers. Set whether a data frame or remote frame is transmitted via the COMCONFm.RTR bit. Setting (1) the RTR bit sets remote frame transmission.

**Remark** m = 00 to 31

#### 19.11 Power Saving Modes

#### 19.11.1 CAN sleep mode

The CAN sleep mode can be used to set the CAN controller to standby mode in order to reduce power consumption. The CAN module can enter the CAN sleep mode from all operation modes. Release of the CAN sleep mode returns the CAN module to exactly the same operation mode from which the CAN sleep mode was entered.

In the CAN sleep mode, the CAN module does not transmit messages, even when transmission requests are issued or pending.

#### (1) Entering CAN sleep mode

The CPU issues a CAN sleep mode transition request by writing 01B to the C0CTRL.PSMODE1 and C0CTRL.PSMODE0 bits.

This transition request is only acknowledged only under the following conditions.

- (i) The CAN module is already in one of the following operation modes
  - Normal operation mode
  - · Normal operation mode with ABT
  - · Receive-only mode
  - · Single-shot mode
  - · Self-test mode
  - CAN stop mode in all the above operation modes
- (ii) The CAN bus state is bus idle (the 4th bit in the interframe space is recessive) Note

**Note** If the CAN bus is fixed to dominant, the request for transition to the CAN sleep mode is held pending. Also the transition from CAN stop mode to CAN sleep mode is independent of the CAN bus state.

#### (iii) No transmission request is pending

If any one of the conditions mentioned above is not met, the CAN module will operate as follows.

- If the CAN sleep mode is requested from the initialization mode, the CAN sleep mode transition request is ignored and the CAN module remains in the initialization mode.
- If the CAN bus state is not bus idle (i.e., the CAN bus state is either transmitting or receiving) when the CAN sleep mode is requested in one of the operation modes, immediate transition to the CAN sleep mode is not possible. In this case, the CAN sleep mode transition request has to be held pending until the CAN bus state becomes bus idle (the 4th bit in the interframe space is recessive). In the time from the CAN sleep mode request to successful transition, the PSMODE1 and PSMODE0 bits remain 00B. When the module has entered the CAN sleep mode, the PSMODE1 and PSMODE0 bits are set to 01B.
- If a request for transition to the initialization mode and a request for transition to the CAN sleep mode
  are made at the same time while the CAN module is in one of the operation modes, the request for the
  initialization mode is enabled. The CAN module enters the initialization mode at a predetermined timing.
  At this time, the CAN sleep mode request is not held pending and is ignored.
- Even when the initialization mode and sleep mode are not requested simultaneously (i.e the first request
  was not granted when a second request was made), the request for initialization has priority over the
  CAN sleep mode request. The CAN sleep mode request is cancelled when the initialization mode is
  requested. When a pending request for the initialization mode is present, a subsequent request for the
  CAN sleep mode request is cancelled right at the point in time when it was submitted.

#### (2) Status in CAN sleep mode

The CAN module is in one of the following states after it enters the CAN sleep mode.

- The internal operating clock is stopped and the power consumption is minimized.
- The function to detect the falling edge of the CAN reception pin (CRXD0) remains in effect to wake up the CAN module from the CAN bus.
- To wake up the CAN module from the CPU, data can be written to the PSMODE1 and PSMODE0 bits, but nothing can be written to other CAN0 module registers or bits.
- The CAN0 module registers can be read, except for the C0LIPT, C0RGPT, C0LOPT, and C0TGPT registers.
- The CAN0 message buffer registers cannot be written or read.
- A request for transition to the initialization mode is not acknowledged and is ignored.

### (3) Releasing CAN sleep mode

The CAN sleep mode is released by the following events.

- When the CPU writes 00B to the PSMODE1 and PSMODE0 bits
- A falling edge at the CAN reception pin (CRXD0) (i.e. the CAN bus level shifts from recessive to dominant)

Caution Even if the falling edge belongs to the SOF of a receive message, this message will not be received and stored. If the CPU has turned off the clock to the CAN while the CAN was in sleep mode, later on the CAN sleep mode will not be released and PSMODE1 and PSMODE0 bits will continue to be 01B unless the clock for the CAN is provided again. In addition to this, the receive message will not be received afterwards.

After releasing the sleep mode, the CAN module returns to the operation mode from which the CAN sleep mode was requested and the PSMODE1 and PSMODE0 bits are reset to 00B. If the CAN sleep mode is released by a change in the CAN bus state, the C0INTS.CINTS5 bit is set to 1, regardless of the C0IE.CIE bit. After the CAN module is released from the CAN sleep mode, it participates in the CAN bus again by automatically detecting 11 consecutive recessive-level bits on the CAN bus.

When a request for transition to the initialization mode is made while the CAN module is in the CAN sleep mode, that request is ignored; the CPU has to be released from sleep mode by software first before entering the initialization mode.

#### 19.11.2 CAN stop mode

The CAN stop mode can be used to set the CAN controller to standby mode to reduce power consumption. The CAN module can enter the CAN stop mode only from the CAN sleep mode. Release of the CAN stop mode puts the CAN module in the CAN sleep mode.

The CAN stop mode can only be released (shifting to CAN sleep mode) by writing 01B to the C0CTRL.PSMODE1 and C0CTRL.PSMODE0 bits and not by a change in the CAN bus state. No message is transmitted even when transmission requests are issued or pending.

#### (1) Entering CAN stop mode

A CAN stop mode transition request is issued by writing 11B to the PSMODE1 and PSMODE0 bits.

A CAN stop mode request is only acknowledged when the CAN module is in the CAN sleep mode. In all other modes, the request is ignored.

Caution To set the CAN module to the CAN stop mode, the module must be in the CAN sleep mode. To confirm that the module is in the sleep mode, check that the PSMODE1 and PSMODE0 bits = 01B, and then request the CAN stop mode. If a bus change occurs at the CAN reception pin (CRXD0) while this process is being performed, the CAN sleep mode is automatically released. In this case, the CAN stop mode transition request cannot be acknowledged.

#### (2) Status in CAN stop mode

The CAN module is in one of the following states after it enters the CAN stop mode.

- The internal operating clock is stopped and the power consumption is minimized.
- To wake up the CAN module from the CPU, data can be written to the PSMODE1 and PSMODE0 bits, but nothing can be written to other CAN0 module registers or bits.
- The CAN0 module registers can be read, except for the C0LIPT, C0RGPT, C0LOPT, and C0TGPT registers.
- The CAN0 message buffer registers cannot be written or read.
- An initialization mode transition request is not acknowledged and is ignored.

# (3) Releasing CAN stop mode

The CAN stop mode can only be released by writing 01B to the PSMODE1 and PSMODE0 bits. After releasing the CAN stop mode, the CAN module enters the CAN sleep mode.

When the initialization mode is requested while the CAN module is in the CAN stop mode, that request is ignored; the CPU has to release the stop mode and subsequently the CAN sleep mode before entering into initialization mode. It is impossible to enter another operation mode directly from the CAN stop mode without entering the CAN sleep mode, the request will be ignored.

#### 19.11.3 Example of using power saving modes

In some application systems, it may be necessary to place the CPU in a power saving mode to reduce the power consumption. By using the power saving mode specific to the CAN module and the power saving mode specific to the CPU in combination, the CPU can be woken up from the power saving status by the CAN bus.

Here is an example of using the power saving modes.

First, put the CAN module in the CAN sleep mode (PSMODE1, PSMODE0 bits = 01B). Next, put the CPU in the power saving mode. If an edge transition from recessive to dominant is detected at the CRXD0 signal in this status, the CINTS5 bit in the CAN module is set to 1. If the COCTRL.CIE5 bit is set to 1, a wakeup interrupt (INTC0WUP) is generated. The CAN module is automatically released from the CAN sleep mode (PSMODE1, PSMODE0 bits = 00B) and returns to normal operation mode. The CPU, in response to INTC0WUP, can release its own power saving mode and return to normal operation mode.

To further reduce the power consumption of the CPU, the internal clocks, including that of the CAN module, may be tuned off. In this case, the operating clock supplied to the CAN module is turned off after the CAN module is put in the CAN sleep mode. Then the CPU enters a power saving mode in which the clock supplied to the CPU is turned off. If an edge transition from recessive to dominant is detected at the CRXD0 signal in this status, the CAN module can set the CINTS5 bit to 1 and generate a wakeup interrupt (INTC0WUP) even if it is not supplied with a clock. The other functions, however, do not operate because the clock supply to the CAN module is shut off, and the module remains in the CAN sleep mode. The CPU, in response to INTC0WUP, releases its power saving mode, resumes supply of the internal clocks, including the clock to the CAN module, after oscillation stabilization time has elapsed, and starts instruction execution. The CAN module is immediately released from the CAN sleep mode when the clock supply is resumed, and returns to normal operation mode (PSMODE1, PSMODE0 bits = 00B).

# 19.12 Interrupt Function

The CAN module provides 6 different interrupt sources.

The occurrence of these interrupt sources is stored in interrupt status registers. Four separate interrupt request signals are generated from the six interrupt sources. When an interrupt request signal that corresponds to two or more interrupt sources is generated, the interrupt sources can be identified by using an interrupt status register. After an interrupt source has occurred, the corresponding interrupt status bit must be cleared to 0 by software.

| No. | Interrupt Status Bit     |          | Status Bit Interrupt Er |          | Interrupt      | Interrupt Source Description                                      |
|-----|--------------------------|----------|-------------------------|----------|----------------|-------------------------------------------------------------------|
|     | Name                     | Register | Name                    | Register | Request Signal |                                                                   |
| 1   | CINTS0 <sup>Note 1</sup> | COINTS   | CIEO <sup>Note 1</sup>  | COIE     | INTC0TRX       | Message frame successfully transmitted from message buffer m      |
| 2   | CINTS1 Note 1            | COINTS   | CIE1 <sup>Note 1</sup>  | COIE     | INTC0REC       | Valid message frame reception in message buffer m                 |
| 3   | CINTS2                   | COINTS   | CIE2                    | COIE     | INTC0ERR       | CAN module error state interrupt <sup>Note 2</sup>                |
| 4   | CINTS3                   | COINTS   | CIE3                    | COIE     |                | CAN module protocol error interrupt <sup>Note 3</sup>             |
| 5   | CINTS4                   | COINTS   | CIE4                    | COIE     |                | CAN module arbitration loss interrupt                             |
| 6   | CINTS5                   | COINTS   | CIE5                    | COIE     | INTC0WUP       | CAN module wakeup interrupt from CAN sleep mode <sup>Note 4</sup> |

Table 19-20. List of CAN Module Interrupt Sources

- **Notes 1.** The COMCTRL.IE bit (message buffer interrupt enable bit) of the corresponding message buffer has to be set to 1 for that message buffer to participate in the interrupt generation process.
  - 2. This interrupt is generated when the transmission/reception error counter is at the warning level, or in the error passive or bus-off state.
  - 3. This interrupt is generated when a stuff error, form error, ACK error, bit error, or CRC error occurs.
  - **4.** This interrupt is generated when the CAN module is woken up from the CAN sleep mode because a falling edge is detected at the CAN reception pin (CAN bus transition from recessive to dominant).

**Remark** m = 00 to 31

# 19.13 Diagnosis Functions and Special Operational Modes

The CAN module provides a receive-only mode, single-shot mode, and self-test mode to support CAN bus diagnosis functions or the operation of special CAN communication methods.

### 19.13.1 Receive-only mode

The receive-only mode is used to monitor receive messages without causing any interference on the CAN bus and can be used for CAN bus analysis nodes.

For example, this mode can be used for automatic baud-rate detection. The baud rate in the CAN module is changed until "valid reception" is detected, so that the baud rates in the module match ("valid reception" means a message frame has been received in the CAN protocol layer without occurrence of an error and with an appropriate ACK between nodes connected to the CAN bus). A valid reception does not require message frames to be stored in a receive message buffer (data frames) or transmit message buffer (remote frames). The event of valid reception is indicated by setting the COCTRL.VALID bit (1).



Figure 19-32. CAN Module Terminal Connection in Receive-Only Mode

In the receive-only mode, no message frames can be transmitted from the CAN module to the CAN bus. Transmit requests issued for message buffers defined as transmit message buffers are held pending.

In the receive-only mode, the CAN transmission pin (CTXD0) in the CAN module is fixed to the recessive level. Therefore, no active error flag can be transmitted from the CAN module to the CAN bus even when a CAN bus error is detected while receiving a message frame. Since no transmission can be issued from the CAN module, the transmission error counter the C0ERC.TEC7 to C0ERC.TEC0 bits are never updated. Therefore, a CAN module in the receive-only mode does not enter the bus-off state.

Furthermore, ACK is not returned to the CAN bus in this mode upon the valid reception of a message frame. Internally, the local node recognizes that it has transmitted ACK. An overload frame cannot be transmitted to the CAN bus.

Caution If only two CAN nodes are connected to the CAN bus and one of them is operating in the receiveonly mode, there is no ACK on the CAN bus. Due to the missing ACK, the transmitting node will
transmit an active error flag, and repeat transmitting a message frame. The transmitting node
becomes error passive after transmitting the message frame 16 times (assuming that the error
counter was 0 in the beginning and no other errors have occurred). When the message frame is
transmitted for the 17th time, the transmitting node generates a passive error flag. The receiving
node in the receive-only mode detects the first valid message frame at this point, and the VALID
bit is set to 1 for the first time.

#### 19.13.2 Single-shot mode

In the single-shot mode, automatic re-transmission as defined in the CAN protocol is switched off. (According to the CAN protocol, a message frame transmission that has been aborted by either arbitration loss or error occurrence has to be repeated without control by software.) All other behavior of single shot mode is identical to normal operation mode. Features of single shot mode can not be used in combination with normal mode with ABT.

The single-shot mode disables the re-transmission of an aborted message frame transmission according to the setting of the COCTRL.AL bit. When the AL bit is cleared to 0, re-transmission upon arbitration loss and upon error occurrence is disabled. If the AL bit is set to 1, re-transmission upon error occurrence is disabled, but re-transmission upon arbitration loss is enabled. As a consequence, the COMCTRLm.TRQ bit in a message buffer defined as a transmit message buffer is cleared to 0 by the following events.

- · Successful transmission of the message frame
- Arbitration loss while sending the message frame (AL bit = 0)
- Error occurrence while sending the message frame

The events arbitration loss and error occurrence can be distinguished by checking the C0INTS.CINTS4 and C0INTS.CINTS3 bits, and the type of the error can be identified by reading the C0LEC.LEC2 to C0LEC.LEC0 bits of the register.

Upon successful transmission of the message frame, the transmit completion interrupt the CINTS0 bit of the COINTS register is set to 1. If the COIE.CIE0 bit is set to 1 at this time, an interrupt request signal is output.

The single-shot mode can be used when emulating time-triggered communication methods (e.g., TTCAN level 1).

Caution The AL bit is only valid in single-shot mode. It does not affect the operation of re-transmission upon arbitration loss in other operation modes.

#### 19.13.3 Self-test mode

In the self-test mode, message frame transmission and message frame reception can be tested without connecting the CAN node to the CAN bus or without affecting the CAN bus.

In the self-test mode, the CAN module is completely disconnected from the CAN bus, but transmission and reception are internally looped back. The CAN transmission pin (CTXD0) is fixed to the recessive level.

If the falling edge on the CAN reception pin (CRXD0) is detected after the CAN module has entered the CAN sleep mode from the self-test mode, however, the module is released from the CAN sleep mode in the same manner as the other operation modes. To keep the module in the CAN sleep mode, use the CAN reception pin (CRXD0) as a port pin.



Figure 19-33. CAN Module Terminal Connection in Self-Test Mode

#### 19.14 Time Stamp Function

CAN is an asynchronous, serial protocol. All nodes connected to the CAN bus have a local, autonomous clock. As a consequence, the clocks of the nodes have no relation (i.e., the clocks are asynchronous and may even have different frequencies).

In some applications, however, a common time base over the network (= global time base) is needed. In order to build up a global time base, a time stamp function is used. The essential mechanism of a time stamp function is the capture of timer values triggered by signals on the CAN bus.

#### 19.14.1 Time stamp function

The CAN controller supports the capturing of timer values triggered by a specific frame. An on-chip 16-bit capture timer unit in a microcontroller system is used in addition to the CAN controller. The 16-bit capture timer unit captures the timer value according to a trigger signal (TSOUT) for capturing that is output when a data frame is received from the CAN controller. The CPU can retrieve the time of occurrence of the capture event, i.e., the time stamp of the message received from the CAN bus, by reading the captured value. The TSOUT signal can be selected from the following two event sources and is specified by the COTS.TSSEL bit.

- SOF event (start of frame) (TSSEL bit = 0)
- EOF event (last bit of end of frame) (TSSEL bit = 1)

The TSOUT signal is enabled by setting the C0TS.TSEN bit to 1.



Figure 19-34. Timing Diagram of Capture Signal TSOUT

The TSOUT signal toggles its level upon occurrence of the selected event during data frame reception (in Figure 19-34, the SOF is used as the trigger event source). To capture a timer value by using the TSOUT signal, the capture timer unit must detect the capture signal at both the rising edge and falling edge.

This time stamp function is controlled by the C0TS.TSLOCK bit. When the TSLOCK bit is cleared to 0, the TSOUT signal toggles upon occurrence of the selected event. If the TSLOCK bit is set to 1, the TSOUT signal toggles upon occurrence of the selected event, but the toggle is stopped as the TSEN bit is automatically cleared to 0 when a data frame starts to be received and stored in message buffer 0. This suppresses the subsequent toggle occurrence by the TSOUT signal, so that the time stamp value toggled last (= captured last) can be saved as the time stamp value of the time at which the data frame was received in message buffer 0.

Caution The time stamp function using the TSLOCK bit stops toggle of the TSOUT signal by receiving a data frame in message buffer 0. Therefore, message buffer 0 must be set as a receive message buffer. Since a receive message buffer cannot receive a remote frame, toggle of the TSOUT signal cannot be stopped by reception of a remote frame. Toggle of the TSOUT signal does not stop when a data frame is received in a message buffer other than message buffer 0.

For these reasons, a data frame cannot be received in message buffer 0 when the CAN module is in the normal operation mode with ABT, because message buffer 0 must be set as a transmit message buffer. In this operation mode, therefore, the function to stop toggle of the TSOUT signal by the TSLOCK bit cannot be used.

# 19.15 Baud Rate Settings

# 19.15.1 Baud rate setting conditions

Make sure that the settings are within the range of limit values for ensuring correct operation of the CAN controller, as follows.

- (a) 5TQ ≤ SPT (sampling point) ≤ 17 TQ
   SPT = TSEG1 + 1
   (b) 8 TQ ≤ DBT (data bit time) ≤ 25 TQ
  - DBT = TSEG1 + TSEG2 + 1TQ = TSEG2 + SPT
- (c) 1 TQ  $\leq$  SJW (synchronization jump width)  $\leq$  4TQ SJW  $\leq$  DBT SPT
- (d)  $4 \le TSEG1 \le 16$  [ $3 \le Setting value of TSEG1[3:0] \le 15$ ]
- (e)  $1 \le TSEG2 \le 8$  [ $0 \le Setting value of TSEG2[2:0] \le 7$ ]

Remark TQ =  $1/f_{TQ}$  (fTQ: CAN protocol layer basic system clock) TSEG1[3:0] (C0BTR.TSEG13 to C0BTR.TSEG10 bits) TSEG2[2:0] (C0BTR.TSEG22 to C0BTR.TSEG20 bits)

Table 19-21 shows the combinations of bit rates that satisfy the above conditions.

Table 19-21. Settable Bit Rate Combinations (1/3)

|            | Va              | alid Bit Rate Sett | C0BTR Register Setting Value Sampling |                   |           |           |          |
|------------|-----------------|--------------------|---------------------------------------|-------------------|-----------|-----------|----------|
| DBT Length | SYNC<br>SEGMENT | PROP<br>SEGMENT    | PHASE<br>SEGMENT1                     | PHASE<br>SEGMENT2 | TSEG13 to | TSEG22 to | (Unit %) |
| 25         | 1               | 8                  | 8                                     | 8                 | 1111      | 111       | 68.0     |
| 24         | 1               | 7                  | 8                                     | 8                 | 1110      | 111       | 66.7     |
| 24         | 1               | 9                  | 7                                     | 7                 | 1111      | 110       | 70.8     |
| 23         | 1               | 6                  | 8                                     | 8                 | 1101      | 111       | 65.2     |
| 23         | 1               | 8                  | 7                                     | 7                 | 1110      | 110       | 69.6     |
| 23         | 1               | 10                 | 6                                     | 6                 | 1111      | 101       | 73.9     |
| 22         | 1               | 5                  | 8                                     | 8                 | 1100      | 111       | 63.6     |
| 22         | 1               | 7                  | 7                                     | 7                 | 1101      | 110       | 68.2     |
| 22         | 1               | 9                  | 6                                     | 6                 | 1110      | 101       | 72.7     |
| 22         | 1               | 11                 | 5                                     | 5                 | 1111      | 100       | 77.3     |
| 21         | 1               | 4                  | 8                                     | 8                 | 1011      | 111       | 61.9     |
| 21         | 1               | 6                  | 7                                     | 7                 | 1100      | 110       | 66.7     |
| 21         | 1               | 8                  | 6                                     | 6                 | 1101      | 101       | 71.4     |
| 21         | 1               | 10                 | 5                                     | 5                 | 1110      | 100       | 76.2     |
| 21         | 1               | 12                 | 4                                     | 4                 | 1111      | 011       | 81.0     |
| 20         | 1               | 3                  | 8                                     | 8                 | 1010      | 111       | 60.0     |
| 20         | 1               | 5                  | 7                                     | 7                 | 1011      | 110       | 65.0     |
| 20         | 1               | 7                  | 6                                     | 6                 | 1100      | 101       | 70.0     |
| 20         | 1               | 9                  | 5                                     | 5                 | 1101      | 100       | 75.0     |
| 20         | 1               | 11                 | 4                                     | 4                 | 1110      | 011       | 80.0     |
| 20         | 1               | 13                 | 3                                     | 3                 | 1111      | 010       | 85.0     |
| 19         | 1               | 2                  | 8                                     | 8                 | 1001      | 111       | 57.9     |
| 19         | 1               | 4                  | 7                                     | 7                 | 1010      | 110       | 63.2     |
| 19         | 1               | 6                  | 6                                     | 6                 | 1011      | 101       | 68.4     |
| 19         | 1               | 8                  | 5                                     | 5                 | 1100      | 100       | 73.7     |
| 19         | 1               | 10                 | 4                                     | 4                 | 1101      | 011       | 78.9     |
| 19         | 1               | 12                 | 3                                     | 3                 | 1110      | 010       | 84.2     |
| 19         | 1               | 14                 | 2                                     | 2                 | 1111      | 001       | 89.5     |
| 18         | 1               | 1                  | 8                                     | 8                 | 1000      | 111       | 55.6     |
| 18         | 1               | 3                  | 7                                     | 7                 | 1001      | 110       | 61.1     |
| 18         | 1               | 5                  | 6                                     | 6                 | 1010      | 101       | 66.7     |
| 18         | 1               | 7                  | 5                                     | 5                 | 1011      | 100       | 72.2     |
| 18         | 1               | 9                  | 4                                     | 4                 | 1100      | 011       | 77.8     |
| 18         | 1               | 11                 | 3                                     | 3                 | 1101      | 010       | 83.3     |
| 18         | 1               | 13                 | 2                                     | 2                 | 1110      | 001       | 88.9     |
| 18         | 1               | 15                 | 1                                     | 1                 | 1111      | 000       | 94.4     |

Table 19-21. Settable Bit Rate Combinations (2/3)

|            | Va              | lid Bit Rate Sett | C0BTR Registe     | er Setting Value  | Sampling Point |           |          |
|------------|-----------------|-------------------|-------------------|-------------------|----------------|-----------|----------|
| DBT Length | SYNC<br>SEGMENT | PROP<br>SEGMENT   | PHASE<br>SEGMENT1 | PHASE<br>SEGMENT2 | TSEG13 to      | TSEG22 to | (Unit %) |
| 17         | 1               | 2                 | 7                 | 7                 | 1000           | 110       | 58.8     |
| 17         | 1               | 4                 | 6                 | 6                 | 1001           | 101       | 64.7     |
| 17         | 1               | 6                 | 5                 | 5                 | 1010           | 100       | 70.6     |
| 17         | 1               | 8                 | 4                 | 4                 | 1011           | 011       | 76.5     |
| 17         | 1               | 10                | 3                 | 3                 | 1100           | 010       | 82.4     |
| 17         | 1               | 12                | 2                 | 2                 | 1101           | 001       | 88.2     |
| 17         | 1               | 14                | 1                 | 1                 | 1110           | 000       | 94.1     |
| 16         | 1               | 1                 | 7                 | 7                 | 0111           | 110       | 56.3     |
| 16         | 1               | 3                 | 6                 | 6                 | 1000           | 101       | 62.5     |
| 16         | 1               | 5                 | 5                 | 5                 | 1001           | 100       | 68.8     |
| 16         | 1               | 7                 | 4                 | 4                 | 1010           | 011       | 75.0     |
| 16         | 1               | 9                 | 3                 | 3                 | 1011           | 010       | 81.3     |
| 16         | 1               | 11                | 2                 | 2                 | 1100           | 001       | 87.5     |
| 16         | 1               | 13                | 1                 | 1                 | 1101           | 000       | 93.8     |
| 15         | 1               | 2                 | 6                 | 6                 | 0111           | 101       | 60.0     |
| 15         | 1               | 4                 | 5                 | 5                 | 1000           | 100       | 66.7     |
| 15         | 1               | 6                 | 4                 | 4                 | 1001           | 011       | 73.3     |
| 15         | 1               | 8                 | 3                 | 3                 | 1010           | 010       | 80.0     |
| 15         | 1               | 10                | 2                 | 2                 | 1011           | 001       | 86.7     |
| 15         | 1               | 12                | 1                 | 1                 | 1100           | 000       | 93.3     |
| 14         | 1               | 1                 | 6                 | 6                 | 0110           | 101       | 57.1     |
| 14         | 1               | 3                 | 5                 | 5                 | 0111           | 100       | 64.3     |
| 14         | 1               | 5                 | 4                 | 4                 | 1000           | 011       | 71.4     |
| 14         | 1               | 7                 | 3                 | 3                 | 1001           | 010       | 78.6     |
| 14         | 1               | 9                 | 2                 | 2                 | 1010           | 001       | 85.7     |
| 14         | 1               | 11                | 1                 | 1                 | 1011           | 000       | 92.9     |
| 13         | 1               | 2                 | 5                 | 5                 | 0110           | 100       | 61.5     |
| 13         | 1               | 4                 | 4                 | 4                 | 0111           | 011       | 69.2     |
| 13         | 1               | 6                 | 3                 | 3                 | 1000           | 010       | 76.9     |
| 13         | 1               | 8                 | 2                 | 2                 | 1001           | 001       | 84.6     |
| 13         | 1               | 10                | 1                 | 1                 | 1010           | 000       | 92.3     |
| 12         | 1               | 1                 | 5                 | 5                 | 0101           | 100       | 58.3     |
| 12         | 1               | 3                 | 4                 | 4                 | 0110           | 011       | 66.7     |
| 12         | 1               | 5                 | 3                 | 3                 | 0111           | 010       | 75.0     |
| 12         | 1               | 7                 | 2                 | 2                 | 1000           | 001       | 83.3     |
| 12         | 1               | 9                 | 1                 | 1                 | 1001           | 000       | 91.7     |

Table 19-21. Settable Bit Rate Combinations (3/3)

|                   | Va              | lid Bit Rate Sett |                   | C0BTR Registe     | er Setting Value    | Sampling Point      |          |
|-------------------|-----------------|-------------------|-------------------|-------------------|---------------------|---------------------|----------|
| DBT Length        | SYNC<br>SEGMENT | PROP<br>SEGMENT   | PHASE<br>SEGMENT1 | PHASE<br>SEGMENT2 | TSEG13 to<br>TSEG10 | TSEG22 to<br>TSEG20 | (Unit %) |
| 11                | 1               | 2                 | 4                 | 4                 | 0101                | 011                 | 63.6     |
| 11                | 1               | 4                 | 3                 | 3                 | 0110                | 010                 | 72.7     |
| 11                | 1               | 6                 | 2                 | 2                 | 0111                | 001                 | 81.8     |
| 11                | 1               | 8                 | 1                 | 1                 | 1000                | 000                 | 90.9     |
| 10                | 1               | 1                 | 4                 | 4                 | 0100                | 011                 | 60.0     |
| 10                | 1               | 3                 | 3                 | 3                 | 0101                | 010                 | 70.0     |
| 10                | 1               | 5                 | 2                 | 2                 | 0110                | 001                 | 80.0     |
| 10                | 1               | 7                 | 1                 | 1                 | 0111                | 000                 | 90.0     |
| 9                 | 1               | 2                 | 3                 | 3                 | 0100                | 010                 | 66.7     |
| 9                 | 1               | 4                 | 2                 | 2                 | 0101                | 001                 | 77.8     |
| 9                 | 1               | 6                 | 1                 | 1                 | 0110                | 000                 | 88.9     |
| 8                 | 1               | 1                 | 3                 | 3                 | 0011                | 010                 | 62.5     |
| 8                 | 1               | 3                 | 2                 | 2                 | 0100                | 001                 | 75.0     |
| 8                 | 1               | 5                 | 1                 | 1                 | 0101                | 000                 | 87.5     |
| 7 <sup>Note</sup> | 1               | 2                 | 2                 | 2                 | 0011                | 001                 | 71.4     |
| 7 <sup>Note</sup> | 1               | 4                 | 1                 | 1                 | 0100                | 000                 | 85.7     |
| 6 <sup>Note</sup> | 1               | 1                 | 2                 | 2                 | 0010                | 001                 | 66.7     |
| 6 <sup>Note</sup> | 1               | 3                 | 1                 | 1                 | 0011                | 000                 | 83.3     |
| 5 <sup>Note</sup> | 1               | 2                 | 1                 | 1                 | 0010                | 000                 | 80.0     |
| 4 <sup>Note</sup> | 1               | 1                 | 1                 | 1                 | 0001                | 000                 | 75.0     |

**Note** Setting with a DBT value of 7 or less is valid only when the value of the C0BRP register is other than 00H.

Caution The values in Table 19-21 do not guarantee the operation of the network system. Thoroughly check the effect on the network system, taking into consideration oscillation errors and delays of the CAN bus and CAN transceiver.

# 19.15.2 Representative examples of baud rate settings

Tables 19-22 and 19-23 show representative examples of baud rate settings.

Table 19-22. Representative Examples of Baud Rate Settings (fcanmod = 8 MHz) (1/2)

| Set Baud<br>Rate Value | Division<br>Ratio of | C0BRP<br>Register Set |                  | Valid Bit F     | Rate Setting (  | Jnit: kbps)       |                   | _                   | jister Setting<br>lue | Sampling<br>Point |
|------------------------|----------------------|-----------------------|------------------|-----------------|-----------------|-------------------|-------------------|---------------------|-----------------------|-------------------|
| (Unit: kbps)           | C0BRP<br>Register    | Value                 | Length of<br>DBT | SYNC<br>SEGMENT | PROP<br>SEGMENT | PHASE<br>SEGMENT1 | PHASE<br>SEGMENT2 | TSEG13 to<br>TSEG10 | TSEG22 to<br>TSEG20   | (Unit: %)         |
| 1000                   | 1                    | 00000000              | 8                | 1               | 1               | 3                 | 3                 | 0011                | 010                   | 62.5              |
| 1000                   | 1                    | 00000000              | 8                | 1               | 3               | 2                 | 2                 | 0100                | 001                   | 75.0              |
| 1000                   | 1                    | 00000000              | 8                | 1               | 5               | 1                 | 1                 | 0101                | 000                   | 87.5              |
| 500                    | 1                    | 00000000              | 16               | 1               | 1               | 7                 | 7                 | 0111                | 110                   | 56.3              |
| 500                    | 1                    | 00000000              | 16               | 1               | 3               | 6                 | 6                 | 1000                | 101                   | 62.5              |
| 500                    | 1                    | 00000000              | 16               | 1               | 5               | 5                 | 5                 | 1001                | 100                   | 68.8              |
| 500                    | 1                    | 00000000              | 16               | 1               | 7               | 4                 | 4                 | 1010                | 011                   | 75.0              |
| 500                    | 1                    | 00000000              | 16               | 1               | 9               | 3                 | 3                 | 1011                | 010                   | 81.3              |
| 500                    | 1                    | 00000000              | 16               | 1               | 11              | 2                 | 2                 | 1100                | 001                   | 87.5              |
| 500                    | 1                    | 00000000              | 16               | 1               | 13              | 1                 | 1                 | 1101                | 000                   | 93.8              |
| 500                    | 2                    | 0000001               | 8                | 1               | 1               | 3                 | 3                 | 0011                | 010                   | 62.5              |
| 500                    | 2                    | 0000001               | 8                | 1               | 3               | 2                 | 2                 | 0100                | 001                   | 75.0              |
| 500                    | 2                    | 00000001              | 8                | 1               | 5               | 1                 | 1                 | 0101                | 000                   | 87.5              |
| 250                    | 2                    | 0000001               | 16               | 1               | 1               | 7                 | 7                 | 0111                | 110                   | 56.3              |
| 250                    | 2                    | 00000001              | 16               | 1               | 3               | 6                 | 6                 | 1000                | 101                   | 62.5              |
| 250                    | 2                    | 00000001              | 16               | 1               | 5               | 5                 | 5                 | 1001                | 100                   | 68.8              |
| 250                    | 2                    | 00000001              | 16               | 1               | 7               | 4                 | 4                 | 1010                | 011                   | 75.0              |
| 250                    | 2                    | 00000001              | 16               | 1               | 9               | 3                 | 3                 | 1011                | 010                   | 81.3              |
| 250                    | 2                    | 00000001              | 16               | 1               | 11              | 2                 | 2                 | 1100                | 001                   | 87.5              |
| 250                    | 2                    | 00000001              | 16               | 1               | 13              | 1                 | 1                 | 1101                | 000                   | 93.8              |
| 250                    | 4                    | 00000011              | 8                | 1               | 3               | 2                 | 2                 | 0100                | 001                   | 75.0              |
| 250                    | 4                    | 00000011              | 8                | 1               | 5               | 1                 | 1                 | 0101                | 000                   | 87.5              |
| 125                    | 4                    | 00000011              | 16               | 1               | 1               | 7                 | 7                 | 0111                | 110                   | 56.3              |
| 125                    | 4                    | 00000011              | 16               | 1               | 3               | 6                 | 6                 | 1000                | 101                   | 62.5              |
| 125                    | 4                    | 00000011              | 16               | 1               | 5               | 5                 | 5                 | 1001                | 100                   | 68.8              |
| 125                    | 4                    | 00000011              | 16               | 1               | 7               | 4                 | 4                 | 1010                | 011                   | 75.0              |
| 125                    | 4                    | 00000011              | 16               | 1               | 9               | 3                 | 3                 | 1011                | 010                   | 81.3              |
| 125                    | 4                    | 00000011              | 16               | 1               | 11              | 2                 | 2                 | 1100                | 001                   | 87.5              |
| 125                    | 4                    | 00000011              | 16               | 1               | 13              | 1                 | 1                 | 1101                | 000                   | 93.8              |
| 125                    | 8                    | 00000111              | 8                | 1               | 3               | 2                 | 2                 | 0100                | 001                   | 75.0              |
| 125                    | 8                    | 00000111              | 8                | 1               | 5               | 1                 | 1                 | 0101                | 000                   | 87.5              |

Caution The values in Table 19-22 do not guarantee the operation of the network system. Thoroughly check the effect on the network system, taking into consideration oscillation errors and delays of the CAN bus and CAN transceiver.

Table 19-22. Representative Examples of Baud Rate Settings (fcanmod = 8 MHz) (2/2)

| Set Baud<br>Rate Value | Division<br>Ratio of | C0BRP<br>Register Set |                  | Valid Bit F     | Rate Setting (l | Jnit: kbps)       |                   | _                   | gister Setting<br>lue | Sampling<br>Point |
|------------------------|----------------------|-----------------------|------------------|-----------------|-----------------|-------------------|-------------------|---------------------|-----------------------|-------------------|
| (Unit: kbps)           | C0BRP<br>Register    | Value                 | Length of<br>DBT | SYNC<br>SEGMENT | PROP<br>SEGMENT | PHASE<br>SEGMENT1 | PHASE<br>SEGMENT2 | TSEG13 to<br>TSEG10 | TSEG22 to<br>TSEG20   |                   |
| 100                    | 4                    | 00000011              | 20               | 1               | 7               | 6                 | 6                 | 1100                | 101                   | 70.0              |
| 100                    | 4                    | 00000011              | 20               | 1               | 9               | 5                 | 5                 | 1101                | 100                   | 75.0              |
| 100                    | 5                    | 00000100              | 16               | 1               | 7               | 4                 | 4                 | 1010                | 011                   | 75.0              |
| 100                    | 5                    | 00000100              | 16               | 1               | 9               | 3                 | 3                 | 1011                | 010                   | 81.3              |
| 100                    | 8                    | 00000111              | 10               | 1               | 3               | 3                 | 3                 | 0101                | 010                   | 70.0              |
| 100                    | 8                    | 00000111              | 10               | 1               | 5               | 2                 | 2                 | 0110                | 001                   | 80.0              |
| 100                    | 10                   | 00001001              | 8                | 1               | 3               | 2                 | 2                 | 0100                | 001                   | 75.0              |
| 100                    | 10                   | 00001001              | 8                | 1               | 5               | 1                 | 1                 | 0101                | 000                   | 87.5              |
| 83.3                   | 4                    | 00000011              | 24               | 1               | 7               | 8                 | 8                 | 1110                | 111                   | 66.7              |
| 83.3                   | 4                    | 00000011              | 24               | 1               | 9               | 7                 | 7                 | 1111                | 110                   | 70.8              |
| 83.3                   | 6                    | 00000101              | 16               | 1               | 5               | 5                 | 5                 | 1001                | 100                   | 68.8              |
| 83.3                   | 6                    | 00000101              | 16               | 1               | 7               | 4                 | 4                 | 1010                | 011                   | 75.0              |
| 83.3                   | 6                    | 00000101              | 16               | 1               | 9               | 3                 | 3                 | 1011                | 010                   | 81.3              |
| 83.3                   | 6                    | 00000101              | 16               | 1               | 11              | 2                 | 2                 | 1100                | 001                   | 87.5              |
| 83.3                   | 8                    | 00000111              | 12               | 1               | 5               | 3                 | 3                 | 0111                | 010                   | 75.0              |
| 83.3                   | 8                    | 00000111              | 12               | 1               | 7               | 2                 | 2                 | 1000                | 001                   | 83.3              |
| 83.3                   | 12                   | 00001011              | 8                | 1               | 3               | 2                 | 2                 | 0100                | 001                   | 75.0              |
| 83.3                   | 12                   | 00001011              | 8                | 1               | 5               | 1                 | 1                 | 0101                | 000                   | 87.5              |
| 33.3                   | 10                   | 00001001              | 24               | 1               | 7               | 8                 | 8                 | 1110                | 111                   | 66.7              |
| 33.3                   | 10                   | 00001001              | 24               | 1               | 9               | 7                 | 7                 | 1111                | 110                   | 70.8              |
| 33.3                   | 12                   | 00001011              | 20               | 1               | 7               | 6                 | 6                 | 1100                | 101                   | 70.0              |
| 33.3                   | 12                   | 00001011              | 20               | 1               | 9               | 5                 | 5                 | 1101                | 100                   | 75.0              |
| 33.3                   | 15                   | 00001110              | 16               | 1               | 7               | 4                 | 4                 | 1010                | 011                   | 75.0              |
| 33.3                   | 15                   | 00001110              | 16               | 1               | 9               | 3                 | 3                 | 1011                | 010                   | 81.3              |
| 33.3                   | 16                   | 00001111              | 15               | 1               | 6               | 4                 | 4                 | 1001                | 011                   | 73.3              |
| 33.3                   | 16                   | 00001111              | 15               | 1               | 8               | 3                 | 3                 | 1010                | 010                   | 80.0              |
| 33.3                   | 20                   | 00010011              | 12               | 1               | 5               | 3                 | 3                 | 0111                | 010                   | 75.0              |
| 33.3                   | 20                   | 00010011              | 12               | 1               | 7               | 2                 | 2                 | 1000                | 001                   | 83.3              |
| 33.3                   | 24                   | 00010111              | 10               | 1               | 3               | 3                 | 3                 | 0101                | 010                   | 70.0              |
| 33.3                   | 24                   | 00010111              | 10               | 1               | 5               | 2                 | 2                 | 0110                | 001                   | 80.0              |
| 33.3                   | 30                   | 00011101              | 8                | 1               | 3               | 2                 | 2                 | 0100                | 001                   | 75.0              |
| 33.3                   | 30                   | 00011101              | 8                | 1               | 5               | 1                 | 1                 | 0101                | 000                   | 87.5              |

Caution The values in Table 19-22 do not guarantee the operation of the network system. Thoroughly check the effect on the network system, taking into consideration oscillation errors and delays of the CAN bus and CAN transceiver.

Table 19-23. Representative Examples of Baud Rate Settings (fcanmod = 16 MHz) (1/2)

| Set Baud<br>Rate Value | Division<br>Ratio of | C0BRP<br>Register Set |                  | Valid Bit F     | Rate Setting (l | Jnit: kbps)       |                   | _                   | gister Setting      | Sampling<br>Point |
|------------------------|----------------------|-----------------------|------------------|-----------------|-----------------|-------------------|-------------------|---------------------|---------------------|-------------------|
| (Unit: kbps)           | C0BRP<br>Register    | Value                 | Length of<br>DBT | SYNC<br>SEGMENT | PROP<br>SEGMENT | PHASE<br>SEGMENT1 | PHASE<br>SEGMENT2 | TSEG13 to<br>TSEG10 | TSEG22 to<br>TSEG20 | (Unit: %)         |
| 1000                   | 1                    | 00000000              | 16               | 1               | 1               | 7                 | 7                 | 0111                | 110                 | 56.3              |
| 1000                   | 1                    | 00000000              | 16               | 1               | 3               | 6                 | 6                 | 1000                | 101                 | 62.5              |
| 1000                   | 1                    | 00000000              | 16               | 1               | 5               | 5                 | 5                 | 1001                | 100                 | 68.8              |
| 1000                   | 1                    | 00000000              | 16               | 1               | 7               | 4                 | 4                 | 1010                | 011                 | 75.0              |
| 1000                   | 1                    | 00000000              | 16               | 1               | 9               | 3                 | 3                 | 1011                | 010                 | 81.3              |
| 1000                   | 1                    | 00000000              | 16               | 1               | 11              | 2                 | 2                 | 1100                | 001                 | 87.5              |
| 1000                   | 1                    | 00000000              | 16               | 1               | 13              | 1                 | 1                 | 1101                | 000                 | 93.8              |
| 1000                   | 2                    | 0000001               | 8                | 1               | 3               | 2                 | 2                 | 0100                | 001                 | 75.0              |
| 1000                   | 2                    | 0000001               | 8                | 1               | 5               | 1                 | 1                 | 0101                | 000                 | 87.5              |
| 500                    | 2                    | 0000001               | 16               | 1               | 1               | 7                 | 7                 | 0111                | 110                 | 56.3              |
| 500                    | 2                    | 0000001               | 16               | 1               | 3               | 6                 | 6                 | 1000                | 101                 | 62.5              |
| 500                    | 2                    | 0000001               | 16               | 1               | 5               | 5                 | 5                 | 1001                | 100                 | 68.8              |
| 500                    | 2                    | 0000001               | 16               | 1               | 7               | 4                 | 4                 | 1010                | 011                 | 75.0              |
| 500                    | 2                    | 0000001               | 16               | 1               | 9               | 3                 | 3                 | 1011                | 010                 | 81.3              |
| 500                    | 2                    | 0000001               | 16               | 1               | 11              | 2                 | 2                 | 1100                | 001                 | 87.5              |
| 500                    | 2                    | 0000001               | 16               | 1               | 13              | 1                 | 1                 | 1101                | 000                 | 93.8              |
| 500                    | 4                    | 00000011              | 8                | 1               | 3               | 2                 | 2                 | 0100                | 001                 | 75.0              |
| 500                    | 4                    | 00000011              | 8                | 1               | 5               | 1                 | 1                 | 0101                | 000                 | 87.5              |
| 250                    | 4                    | 00000011              | 16               | 1               | 3               | 6                 | 6                 | 1000                | 101                 | 62.5              |
| 250                    | 4                    | 00000011              | 16               | 1               | 5               | 5                 | 5                 | 1001                | 100                 | 68.8              |
| 250                    | 4                    | 00000011              | 16               | 1               | 7               | 4                 | 4                 | 1010                | 011                 | 75.0              |
| 250                    | 4                    | 00000011              | 16               | 1               | 9               | 3                 | 3                 | 1011                | 010                 | 81.3              |
| 250                    | 4                    | 00000011              | 16               | 1               | 11              | 2                 | 2                 | 1100                | 001                 | 87.5              |
| 250                    | 8                    | 00000111              | 8                | 1               | 3               | 2                 | 2                 | 0100                | 001                 | 75.0              |
| 250                    | 8                    | 00000111              | 8                | 1               | 5               | 1                 | 1                 | 0101                | 000                 | 87.5              |
| 125                    | 8                    | 00000111              | 16               | 1               | 3               | 6                 | 6                 | 1000                | 101                 | 62.5              |
| 125                    | 8                    | 00000111              | 16               | 1               | 7               | 4                 | 4                 | 1010                | 011                 | 75.0              |
| 125                    | 8                    | 00000111              | 16               | 1               | 9               | 3                 | 3                 | 1011                | 010                 | 81.3              |
| 125                    | 8                    | 00000111              | 16               | 1               | 11              | 2                 | 2                 | 1100                | 001                 | 87.5              |
| 125                    | 16                   | 00001111              | 8                | 1               | 3               | 2                 | 2                 | 0100                | 001                 | 75.0              |
| 125                    | 16                   | 00001111              | 8                | 1               | 5               | 1                 | 1                 | 0101                | 000                 | 87.5              |

Caution The values in Table 19-23 do not guarantee the operation of the network system. Thoroughly check the effect on the network system, taking into consideration oscillation errors and delays of the CAN bus and CAN transceiver.

Table 19-23. Representative Examples of Baud Rate Settings (fcanmod = 16 MHz) (2/2)

| Set Baud<br>Rate Value | Division<br>Ratio of | C0BRP<br>Register Set |                  | Valid Bit F     | Rate Setting (l | Jnit: kbps)       |                   |                     | ister Setting | Sampling<br>Point |
|------------------------|----------------------|-----------------------|------------------|-----------------|-----------------|-------------------|-------------------|---------------------|---------------|-------------------|
| (Unit: kbps)           | C0BRP<br>Register    | Value                 | Length of<br>DBT | SYNC<br>SEGMENT | PROP<br>SEGMENT | PHASE<br>SEGMENT1 | PHASE<br>SEGMENT2 | TSEG13 to<br>TSEG10 | TSEG22 to     |                   |
| 100                    | 8                    | 00000111              | 20               | 1               | 9               | 5                 | 5                 | 1101                | 100           | 75.0              |
| 100                    | 8                    | 00000111              | 20               | 1               | 11              | 4                 | 4                 | 1110                | 011           | 80.0              |
| 100                    | 10                   | 00001001              | 16               | 1               | 7               | 4                 | 4                 | 1010                | 011           | 75.0              |
| 100                    | 10                   | 00001001              | 16               | 1               | 9               | 3                 | 3                 | 1011                | 010           | 81.3              |
| 100                    | 16                   | 00001111              | 10               | 1               | 3               | 3                 | 3                 | 0101                | 010           | 70.0              |
| 100                    | 16                   | 00001111              | 10               | 1               | 5               | 2                 | 2                 | 0110                | 001           | 80.0              |
| 100                    | 20                   | 00010011              | 8                | 1               | 3               | 2                 | 2                 | 0100                | 001           | 75.0              |
| 83.3                   | 8                    | 00000111              | 24               | 1               | 7               | 8                 | 8                 | 1110                | 111           | 66.7              |
| 83.3                   | 8                    | 00000111              | 24               | 1               | 9               | 7                 | 7                 | 1111                | 110           | 70.8              |
| 83.3                   | 12                   | 00001011              | 16               | 1               | 7               | 4                 | 4                 | 1010                | 011           | 75.0              |
| 83.3                   | 12                   | 00001011              | 16               | 1               | 9               | 3                 | 3                 | 1011                | 010           | 81.3              |
| 83.3                   | 12                   | 00001011              | 16               | 1               | 11              | 2                 | 2                 | 1100                | 001           | 87.5              |
| 83.3                   | 16                   | 00001111              | 12               | 1               | 5               | 3                 | 3                 | 0111                | 010           | 75.0              |
| 83.3                   | 16                   | 00001111              | 12               | 1               | 7               | 2                 | 2                 | 1000                | 001           | 83.3              |
| 83.3                   | 24                   | 00010111              | 8                | 1               | 3               | 2                 | 2                 | 0100                | 001           | 75.0              |
| 83.3                   | 24                   | 00010111              | 8                | 1               | 5               | 1                 | 1                 | 0101                | 000           | 87.5              |
| 33.3                   | 30                   | 00011101              | 24               | 1               | 7               | 8                 | 8                 | 1110                | 111           | 66.7              |
| 33.3                   | 30                   | 00011101              | 24               | 1               | 9               | 7                 | 7                 | 1111                | 110           | 70.8              |
| 33.3                   | 24                   | 00010111              | 20               | 1               | 9               | 5                 | 5                 | 1101                | 100           | 75.0              |
| 33.3                   | 24                   | 00010111              | 20               | 1               | 11              | 4                 | 4                 | 1110                | 011           | 80.0              |
| 33.3                   | 30                   | 00011101              | 16               | 1               | 7               | 4                 | 4                 | 1010                | 011           | 75.0              |
| 33.3                   | 30                   | 00011101              | 16               | 1               | 9               | 3                 | 3                 | 1011                | 010           | 81.3              |
| 33.3                   | 32                   | 00011111              | 15               | 1               | 8               | 3                 | 3                 | 1010                | 010           | 80.0              |
| 33.3                   | 32                   | 00011111              | 15               | 1               | 10              | 2                 | 2                 | 1011                | 001           | 86.7              |
| 33.3                   | 37                   | 00100100              | 13               | 1               | 6               | 3                 | 3                 | 1000                | 010           | 76.9              |
| 33.3                   | 37                   | 00100100              | 13               | 1               | 8               | 2                 | 2                 | 1001                | 001           | 84.6              |
| 33.3                   | 40                   | 00100111              | 12               | 1               | 5               | 3                 | 3                 | 0111                | 010           | 75.0              |
| 33.3                   | 40                   | 00100111              | 12               | 1               | 7               | 2                 | 2                 | 1000                | 001           | 83.3              |
| 33.3                   | 48                   | 00101111              | 10               | 1               | 3               | 3                 | 3                 | 0101                | 010           | 70.0              |
| 33.3                   | 48                   | 00101111              | 10               | 1               | 5               | 2                 | 2                 | 0110                | 001           | 80.0              |
| 33.3                   | 60                   | 00111011              | 8                | 1               | 3               | 2                 | 2                 | 0100                | 001           | 75.0              |
| 33.3                   | 60                   | 00111011              | 8                | 1               | 5               | 1                 | 1                 | 0101                | 000           | 87.5              |

Caution The values in Table 19-23 do not guarantee the operation of the network system. Thoroughly check the effect on the network system, taking into consideration oscillation errors and delays of the CAN bus and CAN transceiver.

# 19.16 Operation of CAN Controller

**Remark** m = 00 to 31

Figure 19-35. Initialization



START Clear OPMODE. INIT mode? No Yes C0BRP register, Initialize message C0BTR register. buffers. Set C0ERC and C0INFO C0IE register. No register clear? Yes Set C0MASK register. Set CCERC bit. Set CCERC bit = 1 Set C0CTRL register. (set OPMODE bit) **END** Caution After setting the CAN module to the initialization mode, avoid setting the module to another operation mode immediately after. If it is necessary to immediately set the module to another operation mode, be sure to access registers other than the C0CTRL and C0GMCTRL registers (e.g., set a message buffer). Remark OPMODE: Normal operation mode, normal operation mode with ABT, receive-only mode, singleshot mode, self-test mode

Figure 19-36. Re-initialization

START No RDY bit = 1? Yes Clear RDY bit. Set RDY bit = 0 Clear RDY bit = 1 No RDY bit = 0? Yes Set C0MCONFm register. Set C0MIDHm register, C0MIDLm register. No Transmit message buffer? Yes Set C0MDLCm register. Clear C0MDATAm register. Set C0MCTRLm register. Set RDY bit. Set RDY bit = 1 Clear RDY bit = 0 END Cautions 1. Before a message buffer is initialized, the RDY bit must be cleared. 2. Make the following settings for message buffers not used by the application. • Clear the C0MCTRLm.RDY, C0MCTRLm.TRQ, and C0MCTRLm.DN bits to 0. • Clear the C0MCONFm.MA0 bit to 0.

Figure 19-37. Message Buffer Initialization

Figure 19-38 shows the processing for a receive message buffer (C0MCONFm.MT2 to C0MCONFm.MT0 bits = 001B to 101B).



Figure 19-38. Message Buffer Redefinition

Figure 19-39 shows the processing for a transmit message buffer during transmission (MT2 to MT0 bits of C0MCONFm register = 000B).



Figure 19-39. Message Buffer Redefinition during Transmission

Figure 19-40 shows the processing for a transmit message buffer (C0MCONFm.MT2 to C0MCONFm.MT0 bits = 000B).



Figure 19-40. Message Transmit Processing (Normal Operation Mode)

Figure 19-41 shows the processing for a transmit message buffer (C0MCONFm.MT2 to C0MCONFm.MT0 bits = 000B).



Figure 19-41. ABT Message Transmit Processing

805



Figure 19-42. Transmission via Interrupt (Using C0LOPT register)



Figure 19-43. Transmission via Interrupt (Using C0TGPT Register)



Figure 19-44. Transmission via Software Polling



Figure 19-45. Transmission Abort Processing (Normal Operation Mode)

4. Do not execute a new transmission request that includes other message buffers while transmission request abort processing is in progress.

**START** Clear ABTTRG bit. SET\_ABTTRG bit = 0 CLEAR\_ABTTRG bit = 1 No ABTTRG bit = 0? Yes Clear TRQ bit. SET\_TRQ bit = 0 CLEAR TRQ bit = 1 Wait for 11 CAN data bits. No TSTAT bit = 0? Yes Read C0LOPT register. Message buffer to No be aborted matches C0LOPT register? Yes Transmit abort request was successful. Transmission successful **END** 

Figure 19-46. Transmission Abort Processing Except for ABT Transmission (Normal Operation Mode with ABT)

- Cautions 1. Execute transmission request abort processing by clearing the TRQ bit, not the RDY bit.
  - 2. Before making a sleep mode transition request, confirm that there is no transmission request left using this processing.
  - 3. The TSTAT bit can be periodically checked by a user application or can be checked after the transmit completion interrupt.
  - 4. Do not execute the new transmission request including in the other message buffers while transmission request abort processing is in progress.

Figure 19-47 (a) shows processing that does not skip resuming the transmission of a message that was interrupted when the transmission of an ABT message buffer was aborted.



Figure 19-47 (a). Transmission Abort Processing (Normal Operation Mode with ABT)

Figure 19-47 (b) shows the processing that does not skip resuming the transmission of a message that was interrupted when the transmission of an ABT message buffer was aborted.



Figure 19-47 (b). Transmission Request Abort Processing (Normal Operation Mode with ABT)

- - 2. Make a CAN sleep mode/CAN stop mode request after the ABTTRG bit is cleared (after ABT mode is stopped) following the procedure shown in Figure 19-47 (a) or (b). When clearing a transmission request in an area other than the ABT area, follow the procedure shown in Figure 19-45.



Figure 19-48. Reception via Interrupt (Using C0LIPT Register)



Figure 19-49. Reception via Interrupt (Using CORGPT Register)

Start No CINTS1 bit = 1? Yes Clear CINTS1 bit. Clear CINTS1 bit = 1 Read C0RGPT register. No ROVF bit = 1? Yes Clear ROVF bit. Clear ROVF bit = 1 DN bit = 0Clear DN bit. and Clear DN bit = 1 MUC bit = 0Note No Yes Read C0MDATAxm, C0MDLCm, C0MIDLm, and No C0MIDHm registers. RHPM bit = 1? Yes **END** Note Check the MUC and DN bits using one read access.

Figure 19-50. Reception via Software Polling



Figure 19-51. Setting CAN Sleep Mode/Stop Mode



Figure 19-52. Clear CAN Sleep/Stop Mode

START No BOFF bit = 1? Yes Set C0CTRL register. (clear OPMODE bit) Access to register other than COCTRL and COGMCTRL registers. No Forced recovery from bus off? Yes Set CCERC bit. Set C0CTRL register. Set CCERC bit = 1 (Set OPMODE bit) Set C0CTRL register. (set OPMODE bit) Wait for recovery from bus off. **END** Remark OPMODE: Normal operation mode, normal operation mode with ABT, receive-only mode, singleshot mode, self-test mode

Figure 19-53. Bus-off Recovery

START

INIT mode

Clear GOM bit.
Set GOM bit = 0
Clear GOM bit = 1

Yes

Shutdown successful
GOM bit = 0,
EFSD bit = 0

END

Figure 19-54. Normal Shutdown Process

Start FSD bit.
Set EFSD bit.
Set EFSD bit = 1

Clear GOM bit.
Set GOM bit = 0
Clear GOM bit = 1

No
GOM bit = 0?

Yes

Shutdown successful GOM bit = 0,
EFSD bit = 0

End

Caution Do not read- or write-access any registers by software between setting the EFSD bit and clearing the GOM bit.

Figure 19-55. Forced Shutdown Process

**START** Error interrupt No CINTS2 bit = 1? Yes Check CAN module state. (read C0INFO register) Clear CINTS2 bit. Clear CINTS2 bit = 1 No CINTS3 bit = 1? No CINTS4 bit = 1? Yes Yes Check CAN protocol error state. Clear CINTS4 bit. (read COLEC register) Clear CINTS4 bit = 1 Clear CINTS3 bit. Clear CINTS3 bit = 1

END

Figure 19-56. Error Handling



Figure 19-57. Setting CPU Standby (from CAN Sleep Mode)



Figure 19-58. Setting CPU Standby (from CAN Stop Mode)

# CHAPTER 20 DMA FUNCTION (DMA CONTROLLER)

The V850ES/SG2 includes a direct memory access (DMA) controller (DMAC) that executes and controls DMA transfer.

The DMAC controls data transfer between memory and I/O, between memories, or between I/Os based on DMA requests issued by the on-chip peripheral I/O (serial interface, timer/counter, and A/D converter), interrupts from external input pins, or software triggers (memory refers to internal RAM or external memory).

#### 20.1 Features

- 4 independent DMA channels
- Transfer unit: 8/16 bits
- Maximum transfer count: 65,536 (2<sup>16</sup>)
- Transfer type: Two-cycle transfer
- Transfer mode: Single transfer mode
- Transfer requests
  - Request by interrupts from on-chip peripheral I/O (serial interface, timer/counter, A/D converter) or interrupts from external input pin
  - Requests by software trigger
- Transfer targets
  - Internal RAM ↔ Peripheral I/O
  - Peripheral I/O ↔ Peripheral I/O
  - Internal RAM ↔ External memory
  - External memory ↔ Peripheral I/O

# 20.2 Configuration



# 20.3 Registers

## (1) DMA source address registers 0 to 3 (DSA0 to DSA3)

The DSA0 to DSA3 registers set the DMA source addresses (26 bits each) for DMA channel n (n = 0 to 3).

These registers are divided into two 16-bit registers, DSAnH and DSAnL.

These registers can be read or written in 16-bit units.



| IR | Specification of DMA transfer source      |
|----|-------------------------------------------|
| 0  | External memory or on-chip peripheral I/O |
| 1  | Internal RAM                              |

| SA25 to SA16 | Set the address (A25 to A16) of the DMA transfer source            |
|--------------|--------------------------------------------------------------------|
|              | (default value is undefined).                                      |
|              | During DMA transfer, the next DMA transfer source address is held. |
|              | When DMA transfer is completed, the DMA address set first is held. |

| SA15 to SA0 | Set the address (A15 to A0) of the DMA transfer source             |
|-------------|--------------------------------------------------------------------|
|             | (default value is undefined).                                      |
|             | During DMA transfer, the next DMA transfer source address is held. |
|             | When DMA transfer is completed, the DMA address set first is held. |

### Cautions 1. Be sure to clear bits 14 to 10 of the DSAnH register to 0.

- 2. Set the DSAnH and DSAnL registers at the following timing when DMA transfer is disabled (DCHCn.Enn bit = 0).
  - Period from after reset to start of first DMA transfer
  - Period from after channel initialization by DCHCn.INITn bit to start of DMA transfer
  - Period from after completion of DMA transfer (DCHCn.TCn bit = 1) to start of the next DMA transfer
- 3. When the value of the DSAn register is read, two 16-bit registers, DSAnH and DSAnL, are read. If reading and updating conflict, the value being updated may be read (see 20.13 Cautions).
- 4. Following reset, set the DSAnH, DSAnL, DDAnH, DDAnL, and DBCn registers before starting DMA transfer. If these registers are not set, the operation when DMA transfer is started is not guaranteed.

### (2) DMA destination address registers 0 to 3 (DDA0 to DDA3)

The DDA0 to DDA3 registers set the DMA destination address (26 bits each) for DMA channel n (n = 0 to 3). These registers are divided into two 16-bit registers, DDAnH and DDAnL.

These registers can be read or written in 16-bit units.



| IR Specification of DMA transfer destination |   |                                           |  |  |  |  |
|----------------------------------------------|---|-------------------------------------------|--|--|--|--|
|                                              | 0 | External memory or on-chip peripheral I/O |  |  |  |  |
|                                              | 1 | Internal RAM                              |  |  |  |  |

| DA25 to DA16 | Set an address (A25 to A16) of DMA transfer destination                 |
|--------------|-------------------------------------------------------------------------|
|              | (default value is undefined).                                           |
|              | During DMA transfer, the next DMA transfer destination address is held. |
|              | When DMA transfer is completed, the DMA transfer source address set     |
|              | first is held.                                                          |

| DA15 to DA0 | Set an address (A15 to A0) of DMA transfer destination                  |
|-------------|-------------------------------------------------------------------------|
|             | (default value is undefined).                                           |
|             | During DMA transfer, the next DMA transfer destination address is held. |
|             | When DMA transfer is completed, the DMA transfer source address set     |
|             | first is held.                                                          |

#### Cautions 1. Be sure to clear bits 14 to 10 of the DDAnH register to 0.

- 2. Set the DDAnH and DDAnL registers at the following timing when DMA transfer is disabled (DCHCn.Enn bit = 0).
  - Period from after reset to start of first DMA transfer
  - Period from after channel initialization by DCHCn.INITn bit to start of DMA transfer
  - Period from after completion of DMA transfer (DCHCn.TCn bit = 1) to start of the next DMA transfer
- 3. When the value of the DDAn register is read, two 16-bit registers, DDAnH and DDAnL, are read. If reading and updating conflict, a value being updated may be read (see 20.13 Cautions).
- Following reset, set the DSAnH, DSAnL, DDAnH, DDAnL, and DBCn registers before starting DMA transfer. If these registers are not set, the operation when DMA transfer is started is not guaranteed.

# (3) DMA byte count registers 0 to 3 (DBC0 to DBC3)

The DBC0 to DBC3 registers are 16-bit registers that set the byte transfer count for DMA channel n (n = 0 to 3). These registers hold the remaining transfer count during DMA transfer.

These registers are decremented by 1 per one transfer regardless of the transfer data unit (8/16 bits), and the transfer is terminated if a borrow occurs.

These registers can be read or written in 16-bit units.

After reset: Undefined R/W Address: DBC0 FFFF0C0H, DBC1 FFFF0C2H,

DBC2 FFFF0C4H, DBC3 FFFF0C6H

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

DBCn
n = 0 to 3) BC15 BC14 BC13 BC12 BC11 BC10 BC9 BC8 BC7 BC6 BC5 BC4 BC3 BC2 BC1 BC0

| BC15 to<br>BC0                                               | Byte transfer count setting or remaining byte transfer count during DMA transfer |  |  |  |  |
|--------------------------------------------------------------|----------------------------------------------------------------------------------|--|--|--|--|
| 0000H Byte transfer count 1 or remaining byte transfer count |                                                                                  |  |  |  |  |
| 0001H Byte transfer count 2 or remaining byte transfer count |                                                                                  |  |  |  |  |
| :                                                            | :                                                                                |  |  |  |  |
| FFFFH                                                        | Byte transfer count 65,536 (2 <sup>16</sup> ) or remaining byte transfer count   |  |  |  |  |
| The numb                                                     | The number of transfer data set first is held when DMA transfer is complete.     |  |  |  |  |

- Cautions 1. Set the DBCn register at the following timing when DMA transfer is disabled (DCHCn.Enn bit = 0).
  - Period from after reset to start of first DMA transfer
  - Period from after channel initialization by DCHCn.INITn bit to start of DMA transfer
  - Period from after completion of DMA transfer (DCHCn.TCn bit = 1) to start of the next DMA transfer
  - Following reset, set the DSAnH, DSAnL, DDAnH, DDAnL, and DBCn registers before starting DMA transfer. If these registers are not set, the operation when DMA transfer is started is not guaranteed.

### (4) DMA addressing control registers 0 to 3 (DADC0 to DADC3)

The DADC0 to DADC3 registers are 16-bit registers that control the DMA transfer mode for DMA channel n (n = 0 to 3).

These registers can be read or written in 16-bit units.

Reset input clears these registers to 0000H.

| After res      | After reset: 0000H |      |      | Address: DADC0 FFFFF0D0H, DADC1 FFFFF0D2H, |          |          |         |    |
|----------------|--------------------|------|------|--------------------------------------------|----------|----------|---------|----|
|                |                    |      |      | DADC2 F                                    | FFFF0D4I | H, DADC3 | FFFF0D6 | 6H |
|                | 15                 | 14   | 13   | 12                                         | 11       | 10       | 9       | 8  |
| DADCn          | 0                  | DS0  | 0    | 0                                          | 0        | 0        | 0       | 0  |
| (n = 0  to  3) |                    |      |      |                                            |          |          |         |    |
|                | 7                  | 6    | 5    | 4                                          | 3        | 2        | 1       | 0  |
|                | SAD1               | SAD0 | DAD1 | DAD0                                       | 0        | 0        | 0       | 0  |

| DS0 | Setting of transfer data size |
|-----|-------------------------------|
| 0   | 8 bits                        |
| 1   | 16 bits                       |

| SAD1 | SAD0 | Setting of count direction of the transfer source address |  |  |  |
|------|------|-----------------------------------------------------------|--|--|--|
| 0    | 0    | Increment                                                 |  |  |  |
| 0    | 1    | Decrement                                                 |  |  |  |
| 1    | 0    | Fixed                                                     |  |  |  |
| 1    | 1    | Setting prohibited                                        |  |  |  |

| DAD1 | DAD0 | Setting of count direction of the destination address |  |  |  |
|------|------|-------------------------------------------------------|--|--|--|
| 0    | 0    | Increment                                             |  |  |  |
| 0    | 1    | Decrement                                             |  |  |  |
| 1    | 0    | Fixed                                                 |  |  |  |
| 1    | 1    | Setting prohibited                                    |  |  |  |

# Cautions 1. Be sure to clear bits 15, 13 to 8, and 3 to 0 of the DADCn register to 0.

- 2. Set the DADCn register at the following timing when DMA transfer is disabled (DCHCn.Enn bit = 0).
  - Period from after reset to start of first DMA transfer
  - Period from after channel initialization by DCHCn.INITn bit to start of DMA transfer
  - Period from after completion of DMA transfer (DCHCn.TCn bit = 1) to start of the next DMA transfer
- 3. The DS0 bit specifies the size of the transfer data, and does not control bus sizing. If 8-bit data (DS0 bit = 0) is set, therefore, the lower data bus is not always used.
- 4. If the transfer data size is set to 16 bits (DS0 bit = 1), transfer cannot be started from an odd address. Transfer is always started from an address with the first bit of the lower address aligned to 0.
- 5. If DMA transfer is executed on an on-chip peripheral I/O register (as the transfer source or destination), be sure to specify the same transfer size as the register size. For example, to execute DMA transfer on an 8-bit register, be sure to specify 8-bit transfer.

### (5) DMA channel control registers 0 to 3 (DCHC0 to DCHC3)

The DCHC0 to DCHC3 registers are 8-bit registers that control the DMA transfer operating mode for DMA channel n.

These registers can be read or written in 8-bit or 1-bit units. (However, bit 7 is read-only and bits 1 and 2 are write-only. If bit 1 or 2 is read, the read value is always 0.)

Reset input clears these registers to 00H.

(n = 0 to 3)

| TCn <sup>Note 1</sup>         | Status flag indicates whether DMA transfer through DMA channel n has completed or not |  |  |  |  |
|-------------------------------|---------------------------------------------------------------------------------------|--|--|--|--|
| 0                             | DMA transfer had not completed.                                                       |  |  |  |  |
| 1 DMA transfer had completed. |                                                                                       |  |  |  |  |
| It is set to                  | It is set to 1 on the last DMA transfer and cleared to 0 when it is read.             |  |  |  |  |

INITnNote 2 If the INITn bit is set to 1 with DMA transfer disabled (Enn bit = 0), the DMA transfer status can be initialized.

When re-setting the DMA transfer status (re-setting the DDAnH, DDAnL, DSAnH, DSAnL, DBCn, and DADCn registers) before DMA transfer is completed (before the TCn bit is set to 1), be sure to initialize the DMA channel.

When initializing the DMA controller, however, be sure to observe the procedure described in 20.13 Cautions.

| STGnNote 2 | This is a software startup trigger of DMA transfer.                        |
|------------|----------------------------------------------------------------------------|
|            | If this bit is set to 1 in the DMA transfer enable state (TCn bit = 0, Enn |
|            | bit = 1), DMA transfer is started.                                         |

| Enn                    | Setting of whether DMA transfer through DMA channel n is to be enabled or disabled |  |  |
|------------------------|------------------------------------------------------------------------------------|--|--|
| 0                      | DMA transfer disabled                                                              |  |  |
| 1 DMA transfer enabled |                                                                                    |  |  |

DMA transfer is enabled when the Enn bit is set to 1.

When DMA transfer is completed (when a terminal count is generated), this bit is automatically cleared to 0.

To abort DMA transfer, clear the Enn bit to 0 by software. To resume, set the Enn bit to 1 again.

When aborting or resuming DMA transfer, however, be sure to observe the procedure described in **20.13 Cautions**.

- Notes 1. The TCn bit is read-only.
  - 2. The INITn and STGn bits are write-only.
- Cautions 1. Be sure to clear bits 6 to 3 of the DCHCn register to 0.
  - 2. When DMA transfer is completed (when a terminal count is generated), the Enn bit is cleared to 0 and then the TCn bit is set to 1. If the DCHCn register is read while its bits are being updated, a value indicating "transfer not completed and transfer is disabled" (TCn bit = 0 and Enn bit = 0) may be read.

### (6) DMA trigger factor registers 0 to 3 (DTFR0 to DTFR3)

The DTFR0 to DTFR3 registers are 8-bit registers that control the DMA transfer start trigger via interrupt request signals from on-chip peripheral I/O.

The interrupt request signals set by these registers serve as DMA transfer start factors.

These registers can be read or written in 8-bit units. However, DFn bit can be read or written in 1-bit units.

Reset input clears these registers to 00H.



**Note** The DFn bit is a write-only bit. Write 0 to this bit to clear a DMA transfer request if an interrupt that is specified as the cause of starting DMA transfer occurs while DMA transfer is disabled.

- Cautions 1. Set the IFCn5 to IFCn0 bits at the following timing when DMA transfer is disabled (DCHCn.Enn bit = 0).
  - Period from after reset to start of first DMA transfer
  - Period from after channel initialization by DCHCn.INITn bit to start of DMA transfer
  - Period from after completion of DMA transfer (DCHCn.TCn bit = 1) to start of the next DMA transfer
  - 2. An interrupt request that is generated in the standby mode (IDEL1, IDLE2, STOP, or sub-IDLE mode) does not start the DMA transfer cycle (nor is the DFn bit set to 1).
  - 3. If a DMA start factor is selected by the IFCn5 to IFCn0 bits, the DFn bit is set to 1 when an interrupt occurs from the selected on-chip peripheral I/O, regardless of whether the DMA transfer is enabled or disabled. If DMA is enabled in this status, DMA transfer is immediately started.

Remark For the IFCn5 to IFCn0 bits, see Table 20-1 DMA Start Factors.

Table 20-1. DMA Start Factors (1/2)

| IFCn5 | IFCn4 | IFCn3 | IFCn2 | IFCn1 | IFCn0 | Interrupt Source                  |
|-------|-------|-------|-------|-------|-------|-----------------------------------|
| 0     | 0     | 0     | 0     | 0     | 0     | DMA request by interrupt disabled |
| 0     | 0     | 0     | 0     | 0     | 1     | INTP0                             |
| 0     | 0     | 0     | 0     | 1     | 0     | INTP1                             |
| 0     | 0     | 0     | 0     | 1     | 1     | INTP2                             |
| 0     | 0     | 0     | 1     | 0     | 0     | INTP3                             |
| 0     | 0     | 0     | 1     | 0     | 1     | INTP4                             |
| 0     | 0     | 0     | 1     | 1     | 0     | INTP5                             |
| 0     | 0     | 0     | 1     | 1     | 1     | INTP6                             |
| 0     | 0     | 1     | 0     | 0     | 0     | INTP7                             |
| 0     | 0     | 1     | 0     | 0     | 1     | INTTQ0OV                          |
| 0     | 0     | 1     | 0     | 1     | 0     | INTTQ0CC0                         |
| 0     | 0     | 1     | 0     | 1     | 1     | INTTQ0CC1                         |
| 0     | 0     | 1     | 1     | 0     | 0     | INTTQ0CC2                         |
| 0     | 0     | 1     | 1     | 0     | 1     | INTTQ0CC3                         |
| 0     | 0     | 1     | 1     | 1     | 0     | INTTP0OV                          |
| 0     | 0     | 1     | 1     | 1     | 1     | INTTP0CC0                         |
| 0     | 1     | 0     | 0     | 0     | 0     | INTTP0CC1                         |
| 0     | 1     | 0     | 0     | 0     | 1     | INTTP1OV                          |
| 0     | 1     | 0     | 0     | 1     | 0     | INTTP1CC0                         |
| 0     | 1     | 0     | 0     | 1     | 1     | INTTP1CC1                         |
| 0     | 1     | 0     | 1     | 0     | 0     | INTTP2OV                          |
| 0     | 1     | 0     | 1     | 0     | 1     | INTTP2CC0                         |
| 0     | 1     | 0     | 1     | 1     | 0     | INTTP2CC1                         |
| 0     | 1     | 0     | 1     | 1     | 1     | INTTP3CC0                         |
| 0     | 1     | 1     | 0     | 0     | 0     | INTTP3CC1                         |
| 0     | 1     | 1     | 0     | 0     | 1     | INTTP4CC0                         |
| 0     | 1     | 1     | 0     | 1     | 0     | INTTP4CC1                         |
| 0     | 1     | 1     | 0     | 1     | 1     | INTTP5CC0                         |
| 0     | 1     | 1     | 1     | 0     | 0     | INTTP5CC1                         |
| 0     | 1     | 1     | 1     | 0     | 1     | INTTM0EQ0                         |
| 0     | 1     | 1     | 1     | 1     | 0     | INTCB0R/INTIIC1                   |
| 0     | 1     | 1     | 1     | 1     | 1     | INTCB0T                           |
| 1     | 0     | 0     | 0     | 0     | 0     | INTCB1R                           |
| 1     | 0     | 0     | 0     | 0     | 1     | INTCB1T                           |
| 1     | 0     | 0     | 0     | 1     | 0     | INTCB2R                           |
| 1     | 0     | 0     | 0     | 1     | 1     | INTCB2T                           |
| 1     | 0     | 0     | 1     | 0     | 0     | INTCB3R                           |
| 1     | 0     | 0     | 1     | 0     | 1     | INTCB3T                           |
| 1     | 0     | 0     | 1     | 1     | 0     | INTUA0R/INTCB4R                   |
| 1     | 0     | 0     | 1     | 1     | 1     | INTUA0T/INTCB4T                   |
| 1     | 0     | 1     | 0     | 0     | 0     | INTUA1R/INTIIC2                   |
| 1     | 0     | 1     | 0     | 0     | 1     | INTUA1T                           |
| 1     | 0     | 1     | 0     | 1     | 0     | INTUA2R/INTIIC0                   |

**Remark** n = 0 to 3

Table 20-1. DMA Start Factors (2/2)

| IFCn5 | IFCn4 | IFCn3     | IFCn2              | IFCn1 | IFCn0 | Interrupt Source       |
|-------|-------|-----------|--------------------|-------|-------|------------------------|
| 1     | 0     | 1         | 0                  | 1     | 1     | INTUA2T                |
| 1     | 0     | 1         | 1                  | 0     | 0     | INTAD                  |
| 1     | 0     | 1         | 1                  | 0     | 1     | INTKR                  |
| 1     | 0     | 1         | 1                  | 1     | 0     | INTERR <sup>Note</sup> |
| 1     | 0     | 1         | 1                  | 1     | 1     | INTSTA <sup>Note</sup> |
| 1     | 1     | 0         | 0                  | 0     | 0     | INTIE1 <sup>Note</sup> |
|       |       | Other tha | Setting prohibited |       |       |                        |

Note IEBus controller version only

**Remark** n = 0 to 3

## 20.4 Transfer Targets

Table 20-2 shows the relationship between the transfer targets ( $\sqrt{\cdot}$ : Transfer enabled,  $\times$ : Transfer disabled).

Table 20-2. Relationship Between Transfer Targets

|        |                        |              | Transfer D                | estination   |                 |  |
|--------|------------------------|--------------|---------------------------|--------------|-----------------|--|
|        |                        | Internal ROM | On-Chip<br>Peripheral I/O | Internal RAM | External Memory |  |
|        | On-chip peripheral I/O | ×            | √                         | √            | √               |  |
| Irce   | Internal RAM           | ×            | √                         | ×            | √               |  |
| Source | External memory        | ×            | √                         | √            | √               |  |
|        | Internal ROM           | ×            | ×                         | ×            | ×               |  |

Caution The operation is not guaranteed for combinations of transfer destination and source marked with "x" in Table 20-2.

### 20.5 Transfer Modes

Single transfer is supported as the transfer mode.

In single transfer mode, the bus is released at each byte/halfword transfer. If there is a subsequent DMA transfer request, transfer is performed again once. This operation continues until a terminal count occurs.

When the DMAC has released the bus, if another higher priority DMA transfer request is issued, the higher priority DMA request always takes precedence.

If a new transfer request of the same channel and a transfer request of another channel with a lower priority are generated in a transfer cycle, DMA transfer of the channel with the lower priority is executed after the bus is released to the CPU (the new transfer request of the same channel is ignored in the transfer cycle).

## 20.6 Transfer Types

As a transfer type, the 2-cycle transfer is supported.

In two-cycle transfer, data transfer is performed in two cycles, a read cycle and a write cycle.

In the read cycle, the transfer source address is output and reading is performed from the source to the DMAC. In the write cycle, the transfer destination address is output and writing is performed from the DMAC to the destination.

An idle cycle of one clock is always inserted between a read cycle and a write cycle. If the data bus width differs between the transfer source and destination for DMA transfer of two cycles, the operation is performed as follows.

#### <16-bit data transfer>

<1> Transfer from 32-bit bus → 16-bit bus

A read cycle (the higher 16 bits are in a high-impedance state) is generated, followed by generation of a write cycle (16 bits).

<2> Transfer from 16-/32-bit bus to 8-bit bus

A 16-bit read cycle is generated once, and then an 8-bit write cycle is generated twice.

<3> Transfer from 8-bit bus to 16-/32-bit bus

An 8-bit read cycle is generated twice, and then a 16-bit write cycle is generated once.

<4> Transfer between 16-bit bus and 32-bit bus

A 16-bit read cycle is generated once, and then a 16-bit write cycle is generated once.

For DMA transfer executed to an on-chip peripheral I/O register (transfer source/destination), be sure to specify the same transfer size as the register size. For example, for DMA transfer to an 8-bit register, be sure to specify byte (8-bit) transfer.

Remark The bus width of each transfer target (transfer source/destination) is as follows.

On-chip peripheral I/O: 16-bit bus width
Internal RAM: 32-bit bus width

• External memory: 8-bit or 16-bit bus width

### 20.7 DMA Channel Priorities

The DMA channel priorities are fixed as follows.

DMA channel 0 > DMA channel 1 > DMA channel 2 > DMA channel 3

The priorities are checked for every transfer cycle.

### 20.8 Time Related to DMA Transfer

The time required to respond to a DMA request, and the minimum number of clocks required for DMA transfer are shown below.

Single transfer: DMA response time (<1>) + Transfer source memory access (<2>) + 1<sup>Note 1</sup> + Transfer destination memory access (<2>)

| DM                       | IA Cycle                       | Minimum Number of Execution Clocks                                            |  |  |  |  |
|--------------------------|--------------------------------|-------------------------------------------------------------------------------|--|--|--|--|
| <1> DMA request response | e time                         | 4 clocks (MIN.) + Noise elimination time <sup>Note 2</sup>                    |  |  |  |  |
| <2> Memory access        | External memory access         | Depends on connected memory.                                                  |  |  |  |  |
|                          | Internal RAM access            | 2 clocks <sup>Note 3</sup>                                                    |  |  |  |  |
|                          | Peripheral I/O register access | 3 clocks + Number of wait cycles specified by VSWC register <sup>Note 4</sup> |  |  |  |  |

Notes 1. One clock is always inserted between a read cycle and a write cycle in DMA transfer.

- 2. If an external interrupt (INTPn) is specified as the trigger to start DMA transfer, noise elimination time is added (n = 0 to 7).
- 3. Two clocks are required for a DMA cycle.
- 4. More wait cycles are necessary for accessing a specific peripheral I/O register (for details, see 3.4.9 (2)).

#### 20.9 DMA Transfer Start Factors

There are two types of DMA transfer start factors, as shown below.

### (1) Request by software

If the STGn bit is set to 1 while the DCHCn.TCn bit = 1 and Enn bit = 1 (DMA transfer enabled), DMA transfer is started.

To request the next DMA transfer cycle immediately after that, confirm, by using the DBCn register, that the preceding DMA transfer cycle has been completed, and set the STGn bit to 1 again (n = 0 to 3).

```
TCn bit = 0, Enn bit = 1

↓

STGn bit = 1 ... Starts the first DMA transfer.

↓

Confirm that the contents of the DBCn register have been updated.

STGn bit = 1 ... Starts the second DMA transfer.

↓

:

↓
```

Generation of terminal count  $\dots$  Enn bit = 0, TCn bit = 1, and INTDMAn signal is generated.

## (2) Request by on-chip peripheral I/O

If an interrupt request is generated from the on-chip peripheral I/O set by the DTFRn register when the DCHCn. TCn bit = 0 and Enn bit = 1 (DMA transfer enabled), DMA transfer is started.

- Cautions 1. Two start factors (software trigger and hardware trigger) cannot be used for one DMA channel. If two start factors are simultaneously generated for one DMA channel, only one of them is valid. The start factor that is valid cannot be identified.
  - 2. A new transfer request that is generated after the preceding DMA transfer request was generated or in the preceding DMA transfer cycle is ignored (cleared).
  - 3. The transfer request interval of the same DMA channel varies depending on the setting of bus wait in the DMA transfer cycle, the start status of the other channels, or the external bus hold request. In particular, as described in Caution 2, a new transfer request that is generated for the same channel before the DMA transfer cycle or during the DMA transfer cycle is ignored. Therefore, the transfer request intervals for the same DMA channel must be sufficiently separated by the system. When the software trigger is used, completion of the DMA transfer cycle that was generated before can be checked by updating the DBCn register.

### 20.10 DMA Abort Factors

DMA transfer is aborted if a bus hold occurs.

The same applies if transfer is executed between the internal memory/on-chip peripheral I/O and internal memory/on-chip peripheral I/O.

When the bus hold is cleared, DMA transfer is resumed.

### 20.11 End of DMA Transfer

When DMA transfer has been completed the number of times set to the DBCn register and when the DCHCn.Enn bit is cleared to 0 and TCn bit is set to 1, a DMA transfer end interrupt request signal (INTDMAn) is generated for the interrupt controller (INTC) (n = 0 to 3).

The V850ES/SG2 does not output a terminal count signal to an external device. Therefore, confirm completion of DMA transfer by using the DMA transfer end interrupt or polling the TCn bit.

# 20.12 Operation Timing

Figures 20-1 to 20-4 show DMA operation timing.

Read CPU processing Write DMA1 processing Read In the case of transfer between external memory spaces (multiplexed bus, no wait) Figure 20-1. Priority of DMA (1) CPU processing Write **Remarks 1.** Transfer in the order of DMA0  $\rightarrow$  DMA1  $\rightarrow$  DMA2 DMA0 processing Read CPU processing System clock DF1 bit DF2 bit DMA2 transfer request DF0 bit DMA0 transfer request DMA1 transfer request DMA transfer Mode of processing જં

838





Figure 20-3. Period in Which DMA Transfer Request Is Ignored (1)

Remark In the case of transfer between external memory spaces (multiplexed bus, no wait)



841

#### 20.13 Cautions

## (1) Caution for VSWC register

When using the DMAC, be sure to set an appropriate value, in accordance with the operating frequency, to the VSWC register.

When the default value (77H) of the VSWC register is used, or if an inappropriate value is set to the VSWC register, the operation is not correctly performed (for details of the VSWC register, see 3.4.9 (1) (a) System wait control register (VSWC)).

### (2) Caution for DMA transfer executed on internal RAM

When executing the following instructions located in the internal RAM, do not execute a DMA transfer that transfers data to/from the internal RAM (transfer source/destination), because the CPU may not operate correctly afterward.

- Bit manipulation instruction located in internal RAM (SET1, CLR1, or NOT1)
- Data access instruction to misaligned address located in internal RAM

Conversely, when executing a DMA transfer to transfer data to/from the internal RAM (transfer source/destination), do not execute the above two instructions.

#### (3) Caution for reading DCHCn.TCn bit (n = 0 to 3)

The TCn bit is cleared to 0 when it is read, but it is not automatically cleared even if it is read at a specific timing. To accurately clear the TCn bit, add the following processing.

## (a) When waiting for completion of DMA transfer by polling TCn bit

Confirm that the TCn bit has been set to 1 (after TCn bit = 1 is read), and then read the TCn bit three more times.

#### (b) When reading TCn bit in interrupt servicing routine

Execute reading the TCn bit three times.

#### (4) DMA transfer initialization procedure (setting DCHCn.INITn bit to 1)

Even if the INITn bit is set to 1 when the channel executing DMA transfer is to be initialized, the channel may not be initialized. To accurately initialize the channel, execute either of the following two procedures.

### (a) Temporarily stop transfer of all DMA channels

Initialize the channel executing DMA transfer using the procedure in <1> to <7> below.

Note, however, that TCn bit is cleared to 0 when step <5> is executed. Make sure that the other processing programs do not expect that the TCn bit is 1.

- <1> Disable interrupts (DI).
- <2> Read the DCHCn.Enn bit of DMA channels other than the one to be forcibly terminated, and transfer the value to a general-purpose register.
- <3> Clear the Enn bit of the DMA channels used (including the channel to be forcibly terminated) to 0. To clear the Enn bit of the last DMA channel, execute the clear instruction twice. If the target of DMA transfer (transfer source/destination) is the internal RAM, execute the instruction three times.

Example: Execute instructions in the following order if channels 0, 1, and 2 are used (if the target of transfer is not the internal RAM).

- Clear DCHC0.E00 bit to 0.
- Clear DCHC1.E11 bit to 0.
- Clear DCHC2.E22 bit to 0.
- Clear DCHC2.E22 bit to 0 again.
- <4> Set the INITn bit of the channel to be forcibly terminated to 1.
- <5> Read the TCn bit of each channel not to be forcibly terminated. If both the TCn bit and the Enn bit read in <2> are 1 (logical product (AND) is 1), clear the saved Enn bit to 0.
- <6> After the operation in <5>, write the Enn bit value to the DCHCn register.
- <7> Enable interrupts (EI).

Caution Be sure to execute step <5> above to prevent illegal setting of the Enn bit of the channels whose DMA transfer has been normally completed between <2> and <3>.

#### (b) Repeatedly execute setting INITn bit until transfer is forcibly terminated correctly

- <1> Suppress a request from the DMA request source of the channel to be forcibly terminated (stop operation of the on-chip peripheral I/O).
- <2> Check that the DMA transfer request of the channel to be forcibly terminated is not held pending, by using the DTFRn.DFn bit. If a DMA transfer request is held pending, wait until execution of the pending request is completed.
- <3> When it has been confirmed that the DMA request of the channel to be forcibly terminated is not held pending, clear the Enn bit to 0.
- <4> Again, clear the Enn bit of the channel to be forcibly terminated.
  If the target of transfer for the channel to be forcibly terminated (transfer source/destination) is the internal RAM, execute this operation once more.
- <5> Copy the initial number of transfers of the channel to be forcibly terminated to a general-purpose register.
- <6> Set the INITn bit of the channel to be forcibly terminated to 1.
- <7> Read the value of the DBCn register of the channel to be forcibly terminated, and compare it with the value copied in <5>. If the two values do not match, repeat operations <6> and <7>.
- **Remarks 1.** When the value of the DBCn register is read in <7>, the initial number of transfers is read if forced termination has been correctly completed. If not, the remaining number of transfers is read.
  - 2. Note that method (b) may take a long time if the application frequently uses DMA transfer for a channel other than the DMA channel to be forcibly terminated.

## (5) Procedure of temporarily stopping DMA transfer (clearing Enn bit)

Stop and resume the DMA transfer under execution using the following procedure.

- <1> Suppress a transfer request from the DMA request source (stop the operation of the on-chip peripheral I/O)
- <2> Check the DMA transfer request is not held pending, by using the DFn bit (check if the DFn bit = 0).
  If a request is pending, wait until execution of the pending DMA transfer request is completed.
- <3> If it has been confirmed that no DMA transfer request is held pending, clear the Enn bit to 0 (this operation stops DMA transfer).
- <4> Set the Enn bit to 1 to resume DMA transfer.
- <5> Resume the operation of the DMA request source that has been stopped (start the operation of the onchip peripheral I/O).

### (6) Memory boundary

The operation is not guaranteed if the address of the transfer source or destination exceeds the area of the DMA target (external memory, internal RAM, or on-chip peripheral I/O) during DMA transfer.

### (7) Transferring misaligned data

DMA transfer of misaligned data with a 16-bit bus width is not supported.

If an odd address is specified as the transfer source or destination, the least significant bit of the address is forcibly assumed to be 0.

### (8) Bus arbitration for CPU

Because the DMA controller has a higher priority bus mastership than the CPU, a CPU access that takes place during DMA transfer is held pending until the DMA transfer cycle is completed and the bus is released to the CPU.

However, the CPU can access the external memory, on-chip peripheral I/O, and internal RAM to/from which DMA transfer is not being executed.

- The CPU can access the internal RAM when DMA transfer is being executed between the external memory and on-chip peripheral I/O.
- The CPU can access the internal RAM and on-chip peripheral I/O when DMA transfer is being executed between the external memory and external memory.

#### (9) Registers/bits that must not be rewritten during DMA operation

Set the following registers at the following timing when a DMA operation is not under execution.

#### [Registers]

- DSAnH, DSAnL, DDAnH, DDAnL, DBCn, and DADCn registers
- DTFRn.IFCn5 to DTFRn.IFCn0 bits

## [Timing of setting]

- Period from after reset to start of the first DMA transfer
- Time after channel initialization to start of DMA transfer
- Period from after completion of DMA transfer (TCn bit = 1) to start of the next DMA transfer

## (10) Be sure to set the following register bits to 0.

- Bits 14 to 10 of DSAnH register
- Bits 14 to 10 of DDAnH register
- Bits 15, 13 to 8, and 3 to 0 of DADCn register
- . Bits 6 to 3 of DCHCn register

### (11) DMA start factor

Do not start two or more DMA channels with the same start factor. If two or more channels are started with the same factor, a DMA channel with a lower priority may be acknowledged earlier than a DMA channel with a higher priority.

### (12) Read values of DSAn and DDAn registers

Values in the middle of updating may be read from the DSAn and DDAn registers during DMA transfer (n = 0 to 3).

For example, if the DSAnH register and then the DSAnL register are read when the DMA transfer source address (DSAn register) is 0000FFFFH and the count direction is incremental (DADCn.SAD1 and DADCn.SAD0 bits = 00), the value of the DSAn register differs as follows, depending on whether DMA transfer is executed immediately after the DSAnH register is read.

## (a) If DMA transfer does not occur while DSAn register is read

<1> Read value of DSAnH register: DSAnH = 0000H <2> Read value of DSAnL register: DSAnL = FFFFH

### (b) If DMA transfer occurs while DSAn register is read

<1> Read value of DSAnH register: DSAnH = 0000H

<2> Occurrence of DMA transfer

<3> Incrementing DSAn register: DSAn = 00100000H
<4> Read value of DSAnL register: DSAnL = 0000H

## **CHAPTER 21 CRC FUNCTION**

### 21.1 Functions

- CRC operation circuit for detection of data block errors
- Generation of 16-bit CRC code using a CRC-CCITT (X<sup>16</sup> + X<sup>12</sup> + X<sup>5</sup> + 1) generation polynomial for blocks of data of any length in 8-bit units
- CRC code is set to the CRC data register each time 1-byte data is transferred to the CRCIN register, after the initial value is set to the CRCD register.

# 21.2 Configuration

The CRC function includes the following hardware.

Table 21-1. CRC Configuration

| Item              | Configuration                                       |
|-------------------|-----------------------------------------------------|
| Control registers | CRC input register (CRCIN) CRC data register (CRCD) |

Figure 21-1. Block Diagram of CRC Register



# 21.3 Registers

# (1) CRC input register (CRCIN)

The CRCIN register is an 8-bit register for setting data.

This register can be read or written in 8-bit units.

Reset input clears this register to 00H.



## (2) CRC data register (CRCD)

The CRCD register is a 16-bit register that stores the CRC-CCITT operation results.

This register can be read or written in 16-bit units.

Reset input clears this register to 0000H.

Caution Accessing the CRCD register is prohibited in the following statuses. For details, see 3.4.9 (2)

Accessing specific on-chip peripheral I/O registers.

- When the CPU operates with the subclock and the main clock oscillation is stopped
- When the CPU operates with the internal oscillation clock



## 21.4 Operation

An example of the CRC operation circuit is shown below.

Figure 21-2. CRC Operation Circuit Operation Example (LSB First)



The code when 01H is sent LSB first is (1000 0000). Therefore, the CRC code from generation polynomial  $X^{16} + X^{12} + X^5 + 1$  becomes the remainder when (1000 0000)  $X^{16}$  is divided by (1 0001 0000 0010 0001) using the modulo-2 operation formula.

The modulo-2 operation is performed based on the following formula.

$$0 + 0 = 0$$
  
 $0 + 1 = 1$   
 $1 + 0 = 1$   
 $1 + 1 = 0$   
 $-1 = 1$ 



Therefore, the CRC code becomes  $\frac{9}{1001}$   $\frac{8}{0001}$   $\frac{1}{1000}$  . Since LSB first is used, this corresponds to 1189H in hexadecimal notation.

# 21.5 Usage

How to use the CRC logic circuit is described below.

Figure 21-3. CRC Operation Flow



Communication errors can easily be detected if the CRC code is transmitted/received along with transmit/receive data when transmitting/receiving data consisting of several bytes.

The following is an illustration using the transmission of 12345678H (0001 0010 0011 0100 0101 0110 0111 1000B) LSB-first as an example.

Figure 21-4. CRC Transmission Example



#### Setting procedure on transmitting side

- <1> Write the initial value 0000H to the CRCD register.
- <2> Write the 1 byte of data to be transmitted first to the transmit buffer register. (At this time, also write the same data to the CRCIN register.)
- <3> When transmitting several bytes of data, write the same data to the CRCIN register each time transmit data is written to the transmit buffer register.
- <4> After all the data has been transmitted, write the contents of the CRCD register (CRC code) to the transmit buffer register and transmit them. (Since this is LSB first, transmit the data starting from the lower bytes, then the higher bytes.)

### Setting procedure on receiving side

- <1> Write the initial value 0000H to the CRCD register.
- <2> When reception of the first 1 byte of data is complete, write that receive data to the CRCIN register.
- <3> If receiving several bytes of data, write the receive data to the CRCIN register upon every reception completion. (In the case of normal reception, when all the receive data has been written to the CRCIN register, the contents of the CRCD register on the receiving side and the contents of the CRCD register on the transmitting side are the same.)
- <4> Next, the CRC code is transmitted from the transmitting side, so write this data to the CRCIN register similarly to receive data.
- <5> When reception of all the data, including the CRC code, has been completed, reception was normal if the contents of the CRCD register are 0000H. If the contents of the CRCD register are other than 0000H, this indicates a communication error, so transmit a resend request to the transmitting side.

### CHAPTER 22 INTERRUPT/EXCEPTION PROCESSING FUNCTION

The V850ES/SG2 is provided with a dedicated interrupt controller (INTC) for interrupt servicing and can process a total of 56 to 60 interrupt requests.

An interrupt is an event that occurs independently of program execution, and an exception is an event whose occurrence is dependent on program execution.

The V850ES/SG2 can process interrupt request signals from the on-chip peripheral hardware and external sources. Moreover, exception processing can be started by the TRAP instruction (software exception) or by generation of an exception event (i.e. fetching of an illegal opcode) (exception trap).

#### 22.1 Features

#### Interrupts

• Non-maskable interrupts: 2 sources

• Maskable interrupts: External: 8, Internal: 46/50 sources (see **Table 1-1**)

• 8 levels of programmable priorities (maskable interrupts)

· Multiple interrupt control according to priority

• Masks can be specified for each maskable interrupt request.

• Noise elimination, edge detection, and valid edge specification for external interrupt request signals.

### Exceptions

• Software exceptions: 32 sources

• Exception trap: 2 sources (illegal opcode exception)

Interrupt/exception sources are listed in Table 22-1.

Table 22-1. Interrupt Source List (1/4)

| Туре           | Classification | Default<br>Priority | Name                     | Trigger                                        | Generating<br>Unit | Exception<br>Code       | Handler<br>Address | Restored<br>PC | Interrupt<br>Control<br>Register |
|----------------|----------------|---------------------|--------------------------|------------------------------------------------|--------------------|-------------------------|--------------------|----------------|----------------------------------|
| Reset          | Interrupt      | -                   | RESET                    | RESET pin input Reset input by internal source | RESET              | 0000H                   | 00000000H          | Undefined      | _                                |
| Non-           | Interrupt      | -                   | NMI                      | NMI pin valid edge input                       | Pin                | 0010H                   | 0000010H           | nextPC         | -                                |
| maskable       |                | _                   | INTWDT2                  | WDT2 overflow                                  | WDT2               | 0020H                   | 00000020H          | Note 1         | _                                |
| Software       | Exception      | _                   | TRAP0n <sup>Note 2</sup> | TRAP instruction                               | -                  | 004nH <sup>Note 2</sup> | 00000040H          | nextPC         | -                                |
| exception      |                | -                   | TRAP1n <sup>Note 2</sup> | TRAP instruction                               | -                  | 005nH <sup>Note 2</sup> | 00000050H          | nextPC         | -                                |
| Exception trap | Exception      | -                   | ILGOP/<br>DBG0           | Illegal opcode/ DBTRAP instruction             | _                  | 0060H                   | 00000060H          | nextPC         | -                                |

Notes 1. For the restoring in the case of INTWDT2, see 22.2.2 (2) INTWDT2 signal.

**2.** n = 0 to FH

Table 22-1. Interrupt Source List (2/4)

| Type     | Classification | Default<br>Priority | Name      | Trigger                                             | Generating<br>Unit | Exception<br>Code | Handler<br>Address | Restored<br>PC | Interrupt<br>Control<br>Register |
|----------|----------------|---------------------|-----------|-----------------------------------------------------|--------------------|-------------------|--------------------|----------------|----------------------------------|
| Maskable | Interrupt      | 1                   | INTP0     | External interrupt pin input edge detection (INTP0) | Pin                | 0090H             | 00000090Н          | nextPC         | PIC0                             |
|          |                | 2                   | INTP1     | External interrupt pin input edge detection (INTP1) | Pin                | 00A0H             | 000000A0H          | nextPC         | PIC1                             |
|          |                | 3                   | INTP2     | External interrupt pin input edge detection (INTP2) | Pin                | 00B0H             | 000000B0H          | nextPC         | PIC2                             |
|          |                | 4                   | INTP3     | External interrupt pin input edge detection (INTP3) | Pin                | 00C0H             | 000000С0Н          | nextPC         | PIC3                             |
|          |                | 5                   | INTP4     | External interrupt pin input edge detection (INTP4) | Pin                | 00D0H             | 000000D0H          | nextPC         | PIC4                             |
|          |                | 6                   | INTP5     | External interrupt pin input edge detection (INTP5) | Pin                | 00E0H             | 000000E0H          | nextPC         | PIC5                             |
|          |                | 7                   | INTP6     | External interrupt pin input edge detection (INTP6) | Pin                | 00F0H             | 000000F0H          | nextPC         | PIC6                             |
|          |                | 8                   | INTP7     | External interrupt pin input edge detection (INTP7) | Pin                | 0100H             | 00000100H          | nextPC         | PIC7                             |
|          |                | 9                   | INTTQ00V  | TMQ0 overflow                                       | TMQ0               | 0110H             | 00000110H          | nextPC         | TQ00VIC                          |
|          |                | 10                  | INTTQ0CC0 | TMQ0 capture 0/<br>compare 0 match                  | TMQ0               | 0120H             | 00000120H          | nextPC         | TQ0CCIC                          |
|          |                | 11                  | INTTQ0CC1 | TMQ0 capture 1/<br>compare 1 match                  | TMQ0               | 0130H             | 00000130H          | nextPC         | TQ0CCIC                          |
|          |                | 12                  | INTTQ0CC2 | TMQ0 capture 2/<br>compare 2 match                  | TMQ0               | 0140H             | 00000140H          | nextPC         | TQ0CCIC:                         |
|          |                | 13                  | INTTQ0CC3 | TMQ0 capture 3/<br>compare 3 match                  | TMQ0               | 0150H             | 00000150H          | nextPC         | TQ0CCIC:                         |
|          |                | 14                  | INTTP0OV  | TMP0 overflow                                       | TMP0               | 0160H             | 00000160H          | nextPC         | TP00VIC                          |
|          |                | 15                  | INTTP0CC0 | TMP0 capture 0/<br>compare 0 match                  | TMP0               | 0170H             | 00000170H          | nextPC         | TP0CCIC                          |
|          |                | 16                  | INTTP0CC1 | TMP0 capture 1/<br>compare 1 match                  | TMP0               | 0180H             | 00000180H          | nextPC         | TP0CCIC                          |
|          |                | 17                  | INTTP1OV  | TMP1 overflow                                       | TMP1               | 0190H             | 00000190H          | nextPC         | TP10VIC                          |
|          |                | 18                  | INTTP1CC0 | TMP1 capture 0/<br>compare 0 match                  | TMP1               | 01A0H             | 000001A0H          | nextPC         | TP1CCIC                          |
|          |                | 19                  | INTTP1CC1 | TMP1 capture 1/<br>compare 1 match                  | TMP1               | 01B0H             | 000001B0H          | nextPC         | TP1CCIC*                         |
|          |                | 20                  | INTTP2OV  | TMP2 overflow                                       | TMP2               | 01C0H             | 000001C0H          | nextPC         | TP2OVIC                          |
|          |                | 21                  | INTTP2CC0 | TMP2 capture 0/<br>compare 0 match                  | TMP2               | 01D0H             | 000001D0H          | nextPC         | TP2CCIC(                         |
|          |                | 22                  | INTTP2CC1 | TMP2 capture 1/<br>compare 1 match                  | TMP2               | 01E0H             | 000001E0H          | nextPC         | TP2CCIC <sup>-</sup>             |
|          |                | 23                  | INTTP3OV  | TMP3 overflow                                       | TMP3               | 01F0H             | 000001F0H          | nextPC         | TP3OVIC                          |
|          |                | 24                  | INTTP3CC0 | TMP3 capture 0/<br>compare 0 match                  | ТМР3               | 0200H             | 00000200H          | nextPC         | TP3CCIC(                         |
|          |                | 25                  | INTTP3CC1 | TMP3 capture 1/ compare 1 match                     | ТМР3               | 0210H             | 00000210H          | nextPC         | TP3CCIC1                         |
|          |                | 26                  | INTTP4OV  | TMP4 overflow                                       | TMP4               | 0220H             | 00000220H          | nextPC         | TP4OVIC                          |

Table 22-1. Interrupt Source List (3/4)

| Туре     | Classification | Default<br>Priority | Name                | Trigger                                                                                      | Generating<br>Unit | Exception<br>Code | Handler<br>Address | Restored<br>PC | Interrupt<br>Control<br>Register |
|----------|----------------|---------------------|---------------------|----------------------------------------------------------------------------------------------|--------------------|-------------------|--------------------|----------------|----------------------------------|
| Maskable | Interrupt      | 27                  | INTTP4CC0           | TMP4 capture 0/<br>compare 0 match                                                           | TMP4               | 0230H             | 00000230H          | nextPC         | TP4CCIC0                         |
|          |                | 28                  | INTTP4CC1           | TMP4 capture 1/<br>compare 1 match                                                           | TMP4               | 0240H             | 00000240H          | nextPC         | TP4CCIC1                         |
|          |                | 29                  | INTTP5OV            | TMP5 overflow                                                                                | TMP5               | 0250H             | 00000250H          | nextPC         | TP50VIC                          |
|          |                | 30                  | INTTP5CC0           | TMP5 capture 0/<br>compare 0 match                                                           | TMP5               | 0260H             | 00000260H          | nextPC         | TP5CCIC0                         |
|          |                | 31                  | INTTP5CC1           | TMP5 capture 1/<br>compare 1 match                                                           | TMP5               | 0270H             | 00000270H          | nextPC         | TP5CCIC1                         |
|          |                | 32                  | INTTM0EQ0           | TMM0 compare match                                                                           | ТММО               | 0280H             | 00000280H          | nextPC         | TM0EQIC0                         |
|          |                | 33                  | INTCB0R/<br>INTIIC1 | CSIB0 reception completion/<br>CSIB0 reception error/<br>IIC1 transfer completion            | CSIB0/<br>IIC1     | 0290H             | 00000290H          | nextPC         | CB0RIC/<br>IICIC1                |
|          |                | 34                  | INTCB0T             | CSIB0 consecutive transmission write enable                                                  | CSIB0              | 02A0H             | 000002A0H          | nextPC         | CB0TIC                           |
|          |                | 35                  | INTCB1R             | CSIB1 reception completion/<br>CSIB1 reception error                                         | CSIB1              | 02B0H             | 000002B0H          | nextPC         | CB1RIC                           |
|          |                | 36                  | INTCB1T             | CSIB1 consecutive transmission write enable                                                  | CSIB1              | 02C0H             | 000002C0H          | nextPC         | CB1TIC                           |
|          |                | 37                  | INTCB2R             | CSIB2 reception completion/<br>CSIB2 reception error                                         | CSIB2              | 02D0H             | 000002D0H          | nextPC         | CB2RIC                           |
|          |                | 38                  | INTCB2T             | CSIB2 consecutive transmission write enable                                                  | CSIB2              | 02E0H             | 000002E0H          | nextPC         | CB2TIC                           |
|          |                | 39                  | INTCB3R             | CSIB3 reception completion/<br>CSIB3 reception error                                         | CSIB3              | 02F0H             | 000002F0H          | nextPC         | CB3RIC                           |
|          |                | 40                  | INTCB3T             | CSIB3 consecutive transmission write enable                                                  | CSIB3              | 0300H             | 00000300H          | nextPC         | CB3TIC                           |
|          |                | 41                  | INTUAOR/<br>INTCB4R | UARTA0 reception completion/ CSIB4 reception completion/ CSIB4 reception error               | UARTA0/<br>CSIB4   | 0310H             | 00000310H          | nextPC         | UA0RIC/C<br>B4RIC                |
|          |                | 42                  | INTUA0T/<br>INTCB4T | UARTA0 consecutive<br>transmission enable/<br>CSIB4 consecutive<br>transmission write enable | UARTA0/<br>CSIB4   | 0320H             | 00000320H          | nextPC         | UA0TIC/<br>CB4TIC                |
|          |                | 43                  | INTUA1R/<br>INTIIC2 | UARTA1 reception<br>completion/<br>UARTA1 reception error/<br>IIC2 transfer completion       | UARTA1/<br>IIC2    | 0330H             | 00000330H          | nextPC         | UA1RIC/<br>IICIC2                |
|          |                | 44                  | INTUA1T             | UARTA1 consecutive transmission enable                                                       | UARTA1             | 0340H             | 00000340H          | nextPC         | UA1TIC                           |
|          |                | 45                  | INTUA2R/<br>INTIIC0 | UARTA2 reception<br>completion/<br>IIC0 transfer completion                                  | UARTA/<br>IIC0     | 0350H             | 00000350H          | nextPC         | UA2RIC/<br>IICIC0                |
|          |                | 46                  | INTUA2T             | UARTA2 consecutive transmission enable                                                       | UARTA2             | 0360H             | 00000360H          | nextPC         | UA2TIC                           |

Table 22-1. Interrupt Source List (4/4)

| Туре     | Classification | Default<br>Priority | Name                                                  | Trigger                                          | Generating<br>Unit | Exception<br>Code | Handler<br>Address | Restored<br>PC | Interrupt<br>Control<br>Register |
|----------|----------------|---------------------|-------------------------------------------------------|--------------------------------------------------|--------------------|-------------------|--------------------|----------------|----------------------------------|
| Maskable | Interrupt      | 47                  | INTAD                                                 | A/D conversion completion                        | A/D                | 0370H             | 00000370H          | nextPC         | ADIC                             |
|          |                | 48                  | INTDMA0                                               | DMA0 transfer completion                         | DMA                | 0380H             | 00000380H          | nextPC         | DMAIC0                           |
|          |                | 49                  | INTDMA1                                               | DMA1 transfer completion                         | DMA                | 0390H             | 00000390H          | nextPC         | DMAIC1                           |
|          |                | 50                  | INTDMA2                                               | DMA2 transfer completion                         | DMA                | 03A0H             | 000003A0H          | nextPC         | DMAIC2                           |
|          |                | 51                  | INTDMA3                                               | DMA3 transfer completion                         | DMA                | 03B0H             | 000003B0H          | nextPC         | DMAIC3                           |
|          |                | 52                  | INTKR                                                 | Key return interrupt                             | KR                 | 03C0H             | 000003C0H          | nextPC         | KRIC                             |
|          |                | 53                  | INTWTI                                                | Watch timer interval                             | WT                 | 03D0H             | 000003D0H          | nextPC         | WTIIC                            |
|          |                | 54                  | INTWT                                                 | Watch timer reference time                       | WT                 | 03E0H             | 000003E0H          | nextPC         | WTIC                             |
|          |                | 55                  | INTC0ERR <sup>Note 1</sup> / INTERR <sup>Note 2</sup> | AFCAN0 error/IEBus error                         | AFCAN0/<br>IEBus   | 03F0H             | 000003F0H          | nextPC         | ERRICO/<br>ERRIC                 |
|          |                | 56                  | INTCOWUP <sup>Note 1</sup> / INTSTA <sup>Note 2</sup> | AFCAN0 wakeup/<br>IEBus status                   | AFCAN0/<br>IEBus   | 0400H             | 00000400H          | nextPC         | WUPIC0/<br>STSAIC                |
|          |                | 57                  | INTCOREC <sup>Note 1</sup> / INTIE1 <sup>Note 2</sup> | AFCAN0 reception/ IEBus data interrupt           | AFCAN0/<br>IEBus   | 0410H             | 00000410H          | nextPC         | RECICO/<br>IEIC1                 |
|          |                | 58                  | INTCOTRX <sup>Note 1</sup> / INTIE2 <sup>Note 2</sup> | AFCAN0 transmission/<br>IEBus error/IEBus status | AFCAN0/<br>IEBus   | 0420H             | 00000420H          | nextPC         | TRXIC0/<br>IEIC2                 |

# Notes 1. CAN controller version only

2. IEBus controller version only

**Remarks 1.** Default Priority: The priority order when two or more maskable interrupt requests occur at the same time. The highest priority is 1.

The priority order of non-maskable interrupt is INTWDT2 > NMI.

Restored PC:

The value of the program counter (PC) saved to EIPC, FEPC, or DBPC when interrupt servicing is started. Note, however, that the restored PC when a non-maskable or maskable interrupt is acknowledged while one of the following instructions is being executed does not become the nextPC (if an interrupt is acknowledged during interrupt execution, execution stops, and then resumes after the interrupt servicing has finished).

- Load instructions (SLD.B, SLD.BU, SLD.H, SLD.HU, SLD.W)
- Division instructions (DIV, DIVH, DIVU, DIVHU)
- PREPARE, DISPOSE instructions (only if an interrupt is generated before the stack pointer is updated)

nextPC: The PC value that starts the processing following interrupt/exception processing.

2. The execution address of the illegal instruction when an illegal opcode exception occurs is calculated by (Restored PC – 4).

#### 22.2 Non-Maskable Interrupts

A non-maskable interrupt request signal is acknowledged unconditionally, even when interrupts are in the interrupt disabled (DI) status. An NMI is not subject to priority control and takes precedence over all the other interrupt request signals.

This product has the following two non-maskable interrupt request signals.

- NMI pin input (NMI)
- Non-maskable interrupt request signal generated by overflow of watchdog timer (INTWDT2)

The valid edge of the NMI pin can be selected from four types: "rising edge", "falling edge", "both edges", and "no edge detection".

The non-maskable interrupt request signal generated by overflow of the watchdog timer 2 (INTWDT2) functions when the WDTM2.WDM21 and WDTM2.WDM20 bits are set to "01".

If two or more non-maskable interrupt request signals occur at the same time, the interrupt with the higher priority is serviced, as follows (the interrupt request signal with the lower priority is ignored).

INTWDT2 > NMI

If a new NMI or INTWDT2 request signal is issued while a NMI is being serviced, it is serviced as follows.

#### (1) If new NMI request signal is issued while NMI is being serviced

The new NMI request signal is held pending, regardless of the value of the PSW.NP bit. The pending NMI request signal is acknowledged after the NMI currently under execution has been serviced (after the RETI instruction has been executed).

### (2) If INTWDT2 request signal is issued while NMI is being serviced

The INTWDT2 request signal is held pending if the NP bit remains set (1) while the NMI is being serviced. The pending INTWDT2 request signal is acknowledged after the NMI currently under execution has been serviced (after the RETI instruction has been executed).

If the NP bit is cleared (0) while the NMI is being serviced, the newly generated INTWDT2 request signal is executed (the NMI servicing is stopped).

Caution For the non-maskable interrupt servicing executed by the non-maskable interrupt request signal (INTWDT2), see 22.2.2 (2) INTWDT2 signal.

Figure 22-1. Non-Maskable Interrupt Request Signal Acknowledgment Operation (1/2)



(b) Non-maskable interrupt request signal generated during non-maskable interrupt servicing Non-maskable Non-maskable interrupt request signal generated during non-maskable interrupt servicing interrupt being serviced NMI INTWDT2 NMI NMI request generated during NMI servicing INTWDT2 request generated during NMI servicing (NP bit = 1 retained before INTWDT2 request) Main routine NMI servicing Main routine NMI servicing NMI request (Held pending) NMI → ÍNTWDT2→ request (Held pending) Servicing of NMI request pending NMI request [ INTWDT2 servicing System reset • INTWDT2 request generated during NMI servicing (NP bit = 0 set before INTWDT2 request) Main routine NMI INTWDT2 servicing servicing  $\hat{N}P = 0$ NMI -INTWDT2 → request request System reset INTWDT2 request generated during NMI servicing (NP = 0 set after INTWDT2 request) Main routine NMI INTWDT2 servicing servicing INTWDT2→ (Held pending) request NMI → I NP = 0 → request System reset INTWDT2 • NMI request generated during INTWDT2 servicing • INTWDT2 request generated during INTWDT2 servicing Main routine Main routine INTWDT2 servicing INTWDT2 servicing (Invalid) IŃTWDT2 → (Invalid) request INTWDT2 request → INTWDT2 request → request System reset System reset

Figure 22-1. Non-Maskable Interrupt Request Signal Acknowledgment Operation (2/2)

### 22.2.1 Operation

If a non-maskable interrupt request signal is generated, the CPU performs the following processing, and transfers control to the handler routine.

- <1> Saves the restored PC to FEPC.
- <2> Saves the current PSW to FEPSW.
- <3> Writes exception code (0010H, 0020H) to the higher halfword (FECC) of ECR.
- <4> Sets the PSW.NP and PSW.ID bits to 1 and clears the PSW.EP bit to 0.
- <5> Sets the handler address (00000010H, 00000020H) corresponding to the non-maskable interrupt to the PC, and transfers control.

The servicing configuration of a non-maskable interrupt is shown in Figure 22-2.



Figure 22-2. Servicing Configuration of Non-Maskable Interrupt

### 22.2.2 Restore

# (1) From NMI pin input

Execution is restored from the NMI servicing by the RETI instruction.

When the RETI instruction is executed, the CPU performs the following processing, and transfers control to the address of the restored PC.

- <1> Loads the restored PC and PSW from FEPC and FEPSW, respectively, because the PSW.EP bit is 0 and the PSW.NP bit is 1.
- <2> Transfers control back to the address of the restored PC and PSW.

Figure 22-3 illustrates how the RETI instruction is processed.

PSW.EP

0

PSW.NP

1

PC ← EIPC
PSW ← EIPSW

PC ← FEPC
PSW ← FEPSW

Figure 22-3. RETI Instruction Processing

Caution When the EP and NP bits are changed by the LDSR instruction during non-maskable interrupt servicing, in order to restore the PC and PSW correctly during recovery by the RETI instruction, it is necessary to set the EP bit back to 0 and the NP bit back to 1 using the LDSR instruction immediately before the RETI instruction.

**Remark** The solid line shows the CPU processing flow.

Original processing restored

### (2) From INTWDT2 signal

Restoring from non-maskable interrupt servicing executed by the non-maskable interrupt request (INTWDT2) by using the RETI instruction is disabled. Execute the following software reset processing.

INTWDT2 occurs.

FEPC ← Software reset processing address
FEPSW ← Value that sets NP bit = 1, EP bit = 0

RETI

RETI

RETI 10 times (FEPC and FEPSW<sup>Note</sup> must be set.)

↓
PSW ← PSW default value setting
↓
Initialization processing

Note FEPSW ← Value that sets NP bit = 1, EP bit = 0

Figure 22-4. Software Reset Processing

# 22.2.3 NP flag

The NP flag is a status flag that indicates that non-maskable interrupt servicing is under execution.

This flag is set when a non-maskable interrupt request signal has been acknowledged, and masks non-maskable interrupt requests to prohibit multiple interrupts from being acknowledged.



### 22.3 Maskable Interrupts

Maskable interrupt request signals can be masked by interrupt control registers. The V850ES/SG2 has 54 to 58 maskable interrupt sources.

If two or more maskable interrupt request signals are generated at the same time, they are acknowledged according to the default priority. In addition to the default priority, eight levels of priorities can be specified by using the interrupt control registers (programmable priority control).

When an interrupt request signal has been acknowledged, the acknowledgment of other maskable interrupt request signals is disabled and the interrupt disabled (DI) status is set.

When the EI instruction is executed in an interrupt service routine, the interrupt enabled (EI) status is set, which enables servicing of interrupts having a higher priority than the interrupt request signal in progress (specified by the interrupt control register). Note that only interrupts with a higher priority will have this capability; interrupts with the same priority level cannot be nested.

To enable multiple interrupts, however, save EIPC and EIPSW to memory or general-purpose registers before executing the EI instruction, and execute the DI instruction before the RETI instruction to restore the original values of EIPC and EIPSW.

#### 22.3.1 Operation

If a maskable interrupt occurs, the CPU performs the following processing, and transfers control to a handler routine.

- <1> Saves the restored PC to EIPC.
- <2> Saves the current PSW to EIPSW.
- <3> Writes an exception code to the lower halfword of ECR (EICC).
- <4> Sets the PSW. ID bit to 1 and clears the PSW. EP bit to 0.
- <5> Sets the handler address corresponding to each interrupt to the PC, and transfers control.

The maskable interrupt request signal masked by INTC and the maskable interrupt request signal generated while another interrupt is being serviced (while the PSW.NP bit = 1 or the PSW.ID bit = 1) are held pending inside INTC. In this case, servicing a new maskable interrupt is started in accordance with the priority of the pending maskable interrupt request signal if either the maskable interrupt is unmasked or the NP and ID bits are cleared to 0 by using the RETI or LDSR instruction.

How maskable interrupts are serviced is illustrated below.



Figure 22-5. Maskable Interrupt Servicing

# 22.3.2 Restore

Recovery from maskable interrupt servicing is carried out by the RETI instruction.

When the RETI instruction is executed, the CPU performs the following steps, and transfers control to the address of the restored PC.

- <1> Loads the restored PC and PSW from EIPC and EIPSW because the PSW.EP bit is 0 and the PSW.NP bit is 0.
- <2> Transfers control to the address of the restored PC and PSW.

Figure 22-6 illustrates the processing of the RETI instruction.

RETI instruction

1
PSW.EP

0
PSW.NP
1
PC + EIPC
PSW + EIPSW
Corresponding + 0
bit of ISPRNote

Restores original processing

Figure 22-6. RETI Instruction Processing

Note For the ISPR register, see 22.3.6 In-service priority register (ISPR).

Caution When the EP and NP bits are changed by the LDSR instruction during maskable interrupt servicing, in order to restore the PC and PSW correctly during recovery by the RETI instruction, it is necessary to set the EP bit back to 0 and the NP bit back to 0 using the LDSR instruction immediately before the RETI instruction.

**Remark** The solid line shows the CPU processing flow.

# 22.3.3 Priorities of maskable interrupts

The INTC performs multiple interrupt servicing in which an interrupt is acknowledged while another interrupt is being serviced. Multiple interrupts can be controlled by priority levels.

There are two types of priority level control: control based on the default priority levels, and control based on the programmable priority levels that are specified by the interrupt priority level specification bit (xxPRn) of the interrupt control register (xxlCn). When two or more interrupts having the same priority level specified by the xxPRn bit are generated at the same time, interrupt request signals are serviced in order depending on the priority level allocated to each interrupt request type (default priority level) beforehand. For more information, see **Table 22-1 Interrupt/Exception Source List**. The programmable priority control customizes interrupt request signals into eight levels by setting the priority level specification flag.

Note that when an interrupt request signal is acknowledged, the PSW.ID flag is automatically set to 1. Therefore, when multiple interrupts are to be used, clear the ID flag to 0 beforehand (for example, by placing the EI instruction in the interrupt service program) to set the interrupt enable mode.

Remark xx: Identification name of each peripheral unit (see Table 22-2 Interrupt Control Register (xxICn))

n: Peripheral unit number (see Table 22-2 Interrupt Control Register (xxlCn)).

Main routine Servicing of a Servicing of b ĖΙ ΕI Interrupt Interrupt request a request b (level 3) Interrupt request b is acknowledged because the (level 2) priority of b is higher than that of a and interrupts are enabled. Servicing of c Interrupt request c Interrupt request d Although the priority of interrupt request d is higher (level 3) (level 2)than that of c, d is held pending because interrupts are disabled. Servicing of d Servicing of e ΕI Interrupt request e Interrupt request f Interrupt request f is held pending even if interrupts are (level 2) (level 3) enabled because its priority is lower than that of e. Servicing of f Servicing of g Interrupt request h Interrupt request g (level 1) Interrupt request h is held pending even if interrupts are (level 1) enabled because its priority is the same as that of g. Servicing of h

Figure 22-7. Example of Processing in Which Another Interrupt Request Signal Is Issued
While an Interrupt Is Being Serviced (1/2)

Caution To perform multiple interrupt servicing, the values of the EIPC and EIPSW registers must be saved before executing the EI instruction. When returning from multiple interrupt servicing, restore the values of EIPC and EIPSW after executing the DI instruction.

**Remarks 1.** a to u in the figure are the temporary names of interrupt request signals shown for the sake of explanation.

2. The default priority in the figure indicates the relative priority between two interrupt request signals.

Main routine Servicing of i ĖΙ Servicing of k Ínterrupt Interrupt request i request (level 3) (level 2) Interrupt request j is held pending because its Interrupt request k priority is lower than that of i. (level 1) k that occurs after j is acknowledged because it has the higher priority. Servicing of j Servicing of I Interrupt requests m and n are held pending Interrupt because servicing of I is performed in the interrupt request m (level 3) → disabled status. Interrupt request I Interrupt request n (level 2) (level 1) → Pending interrupt requests are acknowledged after Servicing of n servicing of interrupt request I. At this time, interrupt request n is acknowledged first even though m has occurred first because the priority of n is higher than that of m. Servicing of m Servicing of o Servicing of p FI Servicing of q Interrupt request o ĖΙ Interrupt Servicing of r Interrupt (level 3) request p request q Interrupt (level 2) (level 1) request r (level 0) If levels 3 to 0 are acknowledged Servicing of s Pending interrupt requests t and u are acknowledged after servicing of s. Because the priorities of t and u are the same, u is Interrupt request t acknowledged first because it has the higher (level 2)default priority, regardless of the order in which the Interrupt request s Interrupt request u (level 1) interrupt requests have been generated. (level 2)-Servicing of u Servicing of t Notes 1. Lower default priority 2. Higher default priority Caution To perform multiple interrupt servicing, the values of the EIPC and EIPSW registers must be saved before executing the El instruction. When returning from multiple interrupt servicing, restore the values of EIPC and EIPSW after executing the DI instruction.

Figure 22-7. Example of Processing in Which Another Interrupt Request Signal Is Issued
While an Interrupt Is Being Serviced (2/2)

Figure 22-8. Example of Servicing Interrupt Request Signals Simultaneously Generated



Caution To perform multiple interrupt servicing, the values of the EIPC and EIPSW registers must be saved before executing the EI instruction. When returning from multiple interrupt servicing, restore the values of EIPC and EIPSW after executing the DI instruction.

**Remarks 1.** a to c in the figure are the temporary names of interrupt request signals shown for the sake of explanation.

**2.** The default priority in the figure indicates the relative priority between two interrupt request signals.

# 22.3.4 Interrupt control register (xxlCn)

The xxlCn register is assigned to each interrupt request signal (maskable interrupt) and sets the control conditions for each maskable interrupt request.

This register can be read or written in 8-bit or 1-bit units.

Reset input sets this register to 47H.

Caution Disable interrupts (DI) or mask the interrupt to read the xxICn.xxIFn bit. If the xxIFn bit is read while interrupts are enabled (EI) or while the interrupt is unmasked, the correct value may not be read when acknowledging an interrupt and reading the bit conflict.

After reset: 47H R/W Address: FFFFF112H to FFFFF184H <6> 5 0 <7> 0 0 0 xxPRn1 xxICn xxIFn xxMKnxxPRn2 xxPRn0

| xxIFn | Interrupt request flag <sup>Note</sup> |  |  |  |
|-------|----------------------------------------|--|--|--|
| 0     | terrupt request not issued             |  |  |  |
| 1     | nterrupt request issued                |  |  |  |

| xxMKn | Interrupt mask flag                    |  |  |  |  |
|-------|----------------------------------------|--|--|--|--|
| 0     | Interrupt servicing enabled            |  |  |  |  |
| 1     | Interrupt servicing disabled (pending) |  |  |  |  |

| xxPRn2 | xxPRn1 | xxPRn0 | Interrupt priority specification bit |
|--------|--------|--------|--------------------------------------|
| 0      | 0      | 0      | Specifies level 0 (highest).         |
| 0      | 0      | 1      | Specifies level 1.                   |
| 0      | 1      | 0      | Specifies level 2.                   |
| 0      | 1      | 1      | Specifies level 3.                   |
| 1      | 0      | 0      | Specifies level 4.                   |
| 1      | 0      | 1      | Specifies level 5.                   |
| 1      | 1      | 0      | Specifies level 6.                   |
| 1      | 1      | 1      | Specifies level 7 (lowest).          |

Note The flag xxIFn is reset automatically by the hardware if an interrupt request signal is acknowledged.

Remark xx: Identification name of each peripheral unit (see Table 22-2 Interrupt Control Register (xxICn))

n: Peripheral unit number (see Table 22-2 Interrupt Control Register (xxICn)).

The addresses and bits of the interrupt control registers are as follows.

Table 22-2. Interrupt Control Register (xxICn) (1/2)

| Address   | Register          | Bit               |                   |   |   |   |                     |                     |                     |
|-----------|-------------------|-------------------|-------------------|---|---|---|---------------------|---------------------|---------------------|
|           |                   | <7>               | <6>               | 5 | 4 | 3 | 2                   | 1                   | 0                   |
| FFFFF112H | PIC0              | PIF0              | PMK0              | 0 | 0 | 0 | PPR02               | PPR01               | PPR00               |
| FFFFF114H | PIC1              | PIF1              | PMK1              | 0 | 0 | 0 | PPR12               | PPR11               | PPR10               |
| FFFFF116H | PIC2              | PIF2              | PMK2              | 0 | 0 | 0 | PPR22               | PPR21               | PPR20               |
| FFFFF118H | PIC3              | PIF3              | PMK3              | 0 | 0 | 0 | PPR32               | PPR31               | PPR30               |
| FFFFF11AH | PIC4              | PIF4              | PMK4              | 0 | 0 | 0 | PPR42               | PPR41               | PPR40               |
| FFFFF11CH | PIC5              | PIF5              | PMK5              | 0 | 0 | 0 | PPR52               | PPR51               | PPR50               |
| FFFFF11EH | PIC6              | PIF6              | PMK6              | 0 | 0 | 0 | PPR62               | PPR61               | PPR60               |
| FFFFF120H | PIC7              | PIF7              | PMK7              | 0 | 0 | 0 | PPR72               | PPR71               | PPR70               |
| FFFFF122H | TQ0OVIC           | TQ00VIF           | TQ0OVMK           | 0 | 0 | 0 | TQ0OVPR2            | TQ0OVPR1            | TQ0OVPR0            |
| FFFFF124H | TQ0CCIC0          | TQ0CCIF0          | TQ0CCMK0          | 0 | 0 | 0 | TQ0CCPR02           | TQ0CCPR01           | TQ0CCPR00           |
| FFFFF126H | TQ0CCIC1          | TQ0CCIF1          | TQ0CCMK1          | 0 | 0 | 0 | TQ0CCPR12           | TQ0CCPR11           | TQ0CCPR10           |
| FFFFF128H | TQ0CCIC2          | TQ0CCIF2          | TQ0CCMK2          | 0 | 0 | 0 | TQ0CCPR22           | TQ0CCPR21           | TQ0CCPR20           |
| FFFFF12AH | TQ0CCIC3          | TQ0CCIF3          | TQ0CCMK3          | 0 | 0 | 0 | TQ0CCPR32           | TQ0CCPR31           | TQ0CCPR30           |
| FFFFF12CH | TP0OVIC           | TP00VIF           | TP0OVMK           | 0 | 0 | 0 | TP0OVPR2            | TP0OVPR1            | TP0OVPR0            |
| FFFFF12EH | TP0CCIC0          | TP0CCIF0          | TP0CCMK0          | 0 | 0 | 0 | TP0CCPR02           | TP0CCPR01           | TP0CCPR00           |
| FFFFF130H | TP0CCIC1          | TP0CCIF1          | TP0CCMK1          | 0 | 0 | 0 | TP0CCPR12           | TP0CCPR11           | TP0CCPR10           |
| FFFFF132H | TP10VIC           | TP10VIF           | TP10VMK           | 0 | 0 | 0 | TP1OVPR2            | TP10VPR1            | TP1OVPR0            |
| FFFFF134H | TP1CCIC0          | TP1CCIF0          | TP1CCMK0          | 0 | 0 | 0 | TP1CCPR02           | TP1CCPR01           | TP1CCPR00           |
| FFFFF136H | TP1CCIC1          | TP1CCIF1          | TP1CCMK1          | 0 | 0 | 0 | TP1CCPR12           | TP1CCPR11           | TP1CCPR10           |
| FFFFF138H | TP2OVIC           | TP2OVIF           | TP2OVMK           | 0 | 0 | 0 | TP2OVPR2            | TP2OVPR1            | TP2OVPR0            |
| FFFFF13AH | TP2CCIC0          | TP2CCIF0          | TP2CCMK0          | 0 | 0 | 0 | TP2CCPR02           | TP2CCPR01           | TP2CCPR00           |
| FFFFF13CH | TP2CCIC1          | TP2CCIF1          | TP2CCMK1          | 0 | 0 | 0 | TP2CCPR12           | TP2CCPR11           | TP2CCPR10           |
| FFFFF13EH | TP3OVIC           | TP3OVIF           | TP3OVMK           | 0 | 0 | 0 | TP3OVPR2            | TP3OVPR1            | TP3OVPR0            |
| FFFFF140H | TP3CCIC0          | TP3CCIF0          | TP3CCMK0          | 0 | 0 | 0 | TP3CCPR02           | TP3CCPR01           | TP3CCPR00           |
| FFFFF142H | TP3CCIC1          | TP3CCIF1          | TP3CCMK1          | 0 | 0 | 0 | TP3CCPR12           | TP3CCPR11           | TP3CCPR10           |
| FFFFF144H | TP4OVIC           | TP4OVIF           | TP4OVMK           | 0 | 0 | 0 | TP4OVPR2            | TP40VPR1            | TP4OVPR0            |
| FFFFF146H | TP4CCIC0          | TP4CCIF0          | TP4CCMK0          | 0 | 0 | 0 | TP4CCPR02           | TP4CCPR01           | TP4CCPR00           |
| FFFFF148H | TP4CCIC1          | TP4CCIF1          | TP4CCMK1          | 0 | 0 | 0 | TP4CCPR12           | TP4CCPR11           | TP4CCPR10           |
| FFFFF14AH | TP5OVIC           | TP50VIF           | TP5OVMK           | 0 | 0 | 0 | TP5OVPR2            | TP50VPR1            | TP5OVPR0            |
| FFFFF14CH | TP5CCIC0          | TP5CCIF0          | TP5CCMK0          | 0 | 0 | 0 | TP5CCPR02           | TP5CCPR01           | TP5CCPR00           |
| FFFFF14EH | TP5CCIC1          | TP5CCIF1          | TP5CCMK1          | 0 | 0 | 0 | TP5CCPR12           | TP5CCPR11           | TP5CCPR10           |
| FFFFF150H | TM0EQIC0          | TM0EQIF0          | TM0EQMK0          | 0 | 0 | 0 | TM0EQPR02           | TM0EQPR01           | TM0EQPR00           |
| FFFFF152H | CB0RIC/           | CB0RIF/           | CB0RMK/           | 0 | 0 | 0 | CB0RPR2/            | CB0RPR1/            | CB0RPR0/            |
|           | IICIC1            | IICIF1            | IICMK1            |   |   |   | IICPR12             | IICPR11             | IICPR10             |
| FFFFF154H | CB0TIC            | CB0TIF            | CB0TMK            | 0 | 0 | 0 | CB0TPR2             | CB0TPR1             | CB0TPR0             |
| FFFFF156H | CB1RIC            | CB1RIF            | CB1RMK            | 0 | 0 | 0 | CB1RPR2             | CB1RPR1             | CB1RPR0             |
| FFFFF158H | CB1TIC            | CB1TIF            | CB1TMK            | 0 | 0 | 0 | CB1TPR2             | CB1TPR1             | CB1TPR0             |
| FFFFF15AH | CB2RIC            | CB2RIF            | CB2RMK            | 0 | 0 | 0 | CB2RPR2             | CB2RPR1             | CB2RPR0             |
| FFFFF15CH | CB2TIC            | CB2TIF            | CB2TMK            | 0 | 0 | 0 | CB2TPR2             | CB2TPR1             | CB2TPR0             |
| FFFFF15EH | CB3RIC            | CB3RIF            | CB3RMK            | 0 | 0 | 0 | CB3RPR2             | CB3RPR1             | CB3RPR0             |
| FFFFF160H | CB3TIC            | CB3TIF            | СВЗТМК            | 0 | 0 | 0 | CB3TPR2             | CB3TPR1             | CB3TPR0             |
| FFFFF162H | UA0RIC/<br>CB4RIC | UA0RIF/<br>CB4RIF | UA0RMK/<br>CB4RMK | 0 | 0 | 0 | UA0RPR2/<br>CB4RPR2 | UA0RPR1/<br>CB4RPR1 | UA0RPR0/<br>CB4RPR0 |

Table 22-2. Interrupt Control Register (xxICn) (2/2)

| Address   | Register                                              | Bit               |                   |   |   |   |                     |                     |                     |
|-----------|-------------------------------------------------------|-------------------|-------------------|---|---|---|---------------------|---------------------|---------------------|
|           |                                                       | <7>               | <6>               | 5 | 4 | 3 | 2                   | 1                   | 0                   |
| FFFFF164H | UA0TIC/<br>CB4TIC                                     | UA0TIF/<br>CB4TIF | UA0TMK/<br>CB4TMK | 0 | 0 | 0 | UA0TPR2/<br>CB4TPR2 | UA0TPR1/<br>CB4TPR1 | UA0TPR0/<br>CB4TPR0 |
| FFFFF166H | UA1RIC/<br>IICIC2                                     | UA1RIF/<br>IICIF2 | UA1RMK/<br>IICMK2 | 0 | 0 | 0 | UA1RPR2/<br>IICPR22 | UA1RPR1/<br>IICPR21 | UA1RPR0/<br>IICPR20 |
| FFFFF168H | UA1TIC                                                | UA1TIF            | UA1TMK            | 0 | 0 | 0 | UA1TPR2             | UA1TPR1             | UA1TPR0             |
| FFFFF16AH | UA2RIC/<br>IICIC0                                     | UA2RIF/<br>IICIF0 | UA2RMK/<br>IICMK0 | 0 | 0 | 0 | UA2RPR2/<br>IICPR02 | UA2RPR1/<br>IICPR01 | UA2RPR0/<br>IICPR00 |
| FFFFF16CH | UA2TIC                                                | UA2TIF            | UA2TMK            | 0 | 0 | 0 | UA2TPR2             | UA2TPR1             | UA2TPR0             |
| FFFFF16EH | ADIC                                                  | ADIF              | ADMK              | 0 | 0 | 0 | ADPR2               | ADPR1               | ADPR0               |
| FFFFF170H | DMAIC0                                                | DMAIF0            | DMAMK0            | 0 | 0 | 0 | DMAPR02             | DMAPR01             | DMAPR00             |
| FFFFF172H | DMAIC1                                                | DMAIF1            | DMAMK1            | 0 | 0 | 0 | DMAPR12             | DMAPR11             | DMAPR10             |
| FFFFF174H | DMAIC2                                                | DMAIF2            | DMAMK2            | 0 | 0 | 0 | DMAPR22             | DMAPR21             | DMAPR20             |
| FFFFF176H | DMAIC3                                                | DMAIF3            | DMAMK3            | 0 | 0 | 0 | DMAPR32             | DMAPR31             | DMAPR30             |
| FFFFF178H | KRIC                                                  | KRIF              | KRMK              | 0 | 0 | 0 | KRPR2               | KRPR1               | KRPR0               |
| FFFFF17AH | WTIIC                                                 | WTIIF             | WTIMK             | 0 | 0 | 0 | WTIPR2              | WTIPR1              | WTIPR0              |
| FFFFF17CH | WTIC                                                  | WTIF              | WTMK              | 0 | 0 | 0 | WTPR2               | WTPR1               | WTPR0               |
| FFFFF17EH | ERRICO <sup>Note 1</sup> /<br>ERRIC <sup>Note 2</sup> | ERRIF0/<br>ERRIF  | ERRMK0/<br>ERRMK  | 0 | 0 | 0 | ERRPR02/<br>ERRPR2  | ERRPR01/<br>ERRPR1  | ERRPR00/<br>ERRPR0  |
| FFFFF180H | WUPICO <sup>Note 1</sup> /<br>STAIC <sup>Note 2</sup> | WUPIF0/<br>STAIF  | WUPMK0/<br>STAMK  | 0 | 0 | 0 | WUPPR02/<br>STAPR2  | WUPPR01/<br>STAPR1  | WUPPR00/<br>STAPR0  |
| FFFFF182H | RECICO <sup>Note 1</sup> /<br>IEIC1 <sup>Note 2</sup> | RECIF0/<br>IEIF1  | RECMK0/<br>IEMK1  | 0 | 0 | 0 | RECPR02/<br>IEPR12  | RECPR01/<br>IEPR11  | RECPR00/<br>IEPR10  |
| FFFFF184H | TRXIC0 <sup>Note 1</sup> / IEIC2 <sup>Note 2</sup>    | TRXIF0/<br>IEIF2  | TRXMK0/<br>IEMK2  | 0 | 0 | 0 | TRXPR02/<br>IEPR22  | TRXPR01/<br>IEPR21  | TRXPR00/<br>IEPR20  |

Notes 1. CAN controller version only

2. IEBus controller version only

# 22.3.5 Interrupt mask registers 0 to 3 (IMR0 to IMR3)

The IMR0 to IMR3 registers set the interrupt mask state for the maskable interrupts. The xxMKn bit of the IMR0 to IMR3 registers is equivalent to the xxICn.xxMKn bit.

The IMRm register can be read or written in 16-bit units (m = 0 to 3).

If the higher 8 bits of the IMRm register are used as an IMRmH register and the lower 8 bits as an IMRmL register, these registers can be read or written in 8-bit or 1-bit units (m = 0 to 3).

Reset input sets these registers to FFFFH.

Caution The device file defines the xxICn.xxMKn bit as a reserved word. If a bit is manipulated using the name of xxMKn, the contents of the xxICn register, instead of the IMRm register, are rewritten (as a result, the contents of the IMRm register are also rewritten).

| After re                      | eset: FFFF                    | H R/W     | Addres            |              | FFFFF106F         | ,                 | FFFFF107          | 7H               |
|-------------------------------|-------------------------------|-----------|-------------------|--------------|-------------------|-------------------|-------------------|------------------|
|                               | 15                            | 14        | 13                | 12           | 11                | 10                | 9                 | 8                |
| IMR3 (IMR3H <sup>Note</sup> ) | 1                             | 1         | 1                 | 1            | 1                 | TRXMK0/<br>IEMK2  | RECMK0/<br>IEMK1  | WUPMK0/<br>STAMK |
|                               | 7                             | 6         | 5                 | 4            | 3                 | 2                 | 1                 | 0                |
| IMR3L                         | ERRMK0/<br>ERRMK              | WTMK      | WTIMK             | KRMK         | DMAMK3            | DMAMK2            | DMAMK1            | DMAMK0           |
| After re                      | eset: FFFF                    | H R/W     | Addres            |              | FFFFF104          | *                 | FFFFF10           | 5H               |
|                               | 15                            | 14        | 13                | 12           | 11                | 10                | 9                 | 8                |
| IMR2 (IMR2H <sup>Note</sup> ) | ADMK                          | UA2TMK    | UA2RMK/<br>IICMK0 | UA1TMK       | UA1RMK/<br>IIC2MK | UA0TMK/<br>CB4TMK | UA0RMK/<br>CB4RMK | СВЗТМК           |
|                               | 7                             | 6         | 5                 | 4            | 3                 | 2                 | 1                 | 0                |
| IMR2L                         | CB3RMK                        | CB2TMK    | CB2RMK            | CB1TMK       | CB1RMK            | CB0TMK            | CB0RMK/<br>IICMK1 | TM0EQMK0         |
| After re                      | eset: FFFF                    | H R/W     | Addres            |              | FFFFF102          |                   | FFFFF10           |                  |
| INADA (INADALINOto)           | 15                            |           |                   |              | 11                |                   |                   | 8                |
| IMR1 (IMR1H <sup>Note</sup> ) | TP5CCMK1                      | TP5CCMK0  | TP5OVMK           | TP4CCMK1     | TP4CCMK0          | TP4OVMK           | TP3CCMK1          | TP3CCMK0         |
|                               | 7                             | 6         | 5                 | 4            | 3                 | 2                 | 1                 | 0                |
| IMR1L                         | TP3OVMK                       | TP2CCMK1  | TP2CCMK0          | TP2OVMK      | TP1CCMK1          | TP1CCMK0          | TP10VMK           | TP0CCMK1         |
| After re                      | eset: FFFF                    | H R/W     | Addres            |              | FFFFF100          | *                 | FFFFF10           | 1H               |
|                               | 15                            | 14        | 13                | 12           | 11                | 10                | 9                 | 8                |
| IMR0 (IMR0H <sup>Note</sup> ) | TP0CCMK0                      | TP00VMK   | TQ0CCMK3          | TQ0CCMK2     | TQ0CCMK1          | TQ0CCMK0          | TQ00VMK           | PMK7             |
|                               | 7                             | 6         | 5                 | 4            | 3                 | 2                 | 1                 | 0                |
| IMR0L                         | PMK6                          | PMK5      | PMK4              | PMK3         | PMK2              | PMK1              | PMK0              | 1                |
|                               |                               |           |                   |              |                   |                   |                   |                  |
|                               | xxMKn                         |           | Sett              | ing of inter | rupt mask f       | lag               |                   |                  |
|                               | 0 Interrupt servicing enabled |           |                   |              |                   |                   |                   |                  |
|                               | 1                             | Interrupt | servicing d       | isabled      |                   |                   |                   |                  |
|                               |                               |           |                   |              |                   |                   |                   |                  |

**Note** To read bits 8 to 15 of the IMR0 to IMR3 registers in 8-bit or 1-bit units, specify them as bits 0 to 7 of IMR0H to IMR3H registers.

Caution Set bits 11 to 15 of the IMR3 register and bit 0 of the IMR0 register to 1. If the setting of these bits is changed, the operation is not guaranteed.

Remark xx: Identification name of each peripheral unit (see Table 22-2 Interrupt Control Register (xxICn)).

n: Peripheral unit number (see Table 22-2 Interrupt Control Register (xxlCn))

# 22.3.6 In-service priority register (ISPR)

The ISPR register holds the priority level of the maskable interrupt currently acknowledged. When an interrupt request signal is acknowledged, the bit of this register corresponding to the priority level of that interrupt request signal is set to 1 and remains set while the interrupt is serviced.

When the RETI instruction is executed, the bit corresponding to the interrupt request signal having the highest priority is automatically reset to 0 by hardware. However, it is not reset to 0 when execution is returned from non-maskable interrupt servicing or exception processing.

This register is read-only, in 8-bit or 1-bit units.

Reset input clears this register to 00H.

Caution If an interrupt is acknowledged while the ISPR register is being read in the interrupt enabled (EI) status, the value of the ISPR register after the bits of the register have been set by acknowledging the interrupt may be read. To accurately read the value of the ISPR register before an interrupt is acknowledged, read the register while interrupts are disabled (DI).



# 22.3.7 ID flag

This flag controls the maskable interrupt's operating state, and stores control information regarding enabling or disabling of interrupt request signals. An interrupt disable flag (ID) is assigned to the PSW.

Reset input sets this flag to 00000020H.



| ID | Specification of maskable interrupt servicing Note                  |
|----|---------------------------------------------------------------------|
| 0  | Maskable interrupt request signal acknowledgment enabled            |
| 1  | Maskable interrupt request signal acknowledgment disabled (pending) |

Note Interrupt disable flag (ID) function

This bit is set to 1 by the DI instruction and cleared to 0 by the EI instruction. Its value is also modified by the RETI instruction or LDSR instruction when referencing the PSW.

Non-maskable interrupt request signals and exceptions are acknowledged regardless of this flag. When a maskable interrupt request signal is acknowledged, the ID flag is automatically set to 1 by hardware.

The interrupt request signal generated during the acknowledgment disabled period (ID flag = 1) is acknowledged when the xxICn.xxIFn bit is set to 1, and the ID flag is cleared to 0.

# 22.3.8 Watchdog timer mode register 2 (WDTM2)

This register can be read or written in 8-bit units (for details, see **CHAPTER 11 FUNCTIONS OF WATCHDOG TIMER 2**).

Reset input sets this register to 67H.



# 22.4 Software Exception

A software exception is generated when the CPU executes the TRAP instruction, and can always be acknowledged.

# 22.4.1 Operation

If a software exception occurs, the CPU performs the following processing, and transfers control to the handler routine.

- <1> Saves the restored PC to EIPC.
- <2> Saves the current PSW to EIPSW.
- <3> Writes an exception code to the lower 16 bits (EICC) of ECR (interrupt source).
- <4> Sets the PSW.EP and PSW.ID bits to 1.
- <5> Sets the handler address (00000040H or 00000050H) corresponding to the software exception to the PC, and transfers control.

Figure 22-9 illustrates the processing of a software exception.

TRAP instructionNote

EIPC — Restored PC
EIPSW — PSW
ECR.EICC — Exception code
PSW.EP — 1
PSW.ID — 1
PC — Handler address

Exception processing

Note TRAP instruction format: TRAP vector (the vector is a value from 00H to 1FH.)

Figure 22-9. Software Exception Processing

The handler address is determined by the TRAP instruction's operand (vector). If the vector is 00H to 0FH, it becomes 00000040H, and if the vector is 10H to 1FH, it becomes 00000050H.

# 22.4.2 Restore

Recovery from software exception processing is carried out by the RETI instruction.

By executing the RETI instruction, the CPU carries out the following processing and shifts control to the restored PC's address.

- <1> Loads the restored PC and PSW from EIPC and EIPSW because the PSW.EP bit is 1.
- <2> Transfers control to the address of the restored PC and PSW.

Figure 22-10 illustrates the processing of the RETI instruction.

Figure 22-10. RETI Instruction Processing



# 22.4.3 EP flag

The EP flag is a status flag used to indicate that exception processing is in progress. It is set when an exception occurs.



# 22.5 Exception Trap

An exception trap is an interrupt that is requested when the illegal execution of an instruction takes place. In the V850ES/SG2, an illegal opcode exception (ILGOP: Illegal Opcode Trap) is considered as an exception trap.

# 22.5.1 Illegal opcode definition

The illegal instruction has an opcode (bits 10 to 5) of 111111B, a sub-opcode (bits 26 to 23) of 0111B to 1111B, and a sub-opcode (bit 16) of 0B. An exception trap is generated when an instruction applicable to this illegal instruction is executed.



Caution Since it is possible to assign this instruction to an illegal opcode in the future, it is recommended that it not be used.

# (1) Operation

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

- <1> Saves the restored PC to DBPC.
- <2> Saves the current PSW to DBPSW.
- <3> Sets the PSW.NP, PSW.EP, and PSW.ID bits to 1.
- <4> Sets the handler address (00000060H) corresponding to the exception trap to the PC, and transfers control.

Figure 22-11 illustrates the processing of the exception trap.

Exception trap (ILGOP) occurs

DBPC — Restored PC
DBPSW — PSW
PSW.NP — 1
PSW.EP — 1
PSW.ID — 1
PC — 00000060H

Exception processing

Figure 22-11. Exception Trap Processing

# (2) Restore

Recovery from an exception trap is carried out by the DBRET instruction. By executing the DBRET instruction, the CPU carries out the following processing and controls the address of the restored PC.

- <1> Loads the restored PC and PSW from DBPC and DBPSW.
- <2> Transfers control to the address indicated by the restored PC and PSW.

Figure 22-12 illustrates the restore processing from an exception trap.

Figure 22-12. Restore Processing from Exception Trap



# 22.5.2 Debug trap

A debug trap is an exception that is generated when the DBTRAP instruction is executed and is always acknowledged.

# (1) Operation

Upon occurrence of a debug trap, the CPU performs the following processing.

- <1> Saves restored PC to DBPC.
- <2> Saves current PSW to DBPSW.
- <3> Sets the PSW.NP, PSW.EP, and PSW.ID bits to 1.
- <4> Sets handler address (00000060H) for debug trap to PC and transfers control.

Figure 22-13 shows the debug trap processing format.

Figure 22-13. Debug Trap Processing Format



# (2) Restoration

Restoration from a debug trap is executed with the DBRET instruction.

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

- <1> The restored PC and PSW are read from DBPC and DBPSW.
- <2> Control is transferred to the fetched address of the restored PC and PSW.

Caution DBPC and DBPSW can be accessed after the DBTRAP instruction is executed and before the DBRET instruction is executed.

Table 22-14 shows the processing format for restoration from a debug trap.

Figure 22-14. Processing Format of Restoration from Debug Trap



# 22.6 External Interrupt Request Input Pins (NMI and INTP0 to INTP7)

#### 22.6.1 Noise elimination

# (1) Eliminating noise on NMI pin

The NMI pin has an internal noise elimination circuit that uses analog delay. Therefore, the input level of the NMI pin is not detected as an edge unless it is maintained for a specific time or longer. Therefore, an edge is detected after specific time.

The NMI pin can be used to release the STOP mode. In the STOP mode, noise is not eliminated by using the system clock because the internal system clock is stopped.

# (2) Eliminating noise on INTP0 to INTP7 pins

The INTP0 to INTP7 pins have an internal noise elimination circuit that uses analog delay. Therefore, the input level of the NMI pin is not detected as an edge unless it is maintained for a specific time or longer. Therefore, an edge is detected after specific time.

#### 22.6.2 Edge detection

The valid edge of each of the NMI and INTP0 to INTP7 pins can be selected from the following four.

- · Rising edge
- · Falling edge
- Both rising and falling edges
- · No edge detected

The edge of the NMI pin is not detected after reset. Therefore, the interrupt request signal is not acknowledged unless a valid edge is enabled by using the INTF0 and INTR0 register (the NMI pin functions as a normal port pin).

# (1) External interrupt falling, rising edge specification register 0 (INTF0, INTR0)

The INTF0 and INTR0 registers are 8-bit registers that specify detection of the falling and rising edges of the NMI pin via bit 2 and the external interrupt pins (INTP0 to INTP3) via bits 3 to 6.

These registers can be read or written in 8-bit or 1-bit units.

Reset input clears these registers to 00H.

Caution When the function is changed from the external interrupt function (alternate function) to the port function, an edge may be detected. Therefore, clear the INTF0n and INTR0n bits to 00, and then set the port mode.



Table 22-3. Valid Edge Specification

| INTF0n | INTR0n | Valid Edge Specification (n = 2 to 6) |
|--------|--------|---------------------------------------|
| 0      | 0      | No edge detected                      |
| 0      | 1      | Rising edge                           |
| 1      | 0      | Falling edge                          |
| 1      | 1      | Both rising and falling edges         |

Caution Be sure to clear the INTF0n and INTR0n bits to 00 when these registers are not used as the NMI or INTP0 to INTP3 pins.

**Remark** n = 2: Control of NMI pin

n = 3 to 6: Control of INTP0 to INTP3 pins

# (2) External interrupt falling, rising edge specification register 3 (INTF3, INTR3)

The INTF3 and INTR3 registers are 8-bit registers that specify detection of the falling and rising edges of the external interrupt pin (INTP7).

These registers can be read or written in 8-bit or 1-bit units.

Reset input clears these registers to 00H.

- Cautions 1. When the function is changed from the external interrupt function (alternate function) to the port function, an edge may be detected. Therefore, clear the INTF31 and INTR31 bits to 00, and then set the port mode.
  - 2. The INTP7 pin and RXDA0 pin are alternate-function pins. When using the pin as the RXDA0 pin, disable edge detection for the INTP7 alternate-function pin (clear the INTF3.INTF31 bit and the INRT3.INTR31 bit to 0). When using the pin as the INTP7 pin, stop UARTA0 reception (clear the UA0CTL0.UA0RXE bit to 0).



Table 22-4. Valid Edge Specification

| INTF31 | INTR31 | Valid Edge Specification      |
|--------|--------|-------------------------------|
| 0      | 0      | No edge detected              |
| 0      | 1      | Rising edge                   |
| 1      | 0      | Falling edge                  |
| 1      | 1      | Both rising and falling edges |

Caution Be sure to clear the INTF31 and INTR31 bits to 00 when these registers are not used as INTP7 pin.

# (3) External interrupt falling, rising edge specification register 9H (INTF9H, INTR9H)

The INTF9H and INTR9H registers are 8-bit registers that specify detection of the falling and rising edges of the external interrupt pins (INTP4 to INTP6).

These registers can be read or written in 8-bit or 1-bit units.

Reset input clears these registers to 00H.

Caution When the function is changed from the external interrupt function (alternate function) to the port function, an edge may be detected. Therefore, clear the INTF9n and INTR9n bits to 0, and then set the port mode.



Table 22-5. Valid Edge Specification

| INTF9n | INTR9n | Valid Edge Specification (n = 13 to 15) |
|--------|--------|-----------------------------------------|
| 0      | 0      | No edge detected                        |
| 0      | 1      | Rising edge                             |
| 1      | 0      | Falling edge                            |
| 1      | 1      | Both rising and falling edges           |

Caution Be sure to clear the INTF9n and INTR9n bits to 00 when these registers are not used as INTP4 to INTP6 pins.

**Remark** n = 13 to 15: Control of INTP4 to INTP6 pins

#### (4) Noise elimination control register (NFC)

Digital noise elimination can be selected for the INTP3 pin. The noise elimination settings are performed using the NFC register.

When digital noise elimination is selected, the sampling clock for digital sampling can be selected from among fxx/64, fxx/128, fxx/256, fxx/512, fxx/1,024, and fxT. Sampling is performed 3 times.

Even when digital noise elimination is selected, using fxT as the sampling clock makes it possible to use the INTP3 interrupt request signal to release the IDLE1, IDLE2, and STOP modes.

This register can be read or written in 8-bit units.

Reset input clears this register to 00H.

Caution After the sampling clock has been changed, it takes 3 sampling clocks to initialize the digital noise eliminator. Therefore, if an INTP3 valid edge is input within these 3 sampling clocks after the sampling clock has been changed, an interrupt request signal may be generated. Therefore, be careful about the following points when using the interrupt and DMA functions.

- When using the interrupt function, after the 3 sampling clocks have elapsed, enable interrupts after the interrupt request flag (PIC3.PIF3 bit) has been cleared.
- When using the DMA function (started by INTP3), enable DMA after 3 sampling clocks have elapsed.

After reset: 00H R/W Address: FFFFF318H 2 0 6 1 NFC1 NFC0 **NFC NFEN** 0 0 0 0 NFC2

| NFEN | Settings of INTP3 pin noise elimination |  |  |  |
|------|-----------------------------------------|--|--|--|
| 0    | Analog noise elimination (60 ns (TYP.)) |  |  |  |
| 1    | Digital noise elimination               |  |  |  |

| NFC2             | NFC1 | NFC0 | Digital sampling clock |
|------------------|------|------|------------------------|
| 0                | 0    | 0    | fxx/64                 |
| 0                | 0    | 1    | fxx/128                |
| 0                | 1    | 0    | fxx/256                |
| 0                | 1    | 1    | fxx/512                |
| 1                | 0    | 0    | fxx/1,024              |
| 1                | 0    | 1    | fxt (subclock)         |
| Other than above |      | ove  | Setting prohibited     |

Remarks 1. Since sampling is performed 3 times, the reliably eliminated noise width is 2 sampling clocks.

2. In the case of noise with a width smaller than 2 sampling clocks, an interrupt request signal is generated if noise synchronized with the sampling clock is input.

# 22.7 Interrupt Acknowledge Time of CPU

Except the following cases, the interrupt acknowledge time of the CPU is 4 clocks minimum. To input interrupt request signals successively, input the next interrupt request signal at least 5 clocks after the preceding interrupt.

- In IDLE1/IDLE2/STOP mode
- · When the external bus is accessed
- When interrupt request non-sampling instructions are successively executed (see 22.8 Periods in Which Interrupts Are Not Acknowledged by CPU.)
- · When the interrupt control register is accessed

Figure 22-15. Pipeline Operation at Interrupt Request Signal Acknowledgment (Outline)



# 22.8 Periods in Which Interrupts Are Not Acknowledged by CPU

An interrupt is acknowledged by the CPU while an instruction is being executed. However, no interrupt will be acknowledged between an interrupt request non-sample instruction and the next instruction (interrupt is held pending). The interrupt request non-sample instructions are as follows.

- El instruction
- DI instruction
- LDSR reg2, 0x5 instruction (for PSW)
- The store instruction for the PRCMD register
- The store, SET1, NOT1, or CLR1 instructions for the following registers.
  - Interrupt-related registers: Interrupt control register (xxICn), interrupt mask registers 0 to 3 (IMR0 to IMR3)
  - Power save control register (PSC)
  - On-chip debug mode register (OCDM)

Remark xx: Identification name of each peripheral unit (see Table 22-2 Interrupt Control Register (xxICn))

n: Peripheral unit number (see Table 22-2 Interrupt Control Register (xxlCn)).

# 22.9 Cautions

The NMI pin and P02 pin are an alternate-function pin, and function as a normal port pin after being reset. To enable the NMI pin, validate the NMI pin with the PMC0 register. The initial setting of the NMI pin is "No edge detected". Select the NMI pin valid edge using the INTF0 and INTR0 registers.

# **CHAPTER 23 KEY INTERRUPT FUNCTION**

# 23.1 Function

A key interrupt request signal (INTKR) can be generated by inputting a falling edge to the eight key input pins (KR0 to KR7) by setting the KRM register.

Table 23-1. Assignment of Key Return Detection Pins

| Flag | Pin Description                    |  |  |  |
|------|------------------------------------|--|--|--|
| KRM0 | Controls KR0 signal in 1-bit units |  |  |  |
| KRM1 | Controls KR1 signal in 1-bit units |  |  |  |
| KRM2 | Controls KR2 signal in 1-bit units |  |  |  |
| KRM3 | Controls KR3 signal in 1-bit units |  |  |  |
| KRM4 | Controls KR4 signal in 1-bit units |  |  |  |
| KRM5 | Controls KR5 signal in 1-bit units |  |  |  |
| KRM6 | Controls KR6 signal in 1-bit units |  |  |  |
| KRM7 | Controls KR7 signal in 1-bit units |  |  |  |

Figure 23-1. Key Return Block Diagram



# 23.2 Register

# (1) Key return mode register (KRM)

The KRM register controls the KRM0 to KRM7 bits using the KR0 to KR7 signals.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.



# 23.3 Cautions

Pin.

- (1) If a low level is input to any of the KR0 to KR7 pins, the INTKR signal is not generated even if the falling edge of another pin is input.
- (2) The RXDA1 and KR7 pins must not be used at the same time. To use the RXDA1 pin, do not use the KR7 pin. To use the KR7 pin, do not use the RXDA1 pin (it is recommended to set the PFC91 bit to 1 and clear PFCE91 bit to 0).
- (3) If the KRM register is changed, an interrupt request signal (INTKR) may be generated. To prevent this, change the KRM register after disabling interrupts (DI) or masking, then clear the interrupt request flag (KRIC.KRIF bit) to 0, and enable interrupts (EI) or clear the mask.
- (4) To use the key interrupt function, be sure to set the port pin to the key return pin and then enable the operation with the KRM register. To switch from the key return pin to the port pin, disable the operation with the KRM register and then set the port pin.

# **CHAPTER 24 STANDBY FUNCTION**

# 24.1 Overview

The power consumption of the system can be effectively reduced by using the standby modes in combination and selecting the appropriate mode for the application. The available standby modes are listed in Table 24-1.

Table 24-1. Standby Modes

| Mode                    | Functional Outline                                                                                                                |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| HALT mode               | Mode in which only the operating clock of the CPU is stopped                                                                      |  |  |  |
| IDLE1 mode              | ode in which all the operations of the internal circuits except the oscillator, PLL <sup>Note</sup> , and flash emory are stopped |  |  |  |
| IDLE2 mode              | Mode in which all the operations of the internal circuits except the oscillator are stopped                                       |  |  |  |
| STOP mode               | Mode in which all the operations of the internal circuits except the subclock oscillator are stopped                              |  |  |  |
| Subclock operation mode | Mode in which the subclock is used as the internal system clock                                                                   |  |  |  |
| Sub-IDLE mode           | Mode in which all the operations of the internal circuits except the oscillator are stopped, in the subclock operation mode       |  |  |  |

**Note** The PLL holds the previous operating status.

Reset Internal oscillation clock operation Sub-IDLE mode WDT overflow (fx operates, PLL operates) Oscillation stabilization wait Normal operation mode Subclock operation mode Clock through mode (fx operates, PLL operates) (PLL operates) PLL lockup HALT mode time wait (fx operates, PLL operates) PLL mode Clock through mode Oscillation (PLL operates) (PLL stops) stabilization wait<sup>Not</sup> IDLE1 mode HALT mode (fx operates, PLL operates) (fx operates, PLL stops) Oscillation Oscillation Subclock operation mode stabilization wait<sup>N</sup> stabilization wait<sup>Note</sup> IDLE1 mode (fx stops, PLL stops) (fx operates, PLL stops) IDLE2 mode STOP mode (fx stops, PLL stops) (fx operates, PLL stops) Sub-IDLE mode (fx stops, PLL stops) Note If a WDT overflow occurs during an oscillation stabilization time, the CPU operates on the internal oscillation clock. Remark fx: Main clock

Figure 24-1. Status Transition

# 24.2 Registers

# (1) Power save control register (PSC)

The PSC register is an 8-bit register that controls the standby function. The STP bit of this register is used to specify the STOP mode. This register is a special register that can be written only by the special sequence combinations (see **3.4.8 Special registers**).

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

After reset: 00H R/W Address: FFFFF1FEH

7 <6> <5> <4> 3 2 <1> 0

PSC 0 NMI1M NMI0M INTM 0 0 STP 0

| NMI1M | Standby mode release control upon occurrence of INTWDT2 signal |  |
|-------|----------------------------------------------------------------|--|
| 0     | Standby mode release by INTWDT2 signal enabled                 |  |
| 1     | Standby mode release by INTWDT2 signal disabled                |  |

| NMIOM | Standby mode release control by NMI pin input  |  |
|-------|------------------------------------------------|--|
| 0     | Standby mode release by NMI pin input enabled  |  |
| 1     | Standby mode release by NMI pin input disabled |  |

| INTM | Standby mode release control via maskable interrupt request signal |  |
|------|--------------------------------------------------------------------|--|
| 0    | Standby mode release by maskable interrupt request signal enabled  |  |
| 1    | Standby mode release by maskable interrupt request signal disabled |  |

| STP | Standby mode <sup>Note</sup> setting |  |  |
|-----|--------------------------------------|--|--|
| 0   | Normal mode                          |  |  |
| 1   | Standby mode                         |  |  |

Note Standby mode set by STP bit: IDLE1, IDLE2, STOP, or sub-IDLE mode

Cautions 1. Before setting the IDLE1, IDLE2, STOP, or sub-IDLE mode, set the PSMR.PSM1 and PSMR.PSM0 bits and then set the STP bit.

2. Settings of the NMI1M, NMI0M, and INTM bits are invalid when HALT mode is released.

# (2) Power save mode register (PSMR)

The PSMR register is an 8-bit register that controls the operation status in the power save mode and the clock operation.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.



| PSM1 | PSM0 | Specification of operation in software standby mode |  |  |
|------|------|-----------------------------------------------------|--|--|
| 0    | 0    | DLE1, sub-IDLE modes                                |  |  |
| 0    | 1    | STOP mode                                           |  |  |
| 1    | 0    | IDLE2, sub-IDLE modes                               |  |  |
| 1    | 1    | STOP mode                                           |  |  |

#### Cautions 1. Be sure to clear bits 2 to 7 to 0.

2. The PSM0 and PSM1 bits are valid only when the PSC.STP bit is 1.

Remark IDLE1: In this mode, all operations except the oscillator operation and some other circuits

(flash memory and PLL) are stopped.

After the IDLE1 mode is released, the normal operation mode is restored without

needing to secure the oscillation stabilization time, like the HALT mode.

IDLE2: In this mode, all operations except the oscillator operation are stopped.

After the IDLE2 mode is released, the normal operation mode is restored following

the lapse of the setup time specified by the OSTS register (flash memory and PLL).

STOP: In this mode, all operations except the subclock oscillator operation are stopped.

After the STOP mode is released, the normal operation mode is restored following the

lapse of the oscillation stabilization time specified by the OSTS register.

Sub-IDLE: In this mode, all other operations are halted except for the oscillator. After the IDLE

mode has been released by the interrupt request signal, the subclock operation mode

will be restored after 12 cycles of the subclock have been secured.

# (3) Oscillation stabilization time select register (OSTS)

The wait time until the oscillation stabilizes after the STOP mode is released or the wait time until the on-chip flash memory stabilizes after the IDLE2 mode is released is controlled by the OSTS register.

The OSTS register can be read or written 8-bit units.

Reset input sets this register to 06H.

| After res | et: 06H | R/W | Address: FFFF6C0H |   |   |       |       |       |
|-----------|---------|-----|-------------------|---|---|-------|-------|-------|
|           | 7       | 6   | 5                 | 4 | 3 | 2     | 1     | 0     |
| OSTS      | 0       | 0   | 0                 | 0 | 0 | OSTS2 | OSTS1 | OSTS0 |

| OSTS2 | OSTS1 | OSTS0 | Selection of oscillation stabilization time/setup time <sup>Note</sup> |          |           |
|-------|-------|-------|------------------------------------------------------------------------|----------|-----------|
|       |       |       |                                                                        | 1        | ·x        |
|       |       |       |                                                                        | 4 MHz    | 5 MHz     |
| 0     | 0     | 0     | 2 <sup>10</sup> /fx                                                    | 0.256 ms | 0.205 ms  |
| 0     | 0     | 1     | 2 <sup>11</sup> /fx                                                    | 0.512 ms | 0.410 ms  |
| 0     | 1     | 0     | 2 <sup>12</sup> /fx                                                    | 1.024 ms | 0.819 ms  |
| 0     | 1     | 1     | 2 <sup>13</sup> /fx                                                    | 2.048 ms | 1.638 ms  |
| 1     | 0     | 0     | 2 <sup>14</sup> /fx                                                    | 4.096 ms | 3.277 ms  |
| 1     | 0     | 1     | 2 <sup>15</sup> /fx                                                    | 8.192 ms | 6.554 ms  |
| 1     | 1     | 0     | 2 <sup>16</sup> /fx                                                    | 16.38 ms | 13.107 ms |
| 1     | 1     | 1     | Setting prohibited                                                     | •        |           |

**Note** The oscillation stabilization time and setup time are required when the STOP mode and IDLE2 mode are released, respectively.

Cautions 1. The wait time following release of the STOP mode does not include the time until the clock oscillation starts ("a" in the figure below) following release of the STOP mode, regardless of whether the STOP mode is released by reset input or the occurrence of an interrupt request signal.



- 2. Be sure to clear bits 3 to 7 to 0.
- 3. The oscillation stabilization time following reset release is  $2^{16}/fx$  (because the initial value of the OSTS register = 06H).

**Remark** fx = Main clock oscillation frequency

#### 24.3 HALT Mode

# 24.3.1 Setting and operation status

The HALT mode is set when a dedicated instruction (HALT) is executed in the normal operation mode.

In the HALT mode, the clock oscillator continues operating. Only clock supply to the CPU is stopped; clock supply to the other on-chip peripheral functions continues.

As a result, program execution is stopped, and the internal RAM retains the contents before the HALT mode was set. The on-chip peripheral functions that are independent of instruction processing by the CPU continue operating.

Table 24-3 shows the operating status in the HALT mode.

The average current consumption of the system can be reduced by using the HALT mode in combination with the normal operation mode for intermittent operation.

#### Cautions 1. Insert five or more NOP instructions after the HALT instruction.

If the HALT instruction is executed while an unmasked interrupt request signal is being held pending, the status shifts to HALT mode, but the HALT mode is then released immediately by the pending interrupt request.

#### 24.3.2 Releasing HALT mode

The HALT mode is released by a non-maskable interrupt request signal (NMI pin input, INTWDT2 signal), unmasked external interrupt request signal (INTP0 to INTP7 pin input), unmasked internal interrupt request signal from a peripheral function operable in the HALT mode, or reset signal (reset by RESET pin input, WDT2RES signal, or clock monitor (CLM)).

After the HALT mode has been released, the normal operation mode is restored.

# (1) Releasing HALT mode by non-maskable interrupt request signal or unmasked maskable interrupt request signal

The HALT mode is released by a non-maskable interrupt request signal or an unmasked maskable interrupt request signal, regardless of the priority of the interrupt request signal. If the HALT mode is set in an interrupt servicing routine, however, an interrupt request signal that is issued later is serviced as follows.

- (a) If an interrupt request signal with a priority lower than that of the interrupt request currently being serviced is issued, the HALT mode is released, but that interrupt request signal is not acknowledged. The interrupt request signal itself is retained.
- (b) If an interrupt request signal with a priority higher than that of the interrupt request currently being serviced is issued (including a non-maskable interrupt request signal), the HALT mode is released and that interrupt request signal is acknowledged.

Table 24-2. Operation After Releasing HALT Mode by Interrupt Request Signal

| Release Source                        | Interrupt Enabled (EI) Status                                                  | Interrupt Disabled (DI) Status    |
|---------------------------------------|--------------------------------------------------------------------------------|-----------------------------------|
| Non-maskable interrupt request signal | Execution branches to the handler address.                                     |                                   |
| Maskable interrupt request signal     | Execution branches to the handler address or the next instruction is executed. | The next instruction is executed. |

# (2) Releasing HALT mode by reset

The same operation as the normal reset operation is performed.

Table 24-3. Operating Status in HALT Mode

| Setting of HALT Mode        |                                          | Operating Status                                                                                                                                                |                     |  |
|-----------------------------|------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|--|
| Item                        |                                          | When Subclock Is Not Used When Subclock Is Use                                                                                                                  |                     |  |
| Main clock oscillator       |                                          | Oscillation enabled                                                                                                                                             |                     |  |
| Subclock oscillato          | r                                        | -                                                                                                                                                               | Oscillation enabled |  |
| Internal oscillator         |                                          | Oscillation enabled                                                                                                                                             |                     |  |
| PLL                         |                                          | Operable                                                                                                                                                        |                     |  |
| CPU                         |                                          | Stops operation                                                                                                                                                 |                     |  |
| DMA                         |                                          | Operable                                                                                                                                                        |                     |  |
| Interrupt controller        | •                                        | Operable                                                                                                                                                        |                     |  |
| ROM correction              |                                          | Stops operation                                                                                                                                                 |                     |  |
| Timer P (TMP0 to            | TMP5)                                    | Operable                                                                                                                                                        |                     |  |
| Timer Q (TMQ0)              |                                          | Operable                                                                                                                                                        |                     |  |
| Timer M (TMM0)              |                                          | Operable when a clock other than fxT is selected as the count clock                                                                                             | Operable            |  |
| Watch timer                 |                                          | Operable when fx (divided BRG) is selected as the count clock                                                                                                   | Operable            |  |
| Watchdog timer 2            |                                          | Operable when a clock other than fxt is selected as the count clock                                                                                             | Operable            |  |
| Serial interface            | CSIB0 to CSIB4                           | Operable                                                                                                                                                        |                     |  |
|                             | I <sup>2</sup> C00 to I <sup>2</sup> C02 | Operable                                                                                                                                                        |                     |  |
|                             | UARTA0 to UARTA2                         | Operable                                                                                                                                                        |                     |  |
| CAN controller              |                                          | Operable                                                                                                                                                        |                     |  |
| IEBus controller            |                                          | Operable                                                                                                                                                        |                     |  |
| A/D converter               |                                          | Operable                                                                                                                                                        |                     |  |
| D/A converter               |                                          | Operable                                                                                                                                                        |                     |  |
| Real-time output f          | unction (RTO)                            | Operable                                                                                                                                                        |                     |  |
| Key interrupt function (KR) |                                          | Operable                                                                                                                                                        |                     |  |
| CRC arithmetic circuit      |                                          | Operable (in the status in which data is not input to CRCIN to stop the CPU)                                                                                    |                     |  |
| External bus interface      |                                          | See 2.2 Pin States.                                                                                                                                             |                     |  |
| Port function               |                                          | Retains status before HALT mode was set                                                                                                                         |                     |  |
| Internal data               |                                          | The CPU registers, statuses, data, and all other internal data such as the contents of the internal RAM are retained as they were before the HALT mode was set. |                     |  |

#### 24.4 IDLE1 Mode

# 24.4.1 Setting and operation status

The IDLE1 mode is set by clearing the PSMR.PSM1 and PSMR.PSM0 bits to 00 and setting the PSC.STP bit to 1 in the normal operation mode.

In the IDLE1 mode, the clock oscillator, PLL, and flash memory continue operating but clock supply to the CPU and other on-chip peripheral functions stops.

As a result, program execution stops and the contents of the internal RAM before the IDLE1 mode was set are retained. The CPU and other on-chip peripheral functions stop operating. However, the on-chip peripheral functions that can operate with the subclock or an external clock continue operating.

Table 24-5 shows the operating status in the IDLE1 mode.

The IDLE1 mode can reduce the power consumption more than the HALT mode because it stops the operation of the on-chip peripheral functions. The main clock oscillator does not stop, so the normal operation mode can be restored without waiting for the oscillation stabilization time after the IDLE1 mode has been released, in the same manner as when the HALT mode is released.

- Cautions 1, Insert five or more NOP instructions after the instruction that stores data in the PSC register to set the IDLE1 mode.
  - If the IDLE1 mode is set while an unmasked interrupt request signal is being held pending, the IDLE1 mode is released immediately by the pending interrupt request.

#### 24.4.2 Releasing IDLE1 mode

The IDLE1 mode is released by a non-maskable interrupt request signal (NMI pin input, INTWDT2 signal), unmasked external interrupt request signal (INTP0 to INTP7 pin input), unmasked internal interrupt request signal from a peripheral function operable in the IDLE1 mode, or reset signal (reset by RESET pin input, WDT2RES signal, or clock monitor (CLM)).

After the IDLE1 mode has been released, the normal operation mode is restored.

# (1) Releasing IDLE1 mode by non-maskable interrupt request signal or unmasked maskable interrupt request signal

The IDLE1 mode is released by a non-maskable interrupt request signal or an unmasked maskable interrupt request signal, regardless of the priority of the interrupt request signal. If the IDLE1 mode is set in an interrupt servicing routine, however, an interrupt request signal that is issued later is processed as follows.

- (a) If an interrupt request signal with a priority lower than that of the interrupt request currently being serviced is issued, the IDLE1 mode is released, but that interrupt request signal is not acknowledged. The interrupt request signal itself is retained.
- (b) If an interrupt request signal with a priority higher than that of the interrupt request currently being serviced is issued (including a non-maskable interrupt request signal), the IDLE1 mode is released and that interrupt request signal is acknowledged.

Caution An interrupt request signal that is disabled by setting the PSC.NMI1M, PSC.NMI0M, and PSC.INTM bits to 1 becomes invalid and IDLE1 mode is not released.

Table 24-4. Operation After Releasing IDLE1 Mode by Interrupt Request Signal

| Release Source                        | Interrupt Enabled (EI) Status                                                  | Interrupt Disabled (DI) Status    |
|---------------------------------------|--------------------------------------------------------------------------------|-----------------------------------|
| Non-maskable interrupt request signal | Execution branches to the handler address.                                     |                                   |
| Maskable interrupt request signal     | Execution branches to the handler address or the next instruction is executed. | The next instruction is executed. |

# (2) Releasing IDLE1 mode by reset

The same operation as the normal reset operation is performed.

Table 24-5. Operating Status in IDLE1 Mode

| Setting of IDLE1 Mode           |                                          | Operating Status                                                                                                                                                 |                                                          |
|---------------------------------|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|
| Item                            |                                          | When Subclock Is Not Used                                                                                                                                        | When Subclock Is Used                                    |
| Main clock oscillator           |                                          | Oscillation enabled                                                                                                                                              |                                                          |
| Subclock oscillator             |                                          | _                                                                                                                                                                | Oscillation enabled                                      |
| Internal oscillator             |                                          | Oscillation enabled                                                                                                                                              |                                                          |
| PLL                             |                                          | Operable                                                                                                                                                         |                                                          |
| CPU                             |                                          | Stops operation                                                                                                                                                  |                                                          |
| DMA                             |                                          | Stops operation                                                                                                                                                  |                                                          |
| Interrupt controller            |                                          | Stops operation (but standby mode release enabled)                                                                                                               |                                                          |
| ROM correction                  |                                          | Stops operation                                                                                                                                                  |                                                          |
| Timer P (TMP0 to TMP5)          |                                          | Stops operation                                                                                                                                                  |                                                          |
| Timer Q (TMQ0)                  |                                          | Stops operation                                                                                                                                                  |                                                          |
| Timer M (TMM0)                  |                                          | Operable when f <sub>R</sub> /8 is selected as the count clock                                                                                                   | Operable when fn/8 or fxT is selected as the count clock |
| Watch timer                     |                                          | Operable when fx (divided BRG) is selected as the count clock                                                                                                    | Operable                                                 |
| Watchdog timer 2                |                                          | Operable when f <sub>R</sub> is selected as the count clock                                                                                                      | Operable when fR or fxT is selected as the count clock   |
| Serial interface                | CSIB0 to CSIB4                           | Operable when the SCKBn input clock is selected as the count clock (n = 0 to 4)                                                                                  |                                                          |
|                                 | I <sup>2</sup> C00 to I <sup>2</sup> C02 | Stops operation                                                                                                                                                  |                                                          |
|                                 | UARTA0 to UARTA2                         | Stops operation (but UARTA0 is operable when the ASCKA0 input clock is selected)                                                                                 |                                                          |
| CAN controller                  |                                          | Stops operation                                                                                                                                                  |                                                          |
| IEBus controller                |                                          | Stops operation                                                                                                                                                  |                                                          |
| A/D converter                   |                                          | Holds operation (conversion result held) <sup>Note</sup>                                                                                                         |                                                          |
| D/A converter                   |                                          | Holds operation (output held Note)                                                                                                                               |                                                          |
| Real-time output function (RTO) |                                          | Stops operation (output held)                                                                                                                                    |                                                          |
| Key interrupt function (KR)     |                                          | Operable                                                                                                                                                         |                                                          |
| CRC arithmetic circuit          |                                          | Stops operation                                                                                                                                                  |                                                          |
| External bus interface          |                                          | See 2.2 Pin States.                                                                                                                                              |                                                          |
| Port function                   |                                          | Retains status before IDLE1 mode was set                                                                                                                         |                                                          |
| Internal data                   |                                          | The CPU registers, statuses, data, and all other internal data such as the contents of the internal RAM are retained as they were before the IDLE1 mode was set. |                                                          |

**Note** To realize low power consumption, stop the A/D converter and D/A converter before shifting to the IDLE1 mode.

#### 24.5 IDLE2 Mode

### 24.5.1 Setting and operation status

The IDLE2 mode is set by setting the PSMR.PSM1 and PSMR.PSM0 bits to 10 and setting the PSC.STP bit to 1 in the normal operation mode.

In the IDLE2 mode, the clock oscillator continues operation but clock supply to the CPU, PLL, flash memory, and other on-chip peripheral functions stops.

As a result, program execution stops and the contents of the internal RAM before the IDLE2 mode was set are retained. The CPU, PLL, and other on-chip peripheral functions stop operating. However, the on-chip peripheral functions that can operate with the subclock or an external clock continue operating.

Table 24-7 shows the operating status in the IDLE2 mode.

The IDLE2 mode can reduce the power consumption more than the IDLE1 mode because it stops the operations of the on-chip peripheral functions, PLL, and flash memory. However, because the PLL and flash memory are stopped, a setup time for the PLL and flash memory is required when IDLE2 mode is released.

- Cautions 1. Insert five or more NOP instructions after the instruction that stores data in the PSC register to set the IDLE2 mode.
  - 2. If the IDLE2 mode is set while an unmasked interrupt request signal is being held pending, the IDLE2 mode is released immediately by the pending interrupt request.

#### 24.5.2 Releasing IDLE2 mode

The IDLE2 mode is released by a non-maskable interrupt request signal (NMI pin input, INTWDT2 signal), unmasked external interrupt request signal (INTP0 to INTP7 pin input), unmasked internal interrupt request signal from the peripheral functions operable in the IDLE2 mode, or reset signal (reset by RESET pin input, WDT2RES signal, or clock monitor (CLM)). The PLL returns to the operating status it was in before the IDLE2 mode was set.

After the IDLE2 mode has been released, the normal operation mode is restored.

# (1) Releasing IDLE2 mode by non-maskable interrupt request signal or unmasked maskable interrupt request signal

The IDLE2 mode is released by a non-maskable interrupt request signal or an unmasked maskable interrupt request signal, regardless of the priority of the interrupt request signal. If the IDLE2 mode is set in an interrupt servicing routine, however, an interrupt request signal that is issued later is processed as follows.

- (a) If an interrupt request signal with a priority lower than that of the interrupt request currently being serviced is issued, the IDLE2 mode is released, but that interrupt request signal is not acknowledged. The interrupt request signal itself is retained.
- (b) If an interrupt request signal with a priority higher than that of the interrupt request currently being serviced is issued (including a non-maskable interrupt request signal), the IDLE2 mode is released and that interrupt request signal is acknowledged.

Caution The interrupt request signal that is disabled by setting the PSC.NMI1M, PSC.NMI0M, and PSC.INTM bits to 1 becomes invalid and IDLE2 mode is not released.

Table 24-6. Operation After Releasing IDLE2 Mode by Interrupt Request Signal

| Release Source                        | Interrupt Enabled (EI) Status Interrupt Disabled (DI) Status                                                            |                                                                            |  |  |
|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--|--|
| Non-maskable interrupt request signal | Execution branches to the handler address af                                                                            | ter securing the prescribed setup time.                                    |  |  |
| Maskable interrupt request signal     | Execution branches to the handler address or the next instruction is executed after securing the prescribed setup time. | The next instruction is executed after securing the prescribed setup time. |  |  |

# (2) Releasing IDLE2 mode by reset

The same operation as the normal reset operation is performed.

Table 24-7. Operating Status in IDLE2 Mode

|                             | Setting of IDLE2 Mode                    | Operatin                                                                                                                                                         | ng Status                                                |  |
|-----------------------------|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|--|
| Item                        |                                          | When Subclock Is Not Used                                                                                                                                        | When Subclock Is Used                                    |  |
| Main clock oscillator       |                                          | Oscillation enabled                                                                                                                                              |                                                          |  |
| Subclock oscillator         | r                                        | -                                                                                                                                                                | Oscillation enabled                                      |  |
| Internal oscillator         |                                          | Oscillation enabled                                                                                                                                              |                                                          |  |
| PLL                         |                                          | Stops operation                                                                                                                                                  |                                                          |  |
| CPU                         |                                          | Stops operation                                                                                                                                                  |                                                          |  |
| DMA                         |                                          | Stops operation                                                                                                                                                  |                                                          |  |
| Interrupt controller        |                                          | Stops operation (but standby mode can be                                                                                                                         | released)                                                |  |
| ROM correction              |                                          | Stops operation                                                                                                                                                  |                                                          |  |
| Timer P (TMP0 to            | TMP5)                                    | Stops operation                                                                                                                                                  |                                                          |  |
| Timer Q (TMP0)              |                                          | Stops operation                                                                                                                                                  |                                                          |  |
| Timer M (TMM0)              |                                          | Operable when fr/8 is selected as the count clock                                                                                                                | Operable when fR/8 or fxT is selected as the count clock |  |
| Watch timer                 |                                          | Operable when fx (divided BRG) is selected as the count clock                                                                                                    | Operable                                                 |  |
| Watchdog timer 2            |                                          | Operable when fn is selected as the count clock                                                                                                                  | Operable when fR or fxT is selected as the count clock   |  |
| Serial interface            | CSIB0 to CSIB4                           | Operable when the SCKBn input clock is selected as the count clock (n = 0 to 4)                                                                                  |                                                          |  |
|                             | I <sup>2</sup> C00 to I <sup>2</sup> C02 | Stops operation                                                                                                                                                  |                                                          |  |
|                             | UARTA0 to UARTA2                         | Stops operation (but UARTA0 is operable v                                                                                                                        | when the ASCKA0 input clock is selected)                 |  |
| CAN controller              |                                          | Stops operation                                                                                                                                                  |                                                          |  |
| IEBus controller            |                                          | Stops operation                                                                                                                                                  |                                                          |  |
| A/D converter               |                                          | Holds operation (conversion result held) <sup>Note</sup>                                                                                                         |                                                          |  |
| D/A converter               |                                          | Holds operation (output held <sup>Note</sup> )                                                                                                                   |                                                          |  |
| Real-time output for        | unction (RTO)                            | Stops operation (output held)                                                                                                                                    |                                                          |  |
| Key interrupt function (KR) |                                          | Operable                                                                                                                                                         |                                                          |  |
| CRC arithmetic circuit      |                                          | Stops operation                                                                                                                                                  |                                                          |  |
| External bus interface      |                                          | See 2.2 Pin States.                                                                                                                                              |                                                          |  |
| Port function               |                                          | Retains status before IDLE2 mode was se                                                                                                                          | t                                                        |  |
| Internal data               |                                          | The CPU registers, statuses, data, and all other internal data such as the contents of the internal RAM are retained as they were before the IDLE2 mode was set. |                                                          |  |

**Note** To realize low power consumption, stop the A/D converter and D/A converter before shifting to the IDLE2 mode.

### 24.5.3 Securing setup time when releasing IDLE2 mode

Secure the setup time for the ROM (flash memory) after releasing the IDLE2 mode because the operation of the blocks other than the main clock oscillator stops after the IDLE2 mode is set.

# (1) Releasing IDLE2 mode by non-maskable interrupt request signal or unmasked maskable interrupt request signal

Secure the specified setup time by setting the OSTS register.

When the releasing source is generated, the dedicated internal timer starts counting according to the OSTS register setting. When it overflows, the normal operation mode is restored.



## (2) Release by reset (RESET pin input, WDT2RES generation)

This operation is the same as that of a normal reset.

The oscillation stabilization time is the initial value of the OSTS register, 2<sup>16</sup>/fx.

#### 24.6 STOP Mode

## 24.6.1 Setting and operation status

The STOP mode is set by setting the PSMR.PSM1 and PSMR.PSM0 bits to 01 or 11 and setting the PSC.STP bit to 1 in the normal operation mode.

In the STOP mode, the subclock oscillator continues operating but the main clock oscillator stops. Clock supply to the CPU and the on-chip peripheral functions is stopped.

As a result, program execution stops, and the contents of the internal RAM before the STOP mode was set are retained. The on-chip peripheral functions that operate with the clock oscillated by the subclock oscillator or an external clock continue operating.

Table 24-9 shows the operating status in the STOP mode.

Because the STOP mode stops operation of the main clock oscillator, it reduces the power consumption to a level lower than the IDLE2 mode. If the subclock oscillator, internal oscillator, and external clock are not used, the power consumption can be minimized with only leakage current flowing.

# Cautions 1, Insert five or more NOP instructions after the instruction that stores data in the PSC register to set the STOP mode.

2. If the STOP mode is set while an unmasked interrupt request signal is being held pending, the STOP mode is released immediately by the pending interrupt request.

#### 24.6.2 Releasing STOP mode

The STOP mode is released by a non-maskable interrupt request signal (NMI pin input, INTWDT2 signal), unmasked external interrupt request signal (INTP0 to INTP7 pin input), unmasked internal interrupt request signal from the peripheral functions operable in the STOP mode, or reset signal (reset by RESET pin input or WDT2RES signal.

After the STOP mode has been released, the normal operation mode is restored after the oscillation stabilization time has been secured.

# (1) Releasing STOP mode by non-maskable interrupt request signal or unmasked maskable interrupt request signal

The STOP mode is released by a non-maskable interrupt request signal or an unmasked maskable interrupt request signal, regardless of the priority of the interrupt request signal. If the STOP mode is set in an interrupt servicing routine, however, an interrupt request signal that is issued later is serviced as follows.

- (a) If an interrupt request signal with a priority lower than that of the interrupt request currently being serviced is issued, the STOP mode is released, but that interrupt request signal is not acknowledged. The interrupt request signal itself is retained.
- (b) If an interrupt request signal with a priority higher than that of the interrupt request currently being serviced is issued (including a non-maskable interrupt request signal), the STOP mode is released and that interrupt request signal is acknowledged.

Caution The interrupt request that is disabled by setting the PSC.NMI1M, PSC.NMI0M, and PSC.INTM bits to 1 becomes invalid and STOP mode is not released.

Table 24-8. Operation After Releasing STOP Mode by Interrupt Request Signal

| Release Source                        | Interrupt Enabled (EI) Status                                                                                                    | Interrupt Enabled (EI) Status Interrupt Disabled (DI) Status                        |  |  |  |
|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|--|--|--|
| Non-maskable interrupt request signal | Execution branches to the handler address aft                                                                                    | ter securing the oscillation stabilization time.                                    |  |  |  |
| Maskable interrupt request signal     | Execution branches to the handler address or the next instruction is executed after securing the oscillation stabilization time. | The next instruction is executed after securing the oscillation stabilization time. |  |  |  |

### (2) Releasing STOP mode by reset

The same operation as the normal reset operation is performed.

Table 24-9. Operating Status in STOP Mode

| Setting of STOP Mode        |                                          | Operatii                                                                                                                                                        | ng Status                                                        |  |
|-----------------------------|------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|--|
| Item                        |                                          | When Subclock Is Not Used                                                                                                                                       | When Subclock Is Used                                            |  |
| Main clock oscillator       |                                          | Stops oscillation                                                                                                                                               |                                                                  |  |
| Subclock oscillato          | r                                        | _                                                                                                                                                               | Oscillation enabled                                              |  |
| Internal oscillator         |                                          | Oscillation enabled                                                                                                                                             |                                                                  |  |
| PLL                         |                                          | Stops operation                                                                                                                                                 |                                                                  |  |
| CPU                         |                                          | Stops operation                                                                                                                                                 |                                                                  |  |
| DMA                         |                                          | Stops operation                                                                                                                                                 |                                                                  |  |
| Interrupt controller        | ſ                                        | Stops operation (but standby mode can be released)                                                                                                              |                                                                  |  |
| ROM correction              |                                          | Stops operation                                                                                                                                                 |                                                                  |  |
| Timer P (TMP0 to            | TMP5)                                    | Stops operation                                                                                                                                                 |                                                                  |  |
| Timer Q (TMP0)              |                                          | Stops operation                                                                                                                                                 |                                                                  |  |
| Timer M (TMM0)              |                                          | Operable when fa/8 is selected as the count clock                                                                                                               | Operable when $f_R/8$ or $f_{XT}$ is selected as the count clock |  |
| Watch timer                 |                                          | Stops operation                                                                                                                                                 | Operable when fxT is selected as the count clock                 |  |
| Watchdog timer 2            |                                          | Operable when fR is selected as the count clock                                                                                                                 | Operable when fR or fxT is selected as the count clock           |  |
| Serial interface            | CSIB0 to CSIB4                           | Operable when the SCKBn input clock is selected as the count clock (n = 0 to 4)                                                                                 |                                                                  |  |
|                             | I <sup>2</sup> C00 to I <sup>2</sup> C02 | Stops operation                                                                                                                                                 |                                                                  |  |
|                             | UARTA0 to UARTA2                         | Stops operation (but UARTA0 is operable                                                                                                                         | when the ASCKA0 input clock is selected)                         |  |
| CAN controller              |                                          | Stops operation                                                                                                                                                 |                                                                  |  |
| IEBus controller            |                                          | Stops operation                                                                                                                                                 |                                                                  |  |
| A/D converter               |                                          | Stops operation (conversion result undefined) <sup>Notes 1, 2</sup>                                                                                             |                                                                  |  |
| D/A converter               |                                          | Stops operation <sup>Notes 3, 4</sup> (high impedance is output)                                                                                                |                                                                  |  |
| Real-time output f          | unction (RTO)                            | Stops operation (output held)                                                                                                                                   |                                                                  |  |
| Key interrupt function (KR) |                                          | Operable                                                                                                                                                        |                                                                  |  |
| CRC arithmetic circuit      |                                          | Stops operation                                                                                                                                                 |                                                                  |  |
| External bus interface      |                                          | See 2.2 Pin States.                                                                                                                                             |                                                                  |  |
| Port function               |                                          | Retains status before STOP mode was set                                                                                                                         |                                                                  |  |
| Internal data               |                                          | The CPU registers, statuses, data, and all other internal data such as the contents of the internal RAM are retained as they were before the STOP mode was set. |                                                                  |  |

- Notes 1. If the STOP mode is set while the A/D converter is operating, the A/D converter is automatically stopped and starts operating again after the STOP mode is released. However, in that case, the A/D conversion results after the STOP mode is released are invalid. All the A/D conversion results before the STOP mode is set are invalid.
  - **2.** Even if the STOP mode is set while the A/D converter is operating, the power consumption is reduced equivalently to when the A/D converter is stopped before the STOP mode is set.
  - 3. If the STOP mode is set while the D/A converter is operating, the D/A converter is automatically stopped and the pin status becomes high impedance. After the STOP mode is released, D/A conversion resumes, the setting time elapses, and the status returns to the output level before the STOP mode was set.
  - **4.** Even if the STOP mode is set while the D/A converter is operating, the power consumption is reduced equivalently to when the D/A converter is stopped before the STOP mode is set.

### 24.6.3 Securing oscillation stabilization time when releasing STOP mode

Secure the oscillation stabilization time for the main clock oscillator after releasing the STOP mode because the operation of the main clock oscillator stops after STOP mode is set.

# (1) Releasing STOP mode by non-maskable interrupt request signal or unmasked maskable interrupt request signal

Secure the oscillation stabilization time by setting the OSTS register.

When the releasing source is generated, the dedicated internal timer starts counting according to the OSTS register setting. When it overflows, the normal operation mode is restored.



### (2) Release by reset

This operation is the same as that of a normal reset.

The oscillation stabilization time is the initial value of the OSTS register, 216/fx.

### 24.7 Subclock Operation Mode

### 24.7.1 Setting and operation status

The subclock operation mode is set by setting the PCC.CK3 bit to 1 in the normal operation mode.

When the subclock operation mode is set, the internal system clock is changed from the main clock to the subclock. Check whether the clock has been switched by using the PCC.CLS bit.

When the PCC.MCK bit is set to 1, the operation of the main clock oscillator is stopped. As a result, the system operates only on the subclock.

In the subclock operation mode, the power consumption can be reduced to a level lower than in the normal operation mode because the subclock is used as the internal system clock. In addition, the power consumption can be further reduced to the level of the STOP mode by stopping the operation of the main clock oscillator.

Table 24-10 shows the operating status in subclock operation mode.

- Cautions 1. When manipulating the CK3 bit, do not change the set values of the PCC.CK2 to PCC.CK0 bits (using a bit manipulation instruction to manipulate the bit is recommended). For details of the PCC register, see 6.3 (1) Processor clock control register (PCC).
  - 2. If the following conditions are not satisfied, change the CK2 to CK0 bits so that the conditions are satisfied and set the subclock operation mode.

Internal system clock (fclk) > Subclock (fxt = 32.768 kHz) × 4

Remark Internal system clock (fclk): Clock generated from the main clock (fxx) by setting the CK2 to CK0 bits

### 24.7.2 Releasing subclock operation mode

The subclock operation mode is released by a reset signal (reset by  $\overline{\text{RESET}}$  pin input, WDT2RES signal, or clock monitor (CLM)) when the CK3 bit is cleared to 0.

If the main clock is stopped (MCK bit = 1), set the MCK bit to 1, secure the oscillation stabilization time of the main clock by software, and clear the CK3 bit to 0.

The normal operation mode is restored when the subclock operation mode is released.

Caution When manipulating the CK3 bit, do not change the set values of the CK2 to CK0 bits (using a bit manipulation instruction to manipulate the bit is recommended).

For details of the PCC register, see 6.3 (1) Processor clock control register (PCC).

Table 24-10. Operating Status in Subclock Operation Mode

| Setting of Su                | ubclock Operation Mode                   | Opera                                                                         | ating Status                                                                      |  |
|------------------------------|------------------------------------------|-------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--|
| Item                         |                                          | When Main Clock Is Oscillating                                                | When Main Clock Is Stopped                                                        |  |
| Subclock oscillato           | or                                       | Oscillation enabled                                                           |                                                                                   |  |
| Internal oscillator          |                                          | Oscillation enabled                                                           |                                                                                   |  |
| PLL                          |                                          | Operable Stops operation <sup>Note</sup>                                      |                                                                                   |  |
| CPU                          |                                          | Operable                                                                      |                                                                                   |  |
| DMA                          |                                          | Operable                                                                      |                                                                                   |  |
| Interrupt controlle          | r                                        | Operable                                                                      |                                                                                   |  |
| ROM correction               |                                          | Operable                                                                      |                                                                                   |  |
| Timer P (TMP0 to             | TMP5)                                    | Operable                                                                      | Stops operation                                                                   |  |
| Timer Q (TMP0)               |                                          | Operable                                                                      | Stops operation                                                                   |  |
| Timer M (TMM0)               |                                          | Operable                                                                      | Operable when f <sub>R</sub> /8 or f <sub>XT</sub> is selected as the count clock |  |
| Watch timer Watchdog timer 2 |                                          | Operable                                                                      | Operable when fxT is selected as the count clock                                  |  |
|                              |                                          | Operable                                                                      | Operable when fn or fxt is selected as the count clock                            |  |
| Serial interface             | CSIB0 to CSIB4                           | Operable                                                                      | Operable when the SCKBn input clock is selected as the count clock (n = 0 to 4)   |  |
|                              | I <sup>2</sup> C00 to I <sup>2</sup> C02 | Operable                                                                      | Stops operation                                                                   |  |
|                              | UARTA0 to UARTA2                         | Operable Stops operation (but UARTA0 operable when the ASCKA0 ir is selected) |                                                                                   |  |
| CAN controller               |                                          | Operable                                                                      | Stops operation                                                                   |  |
| IEBus controller             |                                          | Operable                                                                      | Stops operation                                                                   |  |
| A/D converter                |                                          | Operable                                                                      | Stops operation                                                                   |  |
| D/A converter                |                                          | Operable                                                                      | •                                                                                 |  |
| Real-time output t           | function (RTO)                           | Operable                                                                      | Stops operation (output held)                                                     |  |
| Key interrupt function (KR)  |                                          | Operable                                                                      |                                                                                   |  |
| CRC arithmetic ci            | rcuit                                    | Operable                                                                      |                                                                                   |  |
| External bus inter           | face                                     | See 2.2 Pin States.                                                           |                                                                                   |  |
| Port function                |                                          | Settable                                                                      |                                                                                   |  |
| Internal data                |                                          | Settable                                                                      |                                                                                   |  |

**Note** To stop the main clock, be sure to stop PLL (PLLCTL.PLLON bit = 0).

Caution When the CPU is operating on the subclock and main clock oscillation is stopped, accessing a register in which a wait occurs is disabled. If a wait is generated, it can be released only by reset (see 3.4.9 (2)).

#### 24.8 Sub-IDLE Mode

## 24.8.1 Setting and operation status

The sub-IDLE mode is set by setting the PSMR.PSM1 and PSMR.PSM0 bits to 00 or 10 and setting the PSC.STP bit to 1 in the subclock operation mode.

In this mode, the clock oscillator continues operating but clock supply to the CPU, flash memory, and the other onchip peripheral functions is stopped.

As a result, program execution stops and the contents of the internal RAM before the sub-IDLE mode was set are retained. The CPU and the other on-chip peripheral functions are stopped. However, the on-chip peripheral functions that can operate with the subclock or an external clock continue operating.

Because the sub-IDLE mode stops operation of the CPU, flash memory, and other on-chip peripheral functions, it can reduce the power consumption more than the subclock operation mode. If the sub-IDLE mode is set after the main clock has been stopped, the current consumption can be reduced to a level as low as that in the STOP mode.

Table 24-12 shows the operating status in the sub-IDLE mode.

- Cautions 1. Following the store instruction to set the PSC register to the sub-IDLE mode, insert the five or more NOP instructions.
  - If the sub-IDLE mode is set while an unmasked interrupt request signal is being held pending, the sub-IDLE mode is then released immediately by the pending interrupt request.

## 24.8.2 Releasing sub-IDLE mode

The sub-IDLE mode is released by a non-maskable interrupt request signal (NMI pin input, INTWDT2 signal), unmasked external interrupt request signal (INTP0 to INTP7 pin input), unmasked internal interrupt request signal from the peripheral functions operable in the sub-IDLE mode, or reset signal (reset by  $\overline{\text{RESET}}$  pin input, WDT2RES signal, or clock monitor (CLM)). The PLL returns to the operating status it was in before the sub-IDLE mode was set.

When the sub-IDLE mode is released by an interrupt request signal, the subclock operation mode is set.

# (1) Releasing sub-IDLE mode by non-maskable interrupt request signal or unmasked maskable interrupt request signal

The sub-IDLE mode is released by a non-maskable interrupt request signal or an unmasked maskable interrupt request signal, regardless of the priority of the interrupt request signal.

If the sub-IDLE mode is set in an interrupt servicing routine, however, an interrupt request signal that is issued later is serviced as follows.

- (a) If an interrupt request signal with a priority lower than that of the interrupt request currently being serviced is issued, the sub-IDLE mode is released, but that interrupt request signal is not acknowledged. The interrupt request signal itself is retained.
- (b) If an interrupt request signal with a priority higher than that of the interrupt request currently being serviced is issued (including a non-maskable interrupt request signal), the sub-IDLE mode is released and that interrupt request signal is acknowledged.
- Cautions 1. The interrupt request signal that is disabled by setting the PSC.NMI1M, PSC.NMI0M, and PSC.INTM bits to 1 becomes invalid and sub-IDLE mode is not released.
  - 2. When the sub-IDLE mode is released, 12 cycles of the subclock (about 366  $\mu$ s) elapse from when the interrupt request signal that releases the sub-IDLE mode is generated to when the mode is released.

Table 24-11. Operation After Releasing Sub-IDLE Mode by Interrupt Request Signal

| Release Source                        | Interrupt Enabled (EI) Status                                                  | Interrupt Disabled (DI) Status    |  |
|---------------------------------------|--------------------------------------------------------------------------------|-----------------------------------|--|
| Non-maskable interrupt request signal | • •                                                                            |                                   |  |
| Maskable interrupt request signal     | Execution branches to the handler address or the next instruction is executed. | The next instruction is executed. |  |

## (2) Releasing sub-IDLE mode by reset

The same operation as the normal reset operation is performed.

Table 24-12. Operating Status in Sub-IDLE Mode

| Setting of Sub-IDLE Mode |                                          | Operatin                                                                                                                                                            | ng Status                                        |  |
|--------------------------|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|--|
| Item                     |                                          | When Main Clock Is Oscillating                                                                                                                                      | When Main Clock Is Stopped                       |  |
| Subclock oscillator      |                                          | Oscillation enabled                                                                                                                                                 |                                                  |  |
| Internal oscillator      |                                          | Oscillation enabled                                                                                                                                                 |                                                  |  |
| PLL                      |                                          | Operable                                                                                                                                                            | Stops operationNote 1                            |  |
| CPU                      |                                          | Stops operation                                                                                                                                                     |                                                  |  |
| DMA                      |                                          | Stops operation                                                                                                                                                     |                                                  |  |
| Interrupt controlle      | r                                        | Stops operation (but standby mode can be                                                                                                                            | released)                                        |  |
| ROM correction           |                                          | Stops operation                                                                                                                                                     |                                                  |  |
| Timer P (TMP0 to         | TMP5)                                    | Stops operation                                                                                                                                                     |                                                  |  |
| Timer Q (TMP0)           |                                          | Stops operation                                                                                                                                                     |                                                  |  |
| Timer M (TMM0)           |                                          | Operable when fe/8 or fxT is selected as the                                                                                                                        | e count clock                                    |  |
| Watch timer              |                                          | Stops operation                                                                                                                                                     | Operable when fxT is selected as the count clock |  |
| Watchdog timer 2         |                                          | Operable when f <sub>R</sub> or f <sub>XT</sub> is selected as the count clock                                                                                      |                                                  |  |
| Serial interface         | CSIB0 to CSIB4                           | Operable when the SCKBn input clock is selected as the count clock (n = 0 to 4)                                                                                     |                                                  |  |
|                          | I <sup>2</sup> C00 to I <sup>2</sup> C02 | Stops operation                                                                                                                                                     |                                                  |  |
|                          | UARTA0 to UARTA2                         | Stops operation (but UARTA0 is operable when the ASCKA0 input clock is selected)                                                                                    |                                                  |  |
| CAN controller           |                                          | Stops operation                                                                                                                                                     |                                                  |  |
| IEBus controller         |                                          | Stops operation                                                                                                                                                     |                                                  |  |
| A/D converter            |                                          | Holds operation (conversion result held) <sup>Note 2</sup>                                                                                                          |                                                  |  |
| D/A converter            |                                          | Holds operation (output held <sup>Note 2</sup> )                                                                                                                    |                                                  |  |
| Real-time output f       | unction (RTO)                            | Stops operation (output held)                                                                                                                                       |                                                  |  |
| Key interrupt func       | tion (KR)                                | Operable                                                                                                                                                            |                                                  |  |
| CRC arithmetic ci        | rcuit                                    | Stops operation                                                                                                                                                     |                                                  |  |
| External bus inter       | face                                     | See 2.2 Pin States (same operation status as IDLE1, IDLE2 mode).                                                                                                    |                                                  |  |
| Port function            |                                          | Retains status before sub-IDLE mode was set                                                                                                                         |                                                  |  |
| Internal data            |                                          | The CPU registers, statuses, data, and all other internal data such as the contents of the internal RAM are retained as they were before the sub-IDLE mode was set. |                                                  |  |

**Notes 1.** Be sure to stop the PLL (PLLCTL.PLLON bit = 0) before stopping the main clock.

2. To realize low power consumption, stop the A/D and D/A converters before shifting to the sub-IDLE mode.

### **CHAPTER 25 RESET FUNCTIONS**

#### 25.1 Overview

The following reset functions are available.

#### (1) Three kinds of reset sources

- External reset input via the RESET pin
- Reset via the watchdog timer 2 (WDT2) overflow (WDT2RES)
- System reset via the detecting clock monitor (CLM) oscillation stop

After a reset is released, the source of the reset can be confirmed with the reset source flag register (RESF).

### (2) Emergency operation mode

If the WDT2 overflows during the main clock oscillation stabilization time inserted after reset, a main clock oscillation anomaly is judged and the CPU starts operating on the internal oscillation clock.

Caution When the CPU operates on the internal oscillation clock, access to the register in which a wait state is generated is prohibited. For the register in which a wait state is generated, see 3.4.9 (2) Accessing specific on-chip peripheral I/O registers.

Reset source flag register (RESF)

WDT2RF CLMRF

Set Set Set

Reset signal

CLM reset signal

Clear Clear

Reset signal

Reset signal

Figure 25-1. Block Diagram of Reset Function

## 25.2 Registers to Check Reset Source

The V850ES/SG2 has three kinds of reset sources. After a reset has been released, the source of the reset that occurred can be checked with the reset source flag register (RESF).

### (1) Reset source flag register (RESF)

The RESF register is a special register that can be written only by a combination of specific sequences (see **3.4.8 Special registers**).

The RESF register indicates the source from which a reset signal is generated.

This register is read or written in 8-bit or 1-bit units.

RESET pin input clears this register to 00H. The default value differs if the source of reset is other than the RESET pin signal.



| WDT2RF | Reset signal from WDT2 |
|--------|------------------------|
| 0      | Not generated          |
| 1      | Generated              |

| CLMRF | Reset signal from CLM |
|-------|-----------------------|
| 0     | Not generated         |
| 1     | Generated             |

Note The value of the RESF register is cleared to 00H when a reset is executed via the RESET pin.

When a reset is executed by the watchdog timer 2 (WDT2) or clock monitor (CLM), the reset flags of this register (WDT2RF and CLMRF bits) are set. However, other sources are retained.

Caution Only "0" can be written to each bit of this register. If writing "0" conflicts with setting the flag (occurrence of reset), setting the flag takes precedence.

## 25.3 Operation

# 25.3.1 Reset operation via RESET pin

When a low level is input to the  $\overline{\text{RESET}}$  pin, the system is reset, and each hardware unit is initialized. When the level of the  $\overline{\text{RESET}}$  pin is changed from low to high, the reset status is released.

Table 25-1. Hardware Status on RESET Pin Input

| Item                                              | During Reset After Reset                                                                    |                                                                                       |  |  |
|---------------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--|--|
| Main clock oscillator (fx)                        | Oscillation stops                                                                           | Oscillation starts                                                                    |  |  |
| Subclock oscillator (fxT)                         | Oscillation continues                                                                       |                                                                                       |  |  |
| Internal oscillator                               | Oscillation stops Oscillation starts                                                        |                                                                                       |  |  |
| Peripheral clock (fx to fx/1,024)                 | Operation stops Operation starts after securing osc stabilization time                      |                                                                                       |  |  |
| Internal system clock (fcLk),<br>CPU clock (fcPu) | Operation stops                                                                             | Operation starts after securing oscillation stabilization time (initialized to fxx/8) |  |  |
| CPU                                               | Initialized                                                                                 | Program execution starts after securing oscillation stabilization time                |  |  |
| Watchdog timer 2                                  | Operation stops (initialized to 0)                                                          | Counts up from 0 with internal oscillation clock as source clock.                     |  |  |
| Internal RAM                                      | Undefined if power-on reset or CPU access a<br>Otherwise value immediately after reset inpu |                                                                                       |  |  |
| I/O lines (ports/alternate-function pins)         | High impedance <sup>Note 2</sup>                                                            |                                                                                       |  |  |
| On-chip peripheral I/O registers                  | Initialized to specified status, OCDM register is set (01H).                                |                                                                                       |  |  |
| Other on-chip peripheral functions                | Operation stops Operation can be started after securion oscillation stabilization time      |                                                                                       |  |  |

- **Notes 1.** The firmware of the V850ES/SG2 uses part of the internal RAM after the internal system reset operation has been released because it supports a boot swap function. Therefore, the contents of some RAM areas are not retained on power-on reset. For details, see **25.3.3 Operation after reset release**.
  - 2. When the power is turned on, the following pins may output an undefined level temporarily even during reset.
    - P10/ANO0 pin
    - P11/ANO1 pin
    - P53/SIB2/KR3/TIQ00/TOQ00/RTP03/DDO pin (the DDO pin is provided only in the flash memory version)

Caution The OCDM register is initialized by the RESET pin input. Therefore, note with caution that, if a high level is input to the P05/DRST pin after a reset release before the OCDM.OCDM0 bit is cleared, the V850ES/SG2 may enter on-chip debug mode (flash memory versions only). The mask ROM versions do not support the on-chip debug mode; however the OCDM register controls the pull-down resistor connected to the P05/INTP2 pin. For details, see CHAPTER 4 PORT FUNCTIONS.



Figure 25-2. Timing of Reset Operation by RESET Pin Input





### 25.3.2 Reset operation by watchdog timer 2

When watchdog timer 2 is set to the reset operation mode due to overflow, upon watchdog timer 2 overflow (WDT2RES signal generation), a system reset is executed and the hardware is initialized to the initial status.

Following watchdog timer 2 overflow, the reset status is entered and lasts the predetermined time (analog delay), and the reset status is then automatically released.

The main clock oscillator is stopped during the reset period.

Table 25-2. Hardware Status During Watchdog Timer 2 Reset Operation

| Item                                             | During Reset                                                                                | After Reset                                                       |  |  |
|--------------------------------------------------|---------------------------------------------------------------------------------------------|-------------------------------------------------------------------|--|--|
| Main clock oscillator (fx)                       | Oscillation stops Oscillation starts                                                        |                                                                   |  |  |
| Subclock oscillator (fxT)                        | Oscillation continues                                                                       |                                                                   |  |  |
| Internal oscillator                              | Oscillation stops Oscillation starts                                                        |                                                                   |  |  |
| Peripheral clock (fxx to fxx/1,024)              | Operation stops Operation starts after securing oscil stabilization time                    |                                                                   |  |  |
| Internal system clock (fxx),<br>CPU clock (fcpu) | Operation stops Operation starts after securing os stabilization time (initialized to fxx)  |                                                                   |  |  |
| CPU                                              | Initialized                                                                                 | Program execution after securing oscillation stabilization time   |  |  |
| Watchdog timer 2                                 | Operation stops (initialized to 0)                                                          | Counts up from 0 with internal oscillation clock as source clock. |  |  |
| Internal RAM                                     | Undefined if power-on reset or CPU access a<br>Otherwise value immediately after reset inpu |                                                                   |  |  |
| I/O lines (ports/alternate-function pins)        | High impedance                                                                              |                                                                   |  |  |
| On-chip peripheral I/O register                  | Initialized to specified status, OCDM register retains its value.                           |                                                                   |  |  |
| On-chip peripheral functions other than above    | Operation stops Operation can be started after securing oscillation stabilization time.     |                                                                   |  |  |

**Note** The firmware of the V850ES/SG2 uses part of the internal RAM after the internal system reset operation has been released because it supports a boot swap function. Therefore, the contents of some RAM areas are not retained on power-on reset. For details, see **25.3.3 Operation after reset release**.



Figure 25-4. Timing of Reset Operation by WDT2RES Signal Generation

### 25.3.3 Operation after reset release

After the reset is released, the main clock starts oscillation and oscillation stabilization time (OSTS register initial value: 2<sup>16</sup>/fx) is secured, and the CPU starts program execution.

WDT2 immediately begins to operate after a reset has been released using the internal oscillation clock as a source clock.



Figure 25-5. Operation After Reset Release

## (1) Emergent operation mode

If an anomaly occurs in the main clock before oscillation stabilization time is secured, the WDT2 overflows before executing the CPU program. At this time, the CPU starts program execution by using the internal oscillation clock as the source clock.



Figure 25-6. Operation After Reset Release

The CPU operation clock states can be checked with the CPU operation clock status register (CCLS).

### (2) Firmware operation (flash memory version only)

In the flash memory version, after a reset is released, the on-chip firmware operates before starting the user program to support the boot switch function.



Since the firmware uses a portion of the internal RAM, the contents of the RAM areas of 03FF3000H to 03FF3095H and 03FFEFBAH to 03FFEFFFH are not retained through a reset even in power on status.



### 25.3.4 Reset function operation flow



# 25.4 Valid/Invalid of Internal RAM Data

# (1) Internal RAM data status register (RAMS)

The RAMS register is a special register. This can be written only in a special combination of sequences (see 3.4.8 Special registers).

This register is a flag register that indicates whether the internal RAM is valid or not.

This register can be read or written in 8-bit or 1-bit units.

The set/clear conditions for the RAMF bit are shown below.

• Setting conditions: Detection of voltage lower than specified level

Set by instruction

Generation of reset signal by WDT2 and CLM

Generation of reset signal while RAM is being accessed

Generation of reset signal via the RESET pin while internal RAM is being accessed.

• Clearing condition: Writing of 0 in specific sequence

| After reset: 01H <sup>Note</sup> R/W |   | Address: F | FFFF892H |   |   |   |   |      |
|--------------------------------------|---|------------|----------|---|---|---|---|------|
|                                      | 7 | 6          | 5        | 4 | 3 | 2 | 1 | <0>  |
| RAMS                                 | 0 | 0          | 0        | 0 | 0 | 0 | 0 | RAMF |

| RAMF | Internal RAM data valid/invalid |
|------|---------------------------------|
| 0    | Valid                           |
| 1    | Invalid                         |

Note This register is set to 01H after reset by the RESET pin input (only for RAM access), watchdog timer 2 overflow, or clock monitor. After reset by other sources, the register value at that time will be retained.

### 25.4.1 RAM retention voltage detection operation

The supply voltage and detected voltage are compared. When the supply voltage drops below the detected voltage (including on power application), the RAMS.RAMF bit is set to 1.



Figure 25-7. Operation Timing of RAM Retention Voltage Detection Function

### 25.4.2 Emulation function

When an in-circuit emulator is used, the operation of the RAM retention flag (RAMS.RAMF bit) can be pseudo-controlled and emulated by manipulating the PEMU1 register on the debugger.

This register is valid only in the emulation mode. It is invalid in the normal mode.

## (1) Peripheral emulation register 1 (PEMU1)



Caution This bit is not automatically cleared.

#### [Usage]

When an in-circuit emulator is used, pseudo emulation of RAMF is realized by rewriting this register on the debugger.

- <1> CPU break (CPU operation stops.)
- <2> Set the EVARAMIN bit to 1 by using a register write command.
  By setting the EVARAMIN bit to 1, the RAMF bit is set to 1 on hardware (the internal RAM data is invalid).
- <3> Clear the EVARAMIN bit to 0 by using a register write command again.
  Unless this operation is performed (clearing the EVARAMIN bit to 0), the RAMF bit cannot be cleared to 0 by a CPU operation instruction.
- <4> Run the CPU and resume emulation.

## **CHAPTER 26 CLOCK MONITOR**

### 26.1 Functions

The clock monitor samples the main clock by using the internal oscillation clock and generates a reset request signal when oscillation of the main clock is stopped.

Once the operation of the clock monitor has been enabled by an operation enable flag, it cannot be cleared to 0 by any means other than reset.

When a reset by the clock monitor occurs, the RESF.CLMRF bit is set. For details on the RESF register, see **25.2 Registers to Check Reset Source**.

The clock monitor automatically stops under the following conditions.

- During oscillation stabilization time after STOP mode is released
- When the main clock is stopped (from when the PCC.MCK bit = 1 during subclock operation, until the PCC.CLS bit = 0 during main clock operation)
- · When the sampling clock (internal oscillation clock) is stopped
- When the CPU operates with the internal oscillation clock

## 26.2 Configuration

The clock monitor consists of the following hardware.

Table 26-1. Configuration of Clock Monitor

| Item             | Configuration                     |  |  |
|------------------|-----------------------------------|--|--|
| Control register | Clock monitor mode register (CLM) |  |  |

Figure 26-1. Timing of Reset via the RESET Pin Input



## 26.3 Register

The clock monitor is controlled by the clock monitor mode register (CLM).

## (1) Clock monitor mode register (CLM)

The CLM register is a special register. This can be written only in a special combination of sequences (see 3.4.8 Special registers).

This register is used to set the operation mode of the clock monitor.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.

| After | After reset: 00H |   | Address: F | FFFF870H |   |   |   |      |
|-------|------------------|---|------------|----------|---|---|---|------|
|       | 7                | 6 | 5          | 4        | 3 | 2 | 1 | <0>  |
| CLM   | 0                | 0 | 0          | 0        | 0 | 0 | 0 | CLME |

| CLME | Clock monitor operation enable or disable |  |
|------|-------------------------------------------|--|
| 0    | Disable clock monitor operation.          |  |
| 1    | Enable clock monitor operation.           |  |

- Cautions 1. Once the CLME bit has been set to 1, it cannot be cleared to 0 by any means other than reset.
  - 2. When a reset by the clock monitor occurs, the CLME bit is cleared to 0 and the RESF.CLMRF bit is set to 1.

## 26.4 Operation

This section explains the functions of the clock monitor. The start and stop conditions are as follows.

### <Start condition>

Enabling operation by setting the CLM.CLME bit to 1

#### <Stop conditions>

- While oscillation stabilization time is being counted after STOP mode is released
- When the main clock is stopped (from when PCC.MCK bit = 1 during subclock operation to when PCC.CLS bit = 0 during main clock operation)
- When the sampling clock (internal oscillation clock) is stopped
- When the CPU operates with the internal oscillation clock

Table 26-2. Operation Status of Clock Monitor (When CLM.CLME Bit = 1, During Internal Oscillation Clock Operation)

| CPU Operating Clock                    | Operation Mode     | Status of Main Clock | Status of Internal<br>Oscillation Clock | Status of Clock Monitor    |
|----------------------------------------|--------------------|----------------------|-----------------------------------------|----------------------------|
| Main clock                             | HALT mode          | Oscillates           | Oscillates <sup>Note 1</sup>            | Operates <sup>Note 2</sup> |
|                                        | IDLE1, IDLE2 modes | Oscillates           | Oscillates <sup>Note 1</sup>            | Operates <sup>Note 2</sup> |
|                                        | STOP mode          | Stops                | Oscillates <sup>Note 1</sup>            | Stops                      |
| Subclock (MCK bit of PCC register = 0) | Sub-IDLE mode      | Oscillates           | Oscillates <sup>Note 1</sup>            | Operates <sup>Note 2</sup> |
| Subclock (MCK bit of PCC register = 1) | Sub-IDLE mode      | Stops                | Oscillates <sup>Note 1</sup>            | Stops                      |
| Internal oscillation clock             | _                  | Stops                | Oscillates <sup>Note 3</sup>            | Stops                      |
| During reset                           | -                  | Stops                | Stops                                   | Stops                      |

Notes 1. Internal oscillator can be stopped by setting the RCM.RSTOP bit to 1.

- 2. The clock monitor is stopped while internal oscillator is stopped.
- 3. Internal oscillator cannot be stopped by software.

### (1) Operation when main clock oscillation is stopped (CLME bit = 1)

If oscillation of the main clock is stopped when the CLME bit = 1, an internal reset signal is generated as shown in Figure 26-2.



Figure 26-2. Reset Period Due to That Oscillation of Main Clock Is Stopped

## (2) Clock monitor status after RESET input

RESET

CLME

Monitoring

Clock monitor status

RESET input clears the CLM.CLME bit to 0 and stops the clock monitor operation. When CLME bit is set to 1 by software at the end of the oscillation stabilization time of the main clock, monitoring is started.



Figure 26-3. Clock Monitor Status After  $\overline{RESET}$  Input (CLM.CLME bit = 1 is set after  $\overline{RESET}$  input and at the end of main clock oscillation stabilization time)

Set to 1 by software

Monitoring

Monitoring stopped

# (3) Operation in STOP mode or after STOP mode is released

If the STOP mode is set with the CLM.CLME bit = 1, the monitor operation is stopped in the STOP mode and while the oscillation stabilization time is being counted. After the oscillation stabilization time, the monitor operation is automatically started.



Figure 26-4. Operation in STOP Mode or After STOP Mode Is Released

#### (4) Operation when main clock is stopped (arbitrary)

During subclock operation (PCC.CLS bit = 1) or when the main clock is stopped by setting the PCC.MCK bit to 1, the monitor operation is stopped until the main clock operation is started (PCC.CLS bit = 0). The monitor operation is automatically started when the main clock operation is started.



Figure 26-5. Operation When Main Clock Is Stopped (Arbitrary)

## (5) Operation while CPU is operating on internal oscillation clock (CCLS.CCLSF bit = 1)

The monitor operation is not stopped when the CCLSF bit is 1, even if the CLME bit is set to 1.

## **CHAPTER 27 REGULATOR**

## 27.1 Outline

The V850ES/SG2 includes a regulator to reduce power consumption and noise.

This regulator supplies a stepped-down  $V_{DD}$  power supply voltage to the oscillator block and internal logic circuits (except the A/D converter, D/A converter, and output buffers). The regulator output voltage is set to 2.5 V (TYP.).



Figure 27-1. Regulator

# 27.2 Operation

The regulator of this product always operates in any mode (normal operation mode, HALT mode, IDLE1 mode, IDLE2 mode, STOP mode, or during reset).

Be sure to connect a capacitor (4.7  $\mu$ F (recommended value)) to the REGC pin to stabilize the regulator output. A diagram of the regulator pin connection method is shown below.

Figure 27-2. REGC Pin Connection



## **CHAPTER 28 ROM CORRECTION FUNCTION**

### 28.1 Overview

The ROM correction function is used to replace part of the program in the internal ROM with the program of an external memory or the internal RAM.

By using this function, program bugs found in the internal ROM can be corrected.

Up to four addresses can be specified for correction.

Figure 28-1. Block Diagram of ROM Correction



## 28.2 Registers

### (1) Correction address registers 0 to 3 (CORAD0 to CORAD3)

The CORAD0 to CORAD3 registers set the first address of the program to be corrected in the ROM.

The program can be corrected at up to four places because four CORADn registers are provided (n = 0 to 3).

The CORADn register can be read or written in 32-bit units.

If the higher 16 bits of the CORADn register are used as the CORADnH register, and the lower 16 bits as the CORADnL register, these registers can be read or written in 16-bit units.

Reset input clears these registers to 00000000H.

Because the ROM capacity differs from one product to another, set the correction addresses in the following ranges.

- μPD703262HY, 703272HY, 703282HY (512 KB): 0000000H to 007FFFFH
- $\mu$ PD703263HY, 703273HY, 703283HY, 70F3263HY, 70F3273HY, 70F3283HY (640 KB): 0000000H to 009FFFFH



### (2) Correction control register (CORCN)

The CORCN register disables or enables the correction operation at the addresses set in the CORADn register (n = 0 to 3).

Each channel can be enabled or disabled by this register.

This register can be read or written in 8-bit or 1-bit units.

Reset input clears this register to 00H.



Table 28-1. Correspondence Between CORCN Register Bits and CORADn Registers

| CORCN Register Bit | Corresponding CORADn Register |  |  |
|--------------------|-------------------------------|--|--|
| COREN3             | CORAD3                        |  |  |
| COREN2             | CORAD2                        |  |  |
| COREN1             | CORAD1                        |  |  |
| COREN0             | CORAD0                        |  |  |

# 28.3 ROM Correction Operation and Program Flow

- <1> If the address to be corrected and the fetch address of the internal ROM match, the fetch code is replaced by the DBTRAP instruction.
- <2> When the DBTRAP instruction is executed, execution branches to address 00000060H.
- <3> Software processing after branching causes the result of ROM correction to be judged (the fetch address and ROM correction operation are confirmed) and execution to branch to the correction software.
- <4> After the correction software has been executed, the return address is set, and return processing is started by the DBRET instruction.

Caution The software that performs <3> and <4> must be executed in the internal ROM/RAM.

Reset & start Initialize microcontroller Set CORADn register Load program for judgment Read data for setting ROM of ROM correction and correction from external memory correction codes Set CORCN register CORENn bit = 1? Execute fetch code No Fetch address = CORADn? Yes Execute fetch code Change fetch code to DBTRAP instruction Execute DBTRAP instruction Jump to address 00000060H Branch to ROM correction judgment address CORADn = DBPC-2? No Yes ILGOP processing Branch to correction code address of corresponding channel n Execute correction code Write return address to DBPC. Write value of PSW to DBPSW as necessary. Execute DBRET instruction Remarks 1. : Processing by user program (software) : Processing by ROM correction (hardware) **2.** n = 0 to 3

Figure 28-2. ROM Correction Operation and Program Flow

### 28.4 Cautions

- (1) When setting an address to be corrected in the CORADn register, clear the higher bits to 0 in accordance with the capacity of the internal ROM.
- (2) The ROM correction function cannot be used to correct data in the internal ROM. It can only be used to correct instruction codes. If ROM correction is used to correct data, that data is replaced with a DBTRAP instruction code.
- (3) ROM correction is not performed in regards to the ROM code before writing in the CORCNn register ends.
- (4) After executing a DBTRAP instruction, the PSW.NP, EP, and DI bits are set to 111, and interrupt/exception cannot be acknowledged. After executing a DBTRAP instruction, change the PSW register value as required.
- (5) The DBPC and DBPSW registers can be accessed while DBTRAP instructions are being executed.
- (6) If the addresses of the instructions executed immediately after the CORCNn register setting (enabled) are set as the correction addresses, normal operation may not be obtained (DBTRAP is not generated).

#### **CHAPTER 29 FLASH MEMORY**

The following products are the flash memory versions of the V850ES/SG2.

Caution There are differences in the amount of noise tolerance and noise radiation between flash memory versions and mask ROM versions. When considering changing from a flash memory version to a mask ROM version during the process from experimental manufacturing to mass production, make sure to sufficiently evaluate commercial samples (CS) (not engineering samples (ES)) of the mask ROM versions.

For the electrical specifications related to the flash memory rewriting, see CHAPTER 31 ELECTRICAL SPECIFICATIONS (TARGET).

• μPD70F3263HY, 70F3273HY, 70F3283HY:

Flash memory versions are commonly used in the following development environments and mass production applications.

- O For altering software after the V850ES/SG2 is soldered onto the target system.
- O For data adjustment when starting mass production.
- O For differentiating software according to the specification in small scale production of various models.
- O For facilitating inventory management.
- O For updating software after shipment.

The instruction fetch to the flash memory can be accessed in 4 bytes with 1 clock the same way as for mask ROM versions.

The flash memory can be written to with it mounted on the target system (on-board). Connect the dedicated flash programmer to the target system, then write.

#### 29.1 Features

- O 4-byte/1-clock access (when instruction is fetched)
- O Capacity: 640 KB
- O Write voltage: Erase/write with a single power supply
- O Rewriting method
  - Rewriting by communication with dedicated flash programmer via serial interface (on-board/off-board programming)
  - Rewriting flash memory by user program (self programming)
- O Flash memory write prohibit function supported (security function)
- O Safe rewriting of entire flash memory area by self programming using boot swap function
- O Interrupts can be acknowledged during self programming.

## 29.2 Memory Configuration

The 640 KB internal flash memory area is divided into 8 blocks and can be programmed/erased in block units. All the blocks can also be erased at once.

When the boot swap function is used, the physical memory located at the addresses of blocks 0 and 1 is replaced by the physical memory located at the addresses of blocks 2 and 3. For details of the boot swap function, see **29.5 Rewriting by Self Programming**.

Figure 29-1. Flash Memory Mapping



### 29.3 Functional Outline

The internal flash memory of the V850ES/SG2 can be rewritten by using the rewrite function of the dedicated flash programmer, regardless of whether the V850ES/SG2 has already been mounted on the target system or not (off-board/on-board programming).

In addition, a security function that prohibits rewriting the user program written to the internal flash memory is also supported, so that the program cannot be changed by an unauthorized person.

The rewrite function using the user program (self programming) is ideal for an application where it is assumed that the program is changed after production/shipment of the target system. A boot swap function that rewrites the entire flash memory area safely is also supported. In addition, interrupt servicing is supported during self programming, so that the flash memory can be rewritten under various conditions, such as while communicating with an external device.

Table 29-1. Rewrite Method

| Rewrite Method        | Functional Outline                                                                                                                                                                                                                                                                                                                                                                               | Operation Mode                |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|
| On-board programming  | Flash memory can be rewritten after the device is mounted on the target system, by using a dedicated flash programmer.                                                                                                                                                                                                                                                                           | Flash memory programming mode |
| Off-board programming | Flash memory can be rewritten before the device is mounted on the target system, by using a dedicated flash programmer and a dedicated program adapter board (FA series).                                                                                                                                                                                                                        |                               |
| Self programming      | Flash memory can be rewritten by executing a user program that has been written to the flash memory in advance by means of off-board/on-board programming. (During self-programming, instructions cannot be fetched from or data access cannot be made to the internal flash memory area. Therefore, the rewrite program must be transferred to the internal RAM or external memory in advance). | Normal operation mode         |

Remark The FA series is a product of Naito Densei Machida Mfg. Co., Ltd.

Table 29-2. Basic Functions

| Function         | Functional Outline                                                                                 | Support (O: Support               | ed, ×: Not supported)                                                  |
|------------------|----------------------------------------------------------------------------------------------------|-----------------------------------|------------------------------------------------------------------------|
|                  |                                                                                                    | On-Board/Off-Board<br>Programming | Self Programming                                                       |
| Block erasure    | The contents of specified memory blocks are erased.                                                | 0                                 | 0                                                                      |
| Chip erasure     | The contents of the entire memory area are erased all at once.                                     | 0                                 | ×                                                                      |
| Write            | Writing to specified addresses, and a verify check to see if write level is secured are performed. | 0                                 | 0                                                                      |
| Verify/checksum  | Data read from the flash memory is compared with data transferred from the flash programmer.       | 0                                 | × (Can be read by user program)                                        |
| Blank check      | The erasure status of the entire memory is checked.                                                | 0                                 | 0                                                                      |
| Security setting | Use of the block erase command, chip erase command, and program command can be prohibited.         | 0                                 | × (Only values set by on- board/off-board programming can be retained) |

The following table lists the security functions. The block erase command prohibit, chip erase command prohibit, and program command prohibit functions are enabled by default after shipment, and security can be set by rewriting via on-board/off-board programming. Each security function can be used in combination with the others at the same time.

**Table 29-3. Security Functions** 

| Function                           | Function Outline                                                                                                                                                                                            |                                                                       | on When Prohibited<br>x: Not Executable)                     |
|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|--------------------------------------------------------------|
|                                    |                                                                                                                                                                                                             | On-Board/Off-Board<br>Programming                                     | Self Programming                                             |
| Block erase<br>command<br>prohibit | Execution of a block erase command on all blocks is prohibited. Setting of prohibition can be initialized by execution of a chip erase command.                                                             | Block erase command: ×<br>Chip erase command: O<br>Program command: O | Can always be rewritten regardless of setting of prohibition |
| Chip erase<br>command<br>prohibit  | Execution of block erase and chip erase commands on all the blocks is prohibited.  Once prohibition is set, setting of prohibition cannot be initialized because the chip erase command cannot be executed. | Block erase command: ×<br>Chip erase command: ×<br>Program command: O |                                                              |
| Program<br>command<br>prohibit     | Write and block erase commands on all the blocks are prohibited. Setting of prohibition can be initialized by execution of the chip erase command.                                                          | Block erase command: ×<br>Chip erase command: O<br>Program command: × |                                                              |

## 29.4 Rewriting by Dedicated Flash Programmer

The flash memory can be rewritten by using a dedicated flash programmer after the V850ES/SG2 is mounted on the target system (on-board programming). The flash memory can also be rewritten before the device is mounted on the target system (off-board programming) by using a dedicated program adapter (FA series).

### 29.4.1 Programming environment

The following shows the environment required for writing programs to the flash memory of the V850ES/SG2.

Figure 29-2. Environment Required for Writing Programs to Flash Memory



A host machine is required for controlling the dedicated flash programmer.

UARTA0, CSIB0, or CSIB3 is used for the interface between the dedicated flash programmer and the V850ES/SG2 to perform writing, erasing, etc. A dedicated program adapter (FA series) required for off-board writing.

**Remark** The FA series is a product of Naito Densei Machida Mfg. Co., Ltd.

### 29.4.2 Communication mode

Communication between the dedicated flash programmer and the V850ES/SG2 is performed by serial communication using the UARTA0, CSIB0, or CSIB3 interfaces of the V850ES/SG2.

## (1) UARTA0

Transfer rate: 9,600 to 153,600 bps

Figure 29-3. Communication with Dedicated Flash Programmer (UARTA0)



### (2) CSIB0, CSIB3

Serial clock: 2.4 kHz to 2.5 MHz (MSB first)

Figure 29-4. Communication with Dedicated Flash Programmer (CSIB0, CSIB3)



### (3) CSIB0 + HS, CSIB3 + HS

Serial clock: 2.4 kHz to 2.5 MHz (MSB first)

Figure 29-5. Communication with Dedicated Flash Programmer (CSIB0 + HS, CSIB3 + HS)



The dedicated flash programmer outputs the transfer clock, and the V850ES/SG2 operates as a slave.

When the PG-FP4 is used as the dedicated flash programmer, it generates the following signals to the V850ES/SG2. For details, refer to the **PG-FP4 User's Manual (U15260E)**.

Table 29-4. Signal Connections of Dedicated Flash Programmer (PG-FP4)

|             | PG-FP4 |                                                           |                      | Proces  | ssing for Conr  | nection                   |
|-------------|--------|-----------------------------------------------------------|----------------------|---------|-----------------|---------------------------|
| Signal Name | I/O    | Pin Function                                              | Pin Name             | UARTA0  | CSIB0,<br>CSIB3 | CSIB0 + HS,<br>CSIB3 + HS |
| FLMD0       | Output | Write enable/disable                                      | FLMD0                | 0       | 0               | 0                         |
| FLMD1       | Output | Write enable/disable                                      | FLMD1                | Note 1  | Note 1          | ○Note 1                   |
| VDD         | _      | V <sub>DD</sub> voltage generation/voltage monitor        | V <sub>DD</sub>      | 0       | 0               | 0                         |
| GND         | _      | Ground                                                    | Vss                  | 0       | 0               | 0                         |
| CLK         | Output | Clock output to V850ES/SG2                                | X1, X2               | ×Note 2 | ×Note 2         | ×Note 2                   |
| RESET       | Output | Reset signal                                              | RESET                | 0       | 0               | 0                         |
| SI/RxD      | Input  | Receive signal                                            | SOB0, SOB3/<br>TXDA0 | 0       | 0               | 0                         |
| SO/TxD      | Output | Transmit signal                                           | SIB0, SIB3/<br>RXDA0 | 0       | 0               | 0                         |
| SCK         | Output | Transfer clock                                            | SCKB0, SCKB3         | ×       | 0               | 0                         |
| HS          | Input  | Handshake signal for CSIB0 + HS, CSIB3 + HS communication | РСМ0                 | ×       | ×               | 0                         |

Notes 1. Wire these pins as shown in Figure 29-6, or connect then to GND via pull-down resistor on board.

2. Clock cannot be supplied via the CLK pin of the flash programmer. Create an oscillator on board and supply the clock.

### Remark O: Must be connected.

x: Does not have to be connected.

Table 29-5. Wiring of V850ES/SG2 Flash Writing Adapters (FA-100GC-8EA) (1/2)

| Flash Programmer (FG-FP4) Connection Pin |        | Name of CSIB0 + HS Used FA Board                      |                | S Used             | CSIB0 Used |                    | UARTA0 Used |                          |         |
|------------------------------------------|--------|-------------------------------------------------------|----------------|--------------------|------------|--------------------|-------------|--------------------------|---------|
| Signal<br>Name                           | I/O    | Pin Function                                          | Pin            | Pin Name           | Pin No.    | Pin Name           | Pin No.     | Pin Name                 | Pin No. |
| SI/RxD                                   | Input  | Receive signal                                        | SI             | P41/SOB0/<br>SCL01 | 23         | P41/SOB0/<br>SCL01 | 23          | P30/TXDA0/<br>SOB4       | 25      |
| SO/TxD                                   | Output | Transmit signal                                       | SO             | P40/SIB0/<br>SDA01 | 22         | P40/SIB0/<br>SDA01 | 22          | P31/RXDA0/<br>INTP7/SIB4 | 26      |
| SCK                                      | Output | Transfer clock                                        | SCK            | P42/SCKB0          | 24         | P42/SCKB0          | 24          | Not needed               | -       |
| CLK                                      | Output | Clock to                                              | X1             | Not needed         | -          | Not needed         | -           | Not needed               | _       |
|                                          |        | V850ES/SG2                                            | X2             | Not needed         | -          | Not needed         |             | Not needed               | _       |
| /RESET                                   | Output | Reset signal                                          | /RESET         | RESET              | 14         | RESET              | 14          | RESET                    | 14      |
| FLMD0                                    | Input  | Write voltage                                         | FLMD0          | FLMD0              | 8          | FLMD0              | 8           | FLMD0                    | 8       |
| FLMD1                                    | Input  | Write voltage                                         | FLMD1          | PLD5/AD5/<br>FLMD1 | 76         | PLD5/AD5/<br>FLMD1 | 76          | PLD5/AD5/<br>FLMD1       | 76      |
| HS                                       | Input  | Handshake<br>signal for CSI0<br>+ HS<br>communication | RESERVE/<br>HS | PCM0/WAIT          | 61         | Not needed         | _           | Not needed               | -       |
| VDD                                      | _      | VDD voltage                                           | VDD            | V <sub>DD</sub>    | 9          | V <sub>DD</sub>    | 9           | V <sub>DD</sub>          | 9       |
|                                          |        | generation/                                           |                | BV <sub>DD</sub>   | 70         | BV <sub>DD</sub>   | 70          | BV <sub>DD</sub>         | 70      |
|                                          |        | voltage monitor                                       |                | EV <sub>DD</sub>   | 34         | EV <sub>DD</sub>   | 34          | EV <sub>DD</sub>         | 34      |
|                                          |        |                                                       |                | AV <sub>REF0</sub> | 1          | AV <sub>REF0</sub> | 1           | AV <sub>REF0</sub>       | 1       |
|                                          |        |                                                       |                | AV <sub>REF1</sub> | 5          | AV <sub>REF1</sub> | 5           | AV <sub>REF1</sub>       | 5       |
| GND                                      | _      | Ground                                                | GND            | Vss                | 11         | Vss                | 11          | Vss                      | 11      |
|                                          |        |                                                       |                | AVss               | 2          | AVss               | 2           | AVss                     | 2       |
|                                          |        |                                                       |                | BVss               | 69         | BVss               | 69          | BVss                     | 69      |
|                                          |        |                                                       |                | EVss               | 33         | EVss               | 33          | EVss                     | 33      |

Cautions 1. Be sure to connect the REGC pin to GND via 4.7  $\mu$ F capacitor.

2. Clock cannot be supplied from the CLK pin of the flash programmer. Create an oscillator on the board and supply clock.

Table 29-5. Wiring of V850ES/SG2 Flash Writing Adapters (FA-100GC-8EA) (2/2)

| Flash Programmer (FG-FP4)<br>Connection Pin |        | Name of FA<br>Board Pin                            | CSIB3 + HS Used |                    | CSIB3 Use | d                  |         |
|---------------------------------------------|--------|----------------------------------------------------|-----------------|--------------------|-----------|--------------------|---------|
| Signal<br>Name                              | I/O    | Pin Function                                       |                 | Pin Name           | Pin No.   | Pin Name           | Pin No. |
| SI/RxD                                      | Input  | Receive signal                                     | SI              | P911/A11/SOB3      | 54        | P911/A11/SOB3      | 54      |
| SO/TxD                                      | Output | Transmit signal                                    | SO              | P910/A10/SIB3      | 53        | P910/A10/SIB3      | 53      |
| SCK                                         | Output | Transfer clock                                     | SCK             | P912/A12/SCKB3     | 55        | P912/A12/SCKB3     | 55      |
| CLK                                         | Output | Clock to                                           | X1              | Not needed         | 1         | Not needed         | _       |
|                                             |        | V850ES/SG2                                         | X2              | Not needed         | 1         | Not needed         | _       |
| /RESET                                      | Output | Reset signal                                       | /RESET          | RESET              | 14        | RESET              | 14      |
| FLMD0                                       | Input  | Write voltage                                      | FLMD0           | FLMD0              | 8         | FLMD0              | 8       |
| FLMD1                                       | Input  | Write voltage                                      | FLMD1           | PLD5/AD5/FLMD1     | 76        | PLD5/AD5/FLMD1     | 76      |
| HS                                          | Input  | Handshake signal<br>for CSI0 + HS<br>communication | RESERVE/HS      | PCM0/WAIT          | 61        | Not needed         | -       |
| VDD                                         | =      | VDD voltage                                        | VDD             | V <sub>DD</sub>    | 9         | V <sub>DD</sub>    | 9       |
|                                             |        | generation/                                        |                 | BV <sub>DD</sub>   | 70        | BV <sub>DD</sub>   | 70      |
|                                             |        | voltage monitor                                    |                 | EV <sub>DD</sub>   | 34        | EV <sub>DD</sub>   | 34      |
|                                             |        |                                                    |                 | AV <sub>REF0</sub> | 1         | AV <sub>REF0</sub> | 1       |
|                                             |        |                                                    |                 | AV <sub>REF1</sub> | 5         | AV <sub>REF1</sub> | 5       |
| GND                                         | -      | Ground                                             | GND             | Vss                | 11        | Vss                | 11      |
|                                             |        |                                                    |                 | AVss               | 2         | AVss               | 2       |
|                                             |        |                                                    |                 | BVss               | 69        | BVss               | 69      |
|                                             |        |                                                    |                 | EVss               | 33        | EVss               | 33      |

Cautions 1. Be sure to connect the REGC pin to GND via 4.7  $\mu$ F capacitor.

2. Clock cannot be supplied from the CLK pin of the flash programmer. Create an oscillator on the board and supply clock.



Figure 29-6. Wiring Example of V850ES/SG2 Flash Writing Adapter (FA-100GC-8EA) (In CSIB0 + HS Mode) (1/2)

Figure 29-6. Wiring Example of V850ES/SG2 Flash Writing Adapter (FA-100GC-8EA) (In CSIB0 + HS Mode) (2/2)

Notes 1. Corresponding pins when CSIB3 is used.

- 2. Wire the FLMD1 pin as shown below, or connect it to GND on board via a pull-down resistor.
- **3.** Create an oscillator on the flash writing adapter (shown in broken lines) and supply a clock. Here is an example of the oscillator.

## Example:



**4.** Corresponding pins when UARTA0 is used.

Caution Do not input a high level to the DRST pin.

Remarks 1. Process the pins not shown in accordance with the handling of unused pins (see 2.3 Pin I/O Circuit Types, I/O Buffer Power Supplies, and Connection of Unused Pins).

2. This adapter is for the 100-pin plastic LQFP package.

## 29.4.3 Flash memory control

The following shows the procedure for manipulating the flash memory.

Figure 29-7. Procedure for Manipulating Flash Memory



### 29.4.4 Selection of communication mode

In the V850ES/SG2, the communication mode is selected by inputting pulses (12 pulses max.) to the FLMD0 pin after switching to the flash memory programming mode. The FLMD0 pulse is generated by the dedicated flash programmer.

The following shows the relationship between the number of pulses and the communication mode.



Figure 29-8. Selection of Communication Mode

**Note** The number of clocks is as follows depending on the communication mode.

| FLMD0 Pulse | Communication Mode | Remarks                                                |
|-------------|--------------------|--------------------------------------------------------|
| 0           | UARTA0             | Communication rate: 9,600 bps (after reset), LSB first |
| 8           | CSIB0              | V850ES/SG2 performs slave operation, MSB first         |
| 9           | CSIB3              | V850ES/SG2 performs slave operation, MSB first         |
| 11          | CSIB0 + HS         | V850ES/SG2 performs slave operation, MSB first         |
| 12          | CSIB3 + HS         | V850ES/SG2 performs slave operation, MSB first         |
| Other       | RFU                | Setting prohibited                                     |

Caution When UARTA0 is selected, the receive clock is calculated based on the reset command sent from the dedicated flash programmer after receiving the FLMD0 pulse.

### 29.4.5 Communication commands

The V850ES/SG2 communicates with the dedicated flash programmer by means of commands. The signals sent from the dedicated flash programmer to the V850ES/SG2 are called "commands". The response signals sent from the V850ES/SG2 to the dedicated flash programmer are called "response commands".

Figure 29-9. Communication Commands



The following shows the commands for flash memory control in the V850ES/SG2. All of these commands are issued from the dedicated flash programmer, and the V850ES/SG2 performs the processing corresponding to the commands.

**Table 29-6. Flash Memory Control Commands** 

| Classification          | Command Name              | Support         |                           |              | Function                                                                                                        |
|-------------------------|---------------------------|-----------------|---------------------------|--------------|-----------------------------------------------------------------------------------------------------------------|
|                         |                           | CSIB0,<br>CSIB3 | CSIB0 + HS,<br>CSIB3 + HS | UARTA0       |                                                                                                                 |
| Blank check             | Block blank check command | √               | √                         | $\checkmark$ | Checks if the contents of the memory in the specified block have been correctly erased.                         |
| Erase                   | Chip erase command        | $\checkmark$    | √                         | V            | Erases the contents of the entire memory.                                                                       |
|                         | Block erase command       | <b>V</b>        | √                         | 1            | Erases the contents of the memory of the specified block.                                                       |
| Write                   | Write command             | √               | √                         | $\checkmark$ | Writes the specified address range, and executes a contents verify check.                                       |
| Verify                  | Verify command            | V               | √                         | V            | Compares the contents of memory in the specified address range with data transferred from the flash programmer. |
|                         | Checksum command          | V               | √                         | V            | Reads the checksum in the specified address range.                                                              |
| System setting, control | Silicon signature command | √               | √                         | $\checkmark$ | Reads silicon signature information.                                                                            |
|                         | Security setting command  | V               | √                         | V            | Disables the chip erase command, enables the block erase command, and disables the write command.               |

### 29.4.6 Pin connection

When performing on-board writing, mount a connector on the target system to connect to the dedicated flash programmer. Also, incorporate a function on-board to switch from the normal operation mode to the flash memory programming mode.

In the flash memory programming mode, all the pins not used for flash memory programming become the same status as that immediately after reset. Therefore, pin handling is required when the external device does not acknowledge the status immediately after a reset.

### (1) FLMD0 pin

In the normal operation mode, input a voltage of Vss level to the FLMD0 pin. In the flash memory programming mode, supply a write voltage of V<sub>DD</sub> level to the FLMD0 pin.

Because the FLMD0 pin serves as a write protection pin in the self programming mode, a voltage of V<sub>DD</sub> level must be supplied to the FLMD0 pin via port control, etc., before writing to the flash memory. For details, see **29.5.5 (1) FLMD0 pin**.

Dedicated flash programmer connection pin

Pull-down resistor (R<sub>FLMD0</sub>)

Figure 29-10. FLMD0 Pin Connection Example

## (2) FLMD1 pin

When 0 V is input to the FLMD0 pin, the FLMD1 pin does not function. When V<sub>DD</sub> is supplied to the FLMD0 pin, the flash memory programming mode is entered, so 0 V must be input to the FLMD1 pin. The following shows an example of the connection of the FLMD1 pin.

Figure 29-11. FLMD1 Pin Connection Example



Table 29-7. Relationship Between FLMD0 and FLMD1 Pins and Operation Mode When Reset Is Released

| FLMD0           | FLMD1           | Operation Mode                |
|-----------------|-----------------|-------------------------------|
| 0               | Don't care      | Normal operation mode         |
| V <sub>DD</sub> | 0               | Flash memory programming mode |
| V <sub>DD</sub> | V <sub>DD</sub> | Setting prohibited            |

### (3) Serial interface pin

The following shows the pins used by each serial interface.

Table 29-8. Pins Used by Serial Interfaces

| Serial Interface | Pins Used               |
|------------------|-------------------------|
| UARTA0           | TXDA0, RXDA0            |
| CSIB0            | SOB0, SIB0, SCKB0       |
| CSIB3            | SOB3, SIB3, SCKB3       |
| CSIB0 + HS       | SOB0, SIB0, SCKB0, PCM0 |
| CSIB3 + HS       | SOB3, SIB3, SCKB3, PCM0 |

When connecting a dedicated flash programmer to a serial interface pin that is connected to another device on-board, care should be taken to avoid conflict of signals and malfunction of the other device.

#### (a) Conflict of signals

When the dedicated flash programmer (output) is connected to a serial interface pin (input) that is connected to another device (output), a conflict of signals occurs. To avoid the conflict of signals, isolate the connection to the other device or set the other device to the output high-impedance status.

Figure 29-12. Conflict of Signals (Serial Interface Input Pin)



### (b) Malfunction of other device

When the dedicated flash programmer (output or input) is connected to a serial interface pin (input or output) that is connected to another device (input), the signal is output to the other device, causing the device to malfunction. To avoid this, isolate the connection to the other device.

Figure 29-13. Malfunction of Other Device



## (4) RESET pin

When the reset signals of the dedicated flash programmer are connected to the RESET pin that is connected to the reset signal generator on-board, a conflict of signals occurs. To avoid the conflict of signals, isolate the connection to the reset signal generator.

When a reset signal is input from the user system in the flash memory programming mode, the programming operation will not be performed correctly. Therefore, do not input signals other than the reset signals from the dedicated flash programmer.

Dedicated flash programmer connection pin

Reset signal generator

Output pin

In the flash memory programming mode, the signal the reset signal generator outputs conflicts with the signal the dedicated flash programmer outputs. Therefore, isolate the signals on the reset signal generator side.

Figure 29-14. Conflict of Signals (RESET Pin)

### (5) Port pins (including NMI)

When the system shifts to the flash memory programming mode, all the pins that are not used for flash memory programming are in the same status as that immediately after reset. If the external device connected to each port does not recognize the status of the port immediately after reset, pins require appropriate processing, such as connecting to VDD via a resistor or connecting to VSS via a resistor.

## (6) Other signal pins

Connect X1, X2, XT1, XT2, and REGC in the same status as that in the normal operation mode. During flash memory programming, input a low level to the  $\overline{\text{DRST}}$  pin or leave it open. Do not input a high level.

### (7) Power supply

Supply the same power (VDD, VSS, EVDD, EVSS, BVDD, BVSS, AVREFO, AVREF1, AVSS) as in normal operation mode.

## 29.5 Rewriting by Self Programming

## 29.5.1 Overview

The V850ES/SG2 supports a flash macro service that allows the user program to rewrite the internal flash memory by itself. By using this interface and a self programming library that is used to rewrite the flash memory with a user application program, the flash memory can be rewritten by a user application transferred in advance to the internal RAM or external memory. Consequently, the user program can be upgraded and constant data can be rewritten in the field.

Application program

Self programming library

Flash function execution

Flash macro service

Erase, write

Flash memory

Figure 29-15. Concept of Self Programming

#### 29.5.2 Features

## (1) Secure self programming (boot swap function)

The V850ES/SG2 supports a boot swap function that can exchange the physical memory of blocks 0 and 1 with the physical memory of blocks 2 and 3. By writing the start program to be rewritten to blocks 2 and 3 in advance and then swapping the physical memory, the entire area can be safely rewritten even if a power failure occurs during rewriting because the correct user program always exists in blocks 0 and 1.

Block 7 Block 7 Block 7 Block 6 Block 6 Block 6 Block 5 Block 5 Boot swap Block 5 Block 4 Block 4 Block 4 Block 3 Block 3 Block 3 Rewriting blocks Block 2 Block 2 Block 2 2 and 3 Block 1 Block 1 Block 1 Block 0 Block 0 Block 0

Figure 29-16. Rewriting Entire Memory Area (Boot Swap)

## (2) Interrupt support

Instructions cannot be fetched from the flash memory during self programming. Conventionally, therefore, a user handler written to the flash memory could not be used even if an interrupt occurred. With the V850ES/SG2, a user handler can be registered to an entry RAM area by using a library function, so that interrupt servicing can be performed by internal RAM or external memory execution.

### 29.5.3 Standard self programming flow

The entire processing to rewrite the flash memory by flash self programming is illustrated below.

Flash memory manipulation Flash environment initialization processing • Disable accessing flash area • Disable setting of STOP mode • Disable stopping clock Erase processing Write processing Flash information setting processing Note Internal verify processing All blocks end? Yes Boot area swap processing Note 2 Flash environment end processing End of processing Notes 1. If a security setting is not performed, flash information setting processing does not have to be executed. 2. If boot swap is not used, flash information setting processing and boot swap processing do not have to be executed.

Figure 29-17. Standard Self Programming Flow

### 29.5.4 Flash functions

Table 29-9. Flash Function List

| Function Name        | Outline                                                | Support      |
|----------------------|--------------------------------------------------------|--------------|
| FlashEnv             | Initialization of flash control macro                  | <b>V</b>     |
| FlashBlockErase      | Erasure of only specified one block                    | <b>V</b>     |
| FlashWordWrite       | Writing from specified address                         | $\checkmark$ |
| FlashBlockIVerify    | Internal verification of specified block               | $\checkmark$ |
| FlashBlockBlankCheck | Blank check of specified block                         | $\checkmark$ |
| FlashFLMDCheck       | Check of FLMD pin                                      | $\checkmark$ |
| FlashStatusCheck     | Status check of operation specified immediately before | $\checkmark$ |
| FlashGetInfo         | Reading of flash information                           | $\checkmark$ |
| FlashSetInfo         | Setting of flash information                           | $\checkmark$ |
| FlashBootSwap        | Swapping of boot area                                  | $\checkmark$ |
| FlashSetUserHandler  | User interrupt handler registration function           | $\sqrt{}$    |

### 29.5.5 Pin processing

### (1) FLMD0 pin

The FLMD0 pin is used to set the operation mode when reset is released and to protect the flash memory from being written during self rewriting. It is therefore necessary to keep the voltage applied to the FLMD0 pin at 0 V when reset is released and a normal operation is executed. It is also necessary to apply a voltage of VDD level to the FLMD0 pin during the self programming mode period via port control before the memory is rewritten.

When self programming has been completed, the voltage on the FLMD0 pin must be returned to 0 V.

Figure 29-18. Mode Change Timing



## 29.5.6 Internal resources used

The following table lists the internal resources used for self programming. These internal resources can also be used freely for purposes other than self programming.

Table 29-10. Internal Resources Used

| Resource Name                                                        | Description                                                                                                                                                                                                                        |
|----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Entry RAM area<br>(124 bytes of either internal<br>RAM/external RAM) | Routines and parameters used for the flash macro service are located in this area. The entry program and default parameters are copied by calling a library initialization function.                                               |
| Stack area (user stack + 300 bytes)                                  | An extension of the stack used by the user is used by the library (can be used in both the internal RAM and external RAM).                                                                                                         |
| Library code (1900 bytes)                                            | Program entity of library (can be used anywhere other than the flash memory block to be manipulated).                                                                                                                              |
| Application program                                                  | Executed as user application. Calls flash functions.                                                                                                                                                                               |
| Maskable interrupt                                                   | Can be used in user application execution status or self programming status. To use this interrupt in the self programming status, the interrupt servicing start address must be registered in advance by a registration function. |
| NMI interrupt                                                        | Can be used in user application execution status or self programming status. To use this interrupt in the self programming status the interrupt servicing start address must be registered in advance by a registration function.  |

### **CHAPTER 30 ON-CHIP DEBUG FUNCTION**

The V850ES/SG2 has an on-chip debug function that uses the JTAG (Joint Test Action Group) interface (DRST, DCK, DMS, DDI, and DDO pins) and that can be used via an N-Wire emulator (IE-V850E1-CD-NW).

Caution The on-chip debug function is provided only in the flash memory version. It is not provided with the mask ROM version. However, the OCDM register also exists in the mask ROM version and it controls the pull-down resistor connected to the P05/INTP2 pin, so set the OCDM register even for the mask ROM version.

#### 30.1 Features

- O Hardware break function: 2 points
- O Software break function: 4 points
- O Real-time RAM monitor function: Memory contents can be read during program execution.
- O Dynamic memory modification function (DMM function): RAM contents can be rewritten during program execution.
- O Mask function: RESET, NMI, HLDRQ, WAIT
- O ROM security function: 10-byte ID code authentication

Caution The following functions are not supported.

- Trace function
- Event function
- Debug interrupt interface function (DBINT)

## 30.2 Connection Circuit Example



### 30.3 Interface Signals

The interface signals are described below.

# (1) DRST

This is a reset input signal for the on-chip debug unit. It is a negative-logic signal that asynchronously initializes the debug control unit.

The IE-V850E1-CD-NW raises the DRST signal when it detects VDD of the target system after the integrated debugger is started, and starts the on-chip debug unit of the device.

When the DRST signal goes high, a reset signal is also generated in the CPU.

When starting debugging by starting the integrated debugger, a CPU reset is always generated.

## (2) DCK

This is a clock input signal. It supplies a 20 MHz clock from the IE-V850E1-CD-NW. In the on-chip debug unit, the DMS and DDI signals are sampled at the rising edge of the DCK signal, and the data DDO is output at its falling edge.

#### (3) DMS

This is a transfer mode select signal. The transfer status in the debug unit changes depending on the level of the DMS signal.

#### (4) DDI

This is a data input signal. It is sampled in the on-chip debug unit at the rising edge of DCK.

## (5) DDO

This is a data output signal. It is output from the on-chip debug unit at the falling edge of the DCK signal.

#### (6) EV<sub>DD</sub>

This signal is used to detect VDD of the target system. If VDD from the target system is not detected, the signals output from the IE-V850E1-CD-NW (DRST, DCK, DMS, DDI, FLMD0, and RESET) go into a high-impedance state.

### (7) FLMD0

The flash self programming function is used for the function to download data to the flash memory via the integrated debugger. During flash self programming, the FLMD0 pin must be kept high. In addition, connect a pull-down resistor to the FLMD0 pin.

The FLMD0 pin can be controlled in either of the following two ways.

#### <1> To control from IE-V850E1-CD-NW

Connect the FLMD0 signal of the IE-V850E1-CD-NW to the FLMD0 pin.

In the normal mode, nothing is driven by the IE-V850E1-CD-NW (high impedance).

During a break, the IE-V850E1-CD-NW raises the FLMD0 pin to the high level when the download function of the integrated debugger is executed.

#### <2> To control from port

Connect any port of the device to the FLMD0 pin.

The same port as the one used by the user program to realize the flash self programming function may be used.

On the console of the integrated debugger, make a setting to raise the port pin to high level before executing the download function, or lower the port pin after executing the download function.

For details, refer to the ID850QB Ver. 3.10 Integrated Debugger Operation User's Manual (U17435E).

## (8) RESET

This is a system reset input pin. If the  $\overline{DRST}$  pin is made invalid by the value of the OCDM0 bit of the OCDM register set by the user program, on-chip debugging cannot be executed. Therefore, reset is effected by the IE-V850E1-CD-NW, using the  $\overline{RESET}$  pin, to make the  $\overline{DRST}$  pin valid (initialization).

## 30.4 Register

## (1) On-chip debug mode register (OCDM)

The OCDM register is used to select the normal operation mode or on-chip debug mode. This register is a special register and can be written only in a combination of specific sequences (see **3.4.8 Special registers**). This register is also used to specify whether a pin provided with an on-chip debug function is used as an on-chip debug pin or as an ordinary port/peripheral function pin. It also is used to disconnect the internal pull-down resistor of the P05/INTP2/DRST pin.

The OCDM register can be written only while a low level is input to the DRST pin.

This register can be read or written in 8-bit or 1-bit units.

| After reset: 01H <sup>Note</sup> |   | R/W | Address: FFFF9FCH |   |   |   |   |       |  |
|----------------------------------|---|-----|-------------------|---|---|---|---|-------|--|
|                                  | 7 | 6   | 5                 | 4 | 3 | 2 | 1 | <0>   |  |
| OCDM                             | 0 | 0   | 0                 | 0 | 0 | 0 | 0 | OCDM0 |  |

| OCDM0 | Operation mode                                                                                                                                                                                                                                                                                                                    |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | Selects normal operation mode (in which a pin that functions alternately as on-chip debug function pin is used as a port/peripheral function pin) and disconnects the on-chip pull-down resistor of the P05/INTP2/DRST pin.                                                                                                       |
| 1     | When DRST pin is low:  Normal operation mode (in which a pin that functions alternately as an on-chip debug function pin is used as a port/peripheral function pin)  When DRST pin is high:  On-chip debug mode (in which a pin that functions alternately as an on-chip debug function pin is used as an on-chip debug mode pin) |

**Note** RESET input sets this register to 01H. After reset by the WDT2RES signal or clock monitor (CLM), however, the value of the OCDM register is retained.

- Cautions 1. When using the DDI, DDO, DCK, and DMS pins not as on-chip debug pins but as port pins after external reset, any of the following actions must be taken.
  - Input a low level to the P05/INTP2/DRST pin.
  - Set the ODCM0 bit. In this case, take the following actions.
    - <1> Clear the OCDM0 bit to 0.
    - <2> Fix the P05/INTP2/DRST pin to the low level until <1> is completed.
  - 2. The DRST pin has an on-chip pull-down resistor. This resistor is disconnected when the OCDM0 flag is cleared to 0. The mask ROM version does not have an on-chip debug function but it has the above pull-down resistor. With the mask ROM version also, therefore, the on-chip pull-down resistor must be disconnected by clearing the OCDM0 bit to 0.



## 30.5 Operation

The on-chip debug function is made invalid under the conditions shown in the table below. When this function is not used, keep the  $\overline{\text{DRST}}$  pin low until the OCDM.OCDM0 flag is cleared to 0.

| OCDM0 Flag | 0       | 1       |
|------------|---------|---------|
| DRST Pin   |         |         |
| L          | Invalid | Invalid |
| Н          | Invalid | Valid   |

Remark L: Low-level input H: High-level input

Figure 30-1. Timing When On-Chip Debug Function Is Not Used



## 30.6 ROM Security Function

### 30.6.1 Security ID

The flash memory versions of the V850ES/SG2 perform authentication using a 10-byte ID code to prevent the contents of the flash memory from being read by an unauthorized person during on-chip debugging by the N-Wire emulator.

Set the ID code in the 10-byte on-chip flash memory area from 0000070H to 0000079H to allow the debugger perform ID authentication.

If the IDs match, the security is released and reading flash memory and using the N-Wire emulator are enabled.

- Set the 10-byte ID code to 0000070H to 0000079H.
- Bit 7 of 0000079H is the N-Wire emulator enable flag. (0: Disable, 1: Enable)
- When the N-Wire emulator is started, the debugger requests ID input. When the ID code input on the debugger and the ID code set in 0000070H to 0000079H match, the debugger starts.
- Debugging cannot be performed if the N-Wire emulator enable flag is 0, even if the ID codes match.



Note Values other than 00H can also be set.

Caution When the data in the flash memory has been deleted, all the bits are set to 1.

### 30.6.2 **Setting**

**Example** When the following values are set to addresses 0x70 to 0x79

| Address | Value |              |
|---------|-------|--------------|
| 0x70    | 0x12  |              |
| 0x71    | 0x34  |              |
| 0x72    | 0x56  |              |
| 0x73    | 0x78  |              |
| 0x74    | 0x9A  |              |
| 0x75    | 0xBC  |              |
| 0x76    | 0xDE  |              |
| 0x77    | 0xF1  |              |
| 0x78    | 0x23  |              |
| 0x79    | 0xD4  |              |
| 0x7A    | 0x00  | $\leftarrow$ |
|         |       |              |

← Reserved code (See **3.4.9 (3)**.)

The following shows program examples when the CA850 is used.

# [Program example 1]

Following the "ILGOP" section (address 0x60), enter the 10-byte security code and 1-byte system reserved area data (00H).

```
#-----
 ILGOP handler
#-----
  .section "ILGOP" -- Interrupt handler address 0x60
                 -- Input ILGOP handler code
         0x10
                 -- Skip handler address to 0x70
  .org
#-----
 SECURITYID (continue ILGOP handler)
  .word
                 0x78563412 --0-3 byte code
  .word
                 0xF1DEBC9A --4-7 byte code
  .hword
                 0xD423
                           --8-9 byte code
  .byte
                 0x00
                           --Reserve code
```

Caution When using the CA850 Ver. 3.00 or later, specify the option for disabling the generation of the security ID.

The security ID addition function by linker is added from the CA850 Ver. 3.00. As a result, errors occur during linking in the above program example.

## Error message:

```
F4264: start address (0x00000070) of section "SECURITY_ID" overlaps previous section "ILGOP" ended before address (0xXXXXXXXXX).
```

### [Program example 2]

Enter the 10-byte security code using the "SECURITY\_ID" section (address 0x70).

Caution Data that can be set to the "SECURITY\_ID" section is limited to 10 bytes. For this reason, data cannot be set to the system reserved area (0x7A) following the security code. Consequently, when using a device that needs to set data to the system reserved area, set the security code and system reserved area data using the method shown in "Program example 1".

For details on devices that need to set data to the system reserved area, see 3.4.9 (3) System reserved area.

### 30.7 Cautions

- (1) If a reset signal is input (from the target system or a reset signal from an internal reset source) during RUN (program execution), the break function may malfunction.
- (2) Even if the reset signal is masked by the mask function, the I/O buffer (port pin) may be reset if a reset signal is input from a pin.
- (3) Because a software breakpoint set in the internal flash memory is realized by the ROM correction function, it is made temporarily invalid by target reset or internal reset generated by watchdog timer 2. The breakpoint becomes valid again when a hardware break or forced break occurs, but a software break does not occur until then.
- (4) Pin reset during a break is masked and the CPU and peripheral I/O are not reset. If pin reset or internal reset is generated as soon as the flash memory is rewritten by DMA or read by the RAM monitor function while the user program is being executed, the CPU and peripheral I/O may not be correctly reset.
- (5) Emulation of ROM correction cannot be executed.
- (6) When the following conditions (a) and (b) are satisfied and operation is stopped on the emulator (QB-V850ESSX2, IE-703288-G1-EM1, IE-V850E1-CD-NW) due to a break, etc., the watchdog timer 2 does not stop and a reset or non-maskable interrupt occurs. When a reset occurs, the debugger hangs up.
  - (a) The main clock or subclock is used as the source clock for watchdog timer 2.
  - (b) The internal oscillation clock is stopped (RCM.RSTOP bit = 1).

To avoid this, perform either of the following.

- When an emulator is used, use the internal oscillation clock as the source clock.
- When an emulator is used, do not stop the internal oscillator.
- (7) When the following conditions (a) and (b) are satisfied and operation is stopped on the emulator (QB-V850ESSX2, IE-703288-G1-EM1, IE-V850E1-CD-NW) due to a break, etc., TMM does not stop even if the peripheral break function is set to "Break".
  - (a) Either the INTWT, internal oscillation clock (f<sub>R</sub>/8), or subclock are selected as the TMM source clock.
  - (b) The Main clock is stopped.

To avoid this, perform either of the following.

- When an emulator is used, the main clock (fxx, fxx/2, fxx/4, fxx/64, fxx/512) is used as the source clock.
- When an emulator is used, disable the main clock oscillation.
- (8) In the on-chip debug mode, the DDO pin is forcibly set to the high-level output.

# CHAPTER 31 ELECTRICAL SPECIFICATIONS (TARGET)

# Absolute Maximum Ratings ( $T_A = 25$ °C) (1/2)

| Parameter            | Symbol             | Conditions                                                        | Ratings                                                           | Unit |
|----------------------|--------------------|-------------------------------------------------------------------|-------------------------------------------------------------------|------|
| Supply voltage       | V <sub>DD</sub>    | VDD = EVDD = AVREF0 = AVREF1                                      | -0.5 to +4.6                                                      | ٧    |
|                      | BV <sub>DD</sub>   |                                                                   | -0.5 to +4.6                                                      | ٧    |
|                      | EV <sub>DD</sub>   | VDD = EVDD = AVREF0 = AVREF1                                      | -0.5 to +4.6                                                      | ٧    |
|                      | AV <sub>REF0</sub> | VDD = EVDD = AVREF0 = AVREF1                                      | -0.5 to +4.6                                                      | ٧    |
|                      | AV <sub>REF1</sub> | VDD = EVDD = AVREF0 = AVREF1                                      | -0.5 to +4.6                                                      | ٧    |
|                      | Vss                | Vss = EVss = BVss = AVss                                          | -0.5 to +0.5                                                      | ٧    |
|                      | AVss               | Vss = EVss = BVss = AVss                                          | -0.5 to +0.5                                                      | ٧    |
|                      | BVss               | Vss = EVss = BVss = AVss                                          | -0.5 to +0.5                                                      | ٧    |
|                      | EVss               | Vss = EVss = BVss = AVss                                          | -0.5 to +0.5                                                      | ٧    |
| Input voltage        | VI1                | RESET, FLMD0 <sup>Note 1</sup> , PDH4, PDH5                       | -0.5 to EV <sub>DD</sub> + 0.5 <sup>Note 2</sup>                  | ٧    |
|                      | V <sub>12</sub>    | PCM0 to PCM3, PCT0, PCT1, PCT4, PCT6, PDH0 to PDH3, PDL0 to PDL15 | -0.5 to BV <sub>DD</sub> + 0.5 <sup>Note 2</sup>                  | V    |
|                      | Vıз                | P10, P11                                                          | -0.5 to AV <sub>REF1</sub> + 0.5 <sup>Note 2</sup>                | ٧    |
|                      | V <sub>I4</sub>    | X1, X2, XT1, XT2                                                  | -0.5 to V <sub>RO</sub> <sup>Note 3</sup> + 0.5 <sup>Note 2</sup> | V    |
|                      | V <sub>I5</sub>    | P02 to P06, P30 to P39, P40 to P42, P50 to P55, P90 to P915       | -0.5 to +6.0                                                      | V    |
| Analog input voltage | VIAN               | P70 to P711                                                       | -0.5 to AV <sub>REF0</sub> + 0.5 <sup>Note 2</sup>                | ٧    |

# Notes 1. Flash memory version only

- 2. Be sure not to exceed the absolute maximum ratings (MAX. value) of each supply voltage.
- 3. On-chip regulator output voltage (2.5 V (TYP.))

### Absolute Maximum Ratings (T<sub>A</sub> = 25°C) (2/2)

| Parameter                     | Symbol                | Conditions                                                              |                   | Ratings    | Unit |
|-------------------------------|-----------------------|-------------------------------------------------------------------------|-------------------|------------|------|
| Output current, low           | loL                   | P02 to P06, P30 to P39, P40 to P42,                                     | Per pin           | 4          | mA   |
|                               |                       | P50 to P55, P90 to P915, PDH4, PDH5                                     | Total of all pins | 50         | mA   |
|                               |                       | PCM0 to PCM3, PCT0, PCT1, PCT4,                                         | Per pin           | 4          | mA   |
|                               |                       | PCT6, PDH0 to PDH3, PDL0 to PDL15                                       | Total of all pins | 50         | mA   |
|                               |                       | P10, P11                                                                | Per pin           | 4          | mA   |
|                               | Total of all pins     |                                                                         | Total of all pins | 8          | mA   |
|                               |                       | P70 to P711                                                             | Per pin           | 4          | mA   |
|                               |                       |                                                                         | Total of all pins | 20         | mA   |
| Output current, high          | Іон                   | P02 to P06, P30 to P39, P40 to P42, P50 to P55, P90 to P915, PDH4, PDH5 | Per pin           | -4         | mA   |
|                               |                       |                                                                         | Total of all pins | -50        | mA   |
|                               |                       | PCM0 to PCM3, PCT0, PCT1, PCT4, PCT6, PDH0 to PDH3, PDL0 to PDL15       | Per pin           | -4         | mA   |
|                               |                       |                                                                         | Total of all pins | -50        | mA   |
|                               |                       | P10, P11                                                                | Per pin           | -4         | mA   |
|                               |                       |                                                                         | Total of all pins | -8         | mA   |
|                               |                       | P70 to P711                                                             | Per pin           | -4         | mA   |
|                               |                       |                                                                         | Total of all pins | -20        | mA   |
| Operating ambient temperature | TA                    |                                                                         |                   | -40 to +85 | °C   |
| Storage temperature           | T <sub>stg</sub>      | Mask ROM versions                                                       | -65 to +150       | °C         |      |
|                               | Flash memory versions |                                                                         | -40 to +125       | °C         |      |

- Cautions 1. Do not directly connect the output (or I/O) pins of IC products to each other, or to VDD, VCC, and GND. Open-drain pins or open-collector pins, however, can be directly connected to each other. Direct connection of the output pins between an IC product and an external circuit is possible, if the output pins can be set to the high-impedance state and the output timing of the external circuit is designed to avoid output conflict.
  - 2. Product quality may suffer if the absolute maximum rating is exceeded even momentarily for any parameter. That is, the absolute maximum ratings are rated values at which the product is on the verge of suffering physical damage, and therefore the product must be used under conditions that ensure that the absolute maximum ratings are not exceeded. The ratings and conditions indicated for DC characteristics and AC characteristics represent the quality assurance range during normal operation.

Remark Unless specified otherwise, the characteristics of alternate-function pins are the same as those of port pins.

### Capacitance (TA = -40 to +85°C, BVDD ≤ VDD = EVDD = AVREF0 = AVREF1, VSS = EVSS = BVSS = AVSS = 0 V)

| Parameter       | Symbol | Conditions                      | MIN. | TYP. | MAX. | Unit |
|-----------------|--------|---------------------------------|------|------|------|------|
| I/O capacitance | Сю     | fx = 1 MHz                      |      |      | 10   | pF   |
|                 |        | Unmeasured pins returned to 0 V |      |      |      |      |

# **Operating Conditions**

### $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V})$

| Internal System Clock | Conditions                                    | Supply Voltage  |                  |                  |                    |                    | Unit |
|-----------------------|-----------------------------------------------|-----------------|------------------|------------------|--------------------|--------------------|------|
| Frequency             |                                               | V <sub>DD</sub> | EV <sub>DD</sub> | BV <sub>DD</sub> | AV <sub>REF0</sub> | AV <sub>REF1</sub> |      |
| fxx = 2.5 to 32 MHz   | Stabilization capacitance C = 4.7 $\mu$ F     | 3.0 to 3.6      | 3.0 to 3.6       | 3.0 to 3.6       | 3.0 to 3.6         | 3.0 to 3.6         | V    |
| fхт = 32.768 kHz      | connected to REGC pin, All function operating |                 |                  |                  |                    |                    |      |

#### **Main Clock Oscillator Characteristics**

 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \leq V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V})$ 

| Resonator          | Circuit Example | Parameter                                    | Conditions                   | MIN.                  | TYP.                | MAX. | Unit |
|--------------------|-----------------|----------------------------------------------|------------------------------|-----------------------|---------------------|------|------|
| Ceramic resonator/ | X1 X2           | Oscillation frequency (fx) <sup>Note 1</sup> |                              | 2.5                   |                     | 8    | MHz  |
| resonator          |                 | Oscillation stabilization                    | After reset is released      |                       | 2 <sup>16</sup> /fx |      | s    |
|                    | Ť Ť             | time <sup>Note 2</sup>                       | After STOP mode is released  | 1 Note 4              | Note 3              |      | ms   |
|                    | <del>///</del>  |                                              | After IDLE2 mode is released | 350 <sup>Note 4</sup> | Note 3              |      | μs   |

- Notes 1. The oscillation frequency shown above indicates only oscillator characteristics. Use the V850ES/SG2 so that the internal operation conditions do not exceed the ratings shown in AC Characteristics and DC Characteristics.
  - 2. Time required from start of oscillation until the resonator stabilizes.
  - 3. The value varies depending on the setting of the OSTS register.
  - **4.** Time required to set up the flash memory (flash memory version only). Secure the setup time using the OSTS register.
- Cautions 1. When using the main clock oscillator, wire as follows in the area enclosed by the broken lines in the above figure to avoid an adverse effect from wiring capacitance.
  - Keep the wiring length as short as possible.
  - Do not cross the wiring with the other signal lines.
  - Do not route the wiring near a signal line through which a high fluctuating current flows.
  - Always make the ground point of the oscillator capacitor the same potential as Vss.
  - Do not ground the capacitor to a ground pattern through which a high current flows.
  - Do not fetch signals from the oscillator.
  - When the main clock is stopped and the device is operating on the subclock, wait until the oscillation stabilization time has been secured by the program before switching back to the main clock.
  - 3. For the resonator selection and oscillator constant, customers are requested to either evaluate the oscillation themselves or apply to the resonator manufacturer for evaluation.

#### **Subclock Oscillator Characteristics**

 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V})$ 

| Resonator         | Circuit Example | Parameter                                        | Conditions | MIN. | TYP.   | MAX. | Unit |
|-------------------|-----------------|--------------------------------------------------|------------|------|--------|------|------|
| Crystal resonator |                 | Oscillation frequency (fxT) <sup>Note 1</sup>    |            | 32   | 32.768 | 35   | kHz  |
|                   |                 | Oscillation stabilization time <sup>Note 2</sup> |            |      |        | 10   | S    |

- Notes 1. The oscillation frequency shown above indicates only oscillator characteristics. Use the V850ES/SG2 so that the internal operation conditions do not exceed the ratings shown in AC Characteristics and DC Characteristics.
  - 2. Time required from when V<sub>DD</sub> reaches the oscillation voltage range (3.0 V (MIN.)) to when the crystal resonator stabilizes.
- Cautions 1. When using the subclock oscillator, wire as follows in the area enclosed by the broken lines in the above figures to avoid an adverse effect from wiring capacitance.
  - Keep the wiring length as short as possible.
  - Do not cross the wiring with the other signal lines.
  - . Do not route the wiring near a signal line through which a high fluctuating current flows.
  - Always make the ground point of the oscillator capacitor the same potential as Vss.
  - Do not ground the capacitor to a ground pattern through which a high current flows.
  - · Do not fetch signals from the oscillator.
  - 2. The subclock oscillator is designed as a low-amplitude circuit for reducing power consumption, and is more prone to malfunction due to noise than the main clock oscillator.
    - Particular care is therefore required with the wiring method when the subclock is used.
  - 3. For the resonator selection and oscillator constant, customers are requested to either evaluate the oscillation themselves or apply to the resonator manufacturer for evaluation.

#### **PLL Characteristics**

#### $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \leq V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V})$

| 1,               |        | ,                                          |      |      |      |      |  |  |
|------------------|--------|--------------------------------------------|------|------|------|------|--|--|
| Parameter        | Symbol | Conditions                                 | MIN. | TYP. | MAX. | Unit |  |  |
| Input frequency  | fx     | ×4 mode                                    | 2.5  |      | 5    | MHz  |  |  |
|                  |        | ×8 mode                                    | 2.5  |      | 4    | MHz  |  |  |
| Output frequency | fxx    | ×4 mode                                    | 10   |      | 20   | MHz  |  |  |
|                  |        | ×8 mode                                    | 20   |      | 32   | MHz  |  |  |
| Lock time        | tPLL   | After V <sub>DD</sub> reaches 3.0 V (MIN.) |      |      | 800  | μs   |  |  |

#### **Internal Oscillator Characteristics**

## $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V})$

| Parameter        | Symbol | Conditions | MIN. | TYP. | MAX. | Unit |
|------------------|--------|------------|------|------|------|------|
| Output frequency | fR     |            | 100  | 200  | 400  | kHz  |

#### **Regulator Characteristics**

## (TA = $-40 \text{ to } +85^{\circ}\text{C}$ , BVDD $\leq$ VDD = EVDD = AVREF0 = AVREF1, Vss = EVss = BVss = AVss = 0 V)

| Parameter                           | Symbol          | Conditions                                                                                                        | MIN. | TYP. | MAX. | Unit |
|-------------------------------------|-----------------|-------------------------------------------------------------------------------------------------------------------|------|------|------|------|
| Input voltage                       | V <sub>DD</sub> | fxx = 32 MHz (MAX.)                                                                                               | 3.0  |      | 3.6  | V    |
| Output voltage                      | VRO             |                                                                                                                   |      | 2.5  |      | V    |
| Regulator output stabilization time | treg            | After V <sub>DD</sub> reaches 3.0 V (MIN.),<br>Stabilization capacitance C = 4.7 $\mu$ F<br>connected to REGC pin |      |      | 1    | ms   |



 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V}) (1/4)$ 

| Parameter                    | Symbol           | Conditions                                                        | MIN.                | TYP.               | MAX.                | Unit |
|------------------------------|------------------|-------------------------------------------------------------------|---------------------|--------------------|---------------------|------|
| Input voltage, high          | V <sub>IH1</sub> | PDH4, PDH5                                                        | 0.7EV <sub>DD</sub> |                    | EV <sub>DD</sub>    | V    |
|                              | V <sub>IH2</sub> | RESET, FLMD0 <sup>Note</sup>                                      | 0.8EV <sub>DD</sub> |                    | EV <sub>DD</sub>    | V    |
|                              | V <sub>IH3</sub> | P02 to P06, P30 to P37, P42, P50 to P55, P92 to P915              | 0.8EV <sub>DD</sub> |                    | 5.5                 | V    |
|                              | V <sub>IH4</sub> | P38, P39, P40, P41, P90, P91                                      | 0.7EV <sub>DD</sub> |                    | 5.5                 | V    |
|                              | V <sub>IH5</sub> | PCM0 to PCM3, PCT0, PCT1, PCT4, PCT6, PDH0 to PDH3, PDL0 to PDL15 | 0.7BV <sub>DD</sub> |                    | BV <sub>DD</sub>    | V    |
|                              | V <sub>IH6</sub> | P70 to P711                                                       | 0.7AVREF0           |                    | AV <sub>REF0</sub>  | V    |
|                              | V <sub>IH7</sub> | P10, P11 0.7AV <sub>REF1</sub>                                    |                     | AV <sub>REF1</sub> | V                   |      |
| Input voltage, low           | V <sub>IL1</sub> | PDH4, PDH5                                                        | EVss                |                    | 0.3EV <sub>DD</sub> | V    |
|                              | V <sub>IL2</sub> | RESET, FLMD0 <sup>Note</sup>                                      | EVss                |                    | 0.2EV <sub>DD</sub> | V    |
|                              | VIL3             | P02 to P06, P30 to P37, P42, P50 to P55, P92 to P915              | EVss                |                    | 0.2EV <sub>DD</sub> | V    |
|                              | V <sub>IL4</sub> | P38, P39, P40, P41, P90, P91                                      | EVss                |                    | 0.3EV <sub>DD</sub> | V    |
|                              | V <sub>IL5</sub> | PCM0 to PCM3, PCT0, PCT1, PCT4, PCT6, PDH0 to PDH3, PDL0 to PDL15 | BVss                |                    | 0.3BV <sub>DD</sub> | V    |
|                              | V <sub>IL6</sub> | P70 to P711                                                       | AVss                |                    | 0.3AVREF0           | V    |
|                              | V <sub>IL7</sub> | P10, P11                                                          | AVss                |                    | 0.3AVREF1           | V    |
| Input leakage current, high  | Ін               | $V_{I} = V_{DD} = EV_{DD} = BV_{DD} = AV_{REF0} = AV_{REF1}$      |                     |                    | 5                   | μΑ   |
| Input leakage current, low   | Lil              | V1 = 0 V                                                          |                     |                    | -5                  | μΑ   |
| Output leakage current, high | Ісон             | Vo = Vdd = EVdd = BVdd = AVref0 = AVref1                          |                     |                    | 5                   | μΑ   |
| Output leakage current, low  | ILOL             | Vo = 0 V                                                          |                     |                    | <b>-</b> 5          | μΑ   |

Note Flash memory version only

**Remark** Unless specified otherwise, the characteristics of alternate-function pins are the same as those of port pins.

#### $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \leq V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V})$ (2/4)

| Parameter                   | Symbol                                                |                                                                                     | Conditions                   |                              | MIN.                   | TYP.               | MAX.               | Unit        |
|-----------------------------|-------------------------------------------------------|-------------------------------------------------------------------------------------|------------------------------|------------------------------|------------------------|--------------------|--------------------|-------------|
| Output voltage, high        | V <sub>OH1</sub>                                      | P02 to P06,<br>P30 to P39,                                                          | Per pin<br>Iон = -1.0 mA     | Total of all pins<br>-20 mA  | EV <sub>DD</sub> – 1.0 |                    | EV <sub>DD</sub>   | <b>V</b>    |
|                             |                                                       | P40 to P42,<br>P50 to P55,<br>P90 to P915,<br>PDH4, PDH5                            | Per pin IoH = $-100 \mu$ A   | Total of all pins<br>-6.0 mA | EV <sub>DD</sub> – 0.5 |                    | EV <sub>DD</sub>   | V           |
|                             | V <sub>OH2</sub>                                      | PCM0 to<br>PCM3, PCT0,                                                              | Per pin<br>Iон = -1.0 mA     | Total of all pins<br>-20 mA  | BV <sub>DD</sub> – 1.0 |                    | BV <sub>DD</sub>   | <b>V</b>    |
|                             |                                                       | PCT1, PCT4,<br>PCT6, PDH0<br>to PDH3,<br>PDL0 to<br>PDL15                           | Per pin IoH = $-100 \mu$ A   | Total of all pins<br>-2.8 mA | BV <sub>DD</sub> - 0.5 |                    | BV <sub>DD</sub>   | <b>&gt;</b> |
|                             | Vонз                                                  | P70 to P711                                                                         | Per pin<br>Iон = -0.4 mA     | Total of all pins -4.8 mA    | AVREFO - 1.0           |                    | AV <sub>REF0</sub> | V           |
| V <sub>OH4</sub> P          |                                                       | Per pin IOH = $-100 \mu$ A                                                          | Total of all pins<br>-1.2 mA | AVREFO - 0.5                 |                        | AV <sub>REF0</sub> | V                  |             |
|                             | P10, P11                                              | Per pin<br>Iон = -0.4 mA                                                            | Total of all pins<br>-0.8 mA | AV <sub>REF1</sub> – 1.0     |                        | AV <sub>REF1</sub> | V                  |             |
|                             |                                                       | Per pin IOH = $-100 \mu A$                                                          | Total of all pins<br>-0.2 mA | AVREF1 – 0.5                 |                        | AV <sub>REF1</sub> | V                  |             |
| Output voltage, low         | P30 to P37<br>P42, P50 to<br>P55, P92 to<br>P915, PDH | P02 to P06,<br>P30 to P37,<br>P42, P50 to<br>P55, P92 to<br>P915, PDH4,<br>PDH5     | Per pin IoL = 1.0 mA         | Total of all pins<br>20 mA   | 0                      |                    | 0.4                | V           |
|                             | V <sub>OL2</sub>                                      | P38, P39,<br>P40, P41,<br>P90, P91                                                  | Per pin<br>loL = 3.0 mA      |                              | 0                      |                    | 0.4                | V           |
|                             | Vols                                                  | PCM0 to<br>PCM3, PCT0,<br>PCT1, PCT4,<br>PCT6, PDH0<br>to PDH3,<br>PDL0 to<br>PDL15 | Per pin IoL = 1.0 mA         | Total of all pins<br>20 mA   | 0                      |                    | 0.4                | >           |
|                             | V <sub>OL4</sub>                                      | P10, P11,<br>P70 to P711                                                            | Per pin<br>IoL = 0.4 mA      | Total of all pins<br>5.6 mA  | 0                      |                    | 0.4                | V           |
| Software pull-down resistor | R <sub>1</sub>                                        | P05                                                                                 | Vı = Vdd                     |                              | 10                     | 30                 | 100                | kΩ          |

**Remarks 1.** Unless specified otherwise, the characteristics of alternate-function pins are the same as those of port pins.

2. When the IoH and IoL conditions are not satisfied for a pin but the total value of all pins is satisfied, only that pin does not satisfy the DC characteristics.

 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V})$  (3/4)

| Parameter                      | Symbol           |                               | Conditions                                                      | MIN. | TYP. | MAX. | Unit |
|--------------------------------|------------------|-------------------------------|-----------------------------------------------------------------|------|------|------|------|
| Supply current <sup>Note</sup> | I <sub>DD1</sub> | Normal operation              | fxx = 32  MHz (fx = 4  MHz)                                     |      | 50   | 70   | mA   |
| (flash memory version)         | I <sub>DD2</sub> | HALT mode                     | fxx = 32  MHz (fx = 4  MHz)                                     |      | 30   | 40   | mA   |
|                                | Іррз             | IDLE1 mode                    | fxx = 4 MHz (fx = 4 MHz),<br>PLL off                            |      | 0.8  | 1.6  | mA   |
|                                | I <sub>DD4</sub> | IDLE2 mode                    | fxx = 4 MHz (fx = 4 MHz),<br>PLL off                            |      | 0.3  | 0.8  | mA   |
|                                |                  | Subclock operating mode       | fxt = 32.768 kHz,<br>main clock,<br>internal oscillator stopped |      | 300  | 600  | μΑ   |
|                                | IDD6             | Sub-IDLE mode                 | fxt = 32.768 kHz,<br>main clock,<br>internal oscillator stopped |      | 18   | 100  | μΑ   |
|                                | I <sub>DD7</sub> | STOP mode                     | Subclock stopped, internal oscillator stopped                   |      | 7    | 50   | μΑ   |
|                                |                  |                               | Subclock operating, internal oscillator stopped                 |      | 10   | 60   | μΑ   |
|                                |                  |                               | Subclock stopped, internal oscillator operating                 |      | 10   | 60   | μΑ   |
|                                | IDD8             | Flash memory programming mode | fxx = 32 MHz (fx = 4 MHz)                                       |      | 55   | 80   | mA   |

**Note** Total of V<sub>DD</sub>, EV<sub>DD</sub>, and BV<sub>DD</sub> currents. Current flowing through the output buffers, A/D converter, D/A converter, and on-chip pull-down resistor is not included.

 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V}) (4/4)$ 

| Parameter                      | Symbol           |                         | Conditions                                                      | MIN. | TYP. | MAX. | Unit |
|--------------------------------|------------------|-------------------------|-----------------------------------------------------------------|------|------|------|------|
| Supply current <sup>Note</sup> | I <sub>DD1</sub> | Normal operation        | fxx = 32  MHz  (fx = 4  MHz)                                    |      | 35   | 55   | mA   |
| (mask ROM version)             | I <sub>DD2</sub> | HALT mode               | fxx = 32  MHz (fx = 4  MHz)                                     |      | 27   | 40   | mA   |
|                                | Іррз             | IDLE1 mode              | fxx = 4 MHz (fx = 4 MHz),<br>PLL off                            |      | 0.3  | 0.8  | mA   |
|                                | I <sub>DD4</sub> | IDLE2 mode              | fxx = 4 MHz (fx = 4 MHz),<br>PLL off                            |      | 0.3  | 0.8  | mA   |
|                                | IDD5             | Subclock operating mode | fxt = 32.768 kHz,<br>main clock,<br>internal oscillator stopped |      | 50   | 100  | μΑ   |
|                                | IDD6             | Sub-IDLE mode           | fxt = 32.768 kHz,<br>main clock,<br>internal oscillator stopped |      | 15   | 70   | μΑ   |
|                                | I <sub>DD7</sub> | STOP mode               | Subclock stopped, internal oscillator stopped                   |      | 6    | 50   | μΑ   |
|                                |                  |                         | Subclock operating, internal oscillator stopped                 |      | 10   | 60   | μΑ   |
|                                |                  |                         | Subclock stopped, internal oscillator operating                 |      | 10   | 60   | μΑ   |

**Note** Total of V<sub>DD</sub>, EV<sub>DD</sub>, and BV<sub>DD</sub> currents. Current flowing through the output buffers, A/D converter, D/A converter, and on-chip pull-down resistor is not included.

#### **Data Retention Characteristics**

In STOP mode

 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V})$ 

| Parameter                          | Symbol | Conditions                              |                      | MIN.     | TYP. | MAX.              | Unit |
|------------------------------------|--------|-----------------------------------------|----------------------|----------|------|-------------------|------|
| Data retention voltage             | VDDDR  | STOP mode (all functions stopped)       |                      | 1.9      |      | 3.6               | ٧    |
| Data retention current             | IDDDR  | STOP mode (all functions                | Mask ROM version     |          | 6    | 50                | μΑ   |
|                                    |        |                                         | Flash memory version |          | 7    | 50                | μΑ   |
| Supply voltage rise time           | trvd   |                                         |                      | 200      |      |                   | μs   |
| Supply voltage fall time           | trvd   |                                         |                      | 200      |      |                   | μs   |
| Supply voltage retention time      | thvd   | After STOP mod                          | de setting           | 0        |      |                   | ms   |
| STOP release signal input time     | torel  | After VDD reach                         | es 3.0 V (MIN.)      | 0        |      |                   | ms   |
| Data retention input voltage, high | VIHDR  | VDD = EVDD = BVDD = VDDDR               |                      | 0.9VDDDR | ·    | V <sub>DDDR</sub> | V    |
| Data retention input voltage, low  | VILDR  | V <sub>DD</sub> = EV <sub>DD</sub> = B' | VDD = VDDDR          | 0        | ·    | 0.1VDDDR          | V    |

# Caution Shifting to STOP mode and restoring from STOP mode must be performed within the rated operating range.



## AC Test Input Measurement Points (VDD, AVREF0, AVREF1, EVDD, BVDD)



#### **AC Test Output Measurement Points**



#### **Load Conditions**



Caution If the load capacitance exceeds 50 pF due to the circuit configuration, bring the load capacitance of the device to 50 pF or less by inserting a buffer or by some other means.

## **CLKOUT Output Timing**

 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V})$ 

| Parameter        | Symb | ool | Conditions | MIN.        | MAX.             | Unit |
|------------------|------|-----|------------|-------------|------------------|------|
| Output cycle     | tcyĸ | <1> |            | 31.25 ns    | 31.25 <i>μ</i> s |      |
| High-level width | twкн | <2> |            | tcvk/2 - 10 |                  | ns   |
| Low-level width  | twĸL | <3> |            | tcvк/2 – 10 |                  | ns   |
| Rise time        | tkr  | <4> |            |             | 10               | ns   |
| Fall time        | tĸF  | <5> |            |             | 10               | ns   |

## **Clock Timing**



#### **Bus Timing**

## (1) In multiplexed bus mode

Cautions When V850ES/SG2 is operated at fxx > 20 MHz, be sure to insert the address hold wait and the address setup wait.

#### (a) Read/write cycle (CLKOUT asynchronous)

(TA = -40 to +85°C, BVDD ≤ VDD = EVDD = AVREF0 = AVREF1, VSS = EVSS = BVSS = AVSS = 0 V, CL = 50 pF)

| Parameter                                                    | Symb          | ol   | Conditions | MIN.                     | MAX.                          | Unit |
|--------------------------------------------------------------|---------------|------|------------|--------------------------|-------------------------------|------|
| Address setup time (to ASTB↓)                                | tsast         | <6>  |            | (0.5 + tasw)T - 20       |                               | ns   |
| Address hold time (from ASTB↓)                               | <b>t</b> HSTA | <7>  |            | (0.5 + tasw)T - 15       |                               | ns   |
| Delay time from RD↓ to address float                         | <b>t</b> frda | <8>  |            |                          | 10                            | ns   |
| Data input setup time from address                           | tsaid         | <9>  |            |                          | (2 + n + tasw + tahw)T - 35   | ns   |
| Data input setup time from $\overline{\text{RD}} \downarrow$ | tsrid         | <10> |            |                          | (1 + n + tasw + tahw)T - 25   | ns   |
| Delay time from ASTB↓ to RD, WRm↓                            | tostrowr      | <11> |            | (0.5 + tahw)T - 15       |                               | ns   |
| Data input hold time (from $\overline{RD}\uparrow$ )         | thrdid        | <12> |            | 0                        |                               | ns   |
| Address output time from RD↑                                 | <b>t</b> DRDA | <13> |            | (1 + i)T - 10            |                               | ns   |
| Delay time from RD, WRm↑ to ASTB↑                            | tordwrst      | <14> |            | 0.5T – 10                |                               | ns   |
| Delay time from RD↑ to ASTB↓                                 | tordst        | <15> |            | (1.5 + i + tasw)T - 10   |                               | ns   |
| RD, WRm low-level width                                      | twrdwrl       | <16> |            | (1 + n)T – 10            |                               | ns   |
| ASTB high-level width                                        | twsтн         | <17> |            | (1 + tasw)T - 10         |                               | ns   |
| Data output time from $\overline{WRm} \downarrow$            | towrod        | <18> |            |                          | 15                            | ns   |
| Data output setup time (to WRm↑)                             | tsodwr        | <19> |            | (1 + n)T – 20            |                               | ns   |
| Data output hold time (from WRm↑)                            | thwrod        | <20> |            | T – 15                   |                               | ns   |
| WAIT setup time (to address)                                 | tsawt1        | <21> | n ≥ 1      |                          | (1.5 + tasw + tahw)T - 35     | ns   |
|                                                              | tsawt2        | <22> |            |                          | (1.5 + n + tasw + tahw)T - 35 | ns   |
| WAIT hold time (from address)                                | thawt1        | <23> | n ≥ 1      | (0.5 + n + tasw + tahw)T |                               | ns   |
|                                                              | thawt2        | <24> |            | (1.5 + n + tasw + tahw)T |                               | ns   |
| WAIT setup time (to ASTB↓)                                   | tsstwt1       | <25> | n ≥ 1      |                          | (1 + tahw)T - 25              | ns   |
|                                                              | tsstwt2       | <26> |            |                          | (1 + n + tанw)T – 25          | ns   |
| WAIT hold time (from ASTB↓)                                  | thstwt1       | <27> | n ≥ 1      | (n + tahw)T              |                               | ns   |
|                                                              | thstwt2       | <28> |            | (1 + n + tahw)T          |                               | ns   |

#### Remarks 1. tasw: Number of address setup wait clocks

tahw: Number of address hold wait clocks

- **2.** T = 1/fcpu (fcpu: CPU operating clock frequency)
- n: Number of wait clocks inserted in the bus cycleThe sampling timing changes when a programmable wait is inserted.
- **4.** m = 0, 1
- 5. i: Number of idle states inserted after a read cycle (0 or 1)
- **6.** The values in the above specifications are values for when clocks with a 1:1 duty ratio are input from X1.

## Read Cycle (CLKOUT Asynchronous): In Multiplexed Bus Mode



## Write Cycle (CLKOUT Asynchronous): In Multiplexed Bus Mode



## (b) Read/write cycle (CLKOUT synchronous): In multiplexed bus mode

 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V}, C_L = 50 \text{ pF})$ 

| Parameter                                | Sym          | bol  | Conditions | MIN.       | MAX. | Unit |
|------------------------------------------|--------------|------|------------|------------|------|------|
| Delay time from CLKOUT↑ to address       | <b>t</b> DKA | <29> |            | 0          | 25   | ns   |
| Delay time from CLKOUT↑ to address float | tfka         | <30> |            | 0          | 19   | ns   |
| Delay time from CLKOUT↓ to ASTB          | tokst        | <31> |            | -12        | 7    | ns   |
| Delay time from CLKOUT↑ to RD, WRm       | tokrowr      | <32> |            | <b>-</b> 5 | 14   | ns   |
| Data input setup time (to CLKOUT↑)       | tsidk        | <33> |            | 15         |      | ns   |
| Data input hold time (from CLKOUT↑)      | thkid        | <34> |            | 5          |      | ns   |
| Data output delay time from CLKOUT↑      | tokod        | <35> |            |            | 19   | ns   |
| WAIT setup time (to CLKOUT↓)             | tswтк        | <36> |            | 20         |      | ns   |
| WAIT hold time (from CLKOUT↓)            | tнкwт        | <37> |            | 5          |      | ns   |

## Remarks 1. m = 0, 1

2. The values in the above specifications are values for when clocks with a 1:1 duty ratio are input from X1.

## Read Cycle (CLKOUT Synchronous): In Multiplexed Bus Mode



## Write Cycle (CLKOUT Synchronous): In Multiplexed Bus Mode



#### (2) In separate bus mode

Cautions When V850ES/SG2 is operated at fxx > 20 MHz, be sure to insert the address hold wait and the address setup wait.

#### (a) Read cycle (CLKOUT asynchronous): In separate bus mode

 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V}, C_L = 50 \text{ pF})$ 

| Parameter                                                                   | Symb    | ol   | Conditions | MIN.                   | MAX.                        | Unit |
|-----------------------------------------------------------------------------|---------|------|------------|------------------------|-----------------------------|------|
| Address setup time (to $\overline{RD}\downarrow$ )                          | tsard   | <38> |            | (0.5 + tasw)T - 25     |                             | ns   |
| Address hold time (from RD↑)                                                | thard   | <39> |            | iT + 1                 |                             | ns   |
| RD low-level width                                                          | twrdl   | <40> |            | (1.5 + n + ta+w)T – 10 |                             | ns   |
| Data setup time (to RD↑)                                                    | tsisd   | <41> |            | 23                     |                             | ns   |
| Data hold time (from RD↑)                                                   | thisp   | <42> |            | 0                      |                             | ns   |
| Data setup time (to address)                                                | tsaid   | <43> |            |                        | (2 + n + tasw + tahw)T - 40 | ns   |
| $\overline{\text{WAIT}}$ setup time (to $\overline{\text{RD}}\downarrow$ )  | tsrdwt1 | <44> |            |                        | (0.5 + tahw)T – 25          | ns   |
|                                                                             | tsrdwt2 | <45> |            |                        | (0.5 + n + tahw)T - 25      | ns   |
| $\overline{\text{WAIT}}$ hold time (from $\overline{\text{RD}}\downarrow$ ) | thrdwt1 | <46> |            | (n – 0.5 + tанw)Т      |                             | ns   |
|                                                                             | thrdwt2 | <47> |            | (n + 0.5 + tahw)T      |                             | ns   |
| WAIT setup time (to address)                                                | tsawt1  | <48> |            |                        | (1 + tasw + tahw)T - 45     | ns   |
|                                                                             | tsawt2  | <49> |            |                        | (1 + n + tasw + tahw)T - 45 | ns   |
| WAIT hold time (from address)                                               | thawt1  | <50> |            | (1 + tasw + tahw)T     |                             | ns   |
|                                                                             | thawt2  | <51> |            | (1 + n + tasw + tahw)T |                             | ns   |

## Remarks 1. tasw: Number of address setup wait clocks

tahw: Number of address hold wait clocks

- **2.** T = 1/fcpu (fcpu: CPU operating clock frequency)
- n: Number of wait clocks inserted in the bus cycleThe sampling timing changes when a programmable wait is inserted
- 4. i: Number of idle states inserted after a read cycle (0 or 1)
- 5. The values in the above specifications are values for when clocks with a 1:1 duty ratio are input from X1.

## Read Cycle (CLKOUT Asynchronous): In Separate Bus Mode



## (b) Write cycle (CLKOUT asynchronous): In separate bus mode

(TA = -40 to +85°C, BVDD ≤ VDD = EVDD = AVREF0 = AVREF1, VSS = EVSS = BVSS = AVSS = 0 V, CL = 50 pF)

| Parameter                                                  | Syml    | ool  | Conditions | MIN.                    | MAX.                        | Unit |
|------------------------------------------------------------|---------|------|------------|-------------------------|-----------------------------|------|
| Address setup time (to $\overline{\text{WRm}}\downarrow$ ) | tsawr   | <52> |            | (1 + tasw + tahw)T - 25 |                             | ns   |
| Address hold time (from WRm↑)                              | thawr   | <53> |            | 0.5T – 10               |                             | ns   |
| WRm low-level width                                        | twwrL   | <54> |            | (0.5 + n)T - 10         |                             | ns   |
| Data output time from WRm↓                                 | toosow  | <55> |            | <b>-</b> 5              |                             | ns   |
| Data setup time (to WRm↑)                                  | tsospw  | <56> |            | (0.5 + n)T – 20         |                             | ns   |
| Data hold time (from WRm↑)                                 | thospw  | <57> |            | 0.5T – 10               |                             | ns   |
| Data setup time (to address)                               | tsaod   | <58> |            | (1 + tasw + tahw)T - 25 |                             | ns   |
| WAIT setup time (to WRm↓)                                  | tswrwT1 | <59> |            | 22                      |                             | ns   |
|                                                            | tswrwT2 | <60> |            |                         | nT – 22                     | ns   |
| WAIT hold time (from WRm↓)                                 | thwrwT1 | <61> |            | 0                       |                             | ns   |
|                                                            | thwrwT2 | <62> |            | nT                      |                             | ns   |
| WAIT setup time (to address)                               | tsawt1  | <63> |            |                         | (1 + tasw + tahw)T - 45     | ns   |
|                                                            | tsawt2  | <64> |            |                         | (1 + n + tasw + tahw)T - 45 | ns   |
| WAIT hold time (from address)                              | thawt1  | <65> |            | (n + tasw + tahw)T      |                             | ns   |
|                                                            | tHAWT2  | <66> |            | (1 + n + tasw + tahw)T  |                             | ns   |

#### **Remarks 1.** m = 0, 1

- 2. tasw: Number of address setup wait clocks tahw: Number of address hold wait clocks
- **3.** T = 1/fcpu (fcpu: CPU operating clock frequency)
- **4.** n: Number of wait clocks inserted in the bus cycle

  The sampling timing changes when a programmable wait is inserted.
- 5. The values in the above specifications are values for when clocks with a 1:1 duty ratio are input from X1.

## Write Cycle (CLKOUT Asynchronous): In Separate Bus Mode



## (c) Read cycle (CLKOUT synchronous): In separate bus mode

 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V}, C_L = 50 \text{ pF})$ 

| Parameter                           | Syml          | bol  | Conditions | MIN. | MAX. | Unit |
|-------------------------------------|---------------|------|------------|------|------|------|
| Delay time from CLKOUT↑ to address  | <b>t</b> DKSA | <67> |            | 2    | 27   | ns   |
| Data input setup time (to CLKOUT↑)  | tsisbk        | <68> |            | 20   |      | ns   |
| Data input hold time (from CLKOUT↑) | thkisd        | <69> |            | 0    |      | ns   |
| Delay time from CLKOUT↓↑ to RD      | toksr         | <70> |            | -2   | 14   | ns   |
| WAIT setup time (to CLKOUT↑)        | tswтк         | <71> |            | 20   |      | ns   |
| WAIT hold time (from CLKOUT↑)       | tнкwт         | <72> |            | 0    |      | ns   |

Remark The values in the above specifications are values for when clocks with a 1:1 duty ratio are input from X1.

## Read Cycle (CLKOUT Synchronous, 1 Wait): In Separate Bus Mode



## (d) Write cycle (CLKOUT synchronous): In separate bus mode

 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \leq V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V}, C_L = 50 \text{ pF})$ 

| Parameter                                          | Sym           | bol  | Conditions | MIN. | MAX. | Unit |
|----------------------------------------------------|---------------|------|------------|------|------|------|
| Delay time from CLKOUT↑ to address                 | <b>t</b> DKSA | <73> |            | 2    | 27   | ns   |
| Delay time from CLKOUT <sup>↑</sup> to data output | tokso         | <74> |            | 2    | 15   | ns   |
| Delay time from CLKOUT↑↓ to WRm                    | toksw         | <75> |            | -2   | 14   | ns   |
| WAIT setup time (to CLKOUT↑)                       | tswтк         | <76> |            | 20   |      | ns   |
| WAIT hold time (from CLKOUT↑)                      | tнкwт         | <77> |            | 0    |      | ns   |

#### **Remarks 1.** m = 0, 1

2. The values in the above specifications are values for when clocks with a 1:1 duty ratio are input from X1.

## Write Cycle (CLKOUT Synchronous): In Separate Bus Mode



#### (3) Bus hold

## (a) CLKOUT asynchronous

 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V}, C_L = 50 \text{ pF})$ 

| Parameter                            | Symbol        |      | Conditions | MIN.   | MAX.             | Unit |
|--------------------------------------|---------------|------|------------|--------|------------------|------|
| HLDRQ high-level width               | twнqн         | <78> |            | T + 10 |                  | ns   |
| HLDAK low-level width                | twhal         | <79> |            | T – 15 |                  | ns   |
| Delay time from HLDAK↑ to bus output | <b>t</b> DHAC | <80> |            | -5     |                  | ns   |
| Delay time from HLDRQ↓ to HLDAK↓     | tdhqha1       | <81> |            |        | (2n + 7.5)T + 25 | ns   |
| Delay time from HLDRQ↑ to HLDAK↑     | tdhqha2       | <82> |            | 0.5T   | 1.5T + 25        | ns   |

#### **Remarks 1.** T = 1/fcpu (fcpu: CPU operating clock frequency)

- n: Number of wait clocks inserted in the bus cycleThe sampling timing changes when a programmable wait is inserted.
- 3. The values in the above specifications are values for when clocks with a 1:1 duty ratio are input from X1.

## **Bus Hold (CLKOUT Asynchronous)**



## (b) CLKOUT synchronous

 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V}, C_L = 50 \text{ pF})$ 

| Parameter                            | Symb          | ool  | Conditions | MIN. | MAX. | Unit |
|--------------------------------------|---------------|------|------------|------|------|------|
| HLDRQ setup time (to CLKOUT↓)        | tsнак         | <83> |            | 20   |      | ns   |
| HLDRQ hold time (from CLKOUT↓)       | tнкна         | <84> |            | 5    |      | ns   |
| Delay time from CLKOUT↑ to bus float | tokf          | <85> |            |      | 19   | ns   |
| Delay time from CLKOUT↑ to HLDAK     | <b>t</b> DKHA | <86> |            |      | 19   | ns   |

Remark The values in the above specifications are values for when clocks with a 1:1 duty ratio are input from X1.

## **Bus Hold (CLKOUT Synchronous)**



## Power On/Power Off/Reset Timing

 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, V_{SS} = AV_{SS} = BV_{SS} = EV_{SS} = 0 \text{ V}, C_L = 50 \text{ pF})$ 

| Parameter                                                | Sym              | bol  | Conditions                                            | MIN.      | MAX. | Unit |
|----------------------------------------------------------|------------------|------|-------------------------------------------------------|-----------|------|------|
| $EV_DD\!\!\uparrow\toV_DD\!\!\uparrow$                   | trel             | <87> |                                                       | 0         |      | ns   |
| $EV_DD \uparrow \to BV_DD \uparrow$                      | treb             | <88> |                                                       | 0         | trel | ns   |
| $EV_DD \uparrow \to AV_REF0,  AV_REF1 \uparrow$          | trea             | <89> |                                                       | 0         | trel | ns   |
| $EV_{DD} \uparrow \rightarrow \overline{RESET} \uparrow$ | trer             | <90> |                                                       | 500 +     |      | ns   |
|                                                          |                  |      |                                                       | treg Note |      |      |
| RESET low-level width                                    | twrsl            | <91> | Analog noise elimination (during flash erase/writing) | 500       |      | ns   |
|                                                          |                  |      | Analog noise elimination                              | 500       |      | ns   |
| $\overline{RESET} \downarrow \to V_DD \downarrow$        | t <sub>FRE</sub> | <92> |                                                       | 500       |      | ns   |
| $V_{DD} \downarrow \rightarrow EV_{DD} \downarrow$       | t <sub>FEL</sub> | <93> |                                                       | 0         |      | ns   |
| $BV_DD \!\!\downarrow \to EV_DD \!\!\downarrow$          | tғев             | <94> |                                                       | 0         | trel | ns   |
| $AV_REF0 \!\!\downarrow 	o EV_DD \!\!\downarrow$         | t <sub>FEA</sub> | <95> |                                                       | 0         | trel | ns   |

**Note** Depends on the on-chip regulator characteristics.



#### Interrupt, FLMD0 Pin Timing

 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V}, C_L = 50 \text{ pF})$ 

| Parameter              | Symbol | Conditions                            | MIN.                   | MAX. | Unit |
|------------------------|--------|---------------------------------------|------------------------|------|------|
| NMI high-level width   | twnih  | Analog noise elimination              | 500                    |      | ns   |
| NMI low-level width    | twnil  | Analog noise elimination              | 500                    |      | ns   |
| INTPn high-level width | twiтн  | n = 0 to 7 (Analog noise elimination) | 500                    |      | ns   |
|                        |        | n = 3 (Digital noise elimination)     | 3T <sub>SMP</sub> + 20 |      | ns   |
| INTPn low-level width  | twitl  | n = 0 to 7 (Analog noise elimination) | 500                    |      | ns   |
|                        |        | n = 3 (Digital noise elimination)     | 3T <sub>SMP</sub> + 20 |      | ns   |
| FLMD0 high-level width | twмdн  |                                       | 500                    |      | ns   |
| FLMD0 low-level width  | twmdl  |                                       | 500                    |      | ns   |

Remark Tsmp: Noise elimination sampling clock cycle

## **Key Return Timing**

## $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V}, C_L = 50 \text{ pF})$

| Parameter            | Symbol | Conditions               | MIN. | MAX. | Unit |
|----------------------|--------|--------------------------|------|------|------|
| KRn high-level width | twkrh  | Analog noise elimination | 500  |      | ns   |
| KRn low-level width  | twkrl  | Analog noise elimination | 500  |      | ns   |

**Remark** n = 0 to 7

#### **Timer Timing**

## $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V}, C_L = 50 \text{ pF})$

| Parameter           | Symbol | Conditions                                               | MIN.    | MAX. | Unit |
|---------------------|--------|----------------------------------------------------------|---------|------|------|
| TI high-level width | tтıн   | TIP00, TIP01, TIP10, TIP11, TIP20, TIP21,                | 2T + 20 |      | ns   |
| TI low-level width  | t⊤ı∟   | TIP30, TIP31, TIP40, TIP41, TIP50, TIP51, TIQ00 to TIQ03 | 2T + 20 |      | ns   |

**Remark** T = 1/fxx

## **UART Timing**

## $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V}, C_L = 50 \text{ pF})$

| Parameter        | Symbol | Conditions | MIN. | MAX.  | Unit |
|------------------|--------|------------|------|-------|------|
| Transmit rate    |        |            |      | 312.5 | kbps |
| ASCK0 cycle time |        |            |      | 10    | MHz  |

## **CSIB Timing**

## (1) Master mode

 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V}, C_L = 50 \text{ pF})$ 

| Parameter                    | Syn               | nbol  | Conditions | MIN.        | MAX. | Unit |
|------------------------------|-------------------|-------|------------|-------------|------|------|
| SCKBn cycle time             | tkcy1             | <96>  |            | 125         |      | ns   |
| SCKBn high-/low-level width  | <b>t</b> кн1,     | <97>  |            | tkcy1/2 - 5 |      | ns   |
|                              | t <sub>KL1</sub>  |       |            |             |      |      |
| SIBn setup time (to SCKBn↑)  | tsıĸ1             | <98>  |            | 30          |      | ns   |
| SIBn hold time (from SCKBn↑) | t <sub>KSI1</sub> | <99>  |            | 30          |      | ns   |
| Delay time from SCKBn        | tkso1             | <100> |            |             | 30   | ns   |

**Remark** n = 0 to 4

#### (2) Slave mode

 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V}, C_L = 50 \text{ pF})$ 

| Parameter                             | Syn           | nbol  | Conditions | MIN. | MAX. | Unit |
|---------------------------------------|---------------|-------|------------|------|------|------|
| SCKBn cycle time                      | tkCY2         | <96>  |            | 125  |      | ns   |
| SCKBn high-/low-level width           | tкн2,<br>tкL2 | <97>  |            | 57.5 |      | ns   |
| SIBn setup time (to SCKBn↑)           | tsık2         | <98>  |            | 30   |      | ns   |
| SIBn hold time (from SCKBn↑)          | tksi2         | <99>  |            | 30   |      | ns   |
| Delay time from SCKBn↓ to SOBn output | tkso2         | <100> |            |      | 35   | ns   |

#### **Remark** n = 0 to 4



I<sup>2</sup>C Bus Mode

(TA = -40 to +85°C, BVDD ≤ VDD = EVDD = AVREF0 = AVREF1, VSS = EVSS = BVSS = AVSS = 0 V, CL = 50 pF)

| Pa                                | rameter                                 | Symbol       |       | Norma               | l Mode | High-Spe                     | ed Mode               | Unit |
|-----------------------------------|-----------------------------------------|--------------|-------|---------------------|--------|------------------------------|-----------------------|------|
|                                   |                                         |              |       | MIN.                | MAX.   | MIN.                         | MAX.                  |      |
| SCL0n clock free                  | quency                                  | fclk         |       | 0                   | 100    | 0                            | 400                   | kHz  |
| Bus free time<br>(Between start a | nd stop conditions)                     | <b>t</b> BUF | <101> | 4.7                 | -      | 1.3                          | -                     | μs   |
| Hold time <sup>Note 1</sup>       |                                         | thd: STA     | <102> | 4.0                 | _      | 0.6                          | -                     | μs   |
| SCL0n clock low                   | r-level width                           | tLOW         | <103> | 4.7                 | 1      | 1.3                          | -                     | μs   |
| SCL0n clock hig                   | h-level width                           | tніgн        | <104> | 4.0                 | ı      | 0.6                          | -                     | μs   |
| Setup time for st                 | Setup time for start/restart conditions |              | <105> | 4.7                 | ı      | 0.6                          | -                     | μs   |
| Data hold time                    | CBUS compatible master                  | thd: dat     | <106> | 5.0                 | -      | -                            | -                     | μs   |
|                                   | I <sup>2</sup> C mode                   |              |       | O <sup>Note 2</sup> | -      | O <sup>Note 2</sup>          | 0.9 <sup>Note 3</sup> | μs   |
| Data setup time                   |                                         | tsu: DAT     | <107> | 250                 | _      | 100 <sup>Note 4</sup>        | _                     | ns   |
| SDA0n and SCL                     | On signal rise time                     | tR           | <108> | _                   | 1000   | 20 + 0.1Cb <sup>Note 5</sup> | 300                   | ns   |
| SDA0n and SCL                     | On signal fall time                     | tF           | <109> | _                   | 300    | 20 + 0.1Cb Note 5            | 300                   | ns   |
| Stop condition setup time         |                                         | tsu: sto     | <110> | 4.0                 | _      | 0.6                          | -                     | μs   |
| Pulse width of spinput filter     | pike suppressed by                      | tsp          | <111> | _                   | _      | 0                            | 50                    | ns   |
| Capacitance loa                   | d of each bus line                      | Cb           |       | -                   | 400    | _                            | 400                   | pF   |

**Notes 1.** At the start condition, the first clock pulse is generated after the hold time.

- 2. The system requires a minimum of 300 ns hold time internally for the SDA0n signal (at V<sub>IHmin.</sub> of SCL0n signal) in order to occupy the undefined area at the falling edge of SCL0n.
- 3. If the system does not extend the SCL0n signal low hold time (tLOW), only the maximum data hold time (tHD:DAT) needs to be satisfied.
- **4.** The high-speed mode I<sup>2</sup>C bus can be used in the normal-mode I<sup>2</sup>C bus system. In this case, set the high-speed mode I<sup>2</sup>C bus so that it meets the following conditions.
  - If the system does not extend the SCL0n signal's low state hold time:  $t_{\text{SU:DAT}} \geq 250 \text{ ns}$
  - If the system extends the SCL0n signal's low state hold time:
     Transmit the following data bit to the SDA0n line prior to the SCL0n line release (trans. + tsu:DAT = 1,000 + 250 = 1,250 ns: Normal mode l<sup>2</sup>C bus specification).
- 5. Cb: Total capacitance of one bus line (unit: pF)

**Remark** n = 0 to 2

#### I<sup>2</sup>C Bus Mode



## **IEBus Controller (Products with IEBus Controller Only)**

 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V}, C_L = 50 \text{ pF})$ 

| Parameter                    | Symbol | Conditions                     | MIN. | TYP.                 | MAX. | Unit |
|------------------------------|--------|--------------------------------|------|----------------------|------|------|
| IEBus system clock frequency | fs     | Communication mode: Modes 1, 2 | 5.91 | 6.00 <sup>Note</sup> | 6.09 | MHz  |
|                              |        |                                | 6.20 | 6.29 <sup>Note</sup> | 6.38 | MHz  |

Note IEBus system clock frequencies 6.0 MHz and 6.29 MHz cannot be used together.

## **CAN Timing (Products with CAN Controller Only)**

(TA = -40 to +85°C, BVDD ≤ VDD = EVDD = AVREF0 = AVREF1, VSS = EVSS = BVSS = AVSS = 0 V, CL = 50 pF)

| Parameter           | Symbol | Conditions | MIN. | MAX. | Unit |
|---------------------|--------|------------|------|------|------|
| Transmit rate       |        |            |      | 1    | Mbps |
| Internal delay time | tnode  |            |      | 100  | ns   |



Internal delay time (tnode) = Internal transmission delay time (toutput) + Internal reception delay time (tnput)



#### A/D Converter

 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, 3.0 \text{ V} \le AV_{REF0} \le 3.6 \text{ V}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V}, C_L = 50 \text{ pF})$ 

| Parameter                     | Symbol             | Conditions                 | MIN. | TYP. | MAX.               | Unit |
|-------------------------------|--------------------|----------------------------|------|------|--------------------|------|
| Resolution                    |                    |                            |      |      | 10                 | bit  |
| Overall error <sup>Note</sup> |                    | 3.0 ≤ AVREF0 ≤ 3.6 V       |      |      | ±0.6               | %FSR |
| Conversion time               | tconv              |                            | 2.6  |      | 24                 | μs   |
| Zero scale error              |                    |                            |      |      | ±0.5               | %FSR |
| Full scale error              |                    |                            |      |      | ±0.5               | %FSR |
| Non-linearity error           |                    |                            |      |      | ±4.0               | LSB  |
| Differential linearity error  |                    |                            |      |      | ±4.0               | LSB  |
| Analog input voltage          | VIAN               |                            | AVss |      | AV <sub>REF0</sub> | ٧    |
| Reference voltage             | AV <sub>REF0</sub> |                            | 3.0  |      | 3.6                | ٧    |
| AVREFO current                | AI <sub>REF0</sub> | Normal conversion mode     |      | 3    | 6.5                | mA   |
|                               |                    | High-speed conversion mode |      | 4    | 10                 | mA   |
|                               |                    | When A/D converter unused  |      |      | 5                  | μΑ   |

**Note** Excluding quantization error (±0.05 %FSR).

Caution Do not set (read/write) alternate-function ports during A/D conversion; otherwise the conversion resolution may be degraded.

Remark LSB: Least Significant Bit

FSR: Full Scale Range

#### D/A Converter

 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, 3.0 \text{ V} \le AV_{REF1} \le 3.6 \text{ V}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V}, C_L = 50 \text{ pF})$ 

| Parameter                       | Symbol             | Conditions               | MIN. | TYP. | MAX. | Unit |
|---------------------------------|--------------------|--------------------------|------|------|------|------|
| Resolution                      |                    |                          |      |      | 8    | bit  |
| Overall error <sup>Note 1</sup> |                    | $R = 2 M\Omega$          |      |      | ±1.2 | %FSR |
| Settling time                   |                    | C = 20 pF                |      |      | 3    | μs   |
| Output resistor                 | Ro                 | Output data 55H          |      | 3.5  |      | kΩ   |
| Reference voltage               | AV <sub>REF1</sub> |                          | 3.0  |      | 3.6  | V    |
| AVREF1 currentNote 2            | Alref1             | D/A conversion operating |      | 1    | 2.5  | mA   |
|                                 |                    | D/A conversion stopped   |      |      | 5    | μΑ   |

**Notes 1.** Excluding quantization error (±0.5 LSB).

2. Value of 1 channel of D/A converter

**Remark** R is the output pin load resistance and C is the output pin load capacitance.

#### **RAM Retention Detection**

(TA = -40 to +85°C, BVDD ≤ VDD = EVDD = AVREF0 = AVREF1, VSS = EVSS = BVSS = AVSS = 0 V, CL = 50 pF)

| Parameter                     | Symbol         | Conditions                          | MIN.  | TYP. | MAX. | Unit |
|-------------------------------|----------------|-------------------------------------|-------|------|------|------|
| Detection voltage             | VRAMH          |                                     | 1.9   | 2.0  | 2.1  | V    |
| Supply voltage rise time      | tramhth        | V <sub>DD</sub> = 0 to 3.0 V        | 0.002 |      |      | ms   |
| Response time <sup>Note</sup> | <b>t</b> RAMHD | After V <sub>DD</sub> reaches 2.1 V |       | 0.2  | 2.0  | ms   |
| Minimum pulse width           | tramhw         |                                     | 0.2   |      |      | ms   |

Note Time required to detect the detection voltage and set the RAMS.RAMF bit.



## **Flash Memory Programming Characteristics**

 $(T_A = -40 \text{ to } +85^{\circ}\text{C}, BV_{DD} \le V_{DD} = EV_{DD} = AV_{REF0} = AV_{REF1}, V_{SS} = EV_{SS} = BV_{SS} = AV_{SS} = 0 \text{ V}, C_L = 50 \text{ pF})$ 

#### (1) Basic characteristics

| Parameter               | Symbol          | Conditions | MIN. | TYP. | MAX. | Unit  |
|-------------------------|-----------------|------------|------|------|------|-------|
| Operating frequency     | fcpu            |            | 2.5  |      | 32   | MHz   |
| Supply voltage          | V <sub>DD</sub> |            | 3.0  |      | 3.6  | V     |
| Number of rewrites      | Cwrt            |            |      |      | 100  | times |
| Programming temperature | tprg            |            | -40  |      | +85  | °C    |

#### (2) Serial write operation characteristics

| Parameter                                       | Symbol         | Conditions        | MIN.       | TYP. | MAX. | Unit |
|-------------------------------------------------|----------------|-------------------|------------|------|------|------|
| FLMD0, FLMD1 setup time                         | <b>t</b> MDSET |                   | 2          |      | 3000 | ms   |
| FLMD0 count start time from RESET↑              | trece          | fx = 2.5 to 8 MHz | 17855/fx + |      |      | s    |
|                                                 |                |                   | α          |      |      |      |
| FLMD0 counter high-level width/ low-level width | tcH/tcL        |                   | 10         | 100  |      | μs   |
| FLMD0 counter rise time/fall time               | tr/tr          |                   |            |      | 50   | ns   |

**Remark**  $\alpha$  = oscillation stabilization time

## Flash write mode setup timing



## (3) Programming characteristics

| Parameter                             | Symbol | Condition    | s      | MIN. | TYP.   | MAX. | Unit |
|---------------------------------------|--------|--------------|--------|------|--------|------|------|
| Block erase time                      |        | fxx = 32 MHz | Note 1 |      | 651.3  |      | ms   |
|                                       |        |              | Note 2 |      | 3081.9 |      | ms   |
|                                       |        |              | Note 3 |      | 6727.7 |      | ms   |
| Write time per 256 bytes              |        | fxx = 32 MHz |        |      | 8.7    |      | ms   |
| Block internal verify time            |        | fxx = 32 MHz | Note 1 |      | 49.0   |      | ms   |
|                                       |        |              | Note 2 |      | 342.9  |      | ms   |
|                                       |        |              | Note 3 |      | 783.9  |      | ms   |
| Block blank check time                |        | fxx = 32 MHz | Note 1 |      | 22.7   |      | ms   |
|                                       |        |              | Note 2 |      | 159.2  |      | ms   |
|                                       |        |              | Note 3 |      | 364.0  |      | ms   |
| Flash memory information setting time |        | fxx = 32 MHz | -      |      | 1.1    |      | ms   |

Notes 1. Block size = 8 KB

2. Block size = 56 KB

3. Block size = 128 KB

Caution When writing initially to shipped products, it is counted as one rewrite for both "erase to write" and "write only".

Example (P: Write, E: Erase)

Shipped product  $\longrightarrow$  P  $\rightarrow$  E  $\rightarrow$  P  $\rightarrow$  E  $\rightarrow$  P: 3 rewrites Shipped product  $\rightarrow$  E  $\rightarrow$  P  $\rightarrow$  E  $\rightarrow$  P  $\rightarrow$  E  $\rightarrow$  P: 3 rewrites

## **CHAPTER 32 PACKAGE DRAWING**

## 100-PIN PLASTIC LQFP (FINE PITCH) (14x14)



detail of lead end



#### NOTE

Each lead centerline is located within 0.08 mm of its true position (T.P.) at maximum material condition.

| ITEM  | MILLIMETERS            |
|-------|------------------------|
| Α     | 16.00±0.20             |
| В     | 14.00±0.20             |
| С     | 14.00±0.20             |
| D     | 16.00±0.20             |
| F     | 1.00                   |
| G     | 1.00                   |
| Н     | $0.22^{+0.05}_{-0.04}$ |
| 1     | 0.08                   |
| J     | 0.50 (T.P.)            |
| K     | 1.00±0.20              |
| L     | 0.50±0.20              |
| М     | $0.17^{+0.03}_{-0.07}$ |
| N     | 0.08                   |
| Р     | 1.40±0.05              |
| Q     | 0.10±0.05              |
| R     | 3°+7°<br>-3°           |
| S     | 1.60 MAX.              |
| C1004 | CC EC OFIL OF A        |

S100GC-50-8EU, 8EA-2

## **CHAPTER 33 RECOMMENDED SOLDERING CONDITIONS**

TBD

#### APPENDIX A DEVELOPMENT TOOLS

The following development tools are available for the development of systems that employ the V850ES/SG2. Figure A-1 shows the development tool configuration.

#### • Support for PC98-NX series

Unless otherwise specified, products supported by IBM PC/AT<sup>™</sup> compatibles are compatible with PC98-NX series computers. When using PC98-NX series computers, refer to the explanation for IBM PC/AT compatibles.

## Windows<sup>™</sup>

Unless otherwise specified, "Windows" means the following OSs.

- Windows 98
- Windows 2000
- Windows Me
- Windows XP
- Windows NT<sup>™</sup> Ver. 4.0

(1) When using in-circuit emulator IE-V850ES-G1 ---- Software package Language processing software Debugging software • C compiler package • Integrated debugger Device file System simulator Control software Project manager Embedded software (Windows only)Note 1 • Real-time OS • Network library File system Host machine (PC or EWS) Interface adapter Power supply unit Flash memory write environment In-circuit emulator Flash programmer (IE-V850ES-G1)Note 2 Flash memory write adapter Flash memory Conversion socket or conversion adapter Target system **Notes 1.** The project manager PM+ is included in the assembler package. PM+ is only used for Windows. 2. Products other than in-circuit emulator IE-V850ES-G1 are all sold separately.

Figure A-1. Development Tool Configuration (1/2)

(2) When using IECUBE™ QB-V850ESSX2 ----- Software package Language processing software Debugging software • C compiler package • Integrated debugger Device file System simulator Control software Project manager Embedded software (Windows only)Note 1 • Real-time OS Network library • File system Host machine (PC or EWS) USB interface cable Power supply unit Flash memory write environment In-circuit emulator Flash programmer (QB-V850ESSX2)Note 2 Flash memory write adapter Flash memory Conversion socket or conversion adapter Target system **Notes 1.** The project manager PM+ is included in the assembler package. PM+ is only used for Windows. 2. In-circuit emulator QB-V850ESSX2 is supplied with integrated debugger ID850QB, a simple programmer PG-FPL, power supply unit, and USB interface cable. Any other products are sold separately.

Figure A-1. Development Tool Configuration (2/2)

## A.1 Software Package

| SP850                        | Development tools (software) common to the V850 Series are combined in this package. |
|------------------------------|--------------------------------------------------------------------------------------|
| V850 Series software package | Part number: μSxxxSP850                                                              |

**Remark** ×××× in the part number differs depending on the host machine and OS used.



| ×××× | Host Machine          | OS                         | Supply Medium |
|------|-----------------------|----------------------------|---------------|
| AB17 | PC-9800 series,       | Windows (Japanese version) | CD-ROM        |
| BB17 | IBM PC/AT compatibles | Windows (English version)  |               |

## A.2 Language Processing Software

| CA850<br>C compiler package | This compiler converts programs written in C language into object codes executable with a microcontroller. This compiler is started from project manager PM+.         |
|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             | Part number: μSxxxCA703000                                                                                                                                            |
| DF703283H                   | This file contains information peculiar to the device.                                                                                                                |
| Device file                 | This device file should be used in combination with a tool (CA850, SM850, and ID850).  The corresponding OS and host machine differ depending on the tool to be used. |

**Remark** ×××× in the part number differs depending on the host machine and OS used.



| ×××× | Host Machine              | OS                                                                    | Supply Medium |
|------|---------------------------|-----------------------------------------------------------------------|---------------|
| AB17 | PC-9800 series,           | Windows (Japanese version)                                            | CD-ROM        |
| BB17 | IBM PC/AT compatibles     | Windows (English version)                                             |               |
| 3K17 | SPARCstation <sup>™</sup> | SunOS <sup>™</sup> (Rel. 4.1.4),<br>Solaris <sup>™</sup> (Rel. 2.5.1) |               |

#### A.3 Control Software

| PM+             | This is control software designed to enable efficient user program development in the |  |
|-----------------|---------------------------------------------------------------------------------------|--|
| Project manager | Windows environment. All operations used in development of a user program, such as    |  |
|                 | starting the editor, building, and starting the debugger, can be performed from PM+.  |  |
|                 | <caution></caution>                                                                   |  |
|                 | PM+ is included in the C compiler package CA850.                                      |  |
|                 | It can only be used in Windows.                                                       |  |

#### A.4 Debugging Tools (Hardware)

#### A.4.1 When using in-circuit emulator IE-V850ES-G1

The system configuration when connecting the IE-703288-G1-EM1 to the IE-V850ES-G1 and use it connecting to the host machine (PC-9800 series, PC/AT compatible) is shown below.

Target System <7> Host machine (PC-9800 series, PC/AT compatibles) <1> <2> Debugger Device file <3> <4> PC interface board (for PCI bus or PCMCIA) <5> PC interface cable (supplied with the IE-V850ES-G1) Power supply cable (supplied with the IE-V850ES-G1) <6> <7> In-circuit emulator (IE-V850ES-G1) <8> In-circuit emulator emulation board (IE-703288-G1-EM1) Probe (supplied with the IE-703288-G1-EM1) <9> <10> EV-703288GC100

Figure A-2. System Configuration (IE-V850ES-G1 Used)

| <7> IE-V850ES-G1<br>In-circuit emulator    |                                           | The in-circuit emulator serves to debug hardware and software when developing application systems using a V850 Series product. It corresponds to the integrated debugger ID850. This emulator should be used in combination with a power supply unit, emulation probe, and the interface adapter required to connect this emulator to the host machine. |
|--------------------------------------------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <4> IE-70000-CD-IF-A PC card interface     |                                           | This is PC card and interface cable required when using a notebook-type computer as the host machine (PCMCIA socket compatible).                                                                                                                                                                                                                        |
| <4> IE-70000-PCI-IF-A<br>Interface adapter |                                           | This adapter is required when using a computer with a PCI bus as the host machine.                                                                                                                                                                                                                                                                      |
| <8> IE-703288-G1-EM1<br>Emulation board    |                                           | This board emulates the operations of the peripheral hardware peculiar to a device. It should be used in combination with an in-circuit emulator.                                                                                                                                                                                                       |
| <9> GXP-CABLE<br>Emulation probe           |                                           | This probe is used to connect the in-circuit emulator and target system. This is supplied with emulation board IE-703288-G1-EM1.                                                                                                                                                                                                                        |
|                                            | <10> EV-703288GC100<br>Conversion adapter | This conversion adapter is used to connect the emulation probe and target system board on which a 100-pin plastic LQFP (GC-8EA type) can be mounted.                                                                                                                                                                                                    |

**Remarks 1.** The numbers in the square brackets correspond to the numbers in Figure A-2.

**2.** EV-703288GC100 is a product of Application Corporation.

TEL: +81-42-732-1377 Application Corporation

#### A.4.2 When using IECUBE QB-V850ESSX2

The system configuration when connecting the QB-V850ESSX2 to the host machine (PC-9821 series, PC/AT compatible) is shown below. If no option products are prepared, connection is possible.

Figure A-3. System Configuration (QB-V850ESSX2 Used) (1/2)



Figure A-3. System Configuration (QB-V850ESSX2 Used) (2/2)

**Notes 1.** Obtain the device file from the NEC Electronics website. http://www.necel.com/micro/ods/eng/index.html

- 2. Under development
- **3.** Depending on the ordering number, supplied with the device.
  - When QB-V850ESSX2-ZZZ is ordered

    The exchange adapter and the target connector are not supplied.
  - When QB-V850ESSX2-S100GC is ordered
     The QB-100GC-EA-01S and QB-100GC-TC-01S are supplied.
  - When QB-V850ESSX2-T100GC is ordered
     The QB-100GC-EA-01T, QB-100GC-YQ-01T, and QB-100GC-NQ-01T are supplied.
- 4. When using both <9> and <10>, the order between <9> and <10> is not cared.

| <5> QB-V850ESSX2 <sup>Note</sup> In-circuit emulator         | The in-circuit emulator serves to debug hardware and software when developing application systems using a V850ES/SG2 product. It corresponds to the integrated debugger ID850QB. This emulator should be used in combination with a power supply unit and emulation probe. Use USB to connect this emulator to the host machine. |
|--------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <3> USB interface cable                                      | Cable to connect the host machine and the QB-V850ESSX2.                                                                                                                                                                                                                                                                          |
| <4> AC adapter                                               | 100 to 240 V can be supported by replacing the AC plug.                                                                                                                                                                                                                                                                          |
| <8> QB-100GC-EA-01S,<br>QB-100GC-EA-01T<br>Exchange adapter  | Adapter to perform pin conversion.                                                                                                                                                                                                                                                                                               |
| <9> QB-100-CA-01S<br>Check pin adapter                       | Adapter used in waveform monitoring using the oscilloscope, etc.                                                                                                                                                                                                                                                                 |
| <10> QB-100-SA-01S,<br>QB-100GC-YS-01T<br>Space adapter      | Adapter to adjust the height.                                                                                                                                                                                                                                                                                                    |
| <12> QB-100GC-MA-01S,<br>QB-100GC-HQ-01T<br>Mount adapter    | Adapter to mount the V850ES/SG2 with socket.                                                                                                                                                                                                                                                                                     |
| <13> QB-100GC-TC-01S,<br>QB-100GC-NQ-01T<br>Target connector | Connector to solder on the target system.                                                                                                                                                                                                                                                                                        |

**Note** QB-V850ESSX2 is supplied with a power supply unit, USB interface cable, and simple programmer PG-FPL. It is also supplied with integrated debugger ID850QB as control software.

**Remark** The numbers in the square brackets correspond to the numbers in Figure A-3.

## A.5 Debugging Tools (Software)

| SM850 <sup>Note</sup> System simulator                                  | This is a system simulator for the V850 Series. The SM850 and SM+ are Windows-based softwares.                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SM+ <sup>Note</sup><br>System Simulator                                 | It is used to perform debugging at the C source level or assembler level while simulating the operation of the target system on a host machine.  Use of the SM850 and SM+ allows the execution of application logical testing and performance testing on an independent basis from hardware development, thereby providing higher development efficiency and software quality.  The SM850 and SM+ should be used in combination with the device file (sold separately). |
|                                                                         | Part number: μSxxxxSM703000 (SM850)<br>μSxxxxSM703100 (SM+)                                                                                                                                                                                                                                                                                                                                                                                                             |
| ID850 Integrated debugger (supporting in-circuit emulator IE-V850ES-G1) | This debugger supports the in-circuit emulators for the V850 Series. The ID850 and ID850QB are Windows-based software.  It has improved C-compatible debugging functions and can display the results of tracing with the source program using an integrating window function that associates the source                                                                                                                                                                 |
| ID850QB<br>Integrated debugger                                          | program, disassemble display, and memory display with the trace result.  It should be used in combination with the device file (sold separately).                                                                                                                                                                                                                                                                                                                       |
| (supporting in-circuit emulator QB-V850ESSX2)                           | Part number: μSxxxID703000, μSxxxID703000-GC (ID850)                                                                                                                                                                                                                                                                                                                                                                                                                    |

Note Under development

 $\textbf{Remark} \quad \times\!\!\times\!\!\times\! \text{ in the part number differs depending on the OS used.}$ 

 $\begin{tabular}{ll} $\mu$ $\times\!\!\!\times\!\!\!\times$ $M703000 \\ $\mu$ $\times\!\!\!\times\!\!\!\times$ $M703100 \\ $\mu$ $\times\!\!\!\times\!\!\!\times$ ID703000 \\ $\mu$ $\times\!\!\!\times\!\!\!\times$ ID703000-GC \\ \end{tabular}$ 

| ×××× | Host Machine          | OS                         | Supply Medium |
|------|-----------------------|----------------------------|---------------|
| AB17 | PC-9800 series,       | Windows (Japanese version) | CD-ROM        |
| BB17 | IBM PC/AT compatibles | Windows (English version)  |               |

#### A.6 Embedded Software

| RX850, RX850 Pro<br>Real-time OS                     | The RX850 and RX850 Pro are real-time OSs conforming to $\mu$ ITRON 3.0 specifications. A tool (configurator) for generating multiple information tables is supplied. RX850 Pro has more functions than RX850.                      |
|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                      | Part number: μS××××RX703000-ΔΔΔΔ (RX850)<br>μS××××RX703100-ΔΔΔΔ (RX850 Pro)                                                                                                                                                         |
| V850mini-NET (provisional name)<br>(Network library) | This is a network library conforming to RFC.  It is a lightweight TCP/IP of compact design, requiring only a small memory.  In addition to the TCP/IP standard set, an HTTP server, SMTP client, and POP client are also supported. |
| RX-FS850<br>(File system)                            | This is a FAT file system function. It is a file system that supports the CD-ROM file system function. This file system is used with the real-time OS RX850 Pro.                                                                    |

Caution To purchase the RX850 or RX850 Pro, first fill in the purchase application form and sign the user agreement.

**Remark**  $\times\!\times\!\times\!\times$  and  $\Delta\Delta\Delta\Delta$  in the part number differ depending on the host machine and OS used.

| ΔΔΔΔ | Product Outline        | Maximum Number for Use in Mass Production |  |
|------|------------------------|-------------------------------------------|--|
| 001  | Evaluation object      | Do not use for mass-produced product.     |  |
| 100K | Mass-production object | 0.1 million units                         |  |
| 001M |                        | 1 million units                           |  |
| 010M |                        | 10 million units                          |  |
| S01  | Source program         | Object source program for mass production |  |

| ×××× | Host Machine          | os                         | Supply Medium |
|------|-----------------------|----------------------------|---------------|
| AB17 | PC-9800 series,       | Windows (Japanese version) | CD-ROM        |
| BB17 | IBM PC/AT compatibles | Windows (English version)  |               |
| 3K17 | SPARCstation          | Solaris (Rel. 2.5.1)       |               |

#### A.7 Flash Memory Writing Tools

| Flashpro IV<br>(part number: PG-FP4)<br>Flash programmer | Flash programmer dedicated to microcontrollers with on-chip flash memory.                                             |
|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| FA-100GC-8EU-A<br>Flash memory writing adapter           | Flash memory writing adapter used connected to Flashpro IV.  • FA-100GC-8EU-A: For 100-pin plastic LQFP (GC-8EA type) |

Remark FA-100GC-8EU-A is a product of Naito Densei Machida Mfg. Co., Ltd.

TEL: +81-45-475-4191 Naito Densei Machida Mfg. Co., Ltd.

## APPENDIX B REGISTER INDEX

(1/12)

| _         | <del>,</del>                                   |       | (1/12) |
|-----------|------------------------------------------------|-------|--------|
| Symbol    | Name                                           | Unit  | Page   |
| ADA0CR0   | A/D conversion result register 0               | ADC   | 442    |
| ADA0CR0H  | A/D conversion result register 0H              | ADC   | 442    |
| ADA0CR1   | A/D conversion result register 1               | ADC   | 442    |
| ADA0CR10  | A/D conversion result register 10              | ADC   | 442    |
| ADA0CR10H | A/D conversion result register 10H             | ADC   | 442    |
| ADA0CR11  | A/D conversion result register 11              | ADC   | 442    |
| ADA0CR11H | A/D conversion result register 11H             | ADC   | 442    |
| ADA0CR1H  | A/D conversion result register 1H              | ADC   | 442    |
| ADA0CR2   | A/D conversion result register 2               | ADC   | 442    |
| ADA0CR2H  | A/D conversion result register 2H              | ADC   | 442    |
| ADA0CR3   | A/D conversion result register 3               | ADC   | 442    |
| ADA0CR3H  | A/D conversion result register 3H              | ADC   | 442    |
| ADA0CR4   | A/D conversion result register 4               | ADC   | 442    |
| ADA0CR4H  | A/D conversion result register 4H              | ADC   | 442    |
| ADA0CR5   | A/D conversion result register 5               | ADC   | 442    |
| ADA0CR5H  | A/D conversion result register 5H              | ADC   | 442    |
| ADA0CR6   | A/D conversion result register 6               | ADC   | 442    |
| ADA0CR6H  | A/D conversion result register 6H              | ADC   | 442    |
| ADA0CR7   | A/D conversion result register 7               | ADC   | 442    |
| ADA0CR7H  | A/D conversion result register 7H              | ADC   | 442    |
| ADA0CR8   | A/D conversion result register 8               | ADC   | 442    |
| ADA0CR8H  | A/D conversion result register 8H              | ADC   | 442    |
| ADA0CR9   | A/D conversion result register 9               | ADC   | 442    |
| ADA0CR9H  | A/D conversion result register 9H              | ADC   | 442    |
| ADA0M0    | A/D converter mode register 0                  | ADC   | 435    |
| ADA0M1    | A/D converter mode register 1                  | ADC   | 437    |
| ADA0M2    | A/D converter mode register 2                  | ADC   | 440    |
| ADA0PFM   | Power fail comparison mode register            | ADC   | 444    |
| ADA0PFT   | Power fail comparison threshold value register | ADC   | 445    |
| ADA0S     | A/D converter channel specify register         | ADC   | 441    |
| ADIC      | Interrupt control register                     | INTC  | 870    |
| AWC       | Address wait control register                  | BCU   | 188    |
| BCC       | Bus cycle control register                     | BCU   | 189    |
| BCR       | IEBus control register                         | IEBus | 633    |
| BPC       | Peripheral I/O area select control register    | BCU   | 79     |
| BSC       | Bus size configuration register                | BCU   | 177    |
| C0BRP     | CAN0 module bit rate prescaler register        | CAN   | 746    |
| C0BTR     | CAN0 bit rate register                         | CAN   | 747    |
| C0CTRL    | CAN0 module control register                   | CAN   | 736    |
|           |                                                |       |        |

(2/12)

| Symbol     | Name                                                                                                               | Unit | Page |
|------------|--------------------------------------------------------------------------------------------------------------------|------|------|
| COERC      | CAN0 module error counter register                                                                                 | CAN  | 742  |
| COGMABT    | CANO module error counter register  CANO global automatic block transmit control register                          | CAN  | 731  |
| COGMABTD   | CANO global automatic block transmit control register  CANO global automatic block transmit delay setting register | CAN  | 733  |
| COGMCS     |                                                                                                                    | 1    |      |
|            | CANO global clock select register                                                                                  | CAN  | 730  |
| COGMCTRL   | CANO global control register                                                                                       | CAN  | 728  |
| COIE       | CANO module interrupt enable register                                                                              | CAN  | 743  |
| COINFO     | CAN0 module information register                                                                                   | CAN  | 741  |
| COINTS     | CAN0 module interrupt status register                                                                              | CAN  | 745  |
| C0LEC      | CAN0 module last error information register                                                                        | CAN  | 740  |
| C0LIPT     | CAN0 module last receive pointer register                                                                          | CAN  | 749  |
| C0LOPT     | CAN0 module last transmit pointer register                                                                         | CAN  | 751  |
| C0MASK1H   | CAN0 module mask 1 register H                                                                                      | CAN  | 734  |
| C0MASK1L   | CAN0 module mask 1 register L                                                                                      | CAN  | 734  |
| C0MASK2H   | CAN0 module mask 2 register H                                                                                      | CAN  | 734  |
| C0MASK2L   | CAN0 module mask 2 register L                                                                                      | CAN  | 734  |
| C0MASK3H   | CAN0 module mask 3 register H                                                                                      | CAN  | 734  |
| C0MASK3L   | CAN0 module mask 3 register L                                                                                      | CAN  | 734  |
| C0MASK4H   | CAN0 module mask 4 register H                                                                                      | CAN  | 734  |
| C0MASK4L   | CAN0 module mask 4 register L                                                                                      | CAN  | 734  |
| C0MCONFm   | CAN0 massage register m                                                                                            | CAN  | 758  |
| C0MCTRLm   | CAN0 message control register m                                                                                    | CAN  | 760  |
| C0MDATA01m | CAN0 massage data byte 01 register m                                                                               | CAN  | 755  |
| C0MDATA0m  | CAN0 massage data byte 0 register m                                                                                | CAN  | 755  |
| C0MDATA1m  | CAN0 massage data byte 1 register m                                                                                | CAN  | 755  |
| C0MDATA23m | CAN0 massage data byte 23 register m                                                                               | CAN  | 755  |
| C0MDATA2m  | CAN0 massage data byte 2 register m                                                                                | CAN  | 755  |
| C0MDATA3m  | CAN0 massage data byte 3 register m                                                                                | CAN  | 755  |
| C0MDATA45m | CAN0 massage data byte 45 register m                                                                               | CAN  | 755  |
| C0MDATA4m  | CAN0 massage data byte 4 register m                                                                                | CAN  | 755  |
| C0MDATA5m  | CAN0 massage data byte 5 register m                                                                                | CAN  | 755  |
| C0MDATA67m | CAN0 massage data byte 67 register m                                                                               | CAN  | 755  |
| C0MDATA6m  | CAN0 massage data byte 6 register m                                                                                | CAN  | 755  |
| C0MDATA7m  | CAN0 massage data byte 7 register m                                                                                | CAN  | 755  |
| C0MDLCm    | CAN0 message data length code register m                                                                           | CAN  | 757  |
| C0MIDHm    | CAN0 message ID register mH                                                                                        | CAN  | 759  |
| C0MIDLm    | CAN0 message ID register mL                                                                                        | CAN  | 759  |
| C0RGPT     | CAN0 module receive history list register                                                                          | CAN  | 750  |
| C0TGPT     | CAN0 module transmit history list register                                                                         | CAN  | 752  |
| COTS       | CAN0 module time stamp register                                                                                    | CAN  | 753  |
| CB0CTL0    | CSIB0 control register 0                                                                                           | CSIB | 513  |
| CB0CTL1    | CSIB0 control register 1                                                                                           | CSIB | 516  |
| CB0CTL2    | CSIB0 control register 2                                                                                           | CSIB | 517  |
| CB0RIC     | Interrupt control register                                                                                         | INTC | 869  |

**Remark** m = 00 to 31

(3/12)

| Symbol  | Name                           | Unit | Page |
|---------|--------------------------------|------|------|
| CB0RX   | CSIB0 receive data register    | CSIB | 512  |
| CB0RXL  | CSIB0 receive data register L  | CSIB | 512  |
| CB0STR  | CSIB0 status register          | CSIB | 519  |
| CB0TIC  | Interrupt control register     | INTC | 869  |
| CB0TX   | CSIB0 transmit data register   | CSI  | 512  |
| CB0TXL  | CSIB0 transmit data register L | CSI  | 512  |
| CB1CTL0 | CSIB1 control register 0       | CSI  | 513  |
| CB1CTL1 | CSIB1 control register 1       | CSI  | 516  |
| CB1CTL2 | CSIB1 control register 2       | CSI  | 517  |
| CB1RIC  | Interrupt control register     | INTC | 869  |
| CB1RX   | CSIB1 receive data register    | CSI  | 512  |
| CB1RXL  | CSIB1 receive data register L  | CSI  | 512  |
| CB1STR  | CSIB1 status register          | CSI  | 519  |
| CB1TIC  | Interrupt control register     | INTC | 869  |
| CB1TX   | CSIB1 transmit data register   | CSI  | 512  |
| CB1TXL  | CSIB1 transmit data register L | CSI  | 512  |
| CB2CTL0 | CSIB2 control register 0       | CSI  | 513  |
| CB2CTL1 | CSIB2 control register 1       | CSI  | 516  |
| CB2CTL2 | CSIB2 control register 2       | CSI  | 517  |
| CB2RIC  | Interrupt control register     | INTC | 869  |
| CB2RX   | CSIB2 receive data register    | CSI  | 512  |
| CB2RXL  | CSIB2 receive data register L  | CSI  | 512  |
| CB2STR  | CSIB2 status register          | CSI  | 519  |
| CB2TIC  | Interrupt control register     | INTC | 869  |
| CB2TX   | CSIB2 transmit data register   | CSI  | 512  |
| CB2TXL  | CSIB2 transmit data register L | CSI  | 512  |
| CB3CTL0 | CSIB3 control register 0       | CSI  | 513  |
| CB3CTL1 | CSIB3 control register 1       | CSI  | 516  |
| CB3CTL2 | CSIB3 control register 2       | CSI  | 517  |
| CB3RIC  | Interrupt control register     | INTC | 869  |
| CB3RX   | CSIB3 receive data register    | CSI  | 512  |
| CB3RXL  | CSIB3 receive data register L  | CSI  | 512  |
| CB3STR  | CSIB3 status register          | CSI  | 519  |
| CB3TIC  | Interrupt control register     | INTC | 869  |
| CB3TX   | CSIB3 transmit data register   | CSI  | 512  |
| CB3TXL  | CSIB3 transmit data register L | CSI  | 512  |
| CB4CTL0 | CSIB4 control register 0       | CSI  | 513  |
| CB4CTL1 | CSIB4 control register 1       | CSI  | 516  |
| CB4CTL2 | CSIB4 control register 2       | CSI  | 517  |
| CB4RIC  | Interrupt control register     | INTC | 869  |
| CB4RX   | CSIB4 receive data register    | CSI  | 512  |
| CB4RXL  | CSIB4 receive data register L  | CSI  | 512  |
| CB4STR  | CSIB4 status register          | CSI  | 519  |
| CB4TIC  | Interrupt control register     | INTC | 870  |
| CB4TX   | CSIB4 transmit data register   | CSI  | 512  |

(4/12)

| Symbol  | Name                                        | Unit  | (4/12<br>Page |
|---------|---------------------------------------------|-------|---------------|
| CB4TXL  | CSIB4 transmit data register L              | CSI   | 512           |
| CCLS    | CPU operation clock status register         | CG    | 206           |
| CCR     | IEBus communication count register          | IEBus | 660           |
| CDR     | IEBus control data register                 | IEBus | 651           |
| СКС     | Clock control register                      | CG    | 209           |
| CLM     | Clock monitor mode register                 | CLM   | 923           |
| CORAD0  | Correction address register 0               | ROMC  | 930           |
| CORAD0H | Correction address register 0H              | ROMC  | 930           |
| CORAD0L | Correction address register 0L              | ROMC  | 930           |
| CORAD1  | Correction address register 1               | ROMC  | 930           |
| CORAD1H | Correction address register 1H              | ROMC  | 930           |
| CORAD1L | Correction address register 1L              | ROMC  | 930           |
| CORAD2  | Correction address register 2               | ROMC  | 930           |
| CORAD2H | Correction address register 2H              | ROMC  | 930           |
| CORAD2L | Correction address register 2L              | ROMC  | 930           |
| CORAD3  | Correction address register 3               | ROMC  | 930           |
| CORAD3H | Correction address register 3H              | ROMC  | 930           |
| CORAD3L | Correction address register 3L              | ROMC  | 930           |
| CORCN   | Correction control register                 | ROMC  | 931           |
| CRCD    | CRC data register                           | CRC   | 848           |
| CRCIN   | CRC input register                          | CRC   | 848           |
| СТВР    | CALLT base pointer                          | CPU   | 56            |
| CTPC    | CALLT execution status saving register      | CPU   | 55            |
| CTPSW   | CALLT execution status saving register      | CPU   | 55            |
| DA0CS0  | D/A converter value setting register 0      | DAC   | 469           |
| DA0CS1  | D/A converter value setting register 1      | DAC   | 469           |
| DAOM    | D/A converter mode register                 | DAC   | 468           |
| DADC0   | DMA addressing control register 0           | DMAC  | 829           |
| DADC1   | DMA addressing control register 1           | DMAC  | 829           |
| DADC2   | DMA addressing control register 2           | DMAC  | 829           |
| DADC3   | DMA addressing control register 3           | DMAC  | 829           |
| DBC0    | DMA transfer count register 0               | DMAC  | 828           |
| DBC1    | DMA transfer count register 1               | DMAC  | 828           |
| DBC2    | DMA transfer count register 2               | DMAC  | 828           |
| DBC3    | DMA transfer count register 3               | DMAC  | 828           |
| DBPC    | Exception/debug trap status saving register | CPU   | 56            |
| DBPSW   | Exception/debug trap status saving register | CPU   | 56            |
| DCHC0   | DMA channel control register 0              | DMAC  | 830           |
| DCHC1   | DMA channel control register 1              | DMAC  | 830           |
| DCHC2   | DMA channel control register 2              | DMAC  | 830           |
| DCHC3   | DMA channel control register 3              | DMAC  | 830           |
| DDA0H   | DMA destination address register 0H         | DMAC  | 827           |
| DDA0L   | DMA destination address register 0L         | DMAC  | 827           |
| DDA1H   | DMA destination address register 1H         | DMAC  | 827           |
| DDA1L   |                                             | DMAC  | 827           |
| DDA1L   | DMA destination address register 1L         | DMAC  | 827           |

(5/12)

| Symbol | Name                                         | Unit             | Page |
|--------|----------------------------------------------|------------------|------|
| DDA2H  | DMA destination address register 2H          | DMAC             | 827  |
| DDA2L  | DMA destination address register 2L          | DMAC             | 827  |
| DDA3H  | DMA destination address register 3H          | DMAC             | 827  |
| DDA3L  | DMA destination address register 3L          | DMAC             | 827  |
| DLR    | IEBus telegraph length register              | IEBus            | 656  |
| DMAIC0 | Interrupt control register                   | INTC             | 870  |
| DMAIC1 | Interrupt control register                   | INTC             | 870  |
| DMAIC2 | Interrupt control register                   | INTC             | 870  |
| DMAIC3 | Interrupt control register                   | INTC             | 870  |
| DR     | IEBus data register                          | IEBus            | 657  |
| DSA0H  | DMA source address register 0H               | DMAC             | 826  |
| DSA0L  | DMA source address register 0L               | DMAC             | 826  |
| DSA1H  | DMA source address register 1H               | DMAC             | 826  |
| DSA1L  | DMA source address register 1L               | DMAC             | 826  |
| DSA2H  | DMA source address register 2H               | DMAC             | 826  |
| DSA2L  | DMA source address register 2L               | DMAC             | 826  |
| DSA3H  | DMA source address register 3H               | DMAC             | 826  |
| DSA3L  | DMA source address register 3L               | DMAC             | 826  |
| DTFR0  | DMA trigger source register 0                | DMAC             | 831  |
| DTFR1  | DMA trigger source register 1                | DMAC             | 831  |
| DTFR2  | DMA trigger source register 2                | DMAC             | 831  |
| DTFR3  | DMA trigger source register 3                | DMAC             | 831  |
| DWC0   | Data wait control register 0                 | BCU              | 185  |
| ECR    | Interrupt source register                    | CPU              | 53   |
| EIPC   | Interrupt status saving register             | CPU              | 52   |
| EIPSW  | Interrupt status saving register             | CPU              | 52   |
| ERRIC  | Interrupt control register                   | INTC             | 870  |
| ERRIC0 | Interrupt control register                   | INTC             | 870  |
| ESR    | IEBus error status register                  | IEBus            | 645  |
| EXIMC  | External bus interface mode control register | BCU              | 176  |
| FEPC   | NMI status saving register                   | CPU              | 53   |
| FEPSW  | NMI status saving register                   | CPU              | 53   |
| FSR    | IEBus field status register                  | IEBus            | 658  |
| IEIC1  | Interrupt control register                   | INTC             | 870  |
| IEIC2  | Interrupt control register                   | INTC             | 870  |
| IIC0   | IIC shift register 0                         | I <sup>2</sup> C | 561  |
| IIC1   | IIC shift register 1                         | I <sup>2</sup> C | 561  |
| IIC2   | IIC shift register 2                         | I <sup>2</sup> C | 561  |
| IICC0  | IIC control register 0                       | I <sup>2</sup> C | 547  |
| IICC1  | IIC control register 1                       | I <sup>2</sup> C | 547  |
| IICC2  | IIC control register 2                       | I <sup>2</sup> C | 547  |
| IICCL0 | IIC clock select register 0                  | I <sup>2</sup> C | 557  |
| IICCL1 | IIC clock select register 1                  | I <sup>2</sup> C | 557  |
| IICCL2 | IIC clock select register 2                  | I <sup>2</sup> C | 557  |
| IICF0  | IIC flag register 0                          | I <sup>2</sup> C | 555  |

(6/12)

| Symbol | Name                                                      | Unit             | Page |
|--------|-----------------------------------------------------------|------------------|------|
| IICF1  | IIC flag register 1                                       | I <sup>2</sup> C | 555  |
| IICF2  | IIC flag register 2                                       | I <sup>2</sup> C | 555  |
| IICIC0 | Interrupt control register                                | INTC             | 870  |
| IICIC1 | Interrupt control register                                | INTC             | 869  |
| IICIC2 | Interrupt control register                                | INTC             | 870  |
| IICS0  | IIC status register 0                                     | I <sup>2</sup> C | 552  |
| IICS1  | IIC status register 1                                     | I <sup>2</sup> C | 552  |
| IICS2  | IIC status register 2                                     | I <sup>2</sup> C | 552  |
| IICX0  | IIC function extension register 0                         | I <sup>2</sup> C | 558  |
| IICX1  | IIC function extension register 1                         | I <sup>2</sup> C | 558  |
| IICX2  | IIC function extension register 2                         | I <sup>2</sup> C | 558  |
| IMR0   | Interrupt mask register 0                                 | INTC             | 870  |
| IMR0H  | Interrupt mask register 0H                                | INTC             | 870  |
| IMR0L  | Interrupt mask register 0L                                | INTC             | 870  |
| IMR1   | Interrupt mask register 1                                 | INTC             | 870  |
| IMR1H  | Interrupt mask register 1H                                | INTC             | 870  |
| IMR1L  | Interrupt mask register 1L                                | INTC             | 870  |
| IMR2   | Interrupt mask register 2                                 | INTC             | 870  |
| IMR2H  | Interrupt mask register 2H                                | INTC             | 870  |
| IMR2L  | Interrupt mask register 2L                                | INTC             | 870  |
| IMR3   | Interrupt mask register 3                                 | INTC             | 870  |
| IMR3H  | Interrupt mask register 3H                                | INTC             | 870  |
| IMR3L  | Interrupt mask register 3L                                | INTC             | 870  |
| INTF0  | External interrupt falling edge specification register 0  | INTC             | 882  |
| INTF3  | External interrupt falling edge specification register 3  | INTC             | 883  |
| INTF9H | External interrupt falling edge specification register 9H | INTC             | 884  |
| INTR0  | External interrupt rising edge specification register 0   | INTC             | 882  |
| INTR3  | External interrupt rising edge specification register 3   | INTC             | 883  |
| INTR9H | External interrupt rising edge specification register 9H  | INTC             | 884  |
| ISPR   | In-service priority register                              | INTC             | 872  |
| ISR    | IEBus interrupt status register                           | IEBus            | 642  |
| KRIC   | Interrupt control register                                | INTC             | 870  |
| KRM    | Key return mode register                                  | KR               | 889  |
| LOCKR  | Lock register                                             | CG               | 210  |
| NFC    | Noise elimination control register                        | INTC             | 885  |
| OCDM   | On-chip debug mode register                               | Debug            | 961  |
| OCKS0  | IIC divided clock select register 0                       | I <sup>2</sup> C | 561  |
| OCKS1  | IIC divided clock select register 1                       | I <sup>2</sup> C | 561  |
| OCKS2  | IEBus clock select register                               | IEBus            | 661  |
| OSTS   | Oscillation stabilization time select register            | Standby          | 894  |
| P0     | Port 0 register                                           | Port             | 95   |
| P1     | Port 1 register                                           | Port             | 98   |
| P3     | Port 3 register                                           | Port             | 99   |
| P3H    | Port 3 register H                                         | Port             | 99   |
| P3L    | Port 3 register L                                         | Port             | 99   |

(7/12)

|        |                                              |       | (7/12 |
|--------|----------------------------------------------|-------|-------|
| Symbol | Name                                         | Unit  | Page  |
| P4     | Port 4 register                              | Port  | 105   |
| P5     | Port 5 register                              | Port  | 108   |
| P7H    | Port 7 register H                            | Port  | 112   |
| P7L    | Port 7 register L                            | Port  | 112   |
| P9     | Port 9 register                              | Port  | 115   |
| P9H    | Port 9 register H                            | Port  | 115   |
| P9L    | Port 9 register L                            | Port  | 115   |
| PAR    | IEBus partner address register               | IEBus | 650   |
| PC     | Program counter                              | CPU   | 50    |
| PCC    | Processor clock control register             | CG    | 202   |
| PCM    | Port CM register                             | Port  | 122   |
| PCT    | Port CT register                             | Port  | 124   |
| PDH    | Port DH register                             | Port  | 126   |
| PDL    | Port DL register                             | Port  | 128   |
| PDLH   | Port DL register H                           | Port  | 128   |
| PDLL   | Port DL register L                           | Port  | 128   |
| PEMU1  | Peripheral emulation register 1              | CPU   | 921   |
| PF0    | Port 0 function control register             | Port  | 97    |
| PF3    | Port 3 function control register             | Port  | 104   |
| PF3H   | Port 3 function control register H           | Port  | 104   |
| PF3L   | Port 3 function control register L           | Port  | 104   |
| PF4    | Port 4 function control register             | Port  | 107   |
| PF5    | Port 5 function control register             | Port  | 111   |
| PF9    | Port 9 function control register             | Port  | 121   |
| PF9H   | Port 9 function control register H           | Port  | 121   |
| PF9L   | Port 9 function control register L           | Port  | 121   |
| PFC0   | Port 0 function control register             | Port  | 97    |
| PFC3   | Port 3 function control register             | Port  | 102   |
| PFC3H  | Port 3 function control register H           | Port  | 102   |
| PFC3L  | Port 3 function control register L           | Port  | 102   |
| PFC4   | Port 4 function control register             | Port  | 106   |
| PFC5   | Port 5 function control register             | Port  | 110   |
| PFC9   | Port 9 function control register             | Port  | 118   |
| PFC9H  | Port 9 function control register H           | Port  | 118   |
| PFC9L  | Port 9 function control register L           | Port  | 118   |
| PFCE3L | Port 3 function control extension register L | Port  | 102   |
| PFCE5  | Port 5 function control extension register   | Port  | 110   |
| PFCE9  | Port 9 function control extension register   | Port  | 118   |
| PFCE9H | Port 9 function control extension register H | Port  | 118   |
| PFCE9L | Port 9 function control extension register L | Port  | 118   |
| PIC0   | Interrupt control register                   | INTC  | 869   |
| PIC1   | Interrupt control register                   | INTC  | 869   |
| PIC2   | Interrupt control register                   | INTC  | 869   |
| PIC3   | Interrupt control register                   | INTC  | 869   |
| PIC4   | Interrupt control register                   | INTC  | 869   |
| 1 104  | Interrupt control register                   | 11410 | 003   |

(8/12)

| Symbol | Name                                   | Unit | Page |
|--------|----------------------------------------|------|------|
| PIC5   | Interrupt control register             | INTC | 869  |
| PIC6   | Interrupt control register             | INTC | 869  |
| PIC7   | Interrupt control register             | INTC | 869  |
| PLLCTL | PLL control register                   | CG   | 208  |
| PLLS   | PLL lockup time specification register | CG   | 211  |
| PM0    | Port 0 mode register                   | Port | 96   |
| PM1    | Port 1 mode register                   | Port | 98   |
| PM3    | Port 3 mode register                   | Port | 99   |
| РМЗН   | Port 3 mode register H                 | Port | 99   |
| PM3L   | Port 3 mode register L                 | Port | 99   |
| PM4    | Port 4 mode register                   | Port | 105  |
| PM5    | Port 5 mode register                   | Port | 109  |
| PM7H   | Port 7 mode register H                 | Port | 113  |
| PM7L   | Port 7 mode register L                 | Port | 113  |
| PM9    | Port 9 mode register                   | Port | 115  |
| РМ9Н   | Port 9 mode register H                 | Port | 115  |
| PM9L   | Port 9 mode register L                 | Port | 115  |
| PMC0   | Port 0 mode control register           | Port | 96   |
| PMC3   | Port 3 mode control register           | Port | 100  |
| PMC3H  | Port 3 mode control register H         | Port | 100  |
| PMC3L  | Port 3 mode control register L         | Port | 100  |
| PMC4   | Port 4 mode control register           | Port | 106  |
| PMC5   | Port 5 mode control register           | Port | 109  |
| PMC9   | Port 9 mode control register           | Port | 116  |
| PMC9H  | Port 9 mode control register H         | Port | 116  |
| PMC9L  | Port 9 mode control register L         | Port | 116  |
| PMCCM  | Port CM mode control register          | Port | 123  |
| PMCCT  | Port CT mode control register          | Port | 125  |
| PMCDH  | Port DH mode control register          | Port | 127  |
| PMCDL  | Port DL mode control register          | Port | 129  |
| PMCDLH | Port DL mode control register H        | Port | 129  |
| PMCDLL | Port DL mode control register L        | Port | 129  |
| PMCM   | Port CM mode register                  | Port | 122  |
| PMCT   | Port CT mode register                  | Port | 124  |
| PMDH   | Port DH mode register                  | Port | 126  |
| PMDL   | Port DL mode register                  | Port | 129  |
| PMDLH  | Port DL mode register H                | Port | 129  |
| PMDLL  | Port DL mode register L                | Port | 129  |
| PRCMD  | Command register                       | CPU  | 82   |
| PRSCM0 | Prescaler compare register             | WT   | 413  |
| PRSCM1 | BRG1 prescaler compare register        | BRG  | 537  |
| PRSCM2 | BRG2 prescaler compare register        | BRG  | 537  |
| PRSCM3 | BRG3 prescaler compare register        | BRG  | 537  |
| PRSM0  | Prescaler mode register                | WT   | 412  |
| PRSM1  | BRG1 prescaler mode register           | BRG  | 536  |

(9/12)

|           |                                          |                  | (9/12 |
|-----------|------------------------------------------|------------------|-------|
| Symbol    | Name                                     | Unit             | Page  |
| PRSM2     | BRG2 prescaler mode register             | BRG              | 536   |
| PRSM3     | BRG3 prescaler mode register             | BRG              | 536   |
| PSC       | Power save control register              | CG               | 892   |
| PSMR      | Power save mode register                 | CG               | 893   |
| PSR       | IEBus power save register                | IEBus            | 637   |
| PSW       | Program status word                      | CPU              | 54    |
| r0 to r31 | General-purpose registers                | CPU              | 50    |
| RAMS      | Internal RAM data status register        | CG               | 919   |
| RCM       | Internal oscillation mode register       | CG               | 206   |
| RECIC0    | Interrupt control register               | INTC             | 870   |
| RESF      | Reset source flag register               | Reset            | 911   |
| RSA       | IEBus receive slave address register     | IEBus            | 651   |
| RTBH0     | Real-time output buffer register 0H      | RTP              | 426   |
| RTBL0     | Real-time output buffer register 0L      | RTP              | 426   |
| RTPC0     | Real-time output port control register 0 | RTP              | 428   |
| RTPM0     | Real-time output port mode register 0    | RTP              | 427   |
| SAR       | IEBus slave address register             | IEBus            | 650   |
| SCR       | IEBus success count register             | IEBus            | 659   |
| SELCNT0   | Selector operation control register 0    | Timer            | 299   |
| SSR       | IEBus slave status register              | IEBus            | 638   |
| STAIC     | Interrupt control register               | INTC             | 870   |
| SVA0      | IIC slave address register 0             | I <sup>2</sup> C | 562   |
| SVA1      | IIC slave address register 1             | I <sup>2</sup> C | 562   |
| SVA2      | IIC slave address register 2             | I <sup>2</sup> C | 562   |
| SYS       | System status register 0                 | CPU              | 83    |
| TM0CMP0   | TMM0 compare register 0                  | Timer            | 402   |
| TM0CTL0   | TMM0 control register 0                  | Timer            | 403   |
| TM0EQIC0  | Interrupt control register               | INTC             | 869   |
| TP0CCIC0  | Interrupt control register               | INTC             | 869   |
| TP0CCIC1  | Interrupt control register               | INTC             | 869   |
| TP0CCR0   | TMP0 capture/compare register 0          | Timer            | 222   |
| TP0CCR1   | TMP0 capture/compare register 1          | Timer            | 224   |
| TP0CNT    | TMP0 counter read buffer register        | Timer            | 226   |
| TP0CTL0   | TMP0 control register 0                  | Timer            | 216   |
| TP0CTL1   | TMP0 control register 1                  | Timer            | 216   |
| TP0IOC0   | TMP0 I/O control register 0              | Timer            | 218   |
| TP0IOC1   | TMP0 I/O control register 1              | Timer            | 219   |
| TP0IOC2   | TMP0 I/O control register 2              | Timer            | 220   |
| TP0OPT0   | TMP0 option register 0                   | Timer            | 221   |
| TP0OVIC   | Interrupt control register               | INTC             | 869   |
| TP1CCIC0  | Interrupt control register               | INTC             | 869   |
| TP1CCIC1  | Interrupt control register               | INTC             | 869   |
| TP1CCR0   | TMP1 capture/compare register 0          | Timer            | 222   |
| TP1CCR1   | TMP1 capture/compare register 1          | Timer            | 224   |
| TP1CNT    | TMP1 counter read buffer register        | Timer            | 226   |
|           | 1                                        |                  |       |

(10/12)

| Symbol   | Name                              | Unit  | (10/12<br>Page |
|----------|-----------------------------------|-------|----------------|
| TP1CTL0  | TMP1 control register 0           | Timer | 216            |
| TP1CTL1  | TMP1 control register 1           | Timer | 216            |
| TP1IOC0  | TMP1 I/O control register 0       | Timer | 218            |
| TP1IOC1  | TMP1 I/O control register 1       | Timer | 219            |
| TP1IOC2  | TMP1 I/O control register 2       | Timer | 220            |
| TP1OPT0  | TMP1 option register 0            | Timer | 221            |
| TP10VIC  | Interrupt control register        | INTC  | 869            |
| TP2CCIC0 | Interrupt control register        | INTC  | 869            |
| TP2CCIC1 | Interrupt control register        | INTC  | 869            |
| TP2CCR0  | TMP2 capture/compare register 0   | Timer | 222            |
| TP2CCR1  | TMP2 capture/compare register 1   | Timer | 224            |
| TP2CNT   | TMP2 counter read buffer register | Timer | 226            |
| TP2CTL0  | TMP2 control register 0           | Timer | 216            |
| TP2CTL1  | TMP2 control register 1           | Timer | 216            |
| TP2IOC0  | TMP2 I/O control register 0       | Timer | 218            |
| TP2IOC1  | TMP2 I/O control register 1       | Timer | 219            |
| TP2IOC2  | TMP2 I/O control register 2       | Timer | 220            |
| TP2OPT0  | TMP2 option register 0            | Timer | 221            |
| TP2OVIC  | Interrupt control register        | INTC  | 869            |
| TP3CCIC0 | Interrupt control register        | INTC  | 869            |
| TP3CCIC1 | Interrupt control register        | INTC  | 869            |
| TP3CCR0  | TMP3 capture/compare register 0   | Timer | 222            |
| TP3CCR1  | TMP3 capture/compare register 1   | Timer | 224            |
| TP3CNT   | TMP3 counter read buffer register | Timer | 226            |
| TP3CTL0  | TMP3 control register 0           | Timer | 216            |
| TP3CTL1  | TMP3 control register 1           | Timer | 216            |
| TP3IOC0  | TMP3 I/O control register 0       | Timer | 218            |
| TP3IOC1  | TMP3 I/O control register 1       | Timer | 219            |
| TP3IOC2  | TMP3 I/O control register 2       | Timer | 220            |
| TP3OPT0  | TMP3 option register 0            | Timer | 221            |
| TP3OVIC  | Interrupt control register        | INTC  | 869            |
| TP4CCIC0 | Interrupt control register        | INTC  | 869            |
| TP4CCIC1 | Interrupt control register        | INTC  | 869            |
| TP4CCR0  | TMP4 capture/compare register 0   | Timer | 222            |
| TP4CCR1  | TMP4 capture/compare register 1   | Timer | 224            |
| TP4CNT   | TMP4 counter read buffer register | Timer | 226            |
| TP4CTL0  | TMP4 control register 0           | Timer | 216            |
| TP4CTL1  | TMP4 control register 1           | Timer | 216            |
| TP4IOC0  | TMP4 I/O control register 0       | Timer | 218            |
| TP4IOC1  | TMP4 I/O control register 1       | Timer | 219            |
| TP4IOC2  | TMP4 I/O control register 2       | Timer | 220            |
| TP4OPT0  | TMP4 option register 0            | Timer | 221            |
| TP4OVIC  | Interrupt control register        | INTC  | 869            |
| TP5CCIC0 | Interrupt control register        | INTC  | 869            |
| TP5CCIC1 | Interrupt control register        | INTC  | 869            |

(11/12)

| Cumbal         | Nome                                            | Unit  | (11/12   |
|----------------|-------------------------------------------------|-------|----------|
| Symbol         | Name  TMDF continuo/compara register 0          |       | Page     |
| TP5CCR0        | TMP5 capture/compare register 0                 | Timer | 222      |
| TP5CCR1 TP5CNT | TMP5 capture/compare register 1                 | Timer | 224      |
|                | TMP5 counter read buffer register               |       | _        |
| TP5CTL1        | TMP5 control register 0 TMP5 control register 1 | Timer | 216      |
| TP5IOC0        | TMP5 I/O control register 0                     |       | 218      |
| TP5IOC0        | TMP5 I/O control register 1                     | Timer | 219      |
| TP5IOC1        | TMP5 I/O control register 2                     |       | 220      |
| TP5IOC2        |                                                 | Timer | 221      |
| TP5OVIC        | TMP5 option register 0                          | INTC  | 869      |
|                | Interrupt control register                      |       | 869      |
| TQ0CCIC0       | Interrupt control register                      | INTC  |          |
| TQ0CCIC1       | Interrupt control register                      | INTC  | 869      |
| TQ0CCIC2       | Interrupt control register                      | INTC  | 869      |
| TQ0CCIC3       | Interrupt control register                      | INTC  | 869      |
| TQ0CCR0        | TMQ0 capture/compare register 0                 | Timer | 312      |
| TQ0CCR1        | TMQ0 capture/compare register 1                 | Timer | 314      |
| TQ0CCR2        | TMQ0 capture/compare register 2                 | Timer | 316      |
| TQ0CCR3        | TMQ0 capture/compare register 3                 | Timer | 318      |
| TQ0CNT         | TMQ0 counter read buffer register               | Timer | 320      |
| TQ0CTL0        | TMQ0 control register 0                         | Timer | 306      |
| TQ0CTL1        | TMQ0 control register 1                         | Timer | 307      |
| TQ0IOC0        | TMQ0 I/O control register 0                     | Timer | 308      |
| TQ0IOC1        | TMQ0 I/O control register 1                     | Timer | 309      |
| TQ0IOC2        | TMQ0 I/O control register 2                     | Timer | 310      |
| TQ0OPT0        | TMQ0 option register 0                          | Timer | 311      |
| TQ00VIC        | Interrupt control register                      | INTC  | 869      |
| TRXIC0         | Interrupt control register                      | INTC  | 870      |
| UA0CTL0        | UARTA0 control register 0                       | UARTA | 478      |
| UA0CTL1        | UARTA0 control register 1                       | UARTA | 480, 500 |
| UA0CTL2        | UARTA0 control register 2                       | UARTA | 480, 501 |
| UA0OPT0        | UARTA0 option control register 0                | UARTA | 480      |
| UA0RIC         | Interrupt control register                      | INTC  | 869      |
| UA0RX          | UARTA0 receive data register                    | UARTA | 483      |
| UA0STR         | UARTA0 status register                          | UARTA | 481      |
| UA0TIC         | Interrupt control register                      | INTC  | 870      |
| UA0TX          | UARTA0 transmit data register                   | UARTA | 483      |
| UA1CTL0        | UARTA1 control register 0                       | UARTA | 478      |
| UA1CTL1        | UARTA1 control register 1                       | UARTA | 480, 500 |
| UA1CTL2        | UARTA1 control register 2                       | UARTA | 480, 501 |
| UA1OPT0        | UARTA1 option control register 0                | UARTA | 480      |
| UA1RIC         | Interrupt control register                      | INTC  | 870      |
| UA1RX          | UARTA1 receive data register                    | UARTA | 483      |
| UA1STR         | UARTA1 status register                          | UARTA | 481      |
| UA1TIC         | Interrupt control register                      | INTC  | 870      |
| UA1TX          | UARTA1 transmit data register                   | UARTA | 483      |

(12/12)

| Symbol  | Name                                | Unit  | Page     |
|---------|-------------------------------------|-------|----------|
| UA2CTL0 | UARTA2 control register 0           | UARTA | 478      |
| UA2CTL1 | UARTA2 control register 1           | UARTA | 480, 500 |
| UA2CTL2 | UARTA2 control register 2           | UARTA | 480, 501 |
| UA2OPT0 | UARTA2 option control register 0    | UARTA | 480      |
| UA2RIC  | Interrupt control register          | INTC  | 870      |
| UA2RX   | UARTA2 receive data register        | UARTA | 483      |
| UA2STR  | UARTA2 status register              | UARTA | 481      |
| UA2TIC  | Interrupt control register          | INTC  | 870      |
| UA2TX   | UARTA2 transmit data register       | UARTA | 483      |
| UAR     | IEBus unit address register         | IEBus | 650      |
| USR     | IEBus unit status register          | IEBus | 639      |
| VSWC    | System wait control register        | CPU   | 84       |
| WDTE    | Watchdog timer enable register      | WDT   | 423      |
| WDTM2   | Watchdog timer mode register 2      | WDT   | 421, 873 |
| WTIC    | Interrupt control register          | INTC  | 870      |
| WTIIC   | Interrupt control register          | INTC  | 870      |
| WTM     | Watch timer operation mode register | WT    | 414      |
| WUPIC0  | Interrupt control register          | INTC  | 870      |

## APPENDIX C INSTRUCTION SET LIST

#### C.1 Conventions

## (1) Register symbols used to describe operands

| Register Symbol | Explanation                                                                                                                          |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------|
| reg1            | General-purpose registers: Used as source registers.                                                                                 |
| reg2            | General-purpose registers: Used mainly as destination registers. Also used as source register in some instructions.                  |
| reg3            | General-purpose registers: Used mainly to store the remainders of division results and the higher 32 bits of multiplication results. |
| bit#3           | 3-bit data for specifying the bit number                                                                                             |
| immX            | X bit immediate data                                                                                                                 |
| dispX           | X bit displacement data                                                                                                              |
| regID           | System register number                                                                                                               |
| vector          | 5-bit data that specifies the trap vector (00H to 1FH)                                                                               |
| cccc            | 4-bit data that shows the conditions code                                                                                            |
| sp              | Stack pointer (r3)                                                                                                                   |
| ер              | Element pointer (r30)                                                                                                                |
| listX           | X item register list                                                                                                                 |

# (2) Register symbols used to describe opcodes

| Register Symbol | Explanation                                                        |
|-----------------|--------------------------------------------------------------------|
| R               | 1-bit data of a code that specifies reg1 or regID                  |
| r               | 1-bit data of the code that specifies reg2                         |
| w               | 1-bit data of the code that specifies reg3                         |
| d               | 1-bit displacement data                                            |
| 1               | 1-bit immediate data (indicates the higher bits of immediate data) |
| i               | 1-bit immediate data                                               |
| cccc            | 4-bit data that shows the condition codes                          |
| cccc            | 4-bit data that shows the condition codes of Bcond instruction     |
| bbb             | 3-bit data for specifying the bit number                           |
| L               | 1-bit data that specifies a program register in the register list  |

# (3) Register symbols used in operations

| Register Symbol               | Explanation                                                                                                                                                           |
|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>←</b>                      | Input for                                                                                                                                                             |
| GR[]                          | General-purpose register                                                                                                                                              |
| SR[]                          | System register                                                                                                                                                       |
| zero-extend (n)               | Expand n with zeros until word length.                                                                                                                                |
| sign-extend (n)               | Expand n with signs until word length.                                                                                                                                |
| load-memory (a, b)            | Read size b data from address a.                                                                                                                                      |
| store-memory (a, b, c)        | Write data b into address a in size c.                                                                                                                                |
| load-memory-bit (a, b)        | Read bit b of address a.                                                                                                                                              |
| store-memory-bit (a, b, c)    | Write c to bit b of address a.                                                                                                                                        |
| saturated (n)                 | Execute saturated processing of n (n is a 2's complement).  If, as a result of calculations,  n ≥ 7FFFFFFFH, let it be 7FFFFFFH.  n ≤ 80000000H, let it be 80000000H. |
| result                        | Reflects the results in a flag.                                                                                                                                       |
| Byte                          | Byte (8 bits)                                                                                                                                                         |
| Halfword                      | Half word (16 bits)                                                                                                                                                   |
| Word                          | Word (32 bits)                                                                                                                                                        |
| +                             | Addition                                                                                                                                                              |
| -                             | Subtraction                                                                                                                                                           |
| II                            | Bit concatenation                                                                                                                                                     |
| ×                             | Multiplication                                                                                                                                                        |
| ÷                             | Division                                                                                                                                                              |
| %                             | Remainder from division results                                                                                                                                       |
| AND                           | Logical product                                                                                                                                                       |
| OR                            | Logical sum                                                                                                                                                           |
| XOR                           | Exclusive OR                                                                                                                                                          |
| NOT                           | Logical negation                                                                                                                                                      |
| logically shift left by       | Logical shift left                                                                                                                                                    |
| logically shift right by      | Logical shift right                                                                                                                                                   |
| arithmetically shift right by | Arithmetic shift right                                                                                                                                                |

## (4) Register symbols used in execution clock

| Register Symbol | Explanation                                                                                                 |
|-----------------|-------------------------------------------------------------------------------------------------------------|
| i               | If executing another instruction immediately after executing the first instruction (issue).                 |
| r               | If repeating execution of the same instruction immediately after executing the first instruction (repeat).  |
| 1               | If using the results of instruction execution in the instruction immediately after the execution (latency). |

# (5) Register symbols used in flag operations

| Identifier | Explanation                                    |
|------------|------------------------------------------------|
| (Blank)    | No change                                      |
| 0          | Clear to 0                                     |
| Х          | Set or cleared in accordance with the results. |
| R          | Previously saved values are restored.          |

## (6) Condition codes

| Condition Code (cccc) | Condition Formula        | Explanation                                |
|-----------------------|--------------------------|--------------------------------------------|
| 0 0 0 0               | OV = 1                   | Overflow                                   |
| 1 0 0 0               | OV = 0                   | No overflow                                |
| 0 0 0 1               | CY = 1                   | Carry Lower (Less than)                    |
| 1 0 0 1               | CY = 0                   | No carry Not lower (Greater than or equal) |
| 0 0 1 0               | Z = 1                    | Zero                                       |
| 1 0 1 0               | Z = 0                    | Not zero                                   |
| 0 0 1 1               | (CY or Z) = 1            | Not higher (Less than or equal)            |
| 1 0 1 1               | (CY  or  Z) = 0          | Higher (Greater than)                      |
| 0 1 0 0               | S = 1                    | Negative                                   |
| 1 1 0 0               | S = 0                    | Positive                                   |
| 0 1 0 1               | _                        | Always (Unconditional)                     |
| 1 1 0 1               | SAT = 1                  | Saturated                                  |
| 0 1 1 0               | (S xor OV) = 1           | Less than signed                           |
| 1 1 1 0               | (S xor OV) = 0           | Greater than or equal signed               |
| 0 1 1 1               | ((S xor OV) or Z) = 1    | Less than or equal signed                  |
| 1 1 1 1               | ((S  xor OV)  or  Z) = 0 | Greater than signed                        |

# C.2 Instruction Set (in Alphabetical Order)

(1/6)

|          |                     |                                       | <u> </u>                                                                                             |                                                                                     | ı           |               |             | 1  |    |       | ( | 1/6) |
|----------|---------------------|---------------------------------------|------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|-------------|---------------|-------------|----|----|-------|---|------|
| Mnemonic | Operand             | Opcode                                | Operation                                                                                            |                                                                                     |             | ecut<br>Clocl |             |    | ı  | Flags | 8 |      |
|          |                     |                                       |                                                                                                      |                                                                                     | i           | r             | ı           | CY | ΟV | S     | Z | SAT  |
| ADD      | reg1,reg2           | rrrrr001110RRRRR                      | GR[reg2]←GR[reg2]+GR[reg1]                                                                           |                                                                                     | 1           | 1             | 1           | ×  | ×  | ×     | × |      |
|          | imm5,reg2           | rrrrr010010iiiii                      | GR[reg2]←GR[reg2]+sign-extend(in                                                                     | mm5)                                                                                | 1           | 1             | 1           | ×  | ×  | ×     | × |      |
| ADDI     | imm16,reg1,reg2     | rrrrr110000RRRRR                      | GR[reg2]←GR[reg1]+sign-extend(imm16)                                                                 |                                                                                     |             | 1             | 1           | ×  | ×  | ×     | × |      |
| AND      | reg1,reg2           | rrrrr001010RRRRR                      | GR[reg2]←GR[reg2]AND GR[reg1]                                                                        |                                                                                     | 1           | 1             | 1           |    | 0  | ×     | × |      |
| ANDI     | imm16,reg1,reg2     | rrrrr110110RRRRR                      | GR[reg2]←GR[reg1]AND zero-extend(imm16)                                                              |                                                                                     |             | 1             | 1           |    | 0  | ×     | × |      |
| Bcond    | disp9               | ddddd1011dddcccc<br>Note 1            |                                                                                                      |                                                                                     | 2<br>Note 2 | 2<br>Note 2   | 2<br>Note 2 |    |    |       |   |      |
|          |                     |                                       |                                                                                                      | When conditions are not satisfied                                                   | 1           | 1             | 1           |    |    |       |   |      |
| BSH      | reg2,reg3           | rrrrr11111100000<br>wwwww01101000010  | GR[reg3]←GR[reg2] (23 : 16)    GR<br>GR[reg2] (7 : 0)    GR[reg2] (15 : 8)                           | [reg2] (31 : 24) II                                                                 | 1           | 1             | 1           | ×  | 0  | ×     | × |      |
| BSW      | reg2,reg3           | rrrrr111111100000<br>wwwww01101000000 | GR[reg3]←GR[reg2] (7 : 0)    GR[re<br>[reg2] (23 : 16)    GR[reg2] (31 : 24)                         |                                                                                     | 1           | 1             | 1           | ×  | 0  | ×     | × |      |
| CALLT    | imm6                | 0000001000111111                      | CTPC←PC+2(return PC) CTPSW←PSW adr←CTBP+zero-extend(imm6 logic PC←CTBP+zero-extend(Load-mem          | CTPC←PC+2(return PC) CTPSW←PSW adr←CTBP+zero-extend(imm6 logically shift left by 1) |             | 4             | 4           |    |    |       |   |      |
| CLR1     | bit#3,disp16[reg1]  | 10bbb111110RRRRR<br>dddddddddddddddd  | adr←GR[reg1]+sign-extend(disp16<br>Z flag←Not(Load-memory-bit(adr,b<br>Store-memory-bit(adr,bit#3,0) | •                                                                                   | 3<br>Note 3 | 3<br>Note 3   | 3<br>Note3  |    |    |       | × |      |
|          | reg2,[reg1]         | rrrrr1111111RRRRR<br>0000000011100100 | adr←GR[reg1] Z flag←Not(Load-memory-bit(adr,reg Store-memory-bit(adr,reg2,0)                         | eg2))                                                                               | 3<br>Note 3 | 3<br>Note 3   | 3<br>Note3  |    |    |       | × |      |
| CMOV     | cccc,imm5,reg2,reg3 | rrrrr111111iiii<br>wwwww011000cccc0   | if conditions are satisfied<br>then GR[reg3]←sign-extended(immelse GR[reg3]←GR[reg2]                 | n5)                                                                                 | 1           | 1             | 1           |    |    |       |   |      |
|          | cccc,reg1,reg2,reg3 | rrrrr1111111RRRR<br>wwwww011001cccc0  | if conditions are satisfied<br>then GR[reg3]←GR[reg1]<br>else GR[reg3]←GR[reg2]                      |                                                                                     | 1           | 1             | 1           |    |    |       |   |      |
| СМР      | reg1,reg2           | rrrrr001111RRRRR                      | result←GR[reg2]–GR[reg1]                                                                             |                                                                                     | 1           | 1             | 1           | ×  | ×  | ×     | × |      |
|          | imm5,reg2           | rrrrr010011iiiii                      | result←GR[reg2]–sign-extend(imm                                                                      | 5)                                                                                  | 1           | 1             | 1           | ×  | ×  | ×     | × |      |
| CTRET    |                     | 0000011111100000<br>0000000101000100  | PC←CTPC<br>PSW←CTPSW                                                                                 |                                                                                     | 3           | 3             | 3           | R  | R  | R     | R | R    |
| DBRET    |                     | 0000011111100000<br>0000000101000110  | PC←DBPC<br>PSW←DBPSW                                                                                 |                                                                                     | 3           | 3             | 3           | R  | R  | R     | R | R    |

(2/6)

| Mnemonic | Operand            | Opcode                                             | Operation                                                                                                                                                            | Ex | ecut          | ion          |    |    | lags |   |     |
|----------|--------------------|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---------------|--------------|----|----|------|---|-----|
|          |                    |                                                    | ·                                                                                                                                                                    |    | Cloc          |              |    |    |      |   |     |
|          |                    |                                                    |                                                                                                                                                                      | i  | r             | 1            | CY | OV | S    | Z | SAT |
| DBTRAP   |                    | 1111100001000000                                   | DBPC←PC+2 (restored PC) DBPSW←PSW PSW.NP←1 PSW.EP←1 PSW.ID←1 PC←00000060H                                                                                            | 3  | 3             | 3            |    |    |      |   |     |
| DI       |                    | 0000011111100000<br>0000000101100000               | PSW.ID←1                                                                                                                                                             | 1  | 1             | 1            |    |    |      |   |     |
| DISPOSE  | imm5,list12        | 0000011001iiiiiL<br>LLLLLLLLLL00000                | sp←sp+zero-extend(imm5 logically shift left by 2) GR[reg in list12]←Load-memory(sp,Word) sp←sp+4 repeat 2 steps above until all regs in list12 is loaded             |    | n+1<br>Note4  |              |    |    |      |   |     |
|          | imm5,list12,[reg1] | 0000011001iiiiiL<br>LLLLLLLLLLRRRRR<br>Note 5      | sp←sp+zero-extend(imm5 logically shift left by 2) GR[reg in list12]←Load-memory(sp,Word) sp←sp+4 repeat 2 steps above until all regs in list12 is loaded PC←GR[reg1] |    | n+3<br>Note 4 | n+3<br>Note4 |    |    |      |   |     |
| DIV      | reg1,reg2,reg3     | rrrrr111111RRRRR<br>wwwww01011000000               | GR[reg2]←GR[reg2]÷GR[reg1]<br>GR[reg3]←GR[reg2]%GR[reg1]                                                                                                             | 35 | 35            | 35           |    | ×  | ×    | × |     |
| DIVH     | reg1,reg2          | rrrrr000010RRRRR                                   | GR[reg2]←GR[reg2]÷GR[reg1] <sup>Note 6</sup>                                                                                                                         | 35 | 35            | 35           |    | ×  | ×    | × |     |
|          | reg1,reg2,reg3     | rrrrr1111111RRRRR<br>wwwww01010000000              | GR[reg2]←GR[reg2]÷GR[reg1] <sup>Note 6</sup> GR[reg3]←GR[reg2]%GR[reg1]                                                                                              | 35 | 35            | 35           |    | ×  | ×    | × |     |
| DIVHU    | reg1,reg2,reg3     | rrrrr1111111RRRRR<br>wwwww01010000010              | GR[reg2]←GR[reg2]÷GR[reg1] <sup>Note 6</sup> GR[reg3]←GR[reg2]%GR[reg1]                                                                                              | 34 | 34            | 34           |    | ×  | ×    | × |     |
| DIVU     | reg1,reg2,reg3     | rrrrr1111111RRRRR<br>wwwww01011000010              | GR[reg2]←GR[reg2]÷GR[reg1]<br>GR[reg3]←GR[reg2]%GR[reg1]                                                                                                             | 34 | 34            | 34           |    | ×  | ×    | × |     |
| EI       |                    | 1000011111100000                                   | PSW.ID←0                                                                                                                                                             | 1  | 1             | 1            |    |    |      |   |     |
| HALT     |                    | 0000011111100000<br>0000000100100000               | Stop                                                                                                                                                                 | 1  | 1             | 1            |    |    |      |   |     |
| HSW      | reg2,reg3          | rrrrr11111100000<br>wwwww01101000100               | GR[reg3]←GR[reg2](15 : 0) II GR[reg2] (31 : 16)                                                                                                                      | 1  | 1             | 1            | ×  | 0  | ×    | × |     |
| JARL     | disp22,reg2        | rrrrr11110ddddddddddddddddddddddddddddd            | GR[reg2]←PC+4<br>PC←PC+sign-extend(disp22)                                                                                                                           | 2  | 2             | 2            |    |    |      |   |     |
| JMP      | [reg1]             | 0000000011RRRRR                                    | PC←GR[reg1]                                                                                                                                                          | 3  | 3             | 3            |    |    |      |   |     |
| JR       | disp22             | 0000011110dddddd<br>dddddddddddddd0<br>Note 7      | PC←PC+sign-extend(disp22)                                                                                                                                            | 2  | 2             | 2            |    |    |      |   |     |
| LD.B     | disp16[reg1],reg2  | rrrrr111000RRRRR                                   | adr←GR[reg1]+sign-extend(disp16) GR[reg2]←sign-extend(Load-memory(adr,Byte))                                                                                         | 1  | 1             | Note         |    |    |      |   |     |
| LD.BU    | disp16[reg1],reg2  | rrrrr11110bRRRRR<br>dddddddddddddd1<br>Notes 8, 10 | adr←GR[reg1]+sign-extend(disp16) GR[reg2]←zero-extend(Load-memory(adr,Byte))                                                                                         | 1  | 1             | Note         |    |    |      |   |     |

(3/6)

| Mnemonic | Operand            | Opcode                                          | Oper                                                                             | ration                               |             | ecut<br>Clocl |             |    | ı  | Flags |   | 3/6) |
|----------|--------------------|-------------------------------------------------|----------------------------------------------------------------------------------|--------------------------------------|-------------|---------------|-------------|----|----|-------|---|------|
|          |                    |                                                 |                                                                                  |                                      | i           | r             | ı           | CY | OV | s     | Z | SAT  |
| LD.H     | disp16[reg1],reg2  | rrrrr111001RRRR<br>ddddddddddddddd0<br>Note 8   | adr←GR[reg1]+sign-extend(disp16) GR[reg2]←sign-extend(Load-memory(adr,Halfword)) |                                      |             | 1             | Note<br>11  |    |    |       |   |      |
| LDSR     | reg2,regID         | rrrrr111111RRRRR<br>0000000000100000<br>Note 12 | SR[regID]←GR[reg2]                                                               | Other than regID = PSW regID = PSW   | 1           | 1             | 1           | ×  | ×  | ×     | × | ×    |
| LD.HU    | disp16[reg1],reg2  | rrrrr111111RRRRR<br>ddddddddddddddd1<br>Note 8  | adr←GR[reg1]+sign-exten<br>GR[reg2]←zero-extend(Lo                               |                                      | 1           | 1             | Note<br>11  |    |    |       |   |      |
| LD.W     | disp16[reg1],reg2  | rrrrr111001RRRRR<br>ddddddddddddddd1<br>Note 8  | adr←GR[reg1]+sign-exten<br>GR[reg2]←Load-memory(a                                |                                      | 1           | 1             | Note<br>11  |    |    |       |   |      |
| MOV      | reg1,reg2          | rrrrr000000RRRRR                                | GR[reg2]←GR[reg1]                                                                |                                      | 1           | 1             | 1           |    |    |       |   |      |
|          | imm5,reg2          | rrrrr010000iiiii                                | GR[reg2]←sign-extend(im                                                          | m5)                                  | 1           | 1             | 1           |    |    |       |   |      |
|          | imm32,reg1         | 00000110001RRRRR                                | GR[reg1]←imm32                                                                   |                                      | 2           | 2             | 2           |    |    |       |   |      |
| MOVEA    | imm16,reg1,reg2    | rrrrr110001RRRRR                                | GR[reg2]←GR[reg1]+sign-                                                          | GR[reg2]←GR[reg1]+sign-extend(imm16) |             |               | 1           |    |    |       |   |      |
| MOVHI    | imm16,reg1,reg2    | rrrrr110010RRRRR                                | GR[reg2]←GR[reg1]+(imm                                                           | GR[reg2]←GR[reg1]+(imm16 ll 0¹⁵)     |             |               | 1           |    |    |       |   |      |
| MUL      | reg1,reg2,reg3     | rrrrr1111111RRRRR<br>wwwww01000100000           | GR[reg3] II GR[reg2]←GR <br>Note 14                                              | [reg2]xGR[reg1]                      | 1           | 4             | 5           |    |    |       |   |      |
|          | imm9,reg2,reg3     | rrrrr111111iiii<br>wwwww01001IIII00<br>Note 13  | GR[reg3] II GR[reg2]←GR                                                          | [reg2]xsign-extend(imm9)             | 1           | 4             | 5           |    |    |       |   |      |
| MULH     | reg1,reg2          | rrrrr000111RRRRR                                | GR[reg2]←GR[reg2] <sup>Note 6</sup> xG                                           | GR[reg1] <sup>Note 6</sup>           | 1           | 1             | 2           |    |    |       |   |      |
|          | imm5,reg2          | rrrrr010111iiiii                                | GR[reg2]←GR[reg2] <sup>Note 6</sup> xsi                                          | ign-extend(imm5)                     | 1           | 1             | 2           |    |    |       |   |      |
| MULHI    | imm16,reg1,reg2    | rrrrr110111RRRRR                                | GR[reg2]←GR[reg1] <sup>Note 6</sup> xin                                          | nm16                                 | 1           | 1             | 2           |    |    |       |   |      |
| MULU     | reg1,reg2,reg3     | rrrrr1111111RRRRR<br>wwwww01000100010           | GR[reg3] II GR[reg2]←GR<br>Note 14                                               | [reg2]xGR[reg1]                      | 1           | 4             | 5           |    |    |       |   |      |
|          | imm9,reg2,reg3     | rrrrr111111iiii<br>wwwww01001IIII10<br>Note 13  | GR[reg3] II GR[reg2]←GR                                                          | [reg2]xzero-extend(imm9)             | 1           | 4             | 5           |    |    |       |   |      |
| NOP      |                    | 0000000000000000                                | Pass at least one clock cycle doing nothing.                                     |                                      | 1           | 1             | 1           |    |    |       |   |      |
| NOT      | reg1,reg2          | rrrrr000001RRRRR                                | GR[reg2]←NOT(GR[reg1])                                                           | )                                    | 1           | 1             | 1           |    | 0  | ×     | × | Ш    |
| NOT1     | bit#3,disp16[reg1] | 01bbb111110RRRRR<br>ddddddddddddddddd           | adr←GR[reg1]+sign-exten<br>Z flag←Not(Load-memory-<br>Store-memory-bit(adr,bit#3 | -bit(adr,bit#3))                     | 3<br>Note 3 | 3<br>Note 3   | 3<br>Note 3 |    |    |       | × |      |
|          | reg2,[reg1]        | rrrrr1111111RRRRR<br>0000000011100010           | adr←GR[reg1] Z flag←Not(Load-memory- Store-memory-bit(adr,reg2                   | -bit(adr,reg2))                      | 3<br>Note 3 | 3<br>Note 3   | 3<br>Note 3 |    |    |       | × |      |

(4/6)

| Mnemonic | Operand                                   | Opcode                                                         | Operation                                                                                                                                                 |        | ecut         |                          |    | I  | Flags |   | 4/0) |
|----------|-------------------------------------------|----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------|--------------------------|----|----|-------|---|------|
|          |                                           |                                                                |                                                                                                                                                           | i      | r            | ı                        | CY | ov | S     | Z | SAT  |
| OR       | reg1,reg2                                 | rrrrr001000RRRRR                                               | GR[reg2]—GR[reg2]OR GR[reg1]                                                                                                                              | 1      | 1            | 1                        |    | 0  | ×     | × |      |
| ORI      | imm16,reg1,reg2                           | rrrrr110100RRRRR                                               | GR[reg2]←GR[reg1]OR zero-extend(imm16)                                                                                                                    | 1      | 1            | 1                        |    | 0  | ×     | × |      |
| PREPARE  | list12,imm5                               | 0000011110iiiiiL<br>LLLLLLLLLL00001                            | Store-memory(sp-4,GR[reg in list12],Word) sp←sp-4 repeat 1 step above until all regs in list12 is stored sp←sp-zero-extend(imm5)                          |        | n+1<br>Note4 |                          |    |    |       |   |      |
|          | list12,imm5,<br>sp/imm <sup>Note 15</sup> | 0000011110iiiiiL<br>LLLLLLLLLLLff011<br>imm16/imm32<br>Note 16 | Store-memory(sp–4,GR[reg in list12],Word) sp←sp+4 repeat 1 step above until all regs in list12 is stored sp←sp-zero-extend (imm5) ep←sp/imm               | Note 4 | Note 4       | n+2<br>Note 4<br>Note 17 |    |    |       |   |      |
| RETI     |                                           | 0000011111100000<br>0000000101000000                           | if PSW.EP=1 then PC ←EIPC PSW ←EIPSW else if PSW.NP=1 then PC ←FEPC PSW ←FEPSW else PC ←EIPC PSW ←EIPSW                                                   | 3      | 3            | 3                        | R  | R  | R     | R | R    |
| SAR      | reg1,reg2                                 | rrrrr1111111RRRRR<br>0000000010100000                          | GR[reg2]←GR[reg2]arithmetically shift right by GR[reg1]                                                                                                   | 1      | 1            | 1                        | ×  | 0  | ×     | × |      |
|          | imm5,reg2                                 | rrrrr010101iiiii                                               | GR[reg2]←GR[reg2]arithmetically shift right by zero-extend (imm5)                                                                                         | 1      | 1            | 1                        | ×  | 0  | ×     | × |      |
| SASF     | cccc,reg2                                 | rrrrr1111110ccc                                                | if conditions are satisfied then GR[reg2]←(GR[reg2]Logically shift left by 1) OR 00000001H else GR[reg2]←(GR[reg2]Logically shift left by 1) OR 00000000H | 1      | 1            | 1                        |    |    |       |   |      |
| SATADD   | reg1,reg2                                 | rrrrr000110RRRRR                                               | GR[reg2]←saturated(GR[reg2]+GR[reg1])                                                                                                                     | 1      | 1            | 1                        | ×  | ×  | ×     | × | ×    |
|          | imm5,reg2                                 | rrrrr010001iiiii                                               | GR[reg2]-saturated(GR[reg2]+sign-extend(imm5)                                                                                                             | 1      | 1            | 1                        | ×  | ×  | ×     | × | ×    |
| SATSUB   | reg1,reg2                                 | rrrrr000101RRRRR                                               | GR[reg2]—saturated(GR[reg2]–GR[reg1])                                                                                                                     | 1      | 1            | 1                        | ×  | ×  | ×     | × | ×    |
| SATSUBI  | imm16,reg1,reg2                           | rrrrr110011RRRRR                                               | GR[reg2]←saturated(GR[reg1]–sign-extend(imm16)                                                                                                            | 1      | 1            | 1                        | ×  | ×  | ×     | × | ×    |
| SATSUBR  | reg1,reg2                                 | rrrrr000100RRRRR                                               | GR[reg2]—saturated(GR[reg1]–GR[reg2])                                                                                                                     | 1      | 1            | 1                        | ×  | ×  | ×     | × | ×    |
| SETF     | cccc,reg2                                 | rrrrr1111110ccc                                                | If conditions are satisfied then GR[reg2]←0000001H else GR[reg2]←0000000H                                                                                 | 1      | 1            | 1                        |    |    |       |   |      |

(5/6)

|          |                    |                                                 |                                                                           | 1           |            |             | ı   |     |       | - ( | 5/6) |
|----------|--------------------|-------------------------------------------------|---------------------------------------------------------------------------|-------------|------------|-------------|-----|-----|-------|-----|------|
| Mnemonic | Operand            | Opcode                                          | Operation                                                                 |             | ecut       |             |     | ı   | Flags | ;   |      |
|          |                    |                                                 |                                                                           |             | Cloc       | κ<br>  ,    | 01/ | 01/ | S     | 7   | CAT  |
| OFT4     | h:##0 diam40[41    | 005554444400000000                              | adv. OPfice of Legion as dear d/diseat (C)                                | i           | r          | 1           | CY  | OV  | 5     |     | SAT  |
| SET1     | bit#3,disp16[reg1] | 00bbb111110RRRRR                                | adr—GR[reg1]+sign-extend(disp16) Z flag—Not (Load-memory-bit(adr.bit#3))  | 3<br>Note 3 | 3<br>Note: | 3<br>Note 3 |     |     |       | ×   |      |
|          |                    |                                                 | Store-memory-bit(adr,bit#3,1)                                             |             |            | 110100      |     |     |       |     |      |
|          | reg2,[reg1]        | rrrrr111111RRRRR                                | adr←GR[reg1]                                                              | 3           | 3          | 3           |     |     |       | ×   |      |
|          |                    | 0000000011100000                                | Z flag←Not(Load-memory-bit(adr,reg2))                                     | Note 3      | Note 3     | Note 3      |     |     |       |     |      |
|          |                    |                                                 | Store-memory-bit(adr,reg2,1)                                              |             |            |             |     |     |       |     |      |
| SHL      | reg1,reg2          | rrrrr1111111RRRRR<br>0000000011000000           | GR[reg2]←GR[reg2] logically shift left by GR[reg1]                        | 1           | 1          | 1           | ×   | 0   | ×     | ×   |      |
|          | imm5,reg2          | rrrrr010110iiiii                                | GR[reg2]←GR[reg2] logically shift left by zero-extend(imm5)               | 1           | 1          | 1           | ×   | 0   | ×     | ×   |      |
| SHR      | reg1,reg2          | rrrrr1111111RRRRR<br>0000000010000000           | GR[reg2]←GR[reg2] logically shift right by GR[reg1]                       | 1           | 1          | 1           | ×   | 0   | ×     | ×   |      |
|          | imm5,reg2          | rrrrr010100iiiii                                | GR[reg2]←GR[reg2] logically shift right by zero-extend(imm5)              | 1           | 1          | 1           | ×   | 0   | ×     | ×   |      |
| SLD.B    | disp7[ep],reg2     | rrrrr0110ddddddd                                | adr←ep+zero-extend(disp7) GR[reg2]←sign-extend(Load-memory(adr,Byte))     | 1           | 1          | Note 9      |     |     |       |     |      |
| SLD.BU   | disp4[ep],reg2     | rrrrr0000110dddd<br>Note 18                     | adr←ep+zero-extend(disp4) GR[reg2]←zero-extend(Load-memory(adr,Byte))     | 1           | 1          | Note 9      |     |     |       |     |      |
| SLD.H    | disp8[ep],reg2     | rrrrr1000ddddddd<br>Note 19                     | adr←ep+zero-extend(disp8) GR[reg2]←sign-extend(Load-memory(adr,Halfword)) | 1           | 1          | Note 9      |     |     |       |     |      |
| SLD.HU   | disp5[ep],reg2     | rrrrr0000111dddd<br>Notes 18, 20                | adr←ep+zero-extend(disp5) GR[reg2]←zero-extend(Load-memory(adr,Halfword)) | 1           | 1          | Note 9      |     |     |       |     |      |
| SLD.W    | disp8[ep],reg2     | rrrrr1010dddddd0                                | adr-ep+zero-extend(disp8)                                                 | 1           | 1          | Note 9      |     |     |       |     |      |
| SST.B    | reg2,disp7[ep]     | Note 21                                         | GR[reg2]←Load-memory(adr,Word) adr←ep+zero-extend(disp7)                  | 1           | 1          | 1           |     |     |       |     |      |
|          |                    |                                                 | Store-memory(adr,GR[reg2],Byte)                                           |             |            |             |     |     |       |     |      |
| SST.H    | reg2,disp8[ep]     | rrrrr1001ddddddd<br>Note 19                     | adr←ep+zero-extend(disp8) Store-memory(adr,GR[reg2],Halfword)             | 1           | 1          | 1           |     |     |       |     |      |
| SST.W    | reg2,disp8[ep]     | rrrrr1010dddddd1<br>Note 21                     | adr←ep+zero-extend(disp8) Store-memory(adr,GR[reg2],Word)                 | 1           | 1          | 1           |     |     |       |     |      |
| ST.B     | reg2,disp16[reg1]  | rrrrr111010RRRRR<br>dddddddddddddddd            | adr←GR[reg1]+sign-extend(disp16) Store-memory(adr,GR[reg2],Byte)          | 1           | 1          | 1           |     |     |       |     |      |
| ST.H     | reg2,disp16[reg1]  | rrrrr111011RRRRR<br>dddddddddddddddd0<br>Note 8 | adr←GR[reg1]+sign-extend(disp16) Store-memory (adr,GR[reg2], Halfword)    | 1           | 1          | 1           |     |     |       |     |      |
| ST.W     | reg2,disp16[reg1]  | rrrrr111011RRRRR<br>dddddddddddddddd1<br>Note 8 | adr←GR[reg1]+sign-extend(disp16) Store-memory (adr,GR[reg2], Word)        | 1           | 1          | 1           |     |     |       |     |      |
| STSR     | regID,reg2         | rrrrr111111RRRRR<br>0000000001000000            | GR[reg2]←SR[regID]                                                        | 1           | 1          | 1           |     |     |       |     |      |

(6/6)

| Mnemonic | Operand            | Opcode                                 | Operation                                                                                                                                                                | Execution<br>Clock |             |             | Flags |    |   |   |     |  |
|----------|--------------------|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-------------|-------------|-------|----|---|---|-----|--|
|          |                    |                                        |                                                                                                                                                                          | i                  | r           | ı           | CY    | OV | S | Z | SAT |  |
| SUB      | reg1,reg2          | rrrrr001101RRRRR                       | GR[reg2]←GR[reg2]–GR[reg1]                                                                                                                                               | 1                  | 1           | 1           | ×     | ×  | × | × |     |  |
| SUBR     | reg1,reg2          | rrrrr001100RRRRR                       | GR[reg2]←GR[reg1]–GR[reg2]                                                                                                                                               | 1                  | 1           | 1           | ×     | ×  | × | × |     |  |
| SWITCH   | reg1               | 00000000010RRRRR                       | adr←(PC+2) + (GR [reg1] logically shift left by 1) PC←(PC+2) + (sign-extend (Load-memory (adr,Halfword)) logically shift left by 1                                       | 5                  | 5           | 5           |       |    |   |   |     |  |
| SXB      | reg1               | 00000000101RRRRR                       | GR[reg1]←sign-extend<br>(GR[reg1] (7 : 0))                                                                                                                               | 1                  | 1           | 1           |       |    |   |   |     |  |
| SXH      | reg1               | 00000000111RRRRR                       | GR[reg1]←sign-extend<br>(GR[reg1] (15 : 0))                                                                                                                              | 1                  | 1           | 1           |       |    |   |   |     |  |
| TRAP     | vector             | 00000111111iiii<br>0000000100000000    | EIPC ←PC+4 (Restored PC)  EIPSW ←PSW  ECR.EICC ←Interrupt code  PSW.EP ←1  PSW.ID ←1  PC ←00000040H  (when vector is 00H to 0FH)  00000050H  (when vector is 10H to 1FH) | 3                  | 3           | 3           |       |    |   |   |     |  |
| TST      | reg1,reg2          | rrrrr001011RRRRR                       | result←GR[reg2] AND GR[reg1]                                                                                                                                             | 1                  | 1           | 1           |       | 0  | × | × |     |  |
| TST1     | bit#3,disp16[reg1] | 11bbb111110RRRRR<br>dddddddddddddddd   | adr←GR[reg1]+sign-extend(disp16) Z flag←Not (Load-memory-bit (adr,bit#3))                                                                                                | 3<br>Note 3        | 3<br>Note 3 | 3<br>Note 3 |       |    |   | × |     |  |
|          | reg2, [reg1]       | rrrrr1111111RRRRR<br>00000000011100110 | adr←GR[reg1]<br>Z flag←Not (Load-memory-bit (adr,reg2))                                                                                                                  | 3<br>Note 3        | 3<br>Note 3 | 3<br>Note 3 |       |    |   | × |     |  |
| XOR      | reg1,reg2          | rrrrr001001RRRRR                       | GR[reg2]←GR[reg2] XOR GR[reg1]                                                                                                                                           | 1                  | 1           | 1           |       | 0  | × | × |     |  |
| XORI     | imm16,reg1,reg2    | rrrrr110101RRRRR                       | GR[reg2]←GR[reg1] XOR zero-extend (imm16)                                                                                                                                | 1                  | 1           | 1           |       | 0  | × | × |     |  |
| ZXB      | reg1               | 00000000100RRRRR                       | GR[reg1]←zero-extend (GR[reg1] (7 : 0))                                                                                                                                  | 1                  | 1           | 1           |       |    |   |   |     |  |
| ZXH      | reg1               | 00000000110RRRRR                       | GR[reg1]←zero-extend (GR[reg1] (15 : 0))                                                                                                                                 | 1                  | 1           | 1           |       |    |   |   |     |  |

#### Notes 1. dddddddd: Higher 8 bits of disp9.

- 2. 3 if there is an instruction that rewrites the contents of the PSW immediately before.
- 3. If there is no wait state (3 + the number of read access wait states).
- **4.** n is the total number of list12 load registers. (According to the number of wait states. Also, if there are no wait states, n is the total number of list12 registers. If n = 0, same operation as when n = 1)
- 5. RRRRR: other than 00000.
- 6. The lower halfword data only are valid.
- **7.** dddddddddddddddddd: The higher 21 bits of disp22.
- 8. ddddddddddddd: The higher 15 bits of disp16.
- 9. According to the number of wait states (1 if there are no wait states).
- 10. b: bit 0 of disp16.
- 11. According to the number of wait states (2 if there are no wait states).

**Notes 12.** In this instruction, for convenience of mnemonic description, the source register is made reg2, but the reg1 field is used in the opcode. Therefore, the meaning of register specification in the mnemonic description and in the opcode differs from other instructions.

rrrrr = regID specification

RRRRR = reg2 specification

13. iiiii: Lower 5 bits of imm9.

IIII: Higher 4 bits of imm9.

- **14.** Do not specify the same register for general-purpose registers reg1 and reg3.
- 15. sp/imm: specified by bits 19 and 20 of the sub-opcode.
- **16.** ff = 00: Load sp in ep.
  - 01: Load sign expanded 16-bit immediate data (bits 47 to 32) in ep.
  - 10: Load 16-bit logically left shifted 16-bit immediate data (bits 47 to 32) in ep.
  - 11: Load 32-bit immediate data (bits 63 to 32) in ep.
- 17. If imm = imm32, n + 3 clocks.
- **18.** rrrrr: Other than 00000.
- 19. ddddddd: Higher 7 bits of disp8.
- 20. dddd: Higher 4 bits of disp5.
- 21. dddddd: Higher 6 bits of disp8.