## **FUJITSU SEMICONDUCTOR** CONTROLLER MANUAL

CM44-10118-2E

## F<sup>2</sup>MC<sup>™</sup>-16LX **16-BIT MICROCONTROLLER MB90385 Series** HARDWARE MANUAL

DataShe

DataSheet4U.com

eet4U.com Fl

DataSheet4U.com

www.DataSheet4U.com

et4U.com

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

## F<sup>2</sup>MC<sup>TM</sup>-16LX 16-BIT MICROCONTROLLER MB90385 Series HARDWARE MANUAL

et4U.com

DataShee

DataSheet4U.com

**FUJITSU LIMITED** 

DataSheet4U.com

www.DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

et4U.com

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

## PREFACE

## Manual Objectives and Readers

Thank you very much for your continued patronage of Fujitsu semiconductor products.

The MB90385 series is one of the general-purpose products in the F<sup>2</sup>MC<sup>TM</sup>-16LX family of 16-bit singlechip microcontrollers that is developed by using an application-specific integrated circuit (ASIC).

This manual covers the functions and operations of the MB90385 series for engineers to develop LSIs using this series.

## Trademarks

et4U.com

 $F^2MC$  is the abbreviation of FUJITSU Flexible Microcontroller.

Other system and product names in this manual are trademarks of respective companies or organizations.

The symbols <sup>TM</sup> and <sup>®</sup> are sometimes omitted in this manual.

- The contents of this document are subject to change without notice.
- Customers are advised to consult with FUJITSU sales representatives before ordering.
- The information, such as descriptions of function and application circuit examples, in this document are presented solely for the purpose of reference to show examples of operations and uses of Fujitsu semiconductor device; Fujitsu does not warrant proper operation of the device with respect to use based on such information. When you develop equipment incorporating the device based on such information, you must assume any responsibility arising out of such use of the information. Fujitsu assumes no liability for any damages whatsoever arising out of the use of the information.
- Any information in this document, including descriptions of function and schematic diagrams, shall not be construed as license of the use or exercise of any intellectual property right, such as patent right or copyright, or any other right of Fujitsu or any third party or does Fujitsu warrant non-infringement of any third-party's intellectual property right or other right by using such information. Fujitsu assumes no liability for any infringement of the intellectual property rights or other rights of third parties which would result from the use of information contained herein.
- The products described in this document are designed, developed and manufactured as contemplated for general use, including without limitation, ordinary industrial use, general office use, personal use, and household use, but are not designed, developed and manufactured as contemplated (1) for use accompanying fatal risks or dangers that, unless extremely high safety is secured, could have a serious effect to the public, and could lead directly to death, personal injury, severe physical damage or other loss (i.e., nuclear reaction control in nuclear facility, aircraft flight control, air traffic control, mass transport control, medical life support system, missile launch control in weapon system), or (2) for use requiring extremely high reliability (i.e., submersible repeater and artificial satellite).

Please note that Fujitsu will not be liable against you and/or any third party for any claims or damages arising in connection with above-mentioned uses of the products.

- Any semiconductor devices have an inherent chance of failure. You must protect against injury, damage or loss from such failures by incorporating safety design measures into your facility and equipment such as redundancy, fire protection, and prevention of over-current levels and other abnormal operating conditions.
- If any products described in this document represent goods or technologies subject to certain restrictions on export under the Foreign Exchange and Foreign Trade Law of Japan, the prior authorization by Japanese government will be required for export of those products from Japan.

DataSheet4U.com ©2005 FUJITSU LIMITED Printed in Japan

## HOW TO READ THIS MANUAL

## ■ Page Structure

Each section content can be read easily because it is mentioned within one page or double spread.

A summary under the title in each section outlines the section contents.

The top-level title at the top of a double spread indicates where you are reading without returning to the table of contents or the chapter title page.

## How to Find Information

To find information in each section, use the following index in addition to general table of contents and index.

#### Register index

This index helps you find the page containing the explanation of the corresponding register from a register name or related resource name. You can also check the mapped addresses on memory and reset values.

• Pin function index

et4U.com

This index helps you find the page containing the explanation or block diagram of the corresponding pin from a pin number, pin name, or related resource name. You can also check the circuit types.

Interrupt vector index

DataSheet4U.com

This index helps you find the page containing the explanation of a corresponding interrupt from a name of resource generating the interrupt or an interrupt number. You can also check the names and addresses of interrupt control registers (ICRs), and the interrupt vector addresses.

## Representation of Register Name and Pin Name

Representation of register name and bit name



DataSheet4U.com

• Representation of dual-purpose pin

#### P25/SCK pin

Some pins are dual-purpose pins which functions can be switched by the setting of program. A slash (/) separates and represents the names corresponding to the functions of the dual-purpose pins.

## Register Representation

The  $F^2MC-16LX$  family is a CPU with a 16-bit bus width. The bit position of each control register and data register is given in 16 bits.

In 16-bit registers, bits 15 to 8 are allocated to odd addresses and bits 7 to 0 even addresses.

Even in 8-bit registers, the position of bits allocated to odd addresses is given in bits 15 to 8.

The  $F^2MC-16LX$  family enables access to 8-bit data in order to increase the efficiency of programs. So, if odd-address registers are accessed in 8 bits, bits 7 to 0 in data correspond to bits 15 to 8 in the manual representation.

et4U.com

DataSheet4U.com

DataShe

www.DataSheet4U.com

et4U.com

DataSheet4U.com

DataSheet4U.com

## CONTENTS

| CHAPTE              | R 1 OVERVIEW                                     | 1      |
|---------------------|--------------------------------------------------|--------|
| 1.1                 | Features of MB90385 Series                       | 2      |
| 1.2                 | Product Lineup for MB90385 Series                | 5      |
| 1.3                 | Block Diagram of MB90385 Series                  | 8      |
| 1.4                 | Pin Assignment                                   | 9      |
| 1.5                 | Package Dimension 1                              | 10     |
| 1.6                 | Pin Description 1                                | 11     |
| 1.7                 | I/O Circuit 1                                    | 14     |
| СНАРТЕ              | R 2 HANDLING DEVICES 1                           | 7      |
| 2.1                 | Precautions when Handling Devices 1              |        |
| СНАРТЕ              | R 3 CPU                                          | 21     |
| 3.1                 | Memory Space                                     | 22     |
| 3.1.1               | Mapping of and Access to Memory Space            |        |
| 3.1.2               | Memory Map                                       |        |
| 3.1.3               | Addressing                                       | 27     |
| 3.1.4               | Linear Addressing                                | DotaSt |
| 3.1.5               | Bank Addressing                                  |        |
| 3.1.6               | Allocation of Multi-byte Data on Memory          |        |
| 3.2                 | Dedicated Registers                              |        |
| 3.2.1               | Dedicated Registers and General-purpose Register |        |
| 3.2.2               | Accumulator (A)                                  |        |
| 3.2.3               | Stack Pointer (USP, SSP)                         |        |
| 3.2.4               | Processor Status (PS)                            |        |
| 3.2.                |                                                  |        |
| 3.2.                |                                                  |        |
| 3.2.                |                                                  |        |
| 3.2.5               | Program Counter (PC)                             |        |
| 3.2.6               | Direct Page Register (DPR)                       |        |
| 3.2.7               | Bank Register (PCB, DTB, USB, SSB, and ADB) 4    |        |
| 3.3                 | General-purpose Register                         |        |
| 3.4                 | Prefix Codes                                     |        |
| 3.4.1               | Bank Select Prefix (PCB, DTB, ADB, and SPB)      |        |
| 3.4.2               | Common Register Bank Prefix (CMR)                |        |
| 3.4.3               | Flag Change Inhibit Prefix (NCC)                 |        |
| 3.4.4               | Restrictions on Prefix Code                      |        |
| 3.5                 | Interrupt                                        |        |
| 3.5.1               | Interrupt Factor and Interrupt Vector            |        |
| 3.5.2               | Interrupt Control Registers and Resources        |        |
| 3.5.3               | Interrupt Control Register (ICR00 to ICR15)      |        |
| 3.5.4               | Function of Interrupt Control Register           |        |
| 1U.con <b>3.5.5</b> | Hardware Interrupt                               |        |

| 3.5.6   | Operation of Hardware Interrupt                       | 74       |             |
|---------|-------------------------------------------------------|----------|-------------|
| 3.5.7   | Procedure for Use of Hardware Interrupt               |          |             |
| 3.5.8   | Multiple Interrupts                                   |          |             |
| 3.5.9   | Software Interrupt                                    |          |             |
| 3.5.10  | Interrupt by El <sup>2</sup> OS                       |          |             |
| 3.5.11  | El <sup>2</sup> OS Descriptor (ISD)                   |          |             |
| 3.5.12  | Each Register of El <sup>2</sup> OS Descriptor (ISD)  |          |             |
| 3.5.12  | Operation of El <sup>2</sup> OS                       |          |             |
| 3.5.14  | Procedure for Use of El <sup>2</sup> OS               |          |             |
| 3.5.15  | El <sup>2</sup> OS Processing Time                    |          |             |
| 3.5.16  | Exception Processing Interrupt                        |          |             |
| 3.5.17  | Time Required to Start Interrupt Processing           |          |             |
| 3.5.18  | Stack Operation for Interrupt Processing              |          |             |
| 3.5.19  | Program Example of Interrupt Processing               |          |             |
|         | eset                                                  |          |             |
| 3.6.1   | Reset Factors and Oscillation Stabilization Wait Time |          |             |
| 3.6.2   | External Reset Pin                                    |          |             |
| 3.6.3   | Reset Operation                                       |          |             |
| 3.6.4   | Reset Factor Bit                                      |          |             |
| 3.6.5   | State of Each Pin at Reset                            |          |             |
|         | locks                                                 |          |             |
| 3.7.1   | Block Diagram of Clock Generation Section             |          |             |
| 3.7.2   | Register in Clock Generation Section                  |          | DataShe     |
| 3.7.3   | Clock Select Register (CKSCR) DataSheet4U.com         |          |             |
| 3.7.4   | Clock Mode                                            |          |             |
| 3.7.5   | Oscillation Stabilization Wait Time                   |          |             |
| 3.7.6   | Connection of Oscillator and External Clock           | 123      |             |
| 3.8 L   | ow-power Consumption Mode                             | 124      |             |
| 3.8.1   | Block Diagram of Low-power Consumption Circuit        | 127      |             |
| 3.8.2   | Registers for Setting Low-power Consumption Modes     | 129      |             |
| 3.8.3   | Low-power Consumption Mode Control Register (LPMCR)   | 130      |             |
| 3.8.4   | CPU Intermittent Operation Mode                       | 133      |             |
| 3.8.5   | Standby Mode                                          | 134      |             |
| 3.8.5.  | 1 Sleep Mode                                          | 135      |             |
| 3.8.5.  | 2 Watch mode                                          | 137      |             |
| 3.8.5.  | 3 Timebase Timer Mode                                 | 139      |             |
| 3.8.5.  | 4 Stop Mode                                           | 141      |             |
| 3.8.6   | State Transition in Standby Mode                      | 144      |             |
| 3.8.7   | Pin State in Standby Mode, at Reset                   | 145      |             |
| 3.8.8   | Precautions when Using Low-power Consumption Mode     | 146      |             |
| 3.9 C   | PU Mode                                               | 149      |             |
| 3.9.1   | Mode Pins (MD2 to MD0)                                | 150      |             |
| 3.9.2   | Mode Data                                             | 152      |             |
| 3.9.3   | Memory Access Mode                                    |          |             |
| 3.9.4   | Selection of Memory Access Mode                       | 155      |             |
|         |                                                       |          |             |
| CHAPTER | R 4 I/O PORT                                          | 157      | oot III som |
| J.com   | 1949A                                                 | m.ngrg2U | cc(40.00M   |

et4U.com

|           | 4.1           | Overview of I/O Port                                                               | . 158                 |           |
|-----------|---------------|------------------------------------------------------------------------------------|-----------------------|-----------|
|           | 4.2           | Registers of I/O Port                                                              | . 160                 |           |
|           | 4.3           | Port 1                                                                             | . 161                 |           |
|           | 4.3.1         | Registers for Port 1 (PDR1, DDR1)                                                  | . 163                 |           |
|           | 4.3.2         | Operation of Port 1                                                                | . 164                 |           |
|           | 4.4           | Port 2                                                                             | . 166                 |           |
|           | 4.4.1         | Registers for Port 2 (PDR2, DDR2)                                                  | . 168                 |           |
|           | 4.4.2         |                                                                                    |                       |           |
|           | 4.5           | Port 3                                                                             |                       |           |
|           | 4.5.1         | Registers for Port 3 (PDR3, DDR3)                                                  |                       |           |
|           | 4.5.2         |                                                                                    |                       |           |
|           | 4.6           | Port 4                                                                             |                       |           |
|           | 4.6.1         | Registers for Port 4 (PDR4, DDR4)                                                  |                       |           |
|           | 4.6.2         |                                                                                    |                       |           |
|           | 4.7           | Port 5                                                                             |                       |           |
|           | 4.7.1         | Registers for Port 5 (PDR5, DDR5, ADER)                                            |                       |           |
|           | 4.7.2         |                                                                                    |                       |           |
|           | <b>Τ.1.</b> Ζ |                                                                                    | 100                   |           |
|           | CHAPTE        | ER 5 TIMEBASE TIMER                                                                | 187                   |           |
|           | 5.1           | Overview of Timebase Timer                                                         |                       |           |
|           |               |                                                                                    |                       |           |
| (4) L 00M | 5.2           | Block Diagram of Timebase Timer                                                    |                       |           |
| et4U.com  | 5.3           | Configuration of Timebase Timer                                                    |                       | DataShe   |
|           | 5.3.1         | Timebase Timer Control Register (TBTC)<br>Timebase Timer Interrupt DataSheet4U.com |                       |           |
|           | 5.4           |                                                                                    |                       |           |
|           | 5.5           | Explanation of Operation of Timebase Timer                                         |                       |           |
|           | 5.6           | Precautions when Using Timebase Timer                                              |                       |           |
|           | 5.7           | Program Example of Timebase Timer                                                  | . 201                 |           |
|           | CHAPTE        | ER 6 WATCHDOG TIMER                                                                | 203                   |           |
|           | 6.1           | Overview of Watchdog Timer                                                         | . 204                 |           |
|           | 6.2           | Configuration of Watchdog Timer                                                    |                       |           |
|           | 6.3           | Watchdog Timer Registers                                                           |                       |           |
|           | 6.3.1         | Watchdog Timer Control Register (WDTC)                                             |                       |           |
|           | 6.4           | Explanation of Operation of Watchdog Timer                                         |                       |           |
|           | 6.5           | Precautions when Using Watchdog Timer                                              |                       |           |
|           | 6.6           | Program Examples of Watchdog Timer                                                 |                       |           |
|           |               |                                                                                    |                       |           |
|           | CHAPTE        | ER 7 16-BIT INPUT/OUTPUT TIMER                                                     | 215                   |           |
|           | 7.1           | Overview of 16-bit Input/Output Timer                                              |                       |           |
|           | 7.2           | Block Diagram of 16-bit Input/Output Timer                                         | . 217                 |           |
|           | 7.2.1         | Block Diagram of 16-bit Free-run Timer                                             | . 218                 |           |
|           | 7.2.2         | Block Diagram of Input Capture                                                     | . 220                 |           |
|           | 7.3           | Configuration of 16-bit Input/Output Timer                                         | . 222                 |           |
|           | 7.3.1         | Timer Counter Control Status Register (TCCS)                                       | . 225                 |           |
|           | 7.3.2         | Timer Counter Data Register (TCDT)                                                 | . 227                 |           |
|           | 7.3.3         | Input Capture Control Status Registers (ICS01 and ICS23)                           | . 229                 |           |
| DataSheet | 7.3.4         | Input Capture Data Registers 0 to 3 (IPCP0 to IPCP3)                               | D <mark>232</mark> 5h | eet4U.com |
| DataOneel |               |                                                                                    |                       |           |

DataSheet4U.com

|          | 7.4    |         | ots of 16-bit Input/Output Timer                          |     |
|----------|--------|---------|-----------------------------------------------------------|-----|
|          | 7.5    | •       | ation of Operation of 16-bit Free-run Timer               |     |
|          | 7.6    |         | ation of Operation of Input Capture                       |     |
|          | 7.7    |         | itions when Using 16-bit Input/Output Timer               |     |
|          | 7.8    | Progra  | m Example of 16-bit Input/Output Timer                    | 240 |
|          | СНАРТІ | ER 8    | 16-BIT RELOAD TIMER                                       | 243 |
|          | 8.1    | Overvi  | ew of 16-bit Reload Timer                                 | 244 |
|          | 8.2    | Block [ | Diagram of 16-bit Reload Timer                            | 246 |
|          | 8.3    | Config  | uration of 16-bit Reload Timer                            | 248 |
|          | 8.3.1  | Tim     | er Control Status Registers (High) (TMCSR0: H, TMCSR1: H) | 251 |
|          | 8.3.2  | Tim     | er Control Status Registers (Low) (TMCSR0: L, TMCSR1: L)  | 253 |
|          | 8.3.3  | 16-l    | pit Timer Registers (TMR0, TMR1)                          | 255 |
|          | 8.3.4  | 16-l    | pit Reload Registers (TMRLR0, TMRLR1)                     | 256 |
|          | 8.4    | Interru | ots of 16-bit Reload Timer                                | 257 |
|          | 8.5    | Explan  | ation of Operation of 16-bit Reload Timer                 | 258 |
|          | 8.5.1  | Ope     | eration in Internal Clock Mode                            | 260 |
|          | 8.5.2  | Ope     | eration in Event Count Mode                               | 265 |
|          | 8.6    | Precau  | tions when Using 16-bit Reload Timer                      | 268 |
|          | 8.7    | Progra  | m Example of 16-bit Reload Timer                          | 269 |
| et4U.com | CHAPTI | ER 9    | WATCH TIMER                                               | 273 |
|          | 9.1    | Overvi  | ew of Watch Timer                                         | 274 |
|          | 9.2    | Block [ | Diagram of Watch Timer                                    | 276 |
|          | 9.3    |         | uration of Watch Timer                                    |     |
|          | 9.3.1  | -       | tch Timer Control Register (WTC)                          |     |
|          | 9.4    |         | Timer Interrupt                                           |     |
|          | 9.5    |         | ation of Operation of Watch Timer                         |     |
|          | 9.6    | •       | m Example of Watch Timer                                  |     |
|          | СНАРТІ | =R 10   | 8-/16-BIT PPG TIMER                                       | 285 |
|          | 10.1   |         | ew of 8-/16-bit PPG Timer                                 |     |
|          | 10.1   |         | Diagram of 8-/16-bit PPG Timer                            |     |
|          | 10.2   |         | ck Diagram for 8-/16-bit PPG Timer 0                      |     |
|          | 10.2.  |         | ck Diagram of 8-/16-bit PPG Timer 1                       |     |
|          | 10.2   |         | uration of 8-/16-bit PPG Timer                            |     |
|          | 10.3   | -       | G0 Operation Mode Control Register (PPGC0)                |     |
|          | 10.3.  |         | G1 Operation Mode Control Register (PPGC1)                |     |
|          | 10.3.  |         | G0/1 Count Clock Select Register (PPG01)                  |     |
|          | 10.3.  |         | G Reload Registers (PRLL0/PRLH0, PRLL1/PRLH1)             |     |
|          | 10.3.  |         | ots of 8-/16-bit PPG Timer                                |     |
|          | 10.4   |         | ation of Operation of 8-/16-bit PPG Timer                 |     |
|          | 10.5   |         | t PPG Output 2-channel Independent Operation Mode         |     |
|          | 10.5.  |         | bit PPG Output 2-channel independent Operation Node       |     |
|          | 10.5.  |         | -bit PPG Output Operation Mode                            |     |
|          | 10.5.  |         | tions when Using 8-/16-bit PPG Timer                      |     |
|          | 10.0   | Fieldu  | 110113 WHEH USHIY U7/10-DILFFG TIIIEI                     | 510 |

DataSheet4U.com

| CHAPTER 11 DELAYED INTERRUPT GENERATION MODULE                                                                                         |     |
|----------------------------------------------------------------------------------------------------------------------------------------|-----|
| 11.1 Overview of Delayed Interrupt Generation Module                                                                                   |     |
| 11.2 Block Diagram of Delayed Interrupt Generation Module                                                                              |     |
| 11.3 Configuration of Delayed Interrupt Generation Module                                                                              |     |
| 11.3.1 Delayed Interrupt Request Generate/Cancel Register (DIRR)                                                                       |     |
| 11.4 Explanation of Operation of Delayed Interrupt Generation Module                                                                   |     |
| 11.5 Precautions when Using Delayed Interrupt Generation Module                                                                        | 325 |
| 11.6 Program Example of Delayed Interrupt Generation Module                                                                            | 326 |
| CHAPTER 12 DTP/EXTERNAL INTERRUPT                                                                                                      | 327 |
| 12.1 Overview of DTP/External Interrupt                                                                                                |     |
| 12.2 Block Diagram of DTP/External Interrupt                                                                                           |     |
| 12.3 Configuration of DTP/External Interrupt                                                                                           |     |
| 12.3.1 DTP/External Interrupt Factor Register (EIRR)                                                                                   |     |
| 12.3.2 DTP/External Interrupt Enable Register (ENIR)                                                                                   |     |
| 12.3.3 Detection Level Setting Register (ELVR) (High)                                                                                  |     |
| 12.3.4 Detection Level Setting Register (ELVR) (Low)                                                                                   |     |
| 12.4 Explanation of Operation of DTP/External Interrupt                                                                                |     |
| 12.4.1 External Interrupt Function                                                                                                     |     |
| 12.4.1 External memory Function                                                                                                        |     |
|                                                                                                                                        |     |
| <ul> <li>12.5 Precautions when Using DTP/External Interrupt</li> <li>12.6 Program Example of DTP/External Interrupt Circuit</li> </ul> |     |
| CHAPTER 13 8-/10-BIT A/D CONVERTER                                                                                                     | 347 |
| 13.1 Overview of 8-/10-bit A/D Converter                                                                                               |     |
| 13.2 Block Diagram of 8-/10-bit A/D Converter                                                                                          |     |
| 13.3 Configuration of 8-/10-bit A/D Converter                                                                                          |     |
| -                                                                                                                                      |     |
| <b>o ( o )</b> ( <b>)</b>                                                                                                              |     |
| 13.3.2 A/D Control Status Register (Low) (ADCS: L)                                                                                     |     |
| 13.3.3 A/D Data Register (High) (ADCR: H)                                                                                              |     |
| 13.3.4 A/D Data Register (Low) (ADCR: L)                                                                                               |     |
| 13.3.5 Analog Input Enable Register (ADER)                                                                                             |     |
| 13.4 Interrupt of 8-/10-bit A/D Converter                                                                                              |     |
| 13.5 Explanation of Operation of 8-/10-bit A/D Converter                                                                               |     |
| 13.5.1 Single Conversion Mode                                                                                                          |     |
| 13.5.2 Continuous Conversion Mode                                                                                                      |     |
| 13.5.3 Pause-conversion Mode                                                                                                           |     |
| 13.5.4 Conversion Using EI <sup>2</sup> OS Function                                                                                    |     |
| 13.5.5 A/D-converted Data Protection Function                                                                                          |     |
| 13.6 Precautions when Using 8-/10-bit A/D Converter                                                                                    | 375 |
| CHAPTER 14 UART1                                                                                                                       |     |
| 14.1 Overview of UART1                                                                                                                 |     |
|                                                                                                                                        |     |
| 14.Z BIOCK DIADRAM OF UAR LT                                                                                                           |     |
| 14.2 Block Diagram of UART1                                                                                                            | 283 |
| 14.2 Block Diagram of UART1<br>14.3 Configuration of UART1<br>14.3.1 Serial Control Register 1 (SCR1)                                  |     |

| 14.3.3 Serial Status Register 1 (SSR1)                                          |                     |
|---------------------------------------------------------------------------------|---------------------|
| 14.3.4 Serial Input Data Register 1 (SIDR1) and Serial Output Data Register     | 1 (SODR1) 391       |
| 14.3.5 Communication Prescaler Control Register 1 (CDCR1)                       |                     |
| 14.4 Interrupt of UART1                                                         |                     |
| 14.4.1 Generation of Receive Interrupt and Timing of Flag Set                   |                     |
| 14.4.2 Generation of Transmit Interrupt and Timing of Flag Set                  |                     |
| 14.5 Baud Rate of UART1                                                         | 400                 |
| 14.5.1 Baud Rate by Dedicated Baud Rate Generator                               | 402                 |
| 14.5.2 Baud Rate by Internal Timer (16-bit Reload Timer)                        | 405                 |
| 14.5.3 Baud Rate by External Clock                                              | 407                 |
| 14.6 Explanation of Operation of UART1                                          | 408                 |
| 14.6.1 Operation in Asynchronous Mode (Operation Mode 0 or 1)                   | 410                 |
| 14.6.2 Operation in Clock Synchronous Mode (Operation Mode 2)                   | 415                 |
| 14.6.3 Bidirectional Communication Function (Operation Modes 0 and 2)           | 418                 |
| 14.6.4 Master/Slave Type Communication Function (Multiprocessor Mode) .         | 420                 |
| 14.7 Precautions when Using UART1                                               | 423                 |
| 14.8 Program Example for UART1                                                  | 424                 |
| CHAPTER 15 CAN CONTROLLER                                                       |                     |
| 15.1 Overview of CAN Controller                                                 |                     |
| 15.2 Block Diagram of CAN Controller                                            |                     |
| et4U.com 15.3 Configuration of CAN Controller                                   | 100                 |
| 15.3.1 Control Status Register (High) (CSR: H)                                  | Dataone             |
| 15.3.2 Control Status Register (Low) (CSR <sup>1</sup> L <sup>Sheet4U.com</sup> |                     |
| 15.3.3 Last Event Indicate Register (LEIR)                                      |                     |
| 15.3.4 Receive/Transmit Error Counter (RTEC)                                    |                     |
| 15.3.5 Bit Timing Register (BTR)                                                |                     |
| 15.3.6 Message Buffer Valid Register (BVALR)                                    |                     |
| 15.3.7 IDE Register (IDER)                                                      |                     |
| 15.3.8 Transmission Request Register (TREQR)                                    |                     |
| 15.3.9 Transmission RTR Register (TRTRR)                                        |                     |
| 15.3.10 Remote Frame Receiving Wait Register (RFWTR)                            |                     |
| 15.3.11 Transmission Cancel Register (TCANR)                                    |                     |
| 15.3.12 Transmission Complete Register (TCR)                                    |                     |
| 15.3.13 Transmission Complete Interrupt Enable Register (TIER)                  |                     |
| 15.3.14 Reception Complete Register (RCR)                                       |                     |
| 15.3.15 Reception RTR Register (RRTRR)                                          |                     |
| 15.3.16 Reception Overrun Register (ROVRR)                                      |                     |
| 15.3.17 Reception Complete Interrupt Enable Register (RIER)                     |                     |
| 15.3.18 Acceptance Mask Select Register (AMSR)                                  |                     |
| 15.3.19 Acceptance Mask Register (AMR)                                          |                     |
| 15.3.20 Message Buffers                                                         |                     |
| -                                                                               |                     |
| 15.3.21 ID Register (IDRx, x = 7 to 0)<br>15.3.22 DLC Register (DLCR)           |                     |
| <b>-</b> . , ,                                                                  |                     |
| 15.3.23 Data Register (DTR)<br>15.4 Interrupts of CAN Controller                |                     |
|                                                                                 |                     |
| 15.5 Explanation of Operation of CAN Controller<br>DataSheet4U.com              | www.DataSheet4U.com |

х

|                | 15.5.1 Transmission                                                                             | 487             |           |
|----------------|-------------------------------------------------------------------------------------------------|-----------------|-----------|
|                | 15.5.2 Reception                                                                                |                 |           |
|                | 15.5.3 Procedures for Transmitting and Receiving                                                |                 |           |
|                | 15.5.4 Setting Multiple Message Receiving                                                       |                 |           |
|                | 15.6 Precautions when Using CAN Controller                                                      |                 |           |
|                | 15.7 Program Example of CAN Controller                                                          |                 |           |
| CH             | APTER 16 8/16 ADDRESS MATCH DETECTION FUNCTION                                                  | 507             |           |
|                | 16.1 Overview of Address Match Detection Function                                               |                 |           |
|                | 16.2 Block Diagram of Address Match Detection Function                                          |                 |           |
|                | 16.3 Configuration of Address Match Detection Function                                          |                 |           |
|                | 16.3.1 Address Detection Control Register (PACSR)                                               |                 |           |
|                | 16.3.2 Detect Address Setting Registers (PADR0 and PADR1)                                       |                 |           |
|                | 16.4 Explanation of Operation of Address Match Detection Function                               |                 |           |
|                | 16.4.1 Example of using Address Match Detection Function                                        |                 |           |
|                | 16.5 Program Example of Address Match Detection Function                                        |                 |           |
| CH             | APTER 17 ROM MIRRORING FUNCTION SELECT MODULE                                                   | 523             |           |
| _              | 17.1 Overview of ROM Mirroring Function Select Module                                           |                 |           |
|                | 17.2     ROM Mirroring Function Select Register (ROMM)                                          |                 |           |
| et4U.com       | IAPTER 18 512 KBIT FLASH MEMORY                                                                 | 507             | D. I. Cho |
| UI UI          |                                                                                                 |                 | DataShe   |
|                | <ul> <li>18.1 Overview of 512 Kbit Flash Memory</li></ul>                                       | 520             |           |
|                | 18.3       Flash Memory Control Status Register (FMCS)                                          |                 |           |
|                | 18.4       How to Start Automatic Algorithm of Flash Memory                                     |                 |           |
|                | 18.5 Check the Execution State of Automatic Algorithm                                           |                 |           |
|                | 18.5.1 Data Polling Flag (DQ7)                                                                  |                 |           |
|                | 18.5.2 Toggle Bit Flag (DQ6)                                                                    |                 |           |
|                | 18.5.3 Timing Limit Over Flag (DQ5)                                                             |                 |           |
|                | 18.5.4 Sector Erase Timer Flag (DQ3)                                                            |                 |           |
|                | 18.5.5 Toggle Bit 2 Flag (DQ2)                                                                  |                 |           |
|                | 18.6 Details of Programming/Erasing Flash Memory                                                |                 |           |
|                | 18.6.1 Read/Reset State in Flash Memory                                                         |                 |           |
|                | 18.6.2 Data Programming to Flash Memory                                                         |                 |           |
|                | 18.6.3 Data Erase from Flash Memory (Chip Erase)                                                |                 |           |
|                | 18.6.4 Erasing Any Data in Flash Memory (Sector Erasing)                                        |                 |           |
|                | 18.6.5 Sector Erase Suspension in Flash Memory                                                  |                 |           |
|                | 18.6.6 Sector Erase Resumption in Flash Memory                                                  |                 |           |
|                | 18.7 Program Example of 512 Kbit Flash Memory                                                   |                 |           |
|                |                                                                                                 |                 |           |
|                | IAPTER 19 FLASH SERIAL PROGRAMMING CONNECTION                                                   |                 |           |
|                | 19.1 Basic Configuration of Serial Programming Connection for F <sup>2</sup> MC-16LX MB90F387/S |                 |           |
|                | 19.2 Connection Example in Single-chip Mode (User Power Supply)                                 |                 |           |
|                | 19.3 Connection Example in Single-chip Mode (Writer Power Supply)                               |                 |           |
|                | 19.4 Example of Minimum Connection to Flash Microcontroller Programmer (User Power Supply)      |                 |           |
| DataSheet4U.co | 19.5 Example of Minimum Connection to Flash Microcontroller Programmer (Writer Power Supply)    | ) <b>56</b> 73h | eet4U.com |

| AF | PEND  | DIX                                     | 569 |
|----|-------|-----------------------------------------|-----|
|    |       | DIX A Instructions                      |     |
|    | A.1   | Instruction Types                       | 571 |
|    | A.2   | Addressing                              | 572 |
|    | A.3   | Direct Addressing                       | 574 |
|    | A.4   | Indirect Addressing                     | 580 |
|    | A.5   | Execution Cycle Count                   |     |
|    | A.6   | Effective Address Field                 | 590 |
|    | A.7   | How to Read the Instruction List        |     |
|    |       | F <sup>2</sup> MC-16LX Instruction List |     |
|    |       | Instruction Map                         |     |
|    | APPEN | DIX B Register Index                    | 631 |
|    |       | DIX C Pin Function Index                |     |
|    | APPEN | IDIX D Interrupt Vector Index           | 642 |
|    |       |                                         |     |

DataSheet4U.com

www.DataSheet4U.com

This chapter describes the features and basic specifications of the MB90385 series.

- 1.1 Features of MB90385 Series
- 1.2 Product Lineup for MB90385 Series
- 1.3 Block Diagram of MB90385 Series
- 1.4 Pin Assignment
- 1.5 Package Dimension
- 1.6 Pin Description
- 1.7 I/O Circuit

et4U.com

1

## 1.1 Features of MB90385 Series

The MB90385 series is a general-purpose, high-performance 16-bit microcontroller designed for control of processors such as consumer products requiring high-speed real-time processing. This series has a full CAN interface.

The instruction system is based on the architecture of the F<sup>2</sup>MC family and provides additional high-level language instructions, extended addressing modes, enhanced multiply/divide instructions, and enriched bit processing instructions. A 32-bit accumulator enables long-word data (32 bits) processing.

## Features of MB90385 Series

Clock

- Built-in PLL clock multiplying circuit
- Machine clock (PLL clock) selectable from 1/2 frequency of oscillation clock or 1 to 4-multiplied oscillation clock (4 MHz to 16 MHz when oscillation clock is 4 MHz)
- Subclock operation (8.192 kHz) (MB90387, MB90F387)
- Minimum instruction execution time: 62.5 ns (4-MHz oscillation clock, 4-multiplied PLL clock)

16-MB CPU memory space

• Internal 24-bit addressing

Instruction system optimized for controllers

- Various data types (bit, byte, word, long word)
- 23 types of addressing modes
- Enhanced signed instructions of multiplication/division and RETI instruction function
- High-accuracy operations enhanced by 32-bit accumulator
- Instruction system for high-level language (C language)/multitask
  - System stack pointer
  - Enhanced pointer indirect instructions
  - Barrel shift instructions
- Higher execution speed
  - 4-byte instruction queue
- Powerful interrupt function
  - Powerful interrupt function with 8 levels and 34 factors

DataSheet4U.com

et4U.com

- CPU-independent automatic data transfer function
  - Extended intelligent I/O service (EI<sup>2</sup>OS): Maximum 16 channels
- Lower-power consumption (standby) modes
  - Sleep mode (stops CPU clock)
  - Timebase timer mode (operates only oscillation clock and subclock, timebase timer and watch timer)
  - Watch mode (operates only subclock and watch timer)
  - Stop mode (stops oscillation clock and subclock)
  - CPU Intermittent operation mode
- Process
  - CMOS Technology
- I/O ports
  - General-purpose I/O ports (CMOS output): 34 ports (for M90387 or M90F387) (included 4 output ports for high current)

Note : 36 ports (for MB90387S or MB90F387S) on condition of unusing sub-clock.

#### Timers

et4U.com

DataShe

- Timebase timer, watch timer, watchdog timer: 1 channel
- 8/16-bit PPG timer: 8 bits  $\times$  4 channels or 16 bits  $\times$  2 channels
- 16-bit reload timer: 2 channels
- 16-bit I/O timer
  - 16-bit free-run timer: 1 channel
  - 16-bit input capture (ICU): 4 channels

By detecting the edge of the pin input, the count value of the 16-bit free-run timer is latched to generate an interrupt request.

#### CAN Controller: 1 channel

- Conforms to CAN Specification Ver. 2.0A and Ver. 2.0B.
- Built-in 8 message buffers
- Transfer rate: 10 Kbps to 1 Mbps (at 16-MHz machine clock frequency)
- CAN wake-up
- UART1 (SCI): 1 channel
  - Full-duplex double buffer
  - Clock asynchronous or clock synchronous serial transfer
- DTP/external interrupt: 4 channels
  - External input to start EI<sup>2</sup>OS and external interrupt generation module

- Delayed interrupt generation module
  - Generates interrupt request for task switching
- 8-/10-bit A/D converter: 8 channels
  - 8-bit and 10-bit resolutions
  - Start by external trigger input
  - Conversion time: 6.125µs (including sampling time at 16-MHz machine clock frequency)
- Program patch function
  - Detects address match for two address pointers

et4U.com

DataSheet4U.com

DataShe

4

## 1.2 Product Lineup for MB90385 Series

## The MB90385 series is available in three types. This section provides the product lineup, CPU, and resources.

## ■ Product Lineup for MB90385 Series

| Table 1.2-1 | Product | Lineup for | MB90385 | Series |
|-------------|---------|------------|---------|--------|
|-------------|---------|------------|---------|--------|

|                                          | -                                                       |                                                                          |                                                                       |
|------------------------------------------|---------------------------------------------------------|--------------------------------------------------------------------------|-----------------------------------------------------------------------|
|                                          | MB90V495G                                               | MB90F387/S                                                               | MB90387/S                                                             |
| Classification                           | Evaluation product                                      | Flash ROM                                                                | Mask ROM                                                              |
| ROM Size                                 |                                                         | 64                                                                       | KB                                                                    |
| RAM Size                                 | 6 KB                                                    | 21                                                                       | КВ                                                                    |
| Clock                                    | Dual system products                                    | MB90F387: dual system<br>products<br>MB90F387S: single system<br>product | MB90387: dual system<br>products<br>MB90387S:single system<br>product |
| Process                                  |                                                         | CMOS                                                                     |                                                                       |
| Package                                  | PGA256DataSheet4U.com LQFP-48 (with 0.50-mm pin pitch), |                                                                          | 50-mm pin pitch),                                                     |
| Operating supply voltage                 | 4.5 V to 5.5 V                                          | 3.5 V t                                                                  | o 5.5 V                                                               |
| Power supply for emulator * Not provided |                                                         | -                                                                        |                                                                       |

\*: Setting of DIP Switch (S2) when using emulation pod (MB2145-507). For details, refer to the MB2145-507 Hardware Manual (Section 2.7 Emulator-specific Power Supply).

et4U.com

## ■ CPU and Resources for MB90385 Series

## Table 1.2-2 CPU and Resources for MB90385 Series (1/2)

|                                             |               | MB90V495G                                                                                                                                                         | MB90F387/S                                                      | MB90387/S                             |
|---------------------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|---------------------------------------|
| CPU Function                                |               | Basic instruction count: 351<br>Instruction bit length: 8 or 1<br>Instruction length: 1 to 7 by<br>Data bit length: 1, 8, or 16 b                                 | 6 bits<br>tes                                                   |                                       |
|                                             |               | Minimum instruction execut                                                                                                                                        | tion time: 62.5 ns (at 16-MHz                                   | machine clock frequency)              |
|                                             |               | Interrupt processing time: 1.                                                                                                                                     | 5 µs (at 16-MHz machine clo                                     | ock frequency)                        |
| Low-power consu<br>(standby) modes          | mption        | Sleep mode, watch mode, tin<br>operation mode                                                                                                                     | mebase timer mode, stop mod                                     | le, CPU intermittent                  |
| I/O Ports                                   |               | General-purpose I/O ports (                                                                                                                                       | CMOS output):34 ports (36 p<br>included 4 outj<br>(P14 to P17)  | orts *)<br>put ports for high current |
| Timebase timer                              |               | 18-bit free-run counter<br>Interrupt cycle: 1.024, 4.096<br>(at 4-MHz oscillation clock                                                                           |                                                                 |                                       |
| Watchdog timer                              |               | Reset cycle: 3.58, 14.33, 57.23, 458.75 ms<br>(at 4-MHz oscillation clock frequency)                                                                              |                                                                 |                                       |
| 16-bit I/O timers 16-bit free-<br>run timer |               | Channel count: 1<br>Overflow interrupt                                                                                                                            |                                                                 |                                       |
|                                             | Input capture | Channel count: 4<br>Free-run timer values saved by pin input (rising edge, falling edge, both edges)                                                              |                                                                 |                                       |
| 16-bit reload timer                         |               | Channel count: 2<br>Operation of 16-bit reload ti<br>Count clock cycle: 0.25µs, 0<br>(at 16-MHz machine clock f<br>External event countable                       | ).5μs, 2.0μs                                                    |                                       |
| Watch timer                                 |               | 15-bit free-run counter<br>Interrupt cycle: 31.25, 62.5,<br>frequency)                                                                                            | 12, 250, 500 ms, and 1.0 s, 2.                                  | .0 s (at 8.192-kHz subclock           |
| 8-/16-bit PPG timer                         |               | Channel count: 2 (operable<br>PPG operable with 8 bits x <sup>4</sup><br>Pulse waveform output at ar<br>Count clock: 62.5 ns to 1µs<br>(at 16-MHz machine clock f | t channels or 16 bits x 1 chan<br>bitrary cycle and duty        | nel                                   |
| Delayed interrupt generation module         |               | Interrupt generation module for switching task<br>Used for Real-time OS                                                                                           |                                                                 |                                       |
| DTP/external interrupt                      |               | • • •                                                                                                                                                             | es and by High- or Low-level<br>led intelligent I/O service (EI |                                       |

DataSheet4U.com

et4U.com

## Table 1.2-2 CPU and Resources for MB90385 Series (2/2)

|                         | MB90V495G                                                                                                                                                                                                                                                                                                                                                                                                                                                | MB90F387/S | MB90387/S |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----------|
| 8-/10-bit A/D converter | Channel count: 8<br>Resolution: 10 or 8 bits<br>Conversion time: 6.125µs (including sampling time at 16-MHz machine clock<br>frequency)<br>Two or more continuous channels can be converted sequentially (up to 8 channels)<br>Single conversion mode: Selected channel converted once only<br>Continuous conversion mode: Selected channel converted continuously<br>Stop conversion mode: Selected channel converted and temporary stopped alternately |            |           |
| UART 1                  | Channel count: 1<br>Clock synchronous transfer: 62.5 Kbps to 2 Mbps<br>Clock asynchronous transfer: 9,615 bps to 500 kbps<br>Two-way serial communication function, master/slave-connected communication                                                                                                                                                                                                                                                 |            |           |
| CAN                     | Conforms to CAN Specification Ver. 2.0A and Ver. 2.0B<br>Transmit/receive message buffer: 8<br>Transfer bit rate: 10 Kbps to 1 Mbps (at 16-MHz machine clock)<br>CAN wake-up                                                                                                                                                                                                                                                                             |            | e clock)  |

\*: MB90387S, MB90F387S

et4U.com

DataSheet4U.com

## 1.3 Block Diagram of MB90385 Series

Block diagram of the MB90385 series is shown in the figure below.

## Block Diagram of MB90385 Series





DataSheet4U.com

## 1.4 Pin Assignment

Pin assignment of the MB90385 series is shown in the figure below.

## ■ Pin Assignment (FPT-48P-M26)



DataSheet4U.com

et4U.com

#### **Package Dimension** 1.5

The MB90385 series is available in one type of package.

The package dimensions below are for reference only. Contact Fujitsu for the nominal package dimensions.

## Package Dimension of FPT-48P-M26



## **1.6 Pin Description**

This section describes the I/O pins and their functions of the MB90385 series.

## Pin Description

## Table 1.6-1 Pin Description (1/3)

| Pin Name Type Functi<br>AV <sub>CC</sub> V <sub>CC</sub> power input pin for A/D co<br>Power (Vref+) input pin for A/D |                               |
|------------------------------------------------------------------------------------------------------------------------|-------------------------------|
| Power (Vref⊥) input pin for ∆/                                                                                         | nverter                       |
| Power (Vref+) input pin for A/D                                                                                        |                               |
| AVR                                                                                                                    | converter. The power<br>eding |
| P50 to P57 General-purpose I/O port                                                                                    |                               |
| 10     E     Analog input pin for A/D convert the analog input is set to "enable"                                      |                               |
| P37 General-purpose I/O port.                                                                                          | Data                          |
| ADTG DataShe External trigger input pin for A/I be set to "input port".                                                | D converter. This pin should  |
| P20 General-purpose I/O port.                                                                                          |                               |
| D Event input pin for reload timer "input port."                                                                       | 0. This pin should be set to  |
| P21 General-purpose I/O port.                                                                                          |                               |
| TOT0 D Event output pin for reload times when the output setting is "enabled"                                          |                               |
| P22 General-purpose I/O port.                                                                                          |                               |
| TIN1 D Event input pin for reload timer "input port."                                                                  | 1. This pin should be set to  |
| P23 General-purpose I/O port.                                                                                          |                               |
| TOT1 D Event output pin for reload times when the output setting is "enable                                            |                               |
| P24 to P27 General-purpose I/O port.                                                                                   |                               |
| D External interrupt input pins. Th "input port."                                                                      | ese pins should be set to     |
| MD2 F Input pin for selecting operation                                                                                | mode                          |
| MD1 C Input pin for selecting operation                                                                                | mode                          |
| 2 MD0 C Input pin for selecting operation                                                                              | mode www.DataSheet4U.         |

et4U.com

DataSheet4U.com

| Pin No.  | Pin Name Circuit |         | Function                                                                                                                       |
|----------|------------------|---------|--------------------------------------------------------------------------------------------------------------------------------|
| M26      | FIIINAINE        | Туре    | Function                                                                                                                       |
| 23       | RST              | В       | Input pin for external reset                                                                                                   |
| 24       | V <sub>CC</sub>  |         | Power (5 V) input pin.                                                                                                         |
| 25       | V <sub>SS</sub>  |         | Power (0 V) input pin                                                                                                          |
| 26       | С                |         | Capacity pin for stabilizing power supply. This pin should be connected to a ceramic capacitor of approx. 0.1µF.               |
| 27       | X0               | А       | High-speed oscillation pin                                                                                                     |
| 28       | X1               | А       | High-speed oscillation pin                                                                                                     |
|          | P10 to P13       | D       | General-purpose I/O ports.                                                                                                     |
| 29 to 32 | IN0 to IN3       |         | Trigger input pins for input capture channels 0 to 3. These pins should be set to "input port".                                |
|          | P14 to P17       | G       | General-purpose I/O ports. High current output port.                                                                           |
| 33 to 36 | PPG0 to PPG3     |         | Output pins for PPG timers 01 and 23. These pins are enabled when the output setting is "enabled."                             |
| 37       | P40              | DataShe | General-purpose I/O port                                                                                                       |
|          | SIN1             |         | Serial data input pin for UART1. This pin should be set to "input port."                                                       |
|          | P41              | D       | General-purpose I/O port.                                                                                                      |
| 38       | SCK1             |         | Serial clock I/O pin for UART1. This pin is enabled only<br>when the serial clock I/O setting of the UART1 is "enabled."       |
|          | P42              | D       | General-purpose I/O port.                                                                                                      |
| 39       | SOT1             |         | Serial data output pin for UART1. This pin functions only<br>when the serial data output setting of the UART1 is<br>"enabled". |
|          | P43              | D       | General-purpose I/O port.                                                                                                      |
| 40       | ТХ               |         | CAN transmission output pin. This pin is enabled only when<br>the output setting is "enabled".                                 |
| 41       | P44              | D       | General-purpose I/O port.                                                                                                      |
|          | RX               |         | CAN reception input pin. This pin should be set to "input port."                                                               |
| 42 to 45 | P30 to P33       | D       | General-purpose I/O port.                                                                                                      |
| 46       | X0A*             | А       | Low-speed oscillation pin.                                                                                                     |
|          | P35*             | D       | General-purpose I/O port.                                                                                                      |

## Table 1.6-1 Pin Description (2/3)

et4U.com

DataSheet4U.com

www.DataSheet4U.com

#### Table 1.6-1 Pin Description (3/3)

| Pin No. | - Pin Name       | Circuit<br>Type | Function                                          |
|---------|------------------|-----------------|---------------------------------------------------|
| M26     |                  |                 |                                                   |
| 47      | X1A*             | А               | Low-speed oscillation pin.                        |
|         | P36*             | D               | General-purpose I/O port.                         |
| 48      | AV <sub>SS</sub> |                 | V <sub>SS</sub> power input pin for A/D converter |

\*: MB90387, MB90F387 : X1A, X0A MB90387S, MB90F387S : P36, P35

et4U.com

DataShe

DataSheet4U.com

## 1.7 I/O Circuit

## I/O circuit of the MB90385 series is shown in the figure below.

## ■ I/O Circuit

## Table 1.7-1 I/O Circuit (1/2)



DataSheet4U.com



### Table 1.7-1 I/O Circuit (2/2)

et4U.com

DataSheet4U.com

DataSheet4U.com

et4U.com

DataSheet4U.com

DataSheet4U.com

DataSheet4U.com

DataShe

# CHAPTER 2 HANDLING DEVICES

This chapter describes the precautions when handling general-purpose one chip microcontroller.

2.1 Precautions when Handling Devices

et4U.com

DataSheet4U.com

DataSheet4U.com

## 2.1 Precautions when Handling Devices

## This section describes the precautions against the power supply voltage of the device and processing of pin.

## Precautions when Handling Devices

- Voltage not exceeding maximum ratings (preventing latch-up)
  - For a CMOS IC, latch-up may occur when a voltage higher than V<sub>CC</sub> or a voltage lower than V<sub>SS</sub> is impressed to the I/O pin other than medium-/high-voltage withstand I/O pins, or when a voltage that exceeds the rated voltage is impressed between V<sub>CC</sub> and V<sub>SS</sub>.
  - Latch-up may cause a sudden increase in power supply current, resulting in thermal damage to the device. Therefore, the maximum voltage ratings must not be exceeded.
  - When turning the analog power supply on and off, the analog power supply voltage (AV<sub>CC</sub> and AVR) and the analog input voltage should not exceed the digital power supply voltage (V<sub>CC</sub>).
- Handling not-used pins
  - If unused input pins remain open, a malfunction or latch-up may cause permanent damage, so take countermeasures such as pull-up or pull-down using a 2 k $\Omega$  or larger resistor.

DataShe

www.DataSheet4U.com

Leave unused input pins open in the output state or, if left in the input state, treat them in the same manner as for input pins in use.

Precautions of using external clock

When an external clock is used, drive only the X0 pin and open the X1 pin. Figure 2.1-1 shows an use example of external clock.



#### Figure 2.1-1 Example of Using External Clock

#### Precautions of non-use of subclock

If an oscillator is not connected to the X0A and X1A pins, connect the X0A pin to Pull-down and leave the X1A pin open.

DataSheet4U.com

et4U.com

18

Precautions during operation of PLL clock mode

If the PLL clock mode is selected, the microcontroller attempt to be working with the self-oscillating circuit even when there is no external oscillator or external clock input is stopped. Performance of this operation, however, cannot be guaranteed.

- Power pins
  - When plural  $V_{CC}$  pins and  $V_{SS}$  pins are provided, pins designed to be at the same electric potential are internally connected to the device to prevent malfunctions such as latch-up. However, always connect all same electric potential pins to power supply and ground outside the device to prevent decrease of unnecessary radiation, the malfunction of the strobe signal due to a rise of ground level, and follow the standards of total output current.
  - The power pins should be connected to V<sub>CC</sub> and V<sub>SS</sub> of the MB90385 series device at the lowest possible impedance from the current supply source.
  - It is best to connect approximately 0.1µF capacitor between V<sub>CC</sub> and V<sub>SS</sub> as a bypass capacitor near the pins of the MB90385 series device.
- Crystal oscillator circuit
  - Noise near the X0 and X1 pins may cause the MB90385 series to malfunction. Design the PC board so that the X0 and X1 pins, the crystal (or ceramic) oscillator, and the bypass capacitor to ground are as close as possible to each other, and so the wiring of the X0 and X1 pins and other wiring do not cross.
  - For stable operation, the PC board is recommended to have the artwork with the X0 and X1 pins enclosed by a ground line.

DataShe

- Procedure of A/D converter/analog input power-on
  - Always apply a power to the A/D converter power and the analog input (AN0 to AN7 pins) after or concurrently with the digital power (V<sub>CC</sub>)-on.
  - Always turn off the A/D converter power and the analog input before or concurrently with the digital power-down.
  - Note that AVR should not exceed AV<sub>CC</sub> at turn on or off. (The analog power and digital power can be simultaneously turned on or off with no problem.)
- Handling pins when not using A/D converter

When not using the A/D converter, the pins should be connected so that  $AV_{CC} = AVR = V_{CC}$  and  $AV_{SS} = V_{SS}$ .

Precautions at power on

To prevent a malfunction of the internal step-down circuit, the voltage rise time at power-on should be  $50 \ \mu s$  or more (between 0.2 V and 2.7 V).

DataSheet4U.com

et4U.com

#### CHAPTER 2 HANDLING DEVICES

#### Stabilization of supply voltage

If the power supply voltage varies acutely even within the operation assurance range of the  $V_{CC}$  power supply voltage, a malfunction may occur. The  $V_{CC}$  power supply voltage must therefore be stabilized.

As stabilization guidelines, stabilize the power supply voltage so that  $V_{CC}$  ripple fluctuations (peak to peak value) in the commercial frequencies (50 Hz to 60 Hz) fall within 10% of the standard  $V_{CC}$  power supply voltage and the transient fluctuation rate becomes 0.1V/ms or less in instantaneous fluctuation for power supply switching.

et4U.com

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

This chapter explains the CPU function of the MB90385 series.

- 3.1 Memory Space
- 3.2 Dedicated Registers
- 3.3 General-purpose Register
- 3.4 Prefix Codes
- 3.5 Interrupt DataSheet4U.com
- 3.6 Reset
- 3.7 Clocks
- 3.8 Low-power Consumption Mode
- 3.9 CPU Mode

et4U.com

DataSheet4U.com

www.DataSheet4U.com

## 3.1 Memory Space

The memory space of the F<sup>2</sup>MC-16LX is 16 MB and is allocated to I/O, programs, and data. Part of the memory space is used for specific uses such as the expansion intelligent I/O service (El<sup>2</sup>OS) descriptors, the general-purpose registers, and the vector tables.

#### Memory Space

I/O, programs and data are all allocated somewhere in the 16-MB memory space of the  $F^2MC-16LX$  CPU. The CPU can indicate their addresses in the 24-bit address bus to access each resource.

Figure 3.1-1 shows an example of the relationships between the  $F^2MC-16LX$  and the memory map.



Figure 3.1-1 Example of Relationships between F<sup>2</sup>MC-16LX System and Memory Map

#### ROM Area

- Vector table area (address: "FFFC00<sub>H</sub>" to "FFFFF<sub>H</sub>")
  - The vector table is provided for reset and interrupts.
  - This area is allocated at the top of the ROM area. The starting address of the corresponding processing routine is set to the address of each vector table as data.
- Program area (address: to "FFFBFF<sub>H</sub>")
  - ROM is contained as the internal program area.
  - The capacity of the internal ROM depends on the product.

#### RAM Area

- Data area (address: "000100<sub>H</sub>" to "000900<sub>H</sub>")
  - Static RAM is contained as the internal data area.
  - The capacity of the internal RAM depends on the product.
- General-purpose register area (address: "000180<sub>H</sub>" to "00037F<sub>H</sub>")
  - Auxiliary registers for operations or transfer of the 8-bit, 16-bit, or 32-bit data are allocated in this area.
  - This area is allocated to part of the RAM area, and can also be used as ordinary RAM.
  - When this area is used as general-purpose registers, they can be accessed quickly using a short instruction through general-purpose register addressing.
- Expanded intelligent I/O service (El<sup>2</sup>OS) descriptor area (address: "000100<sub>H</sub>" to "00017F<sub>H</sub>")
  - This area holds the transfer mode, I/O address, transfer count, and buffer address.
  - This area is allocated to part of the RAM area, and can also be used as ordinary RAM.

#### I/O Area

et4U.com

Interrupt control register area (address: "0000B0<sub>H</sub>" to "0000BF<sub>H</sub>")

The interrupt control registers (ICR00 to ICR15) correspond to all resources with an interrupt function, and control the setting of interrupt level and EI<sup>2</sup>OS.

Resource control register area (address: "000020<sub>H</sub>" to "0000AF<sub>H</sub>")

This area controls the resource function and data I/O.

I/O port control register area (address: "000000<sub>H</sub>" to "00001F<sub>H</sub>")

This area controls the I/O ports and data I/O.

#### Extended I/O Area

Peripheral function control register area (address: 003900<sub>H</sub> to 003FFF<sub>H</sub>)

The registers control peripheral functions and input/output data.

DataSheet4U.com

## 3.1.1 Mapping of and Access to Memory Space

#### In the MB90385 series, the single-chip mode can be set as memory access modes.

#### Memory Map for MB90385 Series

In the MB90385 series, the internal address bus is output up to a width of 24 bits and the external address bus is output up to a width of 24 bits; the external access memory can access up to the 16-MB memory space.

Figure 3.1-2 shows the memory map when the ROM mirroring function is enabled and disabled.



#### Figure 3.1-2 Memory Map for MB90385 Series

et4U.com

DataShe

DataSheet4U.com

| Image A    | ccess to Internal ROM                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | In the F <sup>2</sup> MC-16LX family, with the internal ROM in operation, ROM data in the FF bank can be seen as an image in the top 00 bank. This function is called ROM mirroring and enables effective use of a small C compiler.                                                                                                                                                                                                                                                  |
|            | In the $F^2MC-16LX$ family, the lower 16-bit addresses of the FF bank are the same as the lower 16-bit addresses of the 00 bank, so the table in ROM can be referenced without specifying "far" with a pointer.                                                                                                                                                                                                                                                                       |
|            | For example, if $"00C000_{\text{H}}"$ is accessed, data in ROM at "FFC000 <sub>H</sub> " is actually accessed. However, the ROM area in the FF bank exceeds 48 KB and all areas cannot be seen as images in the 00 bank. Therefore, ROM data from "FF4000 <sub>H</sub> " to "FFFFFF <sub>H</sub> " is see as an image from "004000 <sub>H</sub> " to "00FFFF <sub>H</sub> " so the ROM data table should be stored in the area from "FF4000 <sub>H</sub> " to "FFFFFF <sub>H</sub> ". |
| Reference: | To disable the ROM mirroring function (ROMM: $MI = 0$ ), see Section "17.1 Overview of ROM Mirroring Function Select Module".                                                                                                                                                                                                                                                                                                                                                         |

et4U.com

DataSheet4U.com

## 3.1.2 Memory Map

#### The MB90385 series memory map is shown for each product.

#### Memory Map

Figure 3.1-3 shows the memory map for the MB90385 series.



Figure 3.1-3 Memory Map for MB90385 Series

## 3.1.3 Addressing

Linear and bank types are available for addressing.

The F<sup>2</sup>MC-16LX family uses basically bank addressing.

- Linear type: direct-addressing all 24 bits by instruction
- Bank type: addressing higher 8 bits by bank registers suitable for the use, and lower 16 bits by instruction

#### Linear Addressing and Bank Addressing

The linear addressing is to access the 16-MB memory space by direct-addressing. The bank addressing is to access the 16-MB memory space which divided into 256 banks of 64KB, by specifying banks and addresses in banks.

Figure 3.1-4 shows overview of memory management in linear and bank type.



#### Figure 3.1-4 Memory Management in Linear and Bank Types

DataSheet4U.com

www.DataSheet4U.com

## 3.1.4 Linear Addressing

The linear addressing has the following two types:

- Direct-addressing 24 bits by instruction
- Using lower 24 bits of 32-bit general-purpose register for address

#### Linear Addressing by Specifying 24-bit Operand





#### Addressing by Indirect-specifying 32-bit Register

DataShe

#### Figure 3.1-6 Example of indirect-specifying 32-bit General-purpose Register in Linear Type



## 3.1.5 Bank Addressing

The bank addressing is a type of addressing each of 256 banks of 64-KB into which the 16-MB memory space is divided, using the bank register, and the lower 16 bits by an instruction.

Bank register has the following five types depending on the use.

- Program bank register (PCB)
- Data bank register (DTB)
- User stack bank register (USB)
- System stack bank register (SSB)
- Additional bank register (ADB)

#### Bank Registers and Access Space

Table 3.1-1 shows the access space for each bank register and the major use of it.

|                                                  |                          |                                                                                                                                                                    | -                 | _        |
|--------------------------------------------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|----------|
| Bank Register Name                               | Access Space             | Major Use                                                                                                                                                          | Reset Value       |          |
| Program bank register<br>(PCB)                   | Program (PC)<br>space    | Stores instruction code, vector tables, immediate data.                                                                                                            | FF <sub>H</sub>   | DataShee |
| Data bank register<br>(DTB)                      | Data (DT)<br>space       | Stores data that can be read/written<br>and can access resource control<br>registers and data registers.                                                           | 00 <sub>H</sub>   |          |
| User stack bank<br>register (USB)                |                          | These are used for the stack<br>accessing such as the PUSH/POP                                                                                                     | $00_{ m H}$       |          |
| System stack bank<br>register (SSB) <sup>*</sup> | Stack (SP)<br>space      | instruction and the register saving at<br>an interrupt. When the stack flag<br>(CCR: S) is 1, SSB is used. When<br>the stack flag is 0, USB is used <sup>*</sup> . | 00 <sub>H</sub>   |          |
| Additional bank<br>register (ADB)                | Additional<br>(AD) space | Stores data that cannot be stored in data (DT) space.                                                                                                              | $00_{\mathrm{H}}$ |          |

\*: SSB is always used for the stack at an interrupt.

Figure 3.1-7 shows the relationships between the memory space divided into banks and each register.



Figure 3.1-7 Example of Bank Addressing

Reference: For details, see Section "3.2 Dedicated Registers".

### Bank Addressing and Default Space

To improve the instruction code efficiency, the default space shown in Table 3.1-2 is determined for each instruction in each addressing type. To use any bank space other than the default space, specify the prefix code for that bank space before the instruction, which makes the arbitrary bank space corresponding to the prefix code accessible.

Table 3.1-2 Addressing and Default Spaces

| Default Spaces   | Addressing                                                                       |
|------------------|----------------------------------------------------------------------------------|
| Program space    | PC indirect addressing, program-access addressing, branch instruction addressing |
| Data space       | Addressing with @RW0, @RW1, @RW4, @RW5, @A, addr16, and dir                      |
| Stack space      | Addressing with PUSHW, POPW, @RW3, and @RW7                                      |
| Additional space | Addressing with @RW2 and @RW6                                                    |

#### Reference: For details of the prefix codes, see Section "3.4 Prefix Codes".

DataSheet4U.com

## 3.1.6 Allocation of Multi-byte Data on Memory

Multi-byte data is written to memory in sequence starting from the low address. For 32bit length data, the lower 16 bits are written first, and then the higher 16 bits are written. If a reset signal is output immediately after the lower 16 bits is written, the higher 16 bit may not be written.

#### Store of Multi-byte Data in RAM

Figure 3.1-8 shows the order in which multi-byte data is stored. Lower 8 bits are allocated to n address, and in order of n+1, n+2, n+3 and so on.





#### Storage of Multi-byte Length Operand

Figure 3.1-9 shows the configuration of a multi-byte length operand in memory.





DataSheet4U.com

et4U.com

www.DataSheet4U.com

#### ■ Storage of Multi-byte Data in Stack

Figure 3.1-10 shows the order in which multi-byte data is stored in the stack.



#### Figure 3.1-10 Storage of Multi-byte Data in Stack

#### Access to Multi-byte Data

All accesses are basically made inside the bank. Consequently, for an instruction that accesses multi-byte data, the address after the "FFFF<sub>H</sub>" address is the "0000<sub>H</sub>" address of the same bank.

Figure 3.1-11 shows an example of access instruction for multi-byte data on the bank boundary.

Figure 3.1-11 Access to Multi-byte Data on Bank Boundary



DataSheet4U.com

et4U.com

### 3.2 Dedicated Registers

The CPU has the following dedicated registers.

- Accumulator
- User stack pointer
- System stack pointer
- Processor status
- Program counter
- Direct page register
- Bank registers (program bank register, data bank register, user stack bank register, system stack bank register, additional data bank register)

#### Configuration of Dedicated Registers

#### Figure 3.2-1 Configuration of Dedicated Registers

| AH       | AL :    | Accumulator (A)<br>The accumulator is two 16-bit registers, and is used to store operation results.<br>It can also be used as one 32-bit register. |         |
|----------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------|---------|
|          | USP :   | User stack pointer (USP)<br>This is a 16-bit pointer that indicates the user stack address.                                                        | DataShe |
|          | SSP :   | System stack pointer (SSP)<br>This is a 16-bit pointer that indicates the system stack address.                                                    |         |
|          | PS :    | Processor status (PS)<br>This is a 16-bit register that indicates the system status.                                                               |         |
|          | PC :    | Program counter (PC)<br>This is a 16-bit register that indicates the current instruction store location.                                           |         |
|          | DPR :   | Direct page register (DPR)<br>This is an 8-bit register that sets bits 8 to 15 of 24 bits of addresses when using abbreviated direct addressing.   |         |
|          | PCB :   | Program bank register (PCB)<br>This is an 8-bit register that indicates the program space.                                                         |         |
|          | DTB :   | Data bank register (DTB)<br>This is an 8-bit register that indicates the data space.                                                               |         |
|          | USB :   | User stack bank register (USB)<br>This is an 8-bit register that indicates the user stack space.                                                   |         |
|          | SSB :   | System stack bank register (SSB)<br>This is an 8-bit register that indicates the system stack space.                                               |         |
|          | ADB :   | Additional data bank register (ADB)<br>This is an 8-bit register that indicates the additional space.                                              |         |
|          | 8 bits  |                                                                                                                                                    |         |
| <b> </b> | 16 bits |                                                                                                                                                    |         |
| 32       | bits '  |                                                                                                                                                    |         |

et4U.com

DataSheet4U.com

www.DataSheet4U.com

| Dedicated Register                  | Reset Value                                                                                               |
|-------------------------------------|-----------------------------------------------------------------------------------------------------------|
| Accumulator (A)                     | Undefined                                                                                                 |
| User stack pointer (USP)            | Undefined                                                                                                 |
| System stack pointer (SSP)          | Undefined                                                                                                 |
| Processor status (PS)               | bit15 to bit13 bit12       to       bit8 bit7       to       bit0         PS       ILM       RP       CCR |
| Program counter (PC)                | Value of reset vector (data at "FFFFDC <sub>H</sub> " and "FFFFDD <sub>H</sub> ")                         |
| Direct page register (DPR)          | 01 <sub>H</sub>                                                                                           |
| Program bank register (PCB)         | Value of reset vector (data at "FFFFDE <sub>H</sub> ")                                                    |
| Data bank register (DTB)            | 00 <sub>H</sub>                                                                                           |
| User stack bank register (USB)      | 00 <sub>H</sub>                                                                                           |
| System stack bank register (SSB)    | DataSheet4U.com 00 <sub>H</sub>                                                                           |
| Additional data bank register (ADB) | 00 <sub>H</sub>                                                                                           |

#### Table 3.2-1 Reset Values of Dedicated Registers

Note: The above reset values are the reset values for the device. The reset values for the ICE (such as emulator) are different from those of the device.

et4U.com

## 3.2.1 Dedicated Registers and General-purpose Register

## The F<sup>2</sup>MC-16LX family has two types of registers: dedicated registers in the CPU and general-purpose register in the internal RAM.

#### Dedicated Registers and General-purpose Register

The dedicated registers are limited to the use in the hardware architecture of the CPU.

The general-purpose registers are in the internal RAM in the CPU address space. As with the dedicated registers, these registers can be used for addressing and the use of these register is not limited.

Figure 3.2-2 shows the allocation of the dedicated registers and the general-purpose registers.



#### Figure 3.2-2 Dedicated Registers and General-purpose Register

et4U.com

www.DataSheet4U.com

## 3.2.2 Accumulator (A)

An accumulator (A) consists of two 16-bit length operation registers (AH and AL) used for temporary storage of the operation result or data.

Accumulator can be used as a 32-, 16-, or 8-bit register. Various operations can be performed between the register and memory or the other register, or between the AH register and the AL register.

#### ■ Accumulator (A)

Data transfer to accumulator

The accumulator can process 32-bit data (long word), 16-bit data (word), and 8-bit data (byte).

- When processing 32-bit data, the AH register and the AL register are concatenated and used.
- When processing 16- or 8-bit data, only the AL register is used.

#### **Data retention function**

When data of word length or less is transferred to the AL register, data stored in the AL register is transferred automatically to the AH register.

et4U.com

#### Code-extended function and zero-extended function

When transferring data of byte length or less to the AL register, the data is code-extended (MOVX instruction) or zero-extended (MOVX instruction) to be the 16-bit length and stored in the AL register. Data in the AL register can also be treated in word and byte lengths.

Figure 3.2-3 shows data transfer to the accumulator and a concrete example.



#### Figure 3.2-3 Data Transfer to Accumulator

DataSheet4U.com

36

#### Byte processing arithmetic operation of accumulator

When the arithmetic operation instruction for byte processing is executed for the AL register, the higher 8 bits of the AL register in pre-operation are ignored, and the higher 8 bits of the operation result become all 0.

#### Reset value of accumulator

The reset value is undefined.

#### Figure 3.2-4 Example of 8-bit Data Transfer to Accumulator (A) (Data Saving)



et4U.com

DataShe

#### Figure 3.2-5 Example of 8-bit Data Transfer to Accumulator (A) (Data Saving, Zero-extended)



www.DataSheet4U.com









DataShe

## 3.2.3 Stack Pointer (USP, SSP)

The stack pointers include a user stack pointer (USP) and a system stack pointer (SSP). Both these pointers indicate the address where saved data and return data are stored when the PUSH instruction, the POP instruction, and the subroutine is executed.

- The higher 8 bits of the stack address are set by the user stack bank register (USB) or the system stack bank register (SSB).
- When the stack flag (PS: CCR: S) is 0, the USP and USB register are enabled. When the stack flag is 1, the SSP and SSB register are enabled.

#### Stack Selection

For the  $F^2MC-16LX$  family, two types of stack pointer can be used: system stack, and user stack.

The addresses of the stack pointers are set by the stack flag of the condition code register (CCR: S) as shown in Table 3.2-2.

| S Flag | Stack A                              | Address                    |        |
|--------|--------------------------------------|----------------------------|--------|
| S Flag | Higher 8 Bits                        | Lower 16 Bits              | DataSh |
| 0      | User stack bank register (USB)4U.com | User stack pointer (USP)   |        |
| 1*     | System stack bank register (SSB)     | System stack pointer (SSP) |        |

\*: Reset value

Since the stack flag (CCR: S) is set to 1 by a reset, the system stack pointer is used after reset.

Ordinarily, the system stack pointer is used in processing the stack at the interrupt routine, and the user stack pointer is used in processing the stack other than interrupt routine. When it is not necessary to divide the stack space, use only the system stack pointer.

Note: When an interrupt is accepted, the stack flag (CCR: S) is set and the system stack pointer is always used.

Figure 3.2-8 shows an example of the stack operation using the system stack.





Notes:

et4U.com

• Use even addresses for setting value to the stack pointer. Setting an odd address divides the word access into two accesses, decreasing the efficiency.

• The reset values of the USP and SSP registers are undefined.

#### System Stack Pointer (SSP)

When using the system stack pointer (SSP), the stack flag (CCR: S) is set to 1. The higher 8 bits of the address used in processing the stack are set by the system stack bank register (SSB).

#### User Stack Pointer (USP)

When using the user stack pointer (USP), the stack flag (CCR: S) is set to 0. The higher 8 bits of the address used in processing the stack are set by the user stack bank register (USB).

DataSheet4U.com

#### Stack Area

#### Securing stack area

The stack area is used to save and return the program counter (PC) at execution of the interrupt processing, subroutine call instruction (CALL) and vector call instruction (CALLV). It is also used to save and return temporary registers using the PUSHW and POPW instructions.

The stack area is secured with the data area in RAM.

The stack area is as shown below:





As a general rule, even addresses should be set in the stack pointers (SSP and USP).

The system stack area, user stack area, and data area should not overlap. ٠

#### System stack area and user stack area

The system stack area is used for interrupt processing. When an interrupt occurs, even if the user stack area is used, it is switched forcibly to the system stack area. Therefore, in systems mainly using the user stack area also, the system stack area must be set correctly.

In particular, only the system stack area should be used unless it is necessary to divide the stack space.

## 3.2.4 Processor Status (PS)

## The processor status (PS) consists of the bits controlling CPU and various bits indicating the CPU status. The PS consists of the following three registers.

- Interrupt level mask register (ILM)
- Register bank pointer (RP)
- Condition code register (CCR)

#### Configuration of Processor Status (PS)

The processor status (PS) consists of bits controlling CPU and various bits indicating the CPU status.

Figure 3.2-10 shows the configuration of the processor status (PS).

|   |                       |        | ILM  |      |    |    | RP |    |    |   |   |   | СС | CR |   |   |       |
|---|-----------------------|--------|------|------|----|----|----|----|----|---|---|---|----|----|---|---|-------|
|   |                       | bit 15 | 5 14 | 13   | 12 | 11 | 10 | 9  | 8  | 7 | 6 | 5 | 4  | 3  | 2 | 1 | bit 0 |
|   | PS                    | ILM2   | ILM1 | ILM0 | B4 | B3 | B2 | B1 | B0 |   | I | S | Т  | N  | Z | V | С     |
| R | leset value           | 0      | 0    | 0    | 0  | 0  | 0  | 0  | 0  | — | 0 | 1 | Х  | Х  | Х | Х | Х     |
|   | — : Unus<br>( : Undet |        |      |      |    |    |    |    |    |   |   |   |    |    |   |   |       |

#### Figure 3.2-10 Processor Status (PS)

DataShe

#### DataSheet4U.com

#### Interrupt level mask register (ILM)

This register indicates the level of the interrupt that the CPU is currently accepting. The value of this register is compared to the value of the interrupt level setting bits of the interrupt control register (ICR: IL0 to IL2) corresponding to the interrupt request of each resource.

#### • Register bank pointer (RP)

This register set the memory block (register bank) to be used for the general-purpose registers allocated in the internal RAM.

General-purpose registers can be set for up to 32 banks. The general-purpose register banks to be used are set by setting 0 to 31 in the register bank pointer (RP).

#### • Condition code register (CCR)

This register consists of various flags that are set (1) or cleared (0) by instruction execution result or acceptance of an interrupt.

## 3.2.4.1 Condition Code Register (PS: CCR)

## The condition code register (CCR) is an 8-bit register consisting of bits indicating the result of instruction execution, and the bits enabling or disabling the interrupt request.

#### ■ Configuration of Condition Code Register (CCR)

Figure 3.2-11 shows the configuration of the CCR register.



#### Figure 3.2-11 Configuration of Condition Code Register (CCR)

et4U.com

#### DataSheet4U.com

DataShe

#### Interrupt enable flag (I)

All interrupts except software interrupts are enabled when the interrupt enable flag (CCR: I) is set to 1, and are disabled when the interrupt enable flag is set to 0. This flag is cleared to 0 by a reset.

#### Stack flag (S)

This flag sets the pointer for stack processing.

When the stack flag (CCR: S) is 0, the user stack pointer (USP) is enabled. When the stack flag is 1, the system stack pointer (SSP) is enabled. If an interrupt is accepted or a reset occurs, the flag is set to 1.

#### Sticky-bit flag (T)

If either one of the data shifted out of the carry is 1 when the logic right-shift instruction or arithmetic rightshift instruction is executed, this flag is set to 1. If all the shifted-out data is 0 or the shift amount is 0, this flag is set to 0.

Negative flag (N)

If the most significant bit (MSB) of the operation result is 1, this flag is set to 1. If the MSB is 0, the flag is cleared to 0.

#### Zero flag (Z)

If all the bits of the operation result are 0, this flag is set to 1. If any bit is 1, the flag is cleared to 0.

DataSheet4U.com

www.DataSheet4U.com

#### • Overflow flag (V)

If an overflow occurs as a signed numeric value at the execution of operation, this flag is set to 1. If no overflow occurs, the flag is cleared to 0.

#### • Carry flag (C)

If a carry from the MSB or to the least significant bit (LSB) occurs at the execution of operation, this flag is set to 1. If no carry occurs, this flag is cleared to 0.

| Reference: | For the state of the condition code register (CCR) at instruction execution, refer to the Programming |
|------------|-------------------------------------------------------------------------------------------------------|
|            | Manual.                                                                                               |

DataShe

DataSheet4U.com

## 3.2.4.2 Register Bank Pointer (PS: RP)

## The register bank pointer (RP) is a 5-bit register that indicates the starting address of the currently used general-purpose register bank.

#### Register Bank Pointer (RP)

Figure 3.2-12 shows the configuration of the register bank pointer (RP).

Figure 3.2-12 Configuration of Register Bank Pointer (RP)



#### General-purpose Register Area and Register Bank Pointer

The register bank pointer (RP) indicates the allocation of general-purpose registers used in the internal RAM. The relationship between the values of PR and the actual addresses should conform to the conversion rule shown in Figure 3.2-13.

#### Figure 3.2-13 Physical Address Conversion Rules in General-purpose Register Area



- The register bank pointer (RP) can take the values from " $00_{\text{H}}$ " to " $1F_{\text{H}}$ " so that the starting address of the register bank can be set within the range of " $000180_{\text{H}}$ " to " $00037F_{\text{H}}$ ".
- The assembler instruction can use the 8-bit immediate value transfer instruction that is transferred to the register bank pointer (RP), but only the lower 5 bits of that data is actually used.
- The reset value of the register bank pointer (RP) is set to  $"00_{\text{H}}"$  after a reset.

et4U.com

## 3.2.4.3 Interrupt Level Mask Register (PS: ILM)

## The interrupt level mask register (ILM) is a 3-bit register indicating the interrupt level accepted by the CPU.

#### Interrupt Level Mask Register (ILM)

Figure 3.2-14 shows the configuration of the interrupt level mask register (ILM).

| Figure 3.2-14 | Configuration of | of Interrupt Level | Mask Register (ILM)                   |
|---------------|------------------|--------------------|---------------------------------------|
|               |                  |                    | · · · · · · · · · · · · · · · · · · · |

|    | ILM       |      |    |    |    | RP CCR |    |   |   |   |   |   |   |   |       |                 |
|----|-----------|------|----|----|----|--------|----|---|---|---|---|---|---|---|-------|-----------------|
|    | bit 15 14 | 13   | 12 | 11 | 10 | 9      | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | bit 0 | ILM reset value |
| PS | ILM2 ILM1 | ILM0 | B4 | B3 | B2 | B1     | B0 | — | Ι | S | Т | Ν | Ζ | V | С     | 000в            |

The interrupt level mask register (ILM) indicates the level of an interrupt that the CPU is accepting for comparison with the values of the interrupt level setting bits (ICR: IL2 to IL0) set according to interrupt requests from each resource. The CPU performs interrupt processing only when an interrupt with a lower value (interrupt level) than that indicated by the interrupt level mask register (ILM) is requested with an interrupt enabled (CCR: I = 1).

- When an interrupt is accepted, its interrupt level value is set in the interrupt level mask register (ILM). Thereafter, an interrupt with a level value lower than the set level value is not accepted.
- At a reset, the interrupt level mask register (ILM) is always set to 0s to enter the interrupt-disabled (highest interrupt level) state.
- The assembler instruction can use the 8-bit immediate value transfer instruction that is transferred to the interrupt level mask register (ILM), but only the lower 3 bits of that data is actually used.

| ILM2 | ILM1 | ILM0 | Interrupt<br>Level | Interrupt Level (High/Low) |
|------|------|------|--------------------|----------------------------|
| 0    | 0    | 0    | 0                  |                            |
| 0    | 0    | 1    | 1                  | High (Interrupts Disabled) |
| 0    | 1    | 0    | 2                  |                            |
| 0    | 1    | 1    | 3                  |                            |
| 1    | 0    | 0    | 4                  |                            |
| 1    | 0    | 1    | 5                  |                            |
| 1    | 1    | 0    | 6                  |                            |
| 1    | 1    | 1    | 7                  | Low                        |

Table 3.2-3 Interrupt Level Mask Register (ILM) and Interrupt Level (High/Low)

Reference:

For details of the interrupts, see Section "3.5 Interrupt".

et4U.com

DataShe

www.DataSheet4U.com

## 3.2.5 **Program Counter (PC)**

## The program counter (PC) is a 16-bit counter indicating the lower 16 bits of the address for the next instruction code to be executed by the CPU.

#### Program Counter (PC)

The program bank register (PCB) indicates the higher 8 bits of addresses where the next instruction code to be executed by the CPU is stored; the program counter (PC) indicates the lower 16 bits. As shown in Figure 3.2-15, the actual addresses are combined into 24 bits.

The program counter (PC) is updated by the execution of the conditional branch instruction, the subroutine call instruction, by an interrupt or reset, etc.

The program counter (PC) can also be used as the base pointer when reading the operand.

#### Figure 3.2-15 Program Counter (PC)



DataShe

## Note: Neither the program counter (PC) nor the program bank register (PCB) can be rewritten directly by a program (such as MOV PC and #FF).

www.DataSheet4U.com

## 3.2.6 Direct Page Register (DPR)

# The direct page register (DPR) sets bit 8 to bit 15 (addr 15 to addr 8) for the 8 bits of the low address directly specified using the operand when executing the instruction by the abbreviated direct addressing.

#### Direct Page Register (DPR)

The direct page register (DPR) sets bit 8 to bit 15 (addr 15 to addr 8) for the 8 bits of the low address directly specified using the operand when executing the instruction by the abbreviated direct addressing. The direct page register (DPR) is 8 bits long and is set to " $01_{\text{H}}$ " at a reset. It is a read and write register.



Figure 3.2-16 Generation of Physical Address in Direct Page Register (DPR)



DataShe

Figure 3.2-17 shows the setting of direct page register (DPR) and an example of data access.

Figure 3.2-17 Setting of Direct Page Register (DPR) and Data Access Example



## 3.2.7 Bank Register (PCB, DTB, USB, SSB, and ADB)

The bank register sets the MSB 8 bit of the 24-bit address using bank addressing and consists of the following five registers:

- Program bank register (PCB)
- Data bank register (DTB)
- User stack bank register (USB)
- System stack bank register (SSB)
- Additional bank register (ADB)

Each of the above registers indicate the memory bank to which the program, data, user stack, system stack, or additional is allocated.

#### Program Bank Register (PCB)

The program bank register (PCB) sets the program (PC) space.

This register is rewritten at execution of the JMPP, CALLP, RETP, or RETI instruction that branches to the entire 16-MB space, at executing a software interrupt instruction, or at a hardware interrupt or exception interrupt.

### et4U.com ■ Data Bank Register (DTB)

The data bank register (DTB) sets the data (DT) space.

DataShe

#### ■ User Stack Bank Register (USB) and System Stack Bank Register (SSB)

The user stack bank register (USB) and system stack bank register (SSB) set the stack (SP) space. The bank register that is used is determined by the value of the stack flag (CCR: S).

#### Additional Bank Register (ADB)

The additional bank register (ADB) sets the additional (AD) space.

#### Setting of Each Bank and Data Access

Each bank register is 8 bits long. At a reset, the program bank register (PCB) is set to " $FF_H$ " and other bank registers are set to " $OO_H$ ".

The program bank register (PCB) is a read-only register and other bank registers are read and write registers.

Reference: For the operation of each bank register, see Section "3.1 Memory Space".

### 3.3 General-purpose Register

The general-purpose register is a memory block allocated to addresses " $000180_{H}$ " to " $00037F_{H}$ " in the internal RAM in bank units of 16 bits x 8. It is configured as follows:

- General-purpose 8-bit register (byte registers R0 to R7)
- 16-bit register (word registers RW0 to RW7)
- 32-bit register (long-word registers RL0 to RL7)

#### Configuration of General-purpose Register

General-purpose registers are provided as 32 banks in the internal RAM from " $000180_{\text{H}}$ " to " $00037F_{\text{H}}$ ". The banks that are used are set by the register bank pointer (RP). The current banks are indicated by reading the register bank pointer (RP).

The register bank pointer (RP) determines the starting address of each bank as the following expression.

Starting address of general-purpose register = "000180<sub>H</sub>" + RP × "10<sub>H</sub>"

Figure 3.3-1 shows the allocation and configuration of the general-purpose register banks in memory space.

#### Figure 3.3-1 Allocation and Configuration of General-Purpose Register Banks in Memory Space





Note:

The register bank pointer (RP) is initialized to " $00000_{B}$ " by a reset.

DataSheet4U.com

50

#### Register Bank

The register bank can be used as a general-purpose register (byte registers R0 to R7, word registers RW0 to RW7, and long-word registers RL0 to RL3) to perform various operations or to serve as a pointer. The long- word register can also be used as a linear addressing to directly access the entire memory space.

In the same way as ordinary RAM, the value in the general-purpose register is unchanged by a reset, meaning that the state before the reset is held. However, at power-on, the value is undefined.

Table 3.3-1 shows the typical function of the general-purpose register.

| Register Name | Function                                                                                                                                            |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| R0 to R7      | Used as operands for various instructions<br><b>Note:</b> R0 can also be used as the barrel shift counter or the normalized instruction<br>counter. |
| RW0 to RW7    | Used as addressing<br>Used as operands for various instructions<br><b>Note:</b> RW0 can also be used as the string instruction counter.             |
| RL0 to RL3    | Used as linear addressing<br>Used as operands for various instructions                                                                              |

| Table 3.3-1 Typical Function of the General-purpose | Register |
|-----------------------------------------------------|----------|
|-----------------------------------------------------|----------|

et4U.com

DataSheet4U.com

www.DataSheet4U.com

### 3.4 Prefix Codes

When prefix code is inserted prior to an instruction, the operation of the instruction can be changed partially. The prefix code has the following three types:

- Bank select prefix (PCB, DTB, ADB, and SPB)
- Common register bank prefix (CMR)
- Flag change inhibit prefix (NCC)

#### Prefix Code

Bank select prefix (PCB, DTB, ADB, and SPB)

When the bank select prefix (PCB, DTB, ADB, SPB) codes precede an instruction, any memory space to be accessed by the instruction can be selected, regardless of the addressing types.

Common register bank prefix (CMR)

When the common register bank prefix (CMR) code precedes an instruction for accessing a generalpurpose register, the general-purpose register to be accessed by the instruction can be changed to a common bank (register bank selected when the register bank pointer (RP) is 0) at "000180<sub>H</sub>" to "00018F<sub>H</sub>", regardless of the current value of the register bank pointer (RP).

DataShe

et4U.com

• Flag change inhibit prefix (NCC)

DataSheet4U.com

When the flag change inhibit (NCC) code precedes an instruction for changing various flags of the condition code register (CCR), a flag change with instruction execution can be inhibited.

## 3.4.1 Bank Select Prefix (PCB, DTB, ADB, and SPB)

When the bank select prefix (PCB, DTB, ADB, SPB) codes precede an instruction, any memory space accessed by the instruction can be set, regardless of the addressing types.

#### Bank Select Prefix (PCB, DTB, ADB, SPB)

Memory space used at data access is predetermined for each addressing type. However, when the bank select prefix (PCB, DTB, ADB, SPB) codes precede an instruction statement, any memory space accessed by the instruction statement can be set, regardless of the addressing types. Table 3.4-1 shows the bank select prefix code and the memory space to be selected.

Table 3.4-1 Bank Select Prefix

| Bank Select Prefix | Selected Space                                                                                                                |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------|
| РСВ                | Program space                                                                                                                 |
| DTB                | Data space                                                                                                                    |
| ADB                | Additional space                                                                                                              |
| SPB<br>Data        | When the stack flag (CCR: S) is 0, user stack space is selected.<br>When the stack flag is 1, system stack space is selected. |

DataShee

The use of the bank select prefix (PCB, DTB, ADB, SPB) codes causes some instructions to perform exceptional operations as explained below.

Table 3.4-2 shows the instructions not affected by the bank select prefix code, and Table 3.4-3 shows the instructions requiring precaution when using the bank select prefix.

DataSheet4U.com

DataSheet4U.com

#### Table 3.4-2 Instructions Unaffected by Bank Select Prefix

| Instruction Type             | Instruction           |                         | Effect                                                                                                                                                                                                   |        |
|------------------------------|-----------------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| String instruction           | MOVS<br>SCEQ<br>FILS  | MOVSW<br>SCWEQ<br>FILSW | The bank register specified for the operand<br>is used irrespective of the presence or<br>absence of the bank select prefix code.                                                                        |        |
| Stack instruction            | PUSHW                 | POPW                    | Irrespective of the presence or absence of the<br>bank select prefix code, the user stack bank<br>(USB) is used when the S flag is 0; and the<br>system stack bank (SSB) is used when the S<br>flag is 1 |        |
| I/O access instruction       | MOV A,io<br>MOVW A,io | MOVX A, io              | The I/O space (" $000000_{\text{H}}$ " to " $0000FF_{\text{H}}$ ") is<br>accessed irrespective of the presence or<br>absence of the bank select prefix code.                                             |        |
|                              | MOV io,A              | MOVW io,A               |                                                                                                                                                                                                          |        |
|                              | MOV io,#imm8          | MOVW io,#imm16          |                                                                                                                                                                                                          |        |
|                              | MOVB A,io:bp          | MOVB io:bp,A            |                                                                                                                                                                                                          |        |
|                              | SETB io:bp            | CLRB io:bp              |                                                                                                                                                                                                          |        |
|                              | BBC io:bp,rel         | BBS io:bp,rel           | Г                                                                                                                                                                                                        | DataSh |
|                              | WBTC io,bp            | WBTShaettopcom          |                                                                                                                                                                                                          |        |
| Interrupt return instruction | RETI                  |                         | The system stack bank (SSB) is used<br>irrespective of the presence or absence of the<br>bank select prefix code.                                                                                        |        |

#### Table 3.4-3 Instructions Requiring Precaution When Using Bank Select Prefix

| Instruction Type           | Instruction |                        | Explanation                                                          |
|----------------------------|-------------|------------------------|----------------------------------------------------------------------|
| Flag change instruction    | AND<br>OR   | CCR,#imm8<br>CCR,#imm8 | The bank select prefix code affects up to the next instruction.      |
| ILM setting<br>instruction | MOV         | ILM,#imm8              | The bank select prefix code affects up to the next instruction.      |
| PS return instruction      | POPW        | PS                     | Do not add the bank select prefix code to the PS return instruction. |

## 3.4.2 Common Register Bank Prefix (CMR)

When the common register bank prefix (CMR) code precedes an instruction for accessing a general-purpose register, the general-purpose register to be accessed by the instruction can be changed to a common bank register bank selected when the register bank pointer (RP) is 0 at "000180<sub>H</sub>" to "00018F<sub>H</sub>", regardless of the current value of the register bank pointer (RP).

#### Common Register Bank Prefix (CMR)

The F<sup>2</sup>MC-16LX family provides common banks at "000180<sub>H</sub>" to "00018F<sub>H</sub>" as register banks that can be commonly accessed by each task, regardless of the values of the register bank pointer (RP).

The use of the common banks facilitates data exchange between two or more tasks.

When the common register bank prefix (CMR) code precedes an instruction for accessing a generalpurpose register, the general-purpose register accessed by the instruction can be changed to a common bank (register bank to be selected when the register bank pointer (RP) is 0) at " $000180_{\text{H}}$ " to " $00018F_{\text{H}}$ ", regardless of the current value of the register bank pointer (RP).

Table 3.4-4 shows the instructions requiring care when using the common register bank prefix.

#### Table 3.4-4 Instructions Requiring Precaution When Using Common Register Bank Prefix (CMR)

| Instruction Type        | Instruction          |                         | m Explanation                                    |
|-------------------------|----------------------|-------------------------|--------------------------------------------------|
| String instruction      | MOVS<br>SCEQ<br>FILS | MOVSW<br>SCWEQ<br>FILSW | Do not add the CMR code to string instructions.  |
| Flag change instruction | AND<br>OR            | CCR,#imm8<br>CCR,#imm8  | The CMR code affects up to the next instruction. |
| PS return instruction   | POPW                 | PS                      | The CMR code affects up to the next instruction. |
| ILM setting instruction | MOV                  | ILM,#imm8               | The CMR code affects up to the next instruction. |

et4U.com

www.DataSheet4U.com

## 3.4.3 Flag Change Inhibit Prefix (NCC)

# When the flag change inhibit prefix (NCC) code precedes an instruction for changing various flags of the condition code register (CCR), a flag change caused by instruction execution can be inhibited.

#### ■ Flag Change Inhibit Prefix (NCC)

The flag change inhibit prefix (NCC) code is used to inhibit an unnecessary flag change.

When the flag change inhibit prefix (NCC) code precedes an instruction for changing various flags of the condition code register (CCR), a flag change caused by instruction execution can be inhibited. The inhibited flags are:

- Sticky-bit flag (CCR: T)
- Negative flag (CCR: N)
- Zero flag (CCR: Z)
- Overflow flag (CCR: V)
- Carry flag (CCR: C)

Table 3.4-5 shows the instructions requiring precaution when using the flag change inhibit prefix.

### Table 3.4-5 Instructions Requiring Precaution When Using Flag Change Inhibit Prefix (NCC)

DataShe

| Instruction Type                                         | Instru                             | uction DataSheet4U.con  | Explanation                                                                                                                                                |
|----------------------------------------------------------|------------------------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| String instruction                                       | MOVS<br>SCEQ<br>FILS               | MOVSW<br>SCWEQ<br>FILSW | Do not add the NCC code to the string instruction.                                                                                                         |
| Flag change<br>instruction                               | AND CCR,#imm8<br>OR CCR,#imm8      |                         | The CCR changes by execution of an instruction,<br>regardless of the presence or absence of the NCC<br>code.<br>The NCC code affects the next instruction. |
| PS return instruction                                    | POPW PS                            |                         | The CCR changes by execution of an instruction,<br>regardless of the presence or absence of the NCC<br>code.<br>The NCC code affects the next instruction. |
| ILM setting instruction                                  | MOV ILM,#imm8                      |                         | The NCC code affects the next instruction.                                                                                                                 |
| Interrupt instruction<br>Interrupt return<br>instruction | INT #vct8<br>INT<br>addr16<br>RETI | INT9<br>INTP<br>addr24  | The CCR changes by execution of an instruction statement, regardless of the presence or absence of the NCC code.                                           |
| Context<br>switch instruction                            | JCTX @ A                           |                         | The CCR changes by execution of an instruction statement, regardless of the presence or absence of the NCC code.                                           |

DataSheet4U.com

# 3.4.4 Restrictions on Prefix Code

The use of the prefix codes is restricted as follows:

- No interrupt request is accepted during execution of a prefix code and interrupt inhibit instruction.
- When a prefix code precedes an interrupt inhibit instruction, the effect of the prefix code is delayed.
- When conflicting prefix codes are used in succession, the last prefix code is enabled.

#### Prefix Code and Interrupt Inhibit Instruction

The interrupt inhibit instruction and prefix code are restricted as shown below.

|                                                    | Prefix Code Interrupt/Hold Inhibit Instruction<br>(instruction that delays effect of prefix code |                          |                                           |
|----------------------------------------------------|--------------------------------------------------------------------------------------------------|--------------------------|-------------------------------------------|
| Instruction that does not accept interrupt request | PCB<br>DTB<br>ADB<br>SPB                                                                         | MOV<br>OR<br>AND<br>POPW | ILM,#imm8<br>CCR,#imm8<br>CCR,#imm8<br>PS |
| accept interrupt request                           | CMR<br>INCC heet4                                                                                |                          |                                           |

#### Table 3.4-6 Prefix Code and Interrupt Inhibit Instruction

#### Interrupt Inhibition

Even if an interrupt request is generated, it is not accepted during execution of a prefix code and interrupt inhibit instruction. When other instructions are executed after execution of a prefix code and interrupt inhibit instruction, an interrupt is processed.

#### Figure 3.4-1 Interrupt Inhibition



et4U.com

#### Delay of the effect of the prefix code

When a prefix code precedes an interrupt inhibit instruction, it affects an instruction next to the interrupt inhibit instruction.





### Array of Prefix Codes

For array of conflicting prefix codes (PCB, ADB, DTB, SPB), the last one is enabled.

Figure 3.4-3 Array of Prefix Codes



## 3.5 Interrupt

The F<sup>2</sup>MC-16LX family has four interrupt functions for suspending the current processing to transfer control to a program which is defined separately at generation of event.

- Hardware interrupt
- Software interrupt
- Interrupts by extended intelligent I/O service (EI<sup>2</sup>OS)
- Exception processing

#### Type and Function of Interrupt

Hardware interrupt

This transits control to the interrupt processing program defined by user in response to the interrupt request from resources.

Software interrupt

et4U.com

This transfers control to the interrupt processing program defined by user by executing an instruction (such as INT instruction) dedicated to the software interrupt.

DataSheet4U.com

Interrupt by extended intelligent I/O service (EI<sup>2</sup>OS)

The extended intelligent I/O service ( $EI^2OS$ ) provides automatic data transfer between resources and memory. Data can be transferred just by creating the startup-setting program and end program of the  $EI^2OS$ . At completion of data transfer, the interrupt processing program is executed automatically.

21 Obi in completion of the dam dansier, the interrupt processing program is encoured automa

An interrupt generated by the  $EI^2OS$  is a type of the above hardware interrupt.

• Exception processing

If an exception (execution of an undefined instruction) is detected among instructions, ordinary processing is suspended to perform exception processing. This is equivalent to the above software interrupt instruction INT10.

### ■ Interrupt Operation

Figure 3.5-1 shows interrupt start and return processing.





DataShe

DataSheet4U.com

# 3.5.1 Interrupt Factor and Interrupt Vector

## The F<sup>2</sup>MC-16LX family has vector tables corresponding to 256 types of interrupt factor.

#### Interrupt Vector

The interrupt vector tables referenced at interrupt processing are allocated to the most significant addresses ("FFFC00<sub>H</sub>" to "FFFFFF<sub>H</sub>") of the memory area. The interrupt vectors share the same area with the  $EI^2OS$ , exception processing, and hardware and software interrupts.

- Interrupts (INT0 to INT255) are used as software interrupts.
- At hardware interrupts, the interrupt vectors and interrupt control register (ICR) are fixed for each resource.

Table 3.5-1 shows the interrupt number and allocation of interrupt vector.

Software Vector Vector Vector Mode Interrupt Hardware Interrupt Number Interrupt Address Address Address Data Instruction (Middle) (High) (Low) INT0 Unused #0 None **FFFFC**<sub>H</sub> **FFFFD**<sub>H</sub> FFFFE<sub>H</sub> : : : : : DataSh et4U.com FFFFE2<sub>H</sub> INT7 Unused FFFFE0<sub>H</sub> FFFFE1<sub>H</sub> #7 None INT8 FFFFDC<sub>H</sub> **FFFFDE**<sub>H</sub> (RESET vector) **FFFFDD**<sub>H</sub> FFFFDF<sub>H</sub> #8 INT9 Unused FFFFD8<sub>H</sub> FFFFD9<sub>H</sub> **FFFFDA**<sub>H</sub> #9 None INT10 FFFFD4<sub>H</sub> FFFFD5<sub>H</sub> FFFFD6<sub>H</sub> Unused #10 <Exception processing> INT11 Unused FFFFD0<sub>H</sub> FFFFD1<sub>H</sub> FFFFD2<sub>H</sub> #11 Resource interrupt #0 INT12 **FFFFCC**<sub>H</sub> FFFFCD<sub>H</sub> **FFFFCE**<sub>H</sub> Unused #12 Resource interrupt #1 INT13 FFFFC8<sub>H</sub> FFFFC9<sub>H</sub> **FFFFCA<sub>H</sub>** Unused #13 Resource interrupt #2 INT14 FFFFC6<sub>H</sub> Unused Resource interrupt #3 FFFFC4<sub>H</sub> FFFFC5<sub>H</sub> #14 : : : : **INT254** FFFC04<sub>H</sub> FFFC05<sub>H</sub> FFFC06<sub>H</sub> Unused #254 None INT255 FFFC00<sub>H</sub> FFFC01<sub>H</sub> FFFC02<sub>H</sub> Unused #255 None

| Table 3.5-1 | List of | Interrupt | Vectors |
|-------------|---------|-----------|---------|
|-------------|---------|-----------|---------|

Reference:

It is recommended to set the unused interrupt vectors to the addresses for exception processing.

et4U.com

www.DataSheet4U.com

### ■ Interrupt Factor, Interrupt Vector, and Interrupt Control Register

Table 3.5-2 shows the relationships between the interrupt factor except software interrupt, interrupt vector, and interrupt control register.

| Table 3.5-2 Interrupt Factor, | Interrupt Vector, and Interru | pt Control Register (1/2) |
|-------------------------------|-------------------------------|---------------------------|
|                               |                               |                           |

| Interrupt Factor                                                          | El <sup>2</sup> OS-<br>Correspo | Interrupt Vector |                                | Interrupt Control<br>Register    |       | Priority <sup>(*4)</sup>            |              |
|---------------------------------------------------------------------------|---------------------------------|------------------|--------------------------------|----------------------------------|-------|-------------------------------------|--------------|
|                                                                           | nded                            | Number           |                                | Address                          | ICR   | Address                             |              |
| Reset                                                                     | X                               | #08              | 08 <sub>H</sub>                | FFFFDC <sub>H</sub>              | _     | _                                   |              |
| INT9 instruction                                                          | X                               | #09              | 09 <sub>H</sub>                | FFFFD8 <sub>H</sub>              | _     | _                                   | Highest<br>▲ |
| Exception processing                                                      | X                               | #10              | 0A <sub>H</sub>                | FFFFD4 <sub>H</sub>              | _     | _                                   |              |
| CAN controller receive<br>completion (RX)                                 | X                               | #11              | 0B <sub>H</sub>                | FFFFD0 <sub>H</sub>              |       |                                     |              |
| CAN controller transmit<br>completion (TX)/node status<br>transition (NS) | X                               | #12              | 0C <sub>H</sub>                | FFFFCC <sub>H</sub>              | ICR00 | 0000B0 <sub>H</sub> <sup>(*1)</sup> |              |
| Reserved                                                                  | X                               | #13              | $0D_{H}$                       | FFFFC8 <sub>H</sub>              | ICD01 | 0000001                             |              |
| Reserved                                                                  | X                               | #14              | 0E <sub>H</sub>                | FFFFC4 <sub>H</sub>              | ICR01 | 0000B1 <sub>H</sub>                 |              |
| CAN wake-up                                                               | Δ                               | DataSh<br>#15    | $ee_{0F_{H}}^{\downarrow}$ .co | <sup>m</sup> FFFFC0 <sub>H</sub> | ICD02 | 000000 (*3)                         |              |
| Timebase timer                                                            | X                               | #16              | 10 <sub>H</sub>                | FFFFBC <sub>H</sub>              | ICR02 | 0000B2 <sub>H</sub> <sup>(*3)</sup> |              |
| 16-bit reload timer 0                                                     | Δ                               | #17              | $11_{\rm H}$                   | FFFFB8 <sub>H</sub>              | (*1)  |                                     |              |
| 8-/10-bit A/D converter                                                   | Δ                               | #18              | 12 <sub>H</sub>                | FFFFB4 <sub>H</sub>              | ICR03 | 0000B3 <sub>H</sub> <sup>(*1)</sup> |              |
| 16-bit free-run timer overflow                                            |                                 | #19              | 13 <sub>H</sub>                | FFFFB0 <sub>H</sub>              | ICR04 | 0000B4 <sub>H</sub>                 |              |
| Reserved                                                                  | X                               | #20              | 14 <sub>H</sub>                | FFFFAC <sub>H</sub>              | ICK04 | 0000 <b>D</b> 4H                    |              |
| Reserved                                                                  | X                               | #21              | 15 <sub>H</sub>                | FFFFA8 <sub>H</sub>              | ICR05 | 0000B5 <sub>H</sub>                 |              |
| PPG timer ch 0/1 underflow                                                | X                               | #22              | 16 <sub>H</sub>                | FFFFA4 <sub>H</sub>              | ICK05 | 0000 <b>D</b> 3H                    |              |
| Input capture 0 fetched                                                   | Δ                               | #23              | 17 <sub>H</sub>                | FFFFA0 <sub>H</sub>              | ICDOC | 0000 <b>D</b> c (*1)                |              |
| External interrupt (INT4/INT5)                                            | Δ                               | #24              | 18 <sub>H</sub>                | FFFF9C <sub>H</sub>              | ICR06 | 0000B6 <sub>H</sub> <sup>(*1)</sup> |              |
| Input capture 1 fetched                                                   | Δ                               | #25              | 19 <sub>H</sub>                | FFFF98 <sub>H</sub>              | ICD07 | 000007 (*2)                         |              |
| PPG timer ch 2/3 underflow                                                | X                               | #26              | 1A <sub>H</sub>                | FFFF94 <sub>H</sub>              | ICR07 | 0000B7 <sub>H</sub> <sup>(*2)</sup> |              |
| External interrupt (INT6/INT7)                                            | Δ                               | #27              | 1B <sub>H</sub>                | FFFF90 <sub>H</sub>              | ICD09 | 0000000 (*1)                        |              |
| Watch timer                                                               | Δ                               | #28              | 1C <sub>H</sub>                | FFFF8C <sub>H</sub>              | ICR08 | 0000B8 <sub>H</sub> <sup>(*1)</sup> |              |

et4U.com

DataSheet4U.com

www.DataSheet4U.com

| Interrupt Factor                                   | El <sup>2</sup> OS-<br>Correspo |     |                 | Interrupt Control<br>Register |        | Priority <sup>(*4)</sup>            |        |
|----------------------------------------------------|---------------------------------|-----|-----------------|-------------------------------|--------|-------------------------------------|--------|
|                                                    | nded                            | Nun | nber            | Address                       | ICR    | Address                             |        |
| Reserved                                           | X                               | #29 | 1D <sub>H</sub> | FFFF88 <sub>H</sub>           |        |                                     |        |
| Input capture 2 fetched<br>Input capture 3 fetched | X                               | #30 | 1E <sub>H</sub> | FFFF84 <sub>H</sub>           | ICR09  | 0000B9 <sub>H</sub>                 |        |
| Reserved                                           | Х                               | #31 | 1F <sub>H</sub> | FFFF80 <sub>H</sub>           | ICR10  | 0000BA <sub>H</sub>                 |        |
| Reserved                                           | X                               | #32 | 20 <sub>H</sub> | FFFF7C <sub>H</sub>           | ICKIU  | OOODAH                              |        |
| Reserved                                           | X                               | #33 | 21 <sub>H</sub> | FFFF78 <sub>H</sub>           | ICR11  | 0000BB <sub>H</sub>                 |        |
| Reserved                                           | X                               | #34 | 22 <sub>H</sub> | FFFF74 <sub>H</sub>           | ICKII  | OOODDH                              |        |
| Reserved                                           | X                               | #35 | 23 <sub>H</sub> | FFFF70 <sub>H</sub>           | ICR12  | 0000BC                              |        |
| 16-bit reload timer 1                              | 0                               | #36 | 24 <sub>H</sub> | FFFF6C <sub>H</sub>           | ICK12  | 0000BC <sub>H</sub>                 |        |
| UART1 receive                                      | Ø                               | #37 | 25 <sub>H</sub> | FFFF68 <sub>H</sub>           | ICD 12 | 0000 <b>DD</b> (*1)                 |        |
| UART1 transmit                                     | O                               | #38 | 26 <sub>H</sub> | FFFF64 <sub>H</sub>           | ICR13  | 0000BD <sub>H</sub> <sup>(*1)</sup> |        |
| Reserved                                           | X                               | #39 | 27 <sub>H</sub> | FFFF60 <sub>H</sub>           | ICD 14 | 0000BE                              |        |
| Reserved                                           | X                               | #40 | 28 <sub>H</sub> | FFFF5C <sub>H</sub>           | ICR14  | 0000BE <sub>H</sub>                 |        |
| Flash memory                                       | X                               | #41 | 29 <sub>H</sub> | FFFF58 <sub>H</sub>           |        |                                     |        |
| Delayed interrupt generation module                | X                               | #42 | 2A <sub>H</sub> | FFFF54 <sub>H</sub>           | ICR15  | 0000BF <sub>H</sub> <sup>(*1)</sup> | Lowest |

#### Table 3.5-2 Interrupt Factor, Interrupt Vector, and Interrupt Control Register (2/2)

O: Interrupt factor corresponds to EI<sup>2</sup>OS

X: Interrupt factor does not correspond to  $EI^2OS$ 

⊚: Interrupt factor corresponds to EI<sup>2</sup>OS and has EI<sup>2</sup>OS stop function

 $\Delta$ : Interrupt factor can be used when not using interrupt sources sharing ICR register

\*1:

• The interrupt level for resources sharing an ICR register become the same.

• When two resources share an ICR register, only one can use the  $EI^2OS$ .

• When two resources share an ICR register and one specifies the EI<sup>2</sup>OS, the remaining resource cannot use the interrupt.

\*2: The only input capture1 corresponds to the EI<sup>2</sup>OS function and the PPG does not correspond to the EI<sup>2</sup>OS function. Therefore, if the EI<sup>2</sup>OS function is used by the input capture1, the PPG is set to disable generation of interrupt requests.

\*3: The only CAN wake-up corresponds to the EI<sup>2</sup>OS function and the timebase timer dose not correspond to the EI<sup>2</sup>OS function. Therefore, if the EI<sup>2</sup>OS function is used by the CAN wake-up, the timebase timer is set to disable generation of interrupt requests.

\*4: The priority is given when plural interrupts with the same level are generated simultaneously.

et4U.com

# 3.5.2 Interrupt Control Registers and Resources

The interrupt control registers (ICR00 to ICR15) are allocated in the interrupt controller, and correspond to all resources with interrupt functions. The registers control the interrupt and extended intelligent I/O service (EI<sup>2</sup>OS).

### Interrupt Control Register List

Table 3.5-3 lists the resources corresponding to the interrupt control registers.

| Address             | Register                      | Abbreviation | Corresponding Resource                          | 7        |
|---------------------|-------------------------------|--------------|-------------------------------------------------|----------|
| 0000B0 <sub>H</sub> | Interrupt control register 00 | ICR00        | CAN controller                                  |          |
| 0000B1 <sub>H</sub> | Interrupt control register 01 | ICR01        | Reserved                                        |          |
| 0000B2 <sub>H</sub> | Interrupt control register 02 | ICR02        | CAN wake-up<br>Timebase timer                   |          |
| 0000B3 <sub>H</sub> | Interrupt control register 03 | ICR03        | 16-bit reload timer 0<br>A/D converter          | DataShee |
| 0000B4 <sub>H</sub> | Interrupt control register 04 | ICR04        | 16-bit free-run timer overflow                  | Datas    |
| 0000B5 <sub>H</sub> | Interrupt control register 05 | ICR05        | PPG 0/1                                         |          |
| 0000B6 <sub>H</sub> | Interrupt control register 06 | ICR06        | Input capture 0<br>External interrupt INT4/INT5 |          |
| 0000B7 <sub>H</sub> | Interrupt control register 07 | ICR07        | Input capture 1<br>PPG 2/3                      |          |
| 0000B8 <sub>H</sub> | Interrupt control register 08 | ICR08        | External interrupt INT6/INT7<br>Watch timer     |          |
| 0000B9 <sub>H</sub> | Interrupt control register 09 | ICR09        | Input capture 2/3                               |          |
| 0000BA <sub>H</sub> | Interrupt control register 10 | ICR10        | Reserved                                        |          |
| 0000BB <sub>H</sub> | Interrupt control register 11 | ICR11        | Reserved                                        |          |
| 0000BC <sub>H</sub> | Interrupt control register 12 | ICR12        | 16-bit reload timer 1                           |          |
| $0000BD_{\rm H}$    | Interrupt control register 13 | ICR13        | UART1                                           |          |
| 0000BE <sub>H</sub> | Interrupt control register 14 | ICR14        | Reserved                                        | 7        |
| 0000BF <sub>H</sub> | Interrupt control register 15 | ICR15        | Flash memory, delayed interrupt                 |          |

#### Table 3.5-3 Interrupt Control Register List

DataSheet4U.com

The interrupt control register (ICR) has the following four functions.

Some functions of the interrupt control register (ICR) are different at write and read.

- Setting of interrupt level of corresponding resource
- Selection of whether to perform normal interrupt or EI<sup>2</sup>OS for corresponding resource
- Selection of channel of EI<sup>2</sup>OS
- Display of end state of EI<sup>2</sup>OS

Note: Do not access the interrupt control register (ICR) using the read modify write instruction because it causes a malfunction.

DataShe

DataSheet4U.com

www.DataSheet4U.com

# 3.5.3 Interrupt Control Register (ICR00 to ICR15)

The functions of the interrupt control registers are shown below.

### Interrupt Control Register (ICR00 to ICR15)

Part of functions differ depending on whether data is written to or read from the interrupt control registers.





et4U.com



Figure 3.5-3 Interrupt Control Register (ICR00 to ICR15) at Read

et4U.com

DataSheet4U.com

www.DataSheet4U.com

# 3.5.4 Function of Interrupt Control Register

The interrupt control registers (ICR00 to ICR15) consist of the following bits with four functions.

- Interrupt level setting bits (IL2 to IL0)
- El<sup>2</sup>OS enable bit (ISE)
- El<sup>2</sup>OS channel select bits (ICS3 to ICS0)
- El<sup>2</sup>OS status bits (S1 and S0)

### ■ Bit Configuration of Interrupt Control Register (ICR)

The bit configuration of the interrupt control registers (ICR) is show below.

#### Figure 3.5-4 Configuration of Interrupt Control Register (ICR) Configuration of interrupt control register (ICR) at write bit 7 6 5 4 3 2 1 bit 0 Reset value ICS2 ICS1 ICS0 ISE IL2 00000111<sub>B</sub> ICS3 IL1 IL0 W W W W W W W W et4U.com DataShe Configuration of interrupt control register (ICR) at read DataSheet4U.com 2 bit 7 6 5 1 bit 0 Reset value XX000111<sub>B</sub> S1 S0 ISE IL2 IL1 IL0 -R R R R R R R: Read only W: Write only -: Unused References:

The setting of the channel select bits (ICR: ICS3 to ICS0) is enabled only when starting the EI<sup>2</sup>OS.
 When starting the EI<sup>2</sup>OS, set the EI<sup>2</sup>OS enable bit (ICR: ISE) to 1. When not starting the EI<sup>2</sup>OS, set the bit to 0.

• The channel select bits (ICR: ICS3 to ICS0) are enabled only at write, and the EI<sup>2</sup>OS status bits (ICR: S1, S0) are enabled only at read.

### Function of Interrupt Control Register

Interrupt level setting bits (IL2 to IL0)

These bits set the interrupt levels of the corresponding resources. At reset, the bits are set to level 7 (IL2 to  $IL0 = "111_B"$ : no interrupt).

Table 3.5-4 shows the relationship between the interrupt level setting bits and interrupt levels.

| IL2 | IL1 | IL0 | Interrupt Level  |
|-----|-----|-----|------------------|
| 0   | 0   | 0   | 0 (Highest)      |
| 0   | 0   | 1   |                  |
| 0   | 1   | 0   |                  |
| 0   | 1   | 1   |                  |
| 1   | 0   | 0   |                  |
| 1   | 0   | 1   | Ļ                |
| 1   | 1   | 0   | 6 (Lowest)       |
| 1   | 1   | 1   | 7 (No interrupt) |

Table 3.5-4 Relationship between Interrupt Level Setting Bits and Interrupt Levels

et4U.com

• El<sup>2</sup>OS enable bit (ISE)

DataSheet4U.com

When an interrupt occurs with the ISE bit set to 1, the  $EI^2OS$  is started. When an interrupt occurs with the ISE bit set to 0, ordinary interrupt processing is started. If the  $EI^2OS$  end condition is satisfied (when the status bits S1 and S0 are not "00<sub>B</sub>"), the ISE bit is cleared. When the corresponding resources have no

 $EI^2OS$  function, this bit must be set to 0 by the program. At reset, the ISE bit is set to 0.

• El<sup>2</sup>OS channel select bits (ICS3 to ICS0)

These bits select  $EI^2OS$  channels. The  $EI^2OS$  descriptor addresses are set according to the setting values of the ICS3 to ICS0 bits. At reset, the ICS3 to ICS0 are set to " $0000_B$ ".

Table 3.5-5 shows the correspondence between the EI<sup>2</sup>OS channel select bits and descriptor addresses.

| Table 3.5-5 | Correspondence between | El <sup>2</sup> OS Channel Select Bits and De | scriptor Addresses (1/2) |
|-------------|------------------------|-----------------------------------------------|--------------------------|
|-------------|------------------------|-----------------------------------------------|--------------------------|

| ICS3 | ICS2 | ICS1 | ICS0 | Channel to be Selected | Descriptor Address  |                  |
|------|------|------|------|------------------------|---------------------|------------------|
| 0    | 0    | 0    | 0    | 0                      | 000100 <sub>H</sub> |                  |
| 0    | 0    | 0    | 1    | 1                      | 000108 <sub>H</sub> |                  |
| 0    | 0    | 1    | 0    | 2                      | 000110 <sub>H</sub> |                  |
| 0    | 0    | 1    | 1    | 3                      | 000118 <sub>H</sub> |                  |
| 0    | 1    | 0    | 0    | 4                      | 000120 <sub>H</sub> | ww.DataSheet4U.c |

DataSheet4U.com

| ICS3 | ICS2 | ICS1 | ICS0 | Channel to be Selected | Descriptor Address  |
|------|------|------|------|------------------------|---------------------|
| 0    | 1    | 0    | 1    | 5                      | 000128 <sub>H</sub> |
| 0    | 1    | 1    | 0    | 6                      | 000130 <sub>H</sub> |
| 0    | 1    | 1    | 1    | 7                      | 000138 <sub>H</sub> |
| 1    | 0    | 0    | 0    | 8                      | 000140 <sub>H</sub> |
| 1    | 0    | 0    | 1    | 9                      | 000148 <sub>H</sub> |
| 1    | 0    | 1    | 0    | 10                     | 000150 <sub>H</sub> |
| 1    | 0    | 1    | 1    | 11                     | 000158 <sub>H</sub> |
| 1    | 1    | 0    | 0    | 12                     | 000160 <sub>H</sub> |
| 1    | 1    | 0    | 1    | 13                     | 000168 <sub>H</sub> |
| 1    | 1    | 1    | 0    | 14                     | 000170 <sub>H</sub> |
| 1    | 1    | 1    | 1    | 15                     | 000178 <sub>H</sub> |

Table 3.5-5 Correspondence between El<sup>2</sup>OS Channel Select Bits and Descriptor Addresses (2/2)

### et4U.com

• El<sup>2</sup>OS status bits (S1 and S0)

DataShe

When the S1 and S0 bits are read at the termination of the  $EI^2OS$ , the operating and end states can be checked. At reset, the S1 and S0 bits are set to " $OO_B$ ".

Table 3.5-6 shows the relationship between the EI<sup>2</sup>OS status bits (ICR: S1, S0) and the EI<sup>2</sup>OS status.

| Table 3.5-6 | Relationships | Between El <sup>2</sup> | <b>OS Status</b> | Bits and El <sup>2</sup> | OS Status |
|-------------|---------------|-------------------------|------------------|--------------------------|-----------|
|-------------|---------------|-------------------------|------------------|--------------------------|-----------|

| S1 | S0 | EI <sup>2</sup> OS Status                           |  |
|----|----|-----------------------------------------------------|--|
| 0  | 0  | When EI <sup>2</sup> OS in operation or not started |  |
| 0  | 1  | Stop state by end of counting                       |  |
| 1  | 0  | Reserved                                            |  |
| 1  | 1  | Stop state by request from resource                 |  |

## 3.5.5 Hardware Interrupt

The hardware interrupt responds to the interrupt request from a resource, suspends the current-executing program and transfers control to the interrupt processing program defined by user.

The hardware interrupt corresponds to the El<sup>2</sup>OS.

#### Hardware Interrupt

• Function of hardware interrupt

When a hardware interrupt is generated, the interrupt level (IR: IL) of an interrupt request from a resource is compared with the interrupt level mask register (PS: ILM) and the state of the interrupt enable flag (CCR: I) is referenced to determine whether to accept the hardware interrupt.

When the hardware interrupt is accepted, registers in the CPU are automatically saved in the system stack. The interrupt level of the accepted interrupt is stored in the interrupt level mask register (ILM), then branches to the corresponding interrupt vector.

Multiple interrupts

Multiple hardware interrupts can be started.

DataShe

● El<sup>2</sup>OS

When the  $EI^2OS$  function ends, normal interrupt processing is performed. No multiple  $EI^2OS$  are started. Other interrupt requests and  $EI^2OS$  requests are held during  $EI^2OS$  processing.

DataSheet4U.com

External interrupt

The external interrupt (wake-up interrupt included) is accepted as a hardware interrupt via the resource (interrupt request detector).

#### Interrupt vector

The interrupt vector tables referenced during interrupt processing are allocated to "FFFC00<sub>H</sub>" to "FFFFFF<sub>H</sub>" in the memory and shared with software interrupts.

#### Mechanism of Hardware Interrupt

The mechanism related to the hardware interrupt consists of the four sections.

When starting the hardware interrupt, these four sections must be set by the program.

Table 3.5-7 Mechanism Related to Hardware Interrupt

|                                                             | Mechanism Related to<br>Hardware Interrupt  | Function                                                       |  |  |  |
|-------------------------------------------------------------|---------------------------------------------|----------------------------------------------------------------|--|--|--|
| Resource                                                    | Interrupt enable bit, interrupt request bit | Controls interrupt request from resource                       |  |  |  |
| Interrupt controller                                        | Interrupt control register (ICR)            | Sets interrupt level and controls EI <sup>2</sup> OS           |  |  |  |
|                                                             | Interrupt enable flag (I)                   | Identifies interrupt enable state                              |  |  |  |
| СРИ                                                         | Interrupt level mask register<br>(ILM)      | Compares requested interrupt level and current interrupt level |  |  |  |
|                                                             | Microcode                                   | Executes interrupt routine                                     |  |  |  |
| "FFFC00 <sub>H</sub> to<br>"FFFFFF <sub>H</sub> " in memory | Interrupt vector table                      | Stores branch destination address at interrupt processing      |  |  |  |

### Hardware Interrupt Inhibition

No hardware interrupt requests are inhibited under following conditions.

DataShe

DataSheet4U.com

Hardware interrupt inhibition during write to resource control register in I/O area

No hardware interrupt requests are accepted during write to resource control register. This prevents the CPU from malfunctioning with respect to interrupt requests generated during rewrite related to interrupt control registers of each resource.

Figure 3.5-5 shows the hardware interrupt operation during write to the resource control register.

Figure 3.5-5 Hardware Interrupt Request During Write to the Resource Control Register



DataSheet4U.com

#### Hardware interrupt inhibition by interrupt inhibit instruction

Table 3.5-8 shows the hardware interrupt inhibit instructions.

If a hardware interrupt is generated during execution of a hardware interrupt inhibit instruction, it is processed after execution of the hardware interrupt inhibit instruction, then and other instruction.

#### Table 3.5-8 Hardware Interrupt Inhibit Instructions

|                                                    | Prefix code                            |                          | Interrupt Inhibit Instruction             |
|----------------------------------------------------|----------------------------------------|--------------------------|-------------------------------------------|
| Instruction that does not accept interrupt request | PCB<br>DTB<br>ADB<br>SPB<br>CMR<br>NCC | MOV<br>OR<br>AND<br>POPW | ILM,#imm8<br>CCR,#imm8<br>CCR,#imm8<br>PS |

Hardware interrupt inhibition during execution of software interrupt

When a software interrupt is started, the interrupt enable flag (CCR: I) is cleared to 0 and the interrupt is disabled.

et4U.com

DataSheet4U.com

# 3.5.6 Operation of Hardware Interrupt

# The operation from the generation of hardware interrupt request to the completion of interrupt processing is explained below.

#### Start of Hardware Interrupt

• Operation of resource (generation of interrupt request)

The resources with a hardware interrupt request function have an interrupt request flag indicating the generation of an interrupt request, as well as an interrupt enable flag selecting between enabling and disabling an interrupt request. The interrupt request flag is set when events inherent to resources occur. When the interrupt enable flag is set to "enabled", an interrupt request is generated to the interrupt controller.

• Operation of interrupt controller (control of interrupt request)

The interrupt controller compares the interrupt level (ICR: IL2 to IL0) of simultaneously generated interrupt requests, selects the request with the highest level (with the smallest IL setting value), and posts it to the CPU. If there are two or more interrupt requests with the same level, the interrupt request with the smallest interrupt number is preferred.

DataShe

www.DataSheet4U.com

#### • Operation of CPU (interrupt request acceptance and interrupt processing)

The CPU compares the received interrupt level (ICR: IL2 to IL0) with the value of the interrupt level mask register (ILM) and generates an interrupt processing microcode after end of the current instruction execution if the interrupt level (IL) is smaller than the value of the interrupt level mask register (ILM) and an interrupt is enabled (CCR: I = 1).

The  $EI^2OS$  enable bit (ICR: ISE) is referenced at the beginning of the interrupt processing microcode. When the  $EI^2OS$  enable bit (ICR: ISE) is set to 0, ordinary interrupt processing is performed. If the bit is set to 1, the  $EI^2OS$  starts.

At interrupt processing, the values of the dedicated registers (A, DPR, ADB, DTB, PCB, PC and PS) are saved in the system stack (system stack space indicated by SSB and SSP) first.

Next, the address of the vector table corresponding to the generated interrupt is loaded to the program counter (PCB, PC), the interrupt level mask register (ILM) is updated, and the stack flag (CCR: S) is set to 1.

#### Return from Hardware Interrupt

When the interrupt processing program clears the interrupt request flag in the resource that causes the interrupt to execute the RETI instruction, the values of the dedicated registers saved in the system stack are returned to each register and the operation returns to the processing executed before transition to interrupt processing.

The interrupt request output to the interrupt controller by the resource is cleared by clearing the interrupt request flag.

DataSheet4U.com

et4U.com

74

#### Operation of Hardware Interrupt

Figure 3.5-6 shows the operation from the generation of hardware interrupt to the completion of interrupt processing.



Figure 3.5-6 Operation of Hardware Interrupt

- 1. The resource generates an interrupt request.
- 2. When the interrupt enable bit in the resource is set to "enabled", the resource generates an interrupt request to the interrupt controller.
- 3. The interrupt controller that is received the interrupt request determines the priority of interrupts simultaneously requested and posts the interrupt level (IL) corresponding to the appropriate interrupt request to the CPU.
- 4. The CPU compares the interrupt level (IL) requested from the interrupt controller with the value of the interrupt level mask register (ILM).
- 5. If the interrupt request is preferred to the interrupt level mask register (ILM), the interrupt enable flag (CCR: I) is checked.
- 6. When an interrupt is enabled by the interrupt enable flag (CCR: I = 1), the requested interrupt level (IL) is set to the interrupt level mask register (ILM) after completion of the current instruction execution.
- 7. The values of the dedicated registers are saved, and processing transits to interrupt processing.
- 8. The program clears the interrupt request generated from the resource and executes the interrupt return instruction (RETI) to terminate interrupt processing.

et4U.com

# 3.5.7 Procedure for Use of Hardware Interrupt

# The settings of the system stack area, resources, interrupt control registers (ICR) are required for using the hardware interrupt.

#### Procedure for Use of Hardware Interrupt

Figure 3.5-7 shows an example of the procedure for use of the hardware interrupt.



DataShe

www.DataSheet4U.com

Figure 3.5-7 Procedure for Use of Hardware Interrupt

- 1. Set the system stack area.
- 2. Set an interrupt of the resource with the interrupt request function.
- 3. Set the interrupt control register (ICR) in the interrupt controller.
- 4. Set the resource to start operation and the interrupt enable bit to "enabled".
- 5. Set the interrupt level mask register (ILM) and the interrupt enable flag (CCR: I) ready to accept an interrupt (CCR: I = 1).
- 6. An interrupt generated from the resource generates a hardware interrupt request.
- 7. The interrupt controller saves data in the dedicated registers, and processing transits to interrupt processing.
- 8. Execute the program for interrupt generation at interrupt processing.
- 9. Clear the interrupt request from the resource.
- 10.Execute the interrupt return instruction (RETI) to return to the program executed before transition to interrupt processing.

DataSheet4U.com

# 3.5.8 Multiple Interrupts

Multiple hardware interrupts can be generated by setting different interrupt levels in the interrupt level setting bits of the interrupt control register (ICR: ILO to IL2) in response to plural interrupt requests from the resource. However, multiple El<sup>2</sup>OS cannot be started.

#### Multiple Interrupts

• Operation of multiple interrupts

If an interrupt request with a higher priority than the interrupt level of the current interrupt processing is generated during interrupt processing, the current interrupt processing is suspended to accept the generated higher-level interrupt request. When the higher-level interrupt processing is terminated, the suspended interrupt processing is resumed. The interrupt level (IL) can be set to 0 to 7. The interrupt request set to level 7 is never accepted.

If an interrupt request with a priority equal to or lower than the interrupt level of the current-executing interrupt is generated during interrupt processing, unless the setting of the interrupt enable flag (CCR: I) or the interrupt level mask register (ILM) is changed, the new interrupt request is held until the current interrupt processing is completed.

Starting of multiple interrupts generated during interrupt processing can be disabled temporarily by setting the interrupt enable flag (CCR: I) to "disabled" (CCR: 1=0) or the interrupt level mask register (ILM) to "disabled" (ILM = 000).

Note: Multiple EI<sup>2</sup>OS cannot be started. During EI<sup>2</sup>OS processing, other interrupt requests and other EI<sup>2</sup>OS requests are all held.

et4U.com

www.DataSheet4U.com

#### Example of multiple interrupts

As an example of multiple interrupt processing, assuming that a timer interrupt is preferred to an A/D converter interrupt, set the interrupt level of the A/D converter to 2 and the interrupt level of the timer to 1. Figure 3.5-8 shows the processing of the timer interrupt generated during processing of the A/D converter interrupt.



Figure 3.5-8 Example of Multiple Interrupts

DataShe

- When processing of the A/D converter interrupt is started, the interrupt level mask register (ILM) is automatically set to the value (2 in example) of the interrupt level (ICR: IL2 to IL0) of the A/D converter. When an interrupt request with an interrupt level of 1 or 0 is generated under this condition, processing the generated interrupt is preferred.
- When the interrupt return instruction (RETI) is executed after the completion of interrupt processing, the values of the dedicated registers (A, DPR, ADB, DTB, PCB, PC, PS) saved in the system stack are returned to each register and the interrupt level mask register (ILM) is returned to the value before interrupt processing was suspended.

# 3.5.9 Software Interrupt

The software interrupt is a function for transiting control from the current-executing program to the interrupt processing program defined by user by execution of a software interrupt instruction (INT instruction). The hardware interrupt is held during execution of a software interrupt.

# Start and Operation of Software Interrupt Start of software interrupt A software interrupt is started by executing the INT instruction. It does not have an interrupt request flag or an interrupt enable flag. An interrupt request is generated immediately after the INT instruction is executed. Hardware interrupt inhibition Interrupts by the INT instruction have no interrupt level and the interrupt level mask register (ILM) is not updated. During execution of the INT instruction, the interrupt enable flag (CCR: I) is set to 0 and a hardware interrupt is masked. When enabling a hardware interrupt during software interrupt processing, set the interrupt enable flag et4U.com (CCR: I) to 1 during software interrupt processing. Operation of software interrupt When the INT instruction is executed, the software interrupt processing microcode in the CPU is started. The software interrupt processing microcode saves the values of the dedicated registers in the system stack; branching to the address of the corresponding interrupt vector table after a hardware interrupt is masked (CCR: I = 0).Return from Software Interrupt When the interrupt return instruction (RETI) is executed in the interrupt processing program, the values of the dedicated registers saved in the system stack are returned to each register and the operation is returned to the processing performed before branching to interrupt processing. Note:

Note: When the program bank register (PCB) is " $FF_H$ ", the vector area for the CALLV instruction overlaps the table for the INT #vct8 instruction. A CALLV and INT #vct8 instructions can not use the same address in creating a software.

# 3.5.10 Interrupt by El<sup>2</sup>OS

# El<sup>2</sup>OS is a function to automatically transfer data between the resources (I/O) and memory. It generates the hardware interrupt at termination of data transfer.

### ■ El<sup>2</sup>OS

The  $EI^2OS$  provides automatic data transfer between the I/O area and memory. When data transfer is terminated, the termination factor (end condition) is set, branching automatically to the interrupt processing routine. Data can be transferred just by creating a setup program for starting the  $EI^2OS$  and an end program.

#### Advantages of El<sup>2</sup>OS

Compared to data transfer using the interrupt-processing routine, EI<sup>2</sup>OS has the following advantages.

- Since the creation of transfer program is not required, the program size can be reduced.
- The transfer count can be set to prevent transfer of unnecessary data.
- Whether to update the buffer address pointer can be specified.
- Whether to update the I/O address pointer can be specified.

#### Interrupt by El<sup>2</sup>OS termination DataSheet4U.com

At completion of data transfer by the  $EI^2OS$ , the end condition is set in the  $EI^2OS$  status bits (ICR: S1, S0), and then the processing automatically transits to interrupt processing.

The EI<sup>2</sup>OS termination factor can be determined by checking the EI<sup>2</sup>OS status bits (ICR: S1, S0) using the interrupt processing program.

#### Interrupt control register (ICR)

This register is within the interrupt controller, and displays the states at starting, setting channel, and terminating the El<sup>2</sup>OS.

#### • El<sup>2</sup>OS descriptor (ISD)

The EI<sup>2</sup>OS descriptor (ISD), which is allocated between " $000100_{\text{H}}$ " and " $00017F_{\text{H}}$ " in internal RAM, is 8byte data that is used to set the transfer mode, addresses, transfer count and buffer addresses. It has 16 channels, and a channel number is allocated to each of these channels by the interrupt control register (ICR).

| Note: | The CPU stops while the EI <sup>2</sup> OS is in operation. |  |
|-------|-------------------------------------------------------------|--|
|-------|-------------------------------------------------------------|--|

# ■ Operation of El<sup>2</sup>OS

Figure 3.5-9 shows the operation of the  $EI^2OS$ .



Figure 3.5-9 Operation of El<sup>2</sup>OS

DataShe

- 1. An interrupt request is generated and the  $EI^2OS$  is started.
- 2. The interrupt controller selects the  $EI^2OS$  descriptor.
- 3. The transfer-source and transfer-destination address pointers are read from the  $EI^2OS$  descriptor.
- 4. Data is transferred according to the transfer-source and transfer-destination address pointers.
- 5. An interrupt factor is cleared automatically.

DataSheet4U.com

DataSheet4U.com

# 3.5.11 El<sup>2</sup>OS Descriptor (ISD)

# The El<sup>2</sup>OS descriptor (ISD) is allocated to the addresses " $000100_{H}$ " to " $00017F_{H}$ " in the internal RAM, and consists of 8 bytes x 16 channels.

## ■ Configuration of El<sup>2</sup>OS Descriptor (ISD)

ISD consists of 8 bytes x 16 channels, and each ISD is composed as shown in Figure 3.5-10. Table 3.5-9 shows the correspondence between the channel number and ISD address.





DataShe

DataSheet4U.com

| Channel<br>(ICR: ICS3 to ICS0) | Descriptor Starting Address      |
|--------------------------------|----------------------------------|
| 0                              | 000100 <sub>H</sub>              |
| 1                              | 000108 <sub>H</sub>              |
| 2                              | 000110 <sub>H</sub>              |
| 3                              | 000118 <sub>H</sub>              |
| 4                              | 000120 <sub>H</sub>              |
| 5                              | 000128 <sub>H</sub>              |
| 6                              | 000130 <sub>H</sub>              |
| 7                              | 000138 <sub>H</sub>              |
| 8                              | 000140 <sub>H</sub>              |
| 9                              | 000148 <sub>H</sub>              |
| 10                             | 000150 <sub>H</sub>              |
| 11                             | DataSheet4U.com0158 <sub>H</sub> |
| 12                             | 000160 <sub>H</sub>              |
| 13                             | 000168 <sub>H</sub>              |
| 14                             | 000170 <sub>H</sub>              |
| 15                             | 000178 <sub>H</sub>              |

| Table 3.5-9 | El <sup>2</sup> OS | Descriptor | (ISD) Area |
|-------------|--------------------|------------|------------|
|-------------|--------------------|------------|------------|

et4U.com

# 3.5.12 Each Register of El<sup>2</sup>OS Descriptor (ISD)

The El<sup>2</sup>OS descriptor (ISD) consists of the following registers.

- Data counter (DCT)
- I/O address pointer (IOA)
- El<sup>2</sup>OS status register (ISCS)
- Buffer address pointer (BAP)

The reset value of each register is undefined and a reset should be performed carefully.

### Data Counter (DCT)

The data counter (DCT) is a 16-bit register, and corresponds to the transfer data count. It decrements by one each time data is transferred. When the data counter (DCT) reaches 0, the EI<sup>2</sup>OS is terminated and then the processing transits to interrupt processing.

Figure 3.5-11 shows the bit configuration of the data counter (DCT).

#### Figure 3.5-11 Configuration of Data Counter (DCT)

et4U.com

|     | DCTH     |     |               |     |     |     |     | DCTL  |       |     |     |     |     |     |     |       |             |
|-----|----------|-----|---------------|-----|-----|-----|-----|-------|-------|-----|-----|-----|-----|-----|-----|-------|-------------|
|     | bit 15   | 14  | 13            | 12  | 11  | 10  | 9   | bit 8 | bit 7 | 6   | 5   | 4   | 3   | 2   | 1   | bit 0 | _           |
| DCT | B15      | B14 | B13           | B12 | B11 | B10 | B09 | B08   | B07   | B06 | B05 | B04 | B03 | B02 | B01 | B00   | Reset value |
|     | R/W      | R/W | R/W           | R/W | R/W | R/W | R/W | R/W   | R/W   | R/W | R/W | R/W | R/W | R/W | R/W | R/W   |             |
|     | R/W<br>X |     | ad/V<br>defir |     |     |     |     |       |       |     |     |     |     |     |     |       |             |

### ■ I/O Address Pointer (IOA)

The I/O address pointer (IOA) is a 16-bit register that sets the low addresses (A15 to A0) of the 00 bank area where data is transferred to or from the buffer. The high addresses (A23 to A16) are set all to 0 and the area between " $000000_{\text{H}}$ " and " $00FFFF_{\text{H}}$ " can be addressed.

Figure 3.5-12 shows the bit configuration of I/O address pointer (IOA).

|          | IOAH       |     |     |     |     |     |     |       |            | IOAL |     |     |     |     |     |            |             |
|----------|------------|-----|-----|-----|-----|-----|-----|-------|------------|------|-----|-----|-----|-----|-----|------------|-------------|
|          | bit 15     | 14  | 13  | 12  |     | 10  | 9   | bit 8 | l<br>bit 7 | 6    | 5   | 4   | 3   | 2   | 1   | l<br>bit 0 |             |
| IOA      | A15        | A14 | A13 | A12 | A11 | A10 | A09 | A08   | A07        | A06  | A05 | A04 | A03 | A02 | A01 | A00        | Reset value |
|          | R/W        | R/W | R/W | R/W | R/W | R/W | R/W | R/W   | R/W        | R/W  | R/W | R/W | R/W | R/W | R/W | R/W        | -           |
| R/W<br>X | :Re<br>:Ur |     |     |     |     |     |     |       |            |      |     |     |     |     |     |            |             |

DataSheet4U.com

84

### ■ El<sup>2</sup>OS Status Register (ISCS)

The EI<sup>2</sup>OS status register (ISCS) is an 8-bit register that sets the method to update the buffer address pointer and I/O address pointer, transfer data format (byte/word), and transfer direction.

Figure 3.5-13 shows the bit configuration of the EI<sup>2</sup>OS status register (ISCS).



Figure 3.5-13 Configuration of El<sup>2</sup>OS Status Register (ISCS)

DataShe

www.DataSheet4U.com

### Buffer Address Pointer (BAP)

The buffer address pointer (BAP) is a 24-bit register and sets the 16-MB addresses where data is transferred to or from I/O area. When the BAP updating/fixing select bit of the EI<sup>2</sup>OS status register (ISCS: BF) is set to "updated", the buffer address pointer (BAP) changes only in the lower 16 bits (BAPH, BAPL) and does not change in the higher 8 bits (BAPH). Figure 3.5-14 shows the bit configuration of the buffer address pointer (BAP).





DataSheet4U.com

DataSheet4U.com

et4U.com

# 3.5.13 Operation of El<sup>2</sup>OS

The flowchart of operation of the El<sup>2</sup>OS using the microcode in the CPU is shown below:

## ■ Operation of El<sup>2</sup>OS





DataSheet4U.com

et4U.com

www.DataSheet4U.com

# 3.5.14 Procedure for Use of El<sup>2</sup>OS

### The procedure for using the El<sup>2</sup>OS is shown below:

## ■ Procedure for Use of El<sup>2</sup>OS



Figure 3.5-16 Procedure for Use of El<sup>2</sup>OS

DataSheet4U.com

88

# 3.5.15 El<sup>2</sup>OS Processing Time

The time required for El<sup>2</sup>OS processing depends on the following factors:

- Setting of El<sup>2</sup>OS status register (ISCS)
- Data length of transfer data

Some interrupt handling time is required at the transition to hardware interrupt processing after completion of data transfer.

### ■ El<sup>2</sup>OS Processing Time (time for one transfer)

• At continuing data transfer (DCT  $\neq$  0, ISCS: SE=0)

The  $EI^2OS$  processing time at continuing data transfer is determined by the setting of the  $EI^2OS$  status register (ISCS) as shown in Table 3.5-10.

#### Table 3.5-10 El<sup>2</sup>OS Execution Time

| Setting of EI <sup>2</sup> OS Termina<br>Control Bit (SE) | ition       | Termina<br>Terminatio<br>from Re | n Request | Ignores Termination<br>Request from Resource |         |  |  |
|-----------------------------------------------------------|-------------|----------------------------------|-----------|----------------------------------------------|---------|--|--|
| Setting of IOA Updating/F<br>Select Bit (IF)              | ixingSheet4 | U.CFixed                         | Updated   | Fixed                                        | Updated |  |  |
| Setting of BAP address                                    | Fixed       | 32                               | 34        | 33                                           | 35      |  |  |
| updating/fixing select bit (BF)                           | Updated     | 34                               | 36        | 35                                           | 37      |  |  |

Unit: Machine cycle (one machine cycle is equal to one clock cycle of the machine clock  $(\phi)$ .)

In addition, compensation is required depending on the conditions at executing  $EI^2OS$  as shown in Table 3.5-11.

| Table 3.5-11 | Compensation | Value for Data | Transfer at El <sup>2</sup> O | S Processing Time |
|--------------|--------------|----------------|-------------------------------|-------------------|
|--------------|--------------|----------------|-------------------------------|-------------------|

| I/O Regis      | Internal Access |        |    |    |
|----------------|-----------------|--------|----|----|
| i/O rtegic     | B/even          | Odd    |    |    |
| Buffer address | Internal access | B/even | 0  | +2 |
| pointer        | Internal access | Odd    | +2 | +4 |

B: Byte data transfer

Even: Word transfer at even address

Odd: Word transfer at odd address

et4U.com

• At end of data counter (DCT) (DCT  $\neq$  0, ISCS: SE=0)

At completion of data transfer by the  $EI^2OS$ , since the hardware interrupt is started, the interrupt handling time is added. The  $EI^2OS$  processing time at the end of counting is calculated by the following expression.

 $El^2OS$  processing time at end of counting =  $El^2OS$  processing time at continuing data transfer +  $(21 + 6 \times Z)$ machine cycles Interrupt handling time

(Z: Compensation value of interrupt handling time)

The interrupt handling time depends on the address set by the stack pointer. Table 3.5-12 shows the compensation value (Z) of the interrupt handling time.

#### Table 3.5-12 Compensation Value (Z) of Interrupt Handling Time

| Address Set by Stack Pointer     | Compensation Value (Z) |
|----------------------------------|------------------------|
| For internal area (even address) | 0                      |
| For internal area (odd address)  | +2                     |

• At termination by termination request from resource (DCT  $\neq$  0, ISCS=1)

If data transfer by the  $EI^2OS$  is terminated during its processing by the termination request from a resource (ICR: S1, S0 = "11<sub>B</sub>"), processing transits to interrupt processing. The  $EI^2OS$  processing time at a termination request from a resource is calculated as follows:

DataShe

 $El^2OS$  processing time at termination during processing = 36 + 6 x Z machine cycles

(Z: Compensation value of interrupt handling time)

Reference: One machine cycle is equal to one clock cycle of the machine clock  $(\phi)$ .

# 3.5.16 Exception Processing Interrupt

The F<sup>2</sup>MC-16LX family performs exception processing when an undefined instruction is executed.

Exception processing is basically the same as interrupt. When an exception is detected between instructions, normal processing is suspended to perform exception processing.

Exception processing is performed when an unexpected operation is performed, and should be used only for starting recovery software at debugging or in an emergency.

#### Exception Processing

Operation of exception processing

The  $F^2MC-16LX$  family treats all instruction codes not defined in the instruction map as undefined instructions. If an undefined instruction is executed, the processing equal to the software interrupt instruction INT # 10 is performed.

At exception processing, the following processing is performed before the transition to interrupt processing:

• The values of dedicated registers (A, DPR, ADB, DTB, PCB, PC, PS) saved to the system stack

DataShe

- The interrupt enable flag (CCR: I) cleared to 0 and an interrupt disabled
- The stack flag (CCR: S) set to 1

The value of the program counter (PC) saved in the stack is a value of the address where undefined instructions are stored. For instruction codes of 2 bytes or more, the value of the program counter (PC) is a value of the address where instruction codes that can be identified as undefined are stored. When the type of exception factor must be determined at exception processing, use the saved program counter (PC).

#### Return from exception processing

When the program counter (PC) indicates an undefined instruction, the interrupt return instruction (RETI) from exception processing is executed to return to exception processing. Some measures such as performing a software reset should be taken when returning from exception processing.

et4U.com

DataSheet4U.com

www.DataSheet4U.com

# 3.5.17 Time Required to Start Interrupt Processing

The time for terminating the currently executing instruction plus the interrupt handling time is required from generation of the hardware interrupt request to execution of the interrupt-processing.

### Time Required to Start Interrupt Processing

The interrupt request sampling wait time and the interrupt handling time (time required for preparation for interrupt processing) are required from generation of the interrupt request and acceptance of interrupt, to execution of the interrupt processing. Figure 3.5-17 shows the interrupt processing time.



Figure 3.5-17 Interrupt Processing Time

It indicates a time from the generation of the interrupt request to the termination of the currently executing instruction.

Whether the interrupt request is generated or not is determined by sampling the interrupt request in the last cycle of each instruction. The CPU cannot recognize the interrupt request during execution of each instruction, as a result wait time occurs.

Reference: The interrupt request sampling wait time is longest when the interrupt request is generated immediately after starting execution of the POPW, RW0, ...RW7 instructions with the longest execution cycle (45 machine cycles).

et4U.com

#### • Interrupt handling time ( $\theta$ machine cycles)

The CPU requires an interrupt handling time of  $\theta$  machine cycles to save the dedicated registers to the system stack and fetch the interrupt vector table address after accepting the interrupt request. The interrupt handling time ( $\theta$ ) is obtained using the following equations.

 $\theta = 24 + 6 \text{ x Z}$  machine cycles (Z: compensation value of interrupt handling time)

The interrupt handling time depends on the address set by the stack pointer. Table 3.5-13 shows the compensation value (Z) of the interrupt handling time.

Table 3.5-13 Compensation Value (Z) of Interrupt Handling Time

| Address Set by Stack Pointer     | Compensation Value (Z) |
|----------------------------------|------------------------|
| For internal area (even address) | 0                      |
| For internal area (odd address)  | +2                     |

Reference: One machine cycle is equal to one clock cycle of the machine clock  $(\phi)$ .

et4U.com

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

# 3.5.18 Stack Operation for Interrupt Processing

When an interrupt is accepted, the values of dedicated registers are automatically saved to the system stack before transition to interrupt processing. At completion of interrupt processing, the values of the dedicated registers are automatically returned from the system stack.

## Stack Operation at Starting Interrupt Processing

When an interrupt is accepted, the CPU automatically saves the values of the current-dedicated registers in the system stack in the following order.

- Accumulator (AH, AL)
- Direct page register (DPR)
- Additional data bank register (ADB)
- Data bank register (DTB)
- Program bank register (PCB)
- Program counter (PC)
- Processor status (PS)

Figure 3.5-18 shows the stack operation at starting interrupt processing.

DataShe

www.DataSheet4U.com



## Figure 3.5-18 Stack Operation at Starting Interrupt Processing

## ■ Stack Operation at Return from Interrupt Processing

When the interrupt return instruction (RETI) is executed after completion of interrupt processing, the values of the dedicated registers (PS, PC, PCB, DTB, ADB, DPR, AL, AH) are returned to each register from the system stack, and the dedicated registers are returned to the state before interrupt processing was started.

DataSheet4U.com

et4U.com

# 3.5.19 Program Example of Interrupt Processing

This section gives a program example of interrupt processing.

# Program Example of Interrupt Processing

#### Processing specification

This is an example of interrupt program using external interrupt 4 (INT4).

• Coding example

| 4    | 1 1    | $\sim$ | $\sim$ | m  | ۱. |
|------|--------|--------|--------|----|----|
| · ZL | 1.1    |        | U      | 11 | ١. |
| _    | $\sim$ | ~      | -      |    |    |

|         |        |                   | - | Port 2 direction register                            |        |
|---------|--------|-------------------|---|------------------------------------------------------|--------|
|         | EQU    |                   |   | Interrupt/DTP enable register                        |        |
| EIRR    |        |                   |   | Interrupt/DTP flag                                   |        |
| ELVR    | ~      |                   |   | Request level setting register                       |        |
| ICR00   | EQU    | OBOH              | ; | Interrupt control register                           |        |
| STACK   | SSEG   |                   | ; | Stack                                                |        |
| RW      | 100    |                   |   |                                                      |        |
| STACK_T | RW     | 1                 |   |                                                      |        |
| STACK   | ENDS   |                   |   |                                                      |        |
| ;Ma     | ain pi | rogram            |   | D                                                    | ataShe |
| CODE    | CSEG   |                   |   |                                                      |        |
| ;       |        |                   |   |                                                      |        |
| START:  |        |                   |   |                                                      |        |
|         | MOV    | RP,#0             | ; | The general-purpose register uses the starting bank. |        |
|         | MOV    | ILM,#07H          | ; | ILM in PS set to level 7                             |        |
|         | MOV    | A,#!STACK_T       | ; | System stack set                                     |        |
|         | MOV    | SSB,A             |   |                                                      |        |
|         | MOVW   | A,#STACK_T        | ; | Stack pointer set                                    |        |
|         | MOVW   | SP,A              | ; | In this case, S flag = 1, so set to SSP              |        |
|         | MOV    | DDR2,#0000000B    | ; | The P24/INT4 pin set to input.                       |        |
|         | OR     | CCR,#40H          | ; | I flag of CCR in PS set to interrupt enabled         |        |
|         | MOV    | I:ICR00,#00H      | ; | Interrupt level 0 (highest)                          |        |
|         | MOV    | I:ELVR,#00010000B | ; | INT4 as an High level request                        |        |
|         | MOV    | I:EIRR,#00H       | ; | INT4 interrupt factor cleared                        |        |
|         | MOV    | I:ENIR,#10H       | ; | INT4 input enabled                                   |        |
|         | :      |                   |   | -                                                    |        |
| LOOP:   | NOP    |                   | ; | Dummy loop                                           |        |
|         | NOP    |                   |   | * *                                                  |        |
|         | NOP    |                   |   |                                                      |        |
|         | NOP    |                   |   |                                                      |        |
|         | BRA    | LOOP              | ; | Unconditional jump                                   |        |
|         |        |                   |   |                                                      |        |

| ;Interr<br>ED_INT1: | rupt program |                                              |
|---------------------|--------------|----------------------------------------------|
| MOV                 | I:EIRR,#00H  | ; New acceptance of INT4 disabled            |
| NOP                 |              |                                              |
| RETI                |              | ; Return from interrupt                      |
| CODE ENDS           | 5            |                                              |
| ;Vector             | setting      |                                              |
| VECT CSEC           | ABS = OFFH   |                                              |
| ORG                 | OFFDOH       | ; Vector set to interrupt $\#11 (OB_{ m H})$ |
| DSL                 | ED_INT1      |                                              |
| ORG                 | OFFDCH       | ; Reset vector set                           |
| DSL                 | START        |                                              |
| DB                  | 00H          | ; Set to single-chip mode                    |
| VECT ENDS           | 5            |                                              |
| END                 | START        |                                              |

et4U.com

DataShe

DataSheet4U.com

DataSheet4U.com



- Processing specification
  - The EI<sup>2</sup>OS is started by detecting the High level of the signal to be input to the INT4 pin.
  - When the High level is input to the INT4 pin,  $EI^2OS$  is started and the data of port 2 is transferred to memory address " $3000_{\rm H}$ ".
  - The transfer data is 100 bytes. After 100 bytes are transferred, an interrupt is generated at completion of transfer by the El<sup>2</sup>OS transfer.

#### • Coding example

et4U.com

| DDR2    | EQU    | 000012H          | ; | Port 2 direction register                         |         |
|---------|--------|------------------|---|---------------------------------------------------|---------|
| ENIR    | EQU    | 000030H          | ; | Interrupt/DTP enable register                     |         |
| EIRR    | EQU    | 000031H          | ; | Interrupt/DTP factor register                     |         |
| ELVR    | EQU    | 000032H          | ; | Request level setting register                    |         |
| ICR00   | EQU    | 0000B0H          | ; | Interrupt control register                        |         |
| BAPL    | EQU    | 000100H          | ; | Lower of buffer address pointer                   |         |
| BAPM    | EQU    | 000101H          | ; | Middle of buffer address pointer                  |         |
| BAPH    | EQU    | 000102H          | ; | Higher of buffer address pointer                  |         |
| ISCS    | EQU    | 000103H          | ; | EI <sup>2</sup> OS status                         |         |
| IOAL    | EQU    | 000104H          | ; | Lower of I/O address pointer                      |         |
| IOAH    | EQU    | 000105H          | ; | Higher of I/O address pointer                     | DataShe |
| DCTL    | EQU    | 000106H          | ; | Lower of data counter                             |         |
| DCTH    | EQU    | 000107H          | ; | Higher of data counter                            |         |
| ER0     | EQU    | EIRR:0           | ; | External interrupt request flag bit defined       |         |
| STACK   | SSEG   |                  | ; | Stack                                             |         |
|         | RW     | 100              |   |                                                   |         |
| STACK_T | RW 1   | 1                |   |                                                   |         |
| STACK   | ENDS   |                  |   |                                                   |         |
| ; Ma    | ain pi | rogram           |   |                                                   |         |
| CODE    | CSEG   |                  |   |                                                   |         |
| START:  |        |                  |   |                                                   |         |
|         | AND    | CCR,#0BFH        | ; | I flag of CCR in PS cleared to interrupt disabled |         |
|         | MOV    | RP,#00           | ; | Register bank pointer set                         |         |
|         | MOV    | A,#!STACK_T      | ; | System stack set                                  |         |
|         | MOV    | SSB,A            |   |                                                   |         |
|         | MOVW   | A,#STACK_T       | ; | Stack pointer                                     |         |
|         |        |                  | ; | in this case, S flag = 1, so set to SSP           |         |
|         | MOVW   | SP,A             |   |                                                   |         |
|         | MOV    | I:DDR2,#0000000B | ; | P24/INT4 pin set to input                         |         |
|         | MOV    | BAPL,#00H        | ; | Buffer address set (003000H)                      |         |
|         | MOV    | BAPM,#30H        |   |                                                   |         |
|         | MOV    | BAPH,#00H        |   |                                                   |         |
|         |        |                  |   |                                                   |         |

|       | MOV  |            | ;<br>; | I/O Address not updated, byte transfer performed,<br>and buffer address updated<br>Data transferred from I/O to buffer,<br>and termination by resource |         |
|-------|------|------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
|       | MOV  | IOAL,#00H  | ;      | Transfer source address set<br>(port 2: 0000002 <sub>H</sub> )                                                                                         |         |
|       | MOV  | IOAH,#00H  |        |                                                                                                                                                        |         |
|       | MOV  | DCTL,#64H  | ;      | Transfer byte count set (100 bytes)                                                                                                                    |         |
|       | MOV  | DCTH,#00H  |        |                                                                                                                                                        |         |
|       | MOV  |            |        | EI <sup>2</sup> OS channel 0, EI <sup>2</sup> OS enabled,                                                                                              |         |
|       |      |            |        | and interrupt level 0 (highest)                                                                                                                        |         |
|       |      |            |        | INT4 set as an High level request                                                                                                                      |         |
|       |      |            |        | INT4 interrupt factor cleared                                                                                                                          |         |
|       |      |            |        | INT4 interrupt enabled                                                                                                                                 |         |
|       | MOV  |            |        | ILM in PS set to level 7                                                                                                                               |         |
|       | OR   | CCR,#40H   | ;      | I flag of CCR in PS set to interrupt enabled                                                                                                           |         |
|       | :    |            |        |                                                                                                                                                        |         |
| LOOP: |      |            |        | Infinite loop                                                                                                                                          |         |
|       |      |            |        |                                                                                                                                                        |         |
| WARI  |      | ER0        | ;      | Interrupt/DTP request flag cleared                                                                                                                     |         |
|       | :    |            |        |                                                                                                                                                        |         |
|       |      |            |        | EI <sup>2</sup> OS termination factor checked,                                                                                                         |         |
|       | :    |            |        | data processing during buffering                                                                                                                       |         |
|       |      |            | ;      | EI <sup>2</sup> OS reset                                                                                                                               |         |
| CODE  | RETI |            |        |                                                                                                                                                        |         |
| CODE  | ENDS |            |        |                                                                                                                                                        | DataShe |
|       |      | ABS = OFFH |        |                                                                                                                                                        |         |
| VECT  |      |            |        | Master act to intermet #11 (AD )                                                                                                                       |         |
|       |      | WARI       | ;      | Vector set to interrupt $\#11 (0B_{\mathrm{H}})$ .                                                                                                     |         |
|       |      |            |        | Deapt weaton got                                                                                                                                       |         |
|       |      | START      | i      | Reset vector set                                                                                                                                       |         |
|       | DBL  |            |        | Set to gingle abin mode                                                                                                                                |         |
| VECT  | ENDS |            | ï      | Set to single-chip mode                                                                                                                                |         |
| VECI  |      | START      |        |                                                                                                                                                        |         |
|       | сиЛ  | START      |        |                                                                                                                                                        |         |

et4U.com

DataSheet4U.com

# 3.6 Reset

When a reset factor occurs, the CPU immediately suspends the current processing and starts the reset operation.

The reset factors are as follows:

- Power-on reset
- Overflow of watchdog timer
- Software reset request
- Generation of external reset request (RST pin)

## Reset Factors

| Reset                | Factor                                | Machine<br>Clock | Watchdog<br>Timer | Oscillation<br>Stabilization<br>Waiting |
|----------------------|---------------------------------------|------------------|-------------------|-----------------------------------------|
| Power on reset       | At power on                           | MCLK             | Stops             | Generated                               |
| Watchdog timer reset | Watchdog timer overflow               | MCLK             | Stops             | None                                    |
| Software reset       | 0 is written to the RST bit           | MCLK             | Stops             | None                                    |
| External reset       | Input L level to $\overline{RST}$ pin | MCLK             | Stops             | None                                    |

et4U.com

MCLK: Main clock

#### Power on reset

- The power on reset occurs at power on.
- The reset operation is executed after the oscillation stabilization wait time of  $2^{18}$ /HCLK has elapsed.

#### Watchdog timer reset

- Unless the watchdog timer is periodically cleared at the interval time to be repeatedly counted after starting, an overflow occurs, causing a reset.
- The oscillation stabilization wait time is not generated by a watchdog timer reset.

Reference: For the details of the watchdog timer, see "CHAPTER 6 WATCHDOG TIMER".

#### Software reset

- The software reset occurs when 0 is written to the internal reset signal generate bit (LPMCR: RST) in the low-power consumption mode control register.
- The oscillation stabilization wait time is not generated by a software reset.

DataSheet4U.com

www.DataSheet4U.com

#### • External reset

- The external reset occurs when a Low level is input to the external reset pin (RST pin). The time for inputting Low level from the RST pin requires at least 16 machine cycles (main clock).
- An external reset does not require the oscillation stabilization wait time.

| Notes: | <ul> <li>If an external reset request is generated from the RST pin during writing by a transfer instruction (such as MOV), the reset cancel wait state is set after completion of the transfer instruction, so writing is terminated normally. For a string instruction (such as MOVS), the reset cancel wait state may be set before completion of transfer by a specified counter value.</li> <li>When stop mode, sub-clock mode, sub-sleep mode and watch mode are returned to main clock mode using an external reset pin (RST pin), input level "L" for at least "the oscillation time of the oscillator(*) + 100µs + 16 machine cycles (main clock)".</li> <li>*: The oscillation time of the oscillator is the time required to reach 90% of amplitude. It takes several to dozens of ms for crystal oscillators, hundreds of µs to several ms for FAR/ceramic oscillators, and 0 ms for external clocks.</li> </ul> |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

DataSheet4U.com

# 3.6.1 Reset Factors and Oscillation Stabilization Wait Time

The oscillation stabilization wait time after reset varies depending on the reset factors.

# Reset Sources and Oscillation Stabilization Wait Time

| Reset Factor   | Oscillation Stabilization Wait Time<br>(The parenthesized value is a calculation example<br>at 4 MHz oscillation clock frequency.) |
|----------------|------------------------------------------------------------------------------------------------------------------------------------|
| Power on reset | 2 <sup>18</sup> /HCLK (approx. 65.54 ms)                                                                                           |
| Watchdog reset | None                                                                                                                               |
| Software reset | None                                                                                                                               |
| External reset | None                                                                                                                               |

HCLK: Oscillation clock

HCLK: Oscillation clock

et4U.com

DataShe



Voltage step-down circuit stabilization wait time 2<sup>18</sup>/HCLK Oscillation stabilization wait time

#### DataSheet4U.com

# Figure 3.6-1 Oscillation Stabilization Wait time for the MB90385 Series during a Power-on Reset

DataSheet4U.com

| Clock Select Bit |     | Oscillation Stabilization Wait Time<br>(The parenthesized value is a calculation example |  |
|------------------|-----|------------------------------------------------------------------------------------------|--|
| WS1              | WS0 | at 4 MHz oscillation clock frequency.)                                                   |  |
| 0                | 0   | 2 <sup>10</sup> /HCLK (256 μs)                                                           |  |
| 0                | 1   | 2 <sup>13</sup> /HCLK (approx. 2.048 ms)                                                 |  |
| 1                | 0   | 2 <sup>15</sup> /HCLK (approx. 8.192 ms)                                                 |  |
| 1                | 1   | 2 <sup>17</sup> /HCLK (approx. 32.77 ms) *                                               |  |

#### Table 3.6-3 Oscillation Stabilization Wait Time by Clock Select Register (CKSCR)

HCLK: Oscillation clock

\*: At power on, the oscillation stabilization wait time is fixed at  $2^{18}$ /HCLK (approximately 65.54 ms).

Note: Ceramic or crystal oscillators require the oscillation stabilization wait time of several milliseconds to some tens of milliseconds to stabilize oscillation. Set the oscillation stabilization wait time required for the oscillator to be used.

et4U.com

For the details of the clock, see "3.7 Clocks".

DataSheet4U.com

DataShe

102

# 3.6.2 External Reset Pin

The external reset pin ( $\overline{RST}$  pin) is a reset input pin. Input of an external Low level generates a reset factor. The MB90385 series starts the reset operation in synchronization between the CPU and clock.

# Block Diagram of External Reset Pin





# 3.6.3 Reset Operation

During reset operation, the mode for reading mode data and reset vectors is set according to the settings of the mode pins (MD0 to MD2) and a mode fetch is executed. When the oscillation clock is returned from stop states (power on, stop mode) by a reset, a mode fetch is executed after the elapse of the main clock oscillation stabilization wait time.

## Flowchart of Reset Operation

Figure 3.6-3 shows the flowchart of reset operation.





DataShe

## Oscillation Stabilization Wait Time in Standby Mode

When a reset occurs during operation in a stop mode or subclock mode in which the oscillation clock is stopped, and oscillation stabilization wait time of  $2^{17}$ /HCLK (approximately 32.77 ms when the oscillation clock operates at 4 MHz) is generated.

Reference: For standby mode operation, see Section "3.8 Low-power Consumption Mode".

#### Mode Pin

The MD0 to MD2 mode pins are external pins. They are used to set the mode for reading data and reset vectors.

Reference: For the details of the mode pins (MD0 to MD2), see Section "3.9.3 Memory Access Mode".

DataSheet4U.com

#### Mode Fetch

At transition to the reset operation, the CPU automatically transfers mode data and reset vectors by hardware to the appropriate register in the CPU core. The mode data and reset vector are allocated to four bytes of addresses "FFFFDC<sub>H</sub>" to "FFFFDF<sub>H</sub>". After a reset factor is generated (or after the elapse of the oscillation stabilization wait time), the CPU immediately outputs the addresses of the mode data and reset vectors to the bus to fetch the mode data and reset vectors. This operation is called "mode fetch." At completion of mode fetch, the CPU starts processing from the address indicated by the reset vector.





et4U.com

Note:

To read the mode data and reset vectors from internal ROM is set by the mode pins (MD0 to MD2). For use in the single-chip mode, the mode pins should be set to the internal vector mode.

#### Mode data

The mode data is used to set a memory access type or a memory access area after completion of the reset operation. It is allocated to address "FFFFDF<sub>H</sub>". During the reset operation, this data is read automatically by a mode fetch and stored in the mode register.

#### Reset vectors

The reset vectors are the start addresses of execution after completion of the reset operation. They are allocated to addresses "FFFFDC<sub>H</sub>" to "FFFFDE<sub>H</sub>". During the reset operation, these vectors are read automatically by a mode fetch and transferred to the program counter.

# 3.6.4 Reset Factor Bit

# To check reset factors, read the value of the watchdog timer control register (WDTC).

## Reset Factor Bit

Each reset factor provides a flip-flop circuit corresponding to each factor. The state of the flip-flop circuit can be checked by reading the value of the watchdog timer control register (WDTC). If it is necessary to identify reset factors after completion of the reset operation, read the value of the watchdog timer control register (WDTC) by software to branch the value to the appropriate program.



Figure 3.6-5 Block Diagram of Reset Factor Bits

DataShe

et4U.com

## Correspondence of Reset Factor Bit and Reset Factor

Figure 3.6-6 shows the configuration of the reset factor bits in the watchdog timer control register (WDTC: PONR, WRST, ERST, SRST).



#### Figure 3.6-6 Configuration of Reset Factor Bit

Table 3.6-4 Correspondence of Reset Factor Bit Value and Reset Factor

| Reset Factor                                                  | PONR  | WRST | ERST | SRST |
|---------------------------------------------------------------|-------|------|------|------|
| Power on reset                                                | 1     | Х    | Х    | Х    |
| Watchdog timer reset                                          | *     | 1    | *    | *    |
| Input of external reset signal to $\overline{\text{RST}}$ pin | *     | *    | 1    | *    |
| Software reset (RST bit) DataSheet4U                          | .com* | *    | *    | 1    |

DataShe

\*: The previous state is held

X: Undefined

# Notes on Reset Factor Bit

#### Power on reset

When a power on reset is executed, the PONR bit is set to 1 after completion of the reset operation. Any reset factor bit other than the PONR bit is undefined. When the PONR bit is 1 after completion of the reset operation, ignore the value of any bit other than the PONR bit.

#### At two or more reset factors

The reset factor bit is set to 1 according to each reset factor even when two or more reset factors are generated. For example, if the watchdog timer overflows and an external reset request is generated from the  $\overline{\text{RST}}$  pin at the same time, both WRST and ERST bits are set to 1 after completion of the reset operation.

#### Clearing of reset factor bit

Once set, the reset factor bit is not cleared even if any reset factor other than the set factor is generated. The reset factor bit is cleared after the completion of reading the watchdog timer control register (WDTC).

Reference: For the watchdog timer, see "CHAPTER 6 WATCHDOG TIMER".

DataSheet4U.com

et4U.com

# 3.6.5 State of Each Pin at Reset

## This section explains the state of each pin at reset.

#### State of Pins at Reset

The state of the pins during reset operation is determined by the settings of the mode pins (MD0 to MD2).

#### When internal vector mode set:

If the internal vector mode is set, all I/O pins enter the high-impedance state and mode data is read to internal ROM.

#### State of Pins after Mode Data Read

The I/O pins are all set to the high-impedance state, and the mode data read destination is the internal ROM.

Note: Don't let the device connected to pins that enter the high-impedance state malfunction when the reset factor is generated.

et4U.com

DataSheet4U.com

# 3.7 Clocks

The clock generation section controls the internal clock that is an operating clock for the CPU or resources. The clock generated by the clock generation section is called a "machine clock" and one cycle of the machine clock is a machine cycle. The clock to be supplied from a high-speed oscillator is called an "oscillation clock" and the 2-frequency division of the oscillation clock is called a "main clock." The 4-frequency division of a clock to be supplied from a low-speed oscillator is called a "subclock" and the clock to be supplied from the PLL oscillation is called a "PLL clock."

#### Clock

et4U.com

The clock generation section has oscillators and generates an oscillation clock by connecting an oscillator to oscillation pins. External clocks that are input to the oscillation pins can be used as oscillation clocks. The PLL clock multiplying circuit can be used to generate four clocks for multiplying the oscillation clock. The clock generation section controls the oscillation stabilization wait time, PLL clock multiplying, and selects internal clock by the clock selector.

#### Oscillation clock (HCLK)

This clock is generated by connecting an oscillator or inputting an external clock to the high-speed DataSheet oscillation pins (X0 and X1).

#### Main clock (MCLK)

This clock is 2-frequency division of oscillation clock, and is an input clock to the timebase timer and clock selector.

#### Subclock (SCLK)

This clock is a clock with 4-frequency division of the clock generated by connecting an oscillator or inputting an external clock to the low-speed oscillation pins (X0A and X1A). It can also be used as an operating clock for the watch timer or as a low-speed machine clock.

#### PLL clock (PCLK)

This clock is multiplied by the PLL clock multiplying circuit (PLL oscillator). It can be selected from four types of clock according to the setting of the multiplication rate select bits (CKSCR: CS1, CS0).

#### Machine clock

This clock is an operating clock for the CPU and the resources. One cycle of the machine clock is a machine cycle  $(1/\phi)$ . One clock can be selected from the main clock, subclock, and four types of PLL clock.

- When the operating voltage is 5 V, the oscillation clock can oscillate at 3 MHz to 16 MHz. The maximum operating frequency of the CPU or resources is 16 MHz. If a multiplication rate that exceeds the maximum operating frequency is set, the device does not operate normally. If the oscillation clock is 16 MHz, the multiplication rate of PLL clock can only be set to x1. The PLL oscillator oscillates in the range of 3 MHz to 16 MHz, which varies depending on the operating voltage and multiplication rate.
  - There is no sub-clock in MB90F387S and MB90387S.

## Clock Supply Map

Machine clocks generated by the clock generation section are supplied as operating clocks of the CPU and resources. The operation of the CPU and resources is affected by switching among the main clock, subclock, and PLL clock (clock mode) or by switching the multiplication rate of PLL clock. The clock-divided output of the timebase timer is supplied to some resources, and the operating clock can be selected for each resource.

Figure 3.7-1 shows the clock supply map.

et4U.com

DataSheet4U.com

www.DataSheet4U.com



#### Figure 3.7-1 Clock Supply Map

DataShe

DataSheet4U.com

et4U.com

# 3.7.1 Block Diagram of Clock Generation Section

The clock generation section consists of the following five blocks:

- Oscillation clock generator/subclock generator
- PLL multiplying circuit
- Clock selector
- Clock select register (CKSCR)
- Oscillation stabilization wait time selector

# Block Diagram of Clock Generation Section

Figure 3.7-2 shows the block diagram of the clock generation section.

It also includes the standby controller and timebase timer circuit.



#### Figure 3.7-2 Block Diagram of Clock Generation Section

DataSheet4U.com

et4U.com

112

DataSheet4U.com

www.DataSheet4U.com

#### Oscillation clock generator

This generator generates an oscillation clock (HCLK) by connecting an oscillator or inputting an external clock to the high-speed oscillation pins.

#### Subclock generator

This generator generates a subclock (SCLK) by connecting an oscillator or inputting an external clock to the low-speed oscillation pins (X0A, X1A).

#### PLL multiplying circuit

This circuit multiplies the oscillation clock and supplies it as a PLL clock (PCLK) to the clock selector.

#### Clock selector

This selector selects the clock that is supplied to the CPU or resources from the main clock, subclock, and four types of PLL clock.

#### Clock select register (CKSCR)

This register switches between the oscillation clock and the PLL clock, and between the main clock and the subclock, selects the oscillation stabilization wait time, and the multiplication rate of the PLL clock.

#### Oscillation stabilization wait time selector

This selector selects the oscillation stabilization wait time of the oscillation clock. There are four timebase timer outputs to select.

Note: There is no sub-clock in MB90F387S and MB90387S.

et4U.com

# 3.7.2 Register in Clock Generation Section

This section explains the register in the clock generation section.

# Register in Clock Generation Section and List of Reset Values

| Figure 3.7-3 Clo              | ock Se | lect Reg | gister a | nd List | of Res | et Value | es |   |
|-------------------------------|--------|----------|----------|---------|--------|----------|----|---|
| bit                           | 15     | 14       | 13       | 12      | 11     | 10       | 9  | 8 |
| Clock select register (CKSCR) |        |          |          |         | 1      | 1        | 0  | 0 |

et4U.com

DataShe

DataSheet4U.com

DataSheet4U.com

114

DataSh4+U.com

# 3.7.3 Clock Select Register (CKSCR)

The clock select register (CKSCR) switches between the main clock, subclock, and PLL clock, selects the oscillation stabilization wait time and the multiplication rate of PLL clock.

Configuration of Clock Select Register (CKSCR)





www.DataSheet4U.com

| Table 3.7-1 | Function of Ea | ch Bit of Clock | Select Register | (CKSCR) (1/2) |
|-------------|----------------|-----------------|-----------------|---------------|
|-------------|----------------|-----------------|-----------------|---------------|

|       |                | Bit Name                                        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|----------------|-------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | bit 9<br>bit 8 | CS1, CS0:<br>Multiplication rate select<br>bits | These bits are used to select the multiplication rate of the PLL clock from four types.<br>When reset, they all return to their reset value.<br><b>Note:</b> When the PLL clock is selected (CKSCR: MCS = 0), writing is inhibited. When<br>changing the multiplication rate, write 1 to the PLL clock select bit (CKSCR:<br>MCS), rewrite the multiplication rate select bits (CKSCR: CS1, CS0), and then<br>return the PLL clock select bit (CKSCR: MCS) to "0".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| I.com | bit 10         | MCS:<br>PLL clock select bit                    | <ul> <li>This bit sets where to select the main clock or PLL clock as a machine clock.</li> <li>If the machine clock is switched from the main clock to the PLL clock (CKSCR: MCS = 1&gt; 0), the oscillation stabilization wait time of the PLL clock is generated and then the mode transits to the PLL clock mode. The timebase timer is automatically cleared. When the main clock mode is switched to PLL clock, the oscillation stabilization wait time is fixed to 2<sup>14</sup>/HCLK (approximately 4.1 ms when the oscillation clock operates at 4 MHz). When subclock mode is switched to PLL clock, the oscillation stabilization wait time uses the specified values in the oscillation stabilization wait time selection bits (CKSCR: WS1, WS0).</li> <li>When reset, this bit returns to its reset value.</li> <li>Notes: 1. If both the MCS and SCS bits are 0, the SCS bit is preferred and the subclock mode is set.</li> <li>2. When switching the machine clock from the main clock to the PLL clock (CKSCR: MCS = 1&gt; 0), use the interrupt enable bit of the timebase timer (TBTC: TBIE) or the interrupt level mask register (ILM: ILM2 to ILM0) to disable the timebase timer interrupts.</li> </ul>                                                                                                                                                                                                                                                                                                                                       |
|       | bit 11         | SCS:<br>Subclock select bit                     | <ul> <li>This bit sets whether to select main clock or subclock as machine clock.</li> <li>When the machine clock is switched from the main clock to the subclock (CKSCR: SCS = 1&gt; 0), the main clock mode transits to the subclock mode in synchrony with the subclock (approximately 130 µs).</li> <li>When the machine clock is switched from the subclock to the main clock (CKSCR: SCS = 0&gt; 1), the subclock mode transits to the main clock mode after the main clock oscillation stabilization wait time is generated. The timebase timer is automatically cleared.</li> <li>When reset, this bit returns to its reset value.</li> <li>Notes: 1. If both the MCS and SCS bits are 0, the SCS bit is preferred and the subclock mode is set.</li> <li>2. If both the subclock select bit (CKSCR: MCS) and PLL clock select bit (CKSCR: SCS) are 0, the subclock is preferred.</li> <li>3. When switching the machine clock from the main clock to the subclock (CKSCR: SCS = 1&gt; 0), use the interrupt enable bit of the timebase timer (TBTC: TBIE) or the interrupt level mask register (ILM: ILM2 to ILM0) to disable the timebase timer.</li> <li>4. At power on or when the stop mode is cancelled, the subclock oscillation stabilization wait time (approximately 2 s) is generated. Therefore, if the mode is subclock mode to the subclock mode to the subclock mode, the oscillation stabilization wait time is generated.</li> <li>5. There is no sub-clock in MB90F387S and MB90387S. This bit should be set to initial values.</li> </ul> |

|                  | Bit Name                                                        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------------|-----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 13<br>bit 12 | WS1, WS0:<br>Oscillation stabilization<br>wait time select bits | These bits select an oscillation stabilization wait time of the oscillation clock when stop mode was released, when transition occurred from subclock mode to main clock mode, or when transition occurred from four timebase timer outputs.<br>• These bits are used to select from four timebase timer outputs.<br>When reset, they all return to their reset value.<br>Note: Set an oscillation stabilization wait time appropriate for an oscillator. For details, see Section "3.6.1 Reset Factors and Oscillation Stabilization Wait Time".<br>When the main clock mode is switched to PLL clock mode, the oscillation stabilization wait time is fixed to $2^{14}$ /HCLK (approximately 4.1 ms when the oscillation clock operates at 4 MHz). When subclock mode is switched to PLL clock mode, the oscillation stabilization wait time uses the specified values in the WS1 and WS0 bits. For PLL clock mode is switched to PLL clock mode, or when PLL clock mode is switched to PLL clock mode, or when PLL clock mode is switched to PLL clock mode, or when PLL clock mode is switched to PLL clock mode. |
| bit14            | MCM:<br>PLL clock operation bit                                 | <ul> <li>This bit indicates whether to select main clock or PLL clock as machine clock.</li> <li>If the PLL clock operation flag bit (CKSCR: MCM) is 1 and the PLL clock select bit (CKSCR: MCS) is 0, it indicates that the oscillation stabilization wait time of the PLL clock is taken.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| bit 15           | SCM:<br>Subclock operation bit                                  | <ul> <li>This bit indicates whether to select main clock or the subclock as the machine clock.</li> <li>If the subclock operation flag bit (CKSCR: SCM) is 0 and the subclock select bit (CKSCR: SCS) is 1, it indicates that the subclock switches to the main clock. If the subclock operation flag bit (CKSCR: SCM) is 1 and the subclock select bit (CKSCR: SCS) is 0, it indicates that the main clock switches to the subclock.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

## Table 3.7-1 Function of Each Bit of Clock Select Register (CKSCR) (2/2)

et4U.com

DataSheet4U.com

# 3.7.4 Clock Mode

#### Clock modes have a main clock mode, subclock mode, and PLL clock mode.

## Clock Mode

Main clock mode

In the main clock mode, a clock with 2-frequency division of the clock generated by connecting an oscillator or inputting an external clock to the high-speed oscillation pins (X0, X1) is used as the operating clock for the CPU or resources.

#### Subclock mode

In the subclock mode, a clock with 4-frequency division of the clock generated by connecting an oscillator or inputting an external clock to the low-speed oscillation pins (X0A, X1A) is used as the operating clock for the CPU or resources.

#### PLL clock mode

In the PLL clock mode, the oscillation clock multiplied by the PLL clock multiplying circuit (PLL oscillator circuit) is used as the operating clock for the CPU or resources. The PLL clock multiplication rate can be set using the clock select register (CKSCR: CS1, CS0).

DataShe

DataSheet4U.com

There is no sub-clock in MB90F387S and MB90387S.

#### Transition of Clock Mode

In clock modes, the setting of the PLL clock select bit (CKSCR: MCS) and subclock select bit (CKSCR: SCS) transits to the main clock mode, subclock mode or PLL clock mode.

Transition from main clock mode to PLL clock mode

If the PLL clock select bit (CKSCR: MCS) is rewritten from 1 to 0, the main clock switches to the PLL clock after the PLL oscillation stabilization wait time  $(2^{14}/\text{HCLK})$  has elapsed.

Transition from PLL clock mode to main clock mode

If the PLL clock select bit (CKSCR: MCS) is rewritten from 0 to 1, the PLL clock switches to the main clock when the edge of the PLL clock matches the edge of the main clock (after 1 to 8 PLL clocks).

Transition from main clock mode to subclock mode

If the subclock select bit (CKSCR: SCS) is rewritten from 1 to 0, the main clock switches to the subclock synchronizing the subclock (approx.130  $\mu$ s).

et4U.com

Note:

Transition from subclock mode to main clock mode

When the subclock select bit (CKSCR: SCS) is rewritten from 0 to 1, the subclock switches to the main clock after the main clock oscillation stabilization wait time has elapsed.

Notes: When sub-clock mode are returned to main clock mode using an external reset pin (RST pin), input level "L" for at least "the oscillation time of the oscillator $* + 100\mu s + 16$  machine cycles (main clock)". \*: The oscillation time of the oscillator is the time required to reach 90% of amplitude. It takes several to dozens of ms for crystal oscillators, hundreds of  $\mu$ s to several ms for FAR/ceramic oscillators, and 0 ms for external clocks. There is no sub-clock in MB90F387S and MB90387S. Transition from PLL clock mode to subclock mode When the subclock select bit (CKSCR: SCS) is rewritten from 1 to 0, the PLL clock switches to the subclock. Transition from subclock mode to PLL clock mode When the subclock select bit (CKSCR: SCS) is rewritten from 0 to 1, the subclock switches to the PLL clock after the main clock oscillation stabilization wait time has elapsed. Selection of PLL Clock Multiplication Rate The PLL clock multiplication rate can be set from x1 to x4 by writing values of "00B" to "11B" to the multiplication rate select bits (CKSCR: CS1, CS0). Machine Clock DataSheet4U.com The PLL clock, main clock, and subclock output from the PLL multiplying circuit are used as machine clocks supplied to the CPU or resources. Any of the main clock, PLL clock, and subclock can be selected by writing to the subclock select bit (CKSCR: SCS) and the PLL clock select bit (CKSCR: MCS). Notes: • The machine clock is not switched immediately even when the PLL clock select bit (CKSCR: MCS) and the subclock select bit (CKSCR: SCS) are rewritten. When running resources that depend on the machine clock, after switching the machine clock, refer the value of the PLL clock operation flag bit (CKSCR: MCM) or the subclock operation flag bit (CKSCR:SCM) to check that the machine clock has been switched. When the PLL clock select bit (CKSCR: MCS) is 0 (PLL clock mode) and the subclock select bit (CKSCR: SCS) is 0 (subclock mode), the SCS bit is preferred, transiting to the subclock mode. • When transiting a clock mode, do not transit a clock mode to any other clock mode or a low-power

consumption mode until the completion of transition. Refer the MCM and SCM bits in the clock select register (CKSCR) to check that the transition of a clock mode is completed. If the mode is switched to another clock mode or low-power-consumption mode before completion of switching, the mode may not be switched.

• There is no sub-clock in MB90F387S and MB90387S.

et4U.com

Figure 3.7-5 shows the transition of a clock mode.



Figure 3.7-5 Clock Mode Transition

DataShe

DataSheet4U.com

et4U.com

120

Г

|        | <ul> <li>(1) 0 write to MCS bit</li> <li>(2) PLL clock oscillation stabilization waiting termination &amp; CS1, CS0 = 00</li> <li>(3) PLL clock oscillation stabilization waiting termination &amp; CS1, CS0 = 01</li> <li>(4) PLL clock oscillation stabilization waiting termination &amp; CS1, CS0 = 10</li> <li>(5) PLL clock oscillation stabilization waiting termination &amp; CS1, CS0 = 11</li> <li>(6) 1 write to MCS bit (hardware standby and the watchdog reset included)</li> <li>(7) Synchronous timing of PLL clock and main clock</li> <li>(8) 0 write to SCS bit</li> <li>(9) Subclock oscillation stabilization waiting termination (maximum 2<sup>14</sup>/SCLK)</li> <li>(10) 1 write to SCS bit</li> <li>(11) Main clock oscillation stabilization waiting termination</li> <li>(12) Main clock oscillation stabilization waiting termination &amp; CS1, CS0 = 00</li> <li>(13) Main clock oscillation stabilization waiting termination &amp; CS1, CS0 = 01</li> <li>(14) Main clock oscillation stabilization waiting termination &amp; CS1, CS0 = 01</li> <li>(15) Main clock oscillation stabilization waiting termination &amp; CS1, CS0 = 01</li> <li>(16) 1 write to SCS bit</li> <li>(17) Synchronous timing of PLL clock and subclock</li> </ul> MCS : PLL clock select bit of clock select register (CKSCR) MCM : PLL clock display bit of clock select register (CKSCR) SCS : Subclock display bit of clock select register (CKSCR) SCM : Subclock display bit of clock select register (CKSCR) SCM : Subclock display bit of clock select register (CKSCR) | DataShee |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
|        | DataSheet4U.com                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Dame     |
| Notes: | <ul> <li>The reset value of the machine clock is in the main clock mode (MCS = 1, SCS = 1).</li> <li>When SCS and MCS are both 0, SCS is preferred, and the subclock is selected.</li> <li>When transiting from the subclock mode to the PLL clock mode, set the oscillation stabilizat time select bit of the CKSCR register (WS1, WS0) to 10<sub>B</sub> or 11<sub>B</sub>.</li> <li>There is no sub-clock in MB90F387S and MB90387S.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ion wait |

et4U.com

# 3.7.5 Oscillation Stabilization Wait Time

At power on or return from the stop mode, when the oscillation clock is stopped, a time taken until the oscillation clock stabilizes (oscillation stabilization wait time) is required after starting an oscillation. The oscillation stabilization wait time is also required for switching the clock mode from main clock mode to PLL clock mode, from main clock mode to subclock mode, from subclock mode to main clock mode, and from subclock mode to PLL clock mode.

# Operation During Oscillation Stabilization Wait Time

Ceramic and crystal oscillators require several to some tens of milliseconds to reach a stable oscillation frequency after starting oscillation. Therefore when, immediately after an oscillation starts, once the CPU operation is disabled and then an oscillation stabilizes after the elapse of oscillation stabilization wait time, the machine clock is supplied to the CPU.

The oscillation stabilization wait time varies with the type of oscillator (ceramic, crystal, etc.).

It is necessary to select a oscillation stabilization wait time appropriate to an oscillator to be used.

The oscillation stabilization wait time can be selected using the clock select register (CKSCR).

When clock mode is switched from main clock to PLL clock, main clock to subclock, subclock to main clock, or subclock to PLL clock, the CPU runs in the clock mode set before switching for the oscillation stabilization wait time. After the oscillation stabilization wait time has elapsed, the CPU changes to the specified clock mode. Figure 3.7-6 shows the oscillating operation immediately after it starts.

#### Figure 3.7-6 Operation after Oscillation Stabilization Wait Time



Note:

There is no sub-clock in MB90F387S and MB90387S.

DataSheet4U.com

et4U.com

122

DataSheet4U.com

www.DataSheet4U.com

# 3.7.6 Connection of Oscillator and External Clock

The MB90385 series has a system clock generator and generates an internal clock by connecting an oscillator to the oscillation pins. External clocks input to the oscillation pins can be used as oscillation clocks.

# Connection of Oscillator and External Clock

• Example of connection of crystal oscillator or ceramic oscillator





DataShe

• Example of connection of external clock





Note:

There is no sub-clock in MB90F387S and MB90387S.

DataSheet4U.com

et4U.com

# 3.8 Low-power Consumption Mode

The CPU operation modes are classified as follows according to the selection of the operation clock and the oscillation control of a clock. All the operation modes except the PLL clock mode are low-power consumption modes.

- Clock modes (main clock, PLL clock and subclock modes)
- CPU intermittent operation modes (main clock, PLL clock, and subclock modes)
- Standby modes (sleep, stop, watch, and timebase timer modes)

# CPU Operation Modes and Current Consumption

Figure 3.8-1 shows the relationships between the CPU operation mode and current consumption.





DataSheet4U.com

124

DataSheet4U.com

| ● Pl       | L clock mode                                                                                                                                                                                                         |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | In PLL clock mode, the CPU and resources operate on a PLL multiplying clock of oscillation clock (HCLK).                                                                                                             |
| • Ma       | ain clock mode                                                                                                                                                                                                       |
|            | In main clock mode, the CPU and resources operate on a clock with 2-frequency division of oscillation clock (HCLK). In this mode, the PLL multiplying circuit stops.                                                 |
| • Si       | ibclock mode                                                                                                                                                                                                         |
|            | In subclock mode, the CPU and resources operate on a subclock (SCLK). In this mode, the main clock and PLL multiplying circuit stop.                                                                                 |
|            | The subclock oscillation stabilization wait time (approximately 2 s) is generated at power on or at cancellation of the stop mode. Therefore, if the clock mode transits from the main clock mode to the             |
|            | subclock mode during that period, the oscillation stabilization wait time is generated.                                                                                                                              |
| Note:      | There is no sub-clock in MB90F387S and MB90387S.                                                                                                                                                                     |
| Reference: | For the clock mode, see Section "3.7 Clocks".                                                                                                                                                                        |
| CPU Int    | ermittent Operation Mode DataSheet4U.com                                                                                                                                                                             |
|            | In CPU intermittent operation mode, the CPU performs the intermittent operation with the high-speed clock supplied to the resource to reduce the power consumption. In this mode, the intermittent clock is input to |
|            | only the CPU at accessing registers, internal memory, or resources.                                                                                                                                                  |

# Standby Mode

The standby mode causes the standby control circuit to stop the supply of an operation clock to the CPU or resources or to stop the oscillation clock (HCLK) in order to reduce power consumption.

## Sleep mode

The sleep mode stops supply of an operation clock to the CPU during operation in each clock mode. The CPU stops and the resources operate in the clock mode before the transition to the sleep mode. The sleep mode is divided into the main sleep mode, PLL sleep mode, and sub-sleep mode according to the clock mode before the transition to the sleep mode.

## • Watch mode

The watch mode operates only the subclock (SCLK) and watch timer. The main clock and PLL clock stop. All resources except the watch timer stop.

## Timebase timer mode

The timebase timer mode operates only the oscillation clock (HCLK), subclock (SCLK), timebase timer, and watch timer. Resources other than the timebase timer and watch timer stop.

DataSheet4U.com

et4U

# Stop mode The stop mode stops the oscillation clock (HCLK) and subclock (SCLK) during operation in each clock mode. It enables data to be retained with the least power consumption. Notes: When transiting a clock mode, do not transit a clock mode to any other clock mode or a low-power consumption mode until the completion of transition. Refer the MCM and SCM bits in the clock select register (CKSCR) to check that the transition of a clock mode is completed. If the mode is switched to another clock mode or low-power-consumption mode before completion of switching, the mode may not be switched. There is no sub-clock in MB90F387S and MB90387S.

DataSheet4U.com

DataShe

www.DataSheet4U.com

DataSheet4U.com

DataSheet4U.com

# 3.8.1 Block Diagram of Low-power Consumption Circuit

This section shows block diagram of low-power consumption circuit.

# ■ Block Diagram of Low-power Consumption Circuit



#### Figure 3.8-2 Block Diagram of Low-power Consumption Circuit

DataSheet4U.com

www.DataSheet4U.com

|      | -                                                                                                                                                                                                                      |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | CPU intermittent operation selector                                                                                                                                                                                    |
|      | This selector selects the halt cycle count of the CPU clock in the CPU intermittent operation mode.                                                                                                                    |
|      | Standby controller                                                                                                                                                                                                     |
|      | This controller causes the CPU clock controller and resource clock controller to switch between the CPU operating clock and the resource operating clock, and to transits a clock mode to and cancel the standby mode. |
|      | CPU clock controller                                                                                                                                                                                                   |
|      | This controller supplies an operating clock to the CPU.                                                                                                                                                                |
|      | Pin high-impedance controller                                                                                                                                                                                          |
|      | This controller causes the input/output pins to become high impedance in the watch mode, timebase time mode, and stop mode.                                                                                            |
|      | Internal reset generator                                                                                                                                                                                               |
|      | This generator generates the internal reset signal.                                                                                                                                                                    |
|      | Low-power consumption mode control register (LPMCR)                                                                                                                                                                    |
| n    | This register transits a clock mode to and cancels the standby mode, and sets the CPU intermitter operation mode. DataSheet4U.com                                                                                      |
| Note | e: There is no sub-clock in MB90F387S and MB90387S.                                                                                                                                                                    |

# 3.8.2 Registers for Setting Low-power Consumption Modes

This section explains the registers to be used to set lower-power consumption modes.

#### ■ Low-power Consumption Mode Control Register and Reset Values

| bit                                                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----------------------------------------------------|---|---|---|---|---|---|---|---|
| Low-power consumption mode control register (LPMCR) | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 |
|                                                     |   |   |   |   |   |   |   |   |

#### Figure 3.8-3 Low-power Consumption Mode Control Register and Reset Values

et4U.com

DataShee

DataSheet4U.com

www.DataSheet4U.com

# 3.8.3 Low-power Consumption Mode Control Register (LPMCR)

The low-power consumption mode control register (LPMCR) transits an operation mode to and cancels the low-power consumption modes, generates an internal reset signal, and sets the halt cycle count in the CPU intermittent operation mode.



DataSheet4U.com

130

|                | Bit Name                                        | Function                                                                                                                                                                                                                                                                                                                                                                                 |      |
|----------------|-------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| bit 0          | Reserved bit                                    | Always set this bit to 0.                                                                                                                                                                                                                                                                                                                                                                |      |
| bit 1<br>bit 2 | CG1, CG0:<br>CPU halt cycle count<br>select bit | <ul><li>These bits are used to set the halt cycle count of the CPU clock in the CPU intermittent operation mode.</li><li>Any reset causes the bit to return to the reset value.</li></ul>                                                                                                                                                                                                |      |
| bit 3          | TMD:<br>Watch mode bit                          | <ul> <li>This bit is used to transit the operation mode to the watch mode or the timebase timer mode.</li> <li>When set to 0: The mode transits to the watch mode.</li> <li>When set to 1:Not effect</li> <li>This bit is set to 1 by a reset or interrupt.</li> <li>Read: 1 is always read.</li> </ul>                                                                                  |      |
| bit 4          | RST:<br>Internal reset signal<br>generate bit   | This bit is used to generate a software reset.<br>When set to 0: Three machine cycles of internal reset signals are generated.<br>When set to 1: No effect<br>Read: 1 is always read.                                                                                                                                                                                                    |      |
| bit 5          | SPL:<br>Pin state specify bit                   | <ul> <li>This bit is used to set the state of input/output pins in transiting to the stop mode, watch mode or timebase timer mode.</li> <li>When set to 0: The current level of input/output pins is held.</li> <li>When set to 1: The input/output pins are set to high impedance.</li> <li>This bit is initialized to 0 by a reset.</li> </ul>                                         | Data |
| bit 6          | SLP:<br>Sleep mode bit                          | <ul> <li>This bit is used to transit the mode to the sleep mode.</li> <li>When set to 0: No effect</li> <li>When set to 1: The mode transits to the sleep mode.</li> <li>This bit is initialized to 0 by a reset or external interrupt.</li> <li>When both the STP and SLP bits are set to 1 simultaneously, the STP bit is preferred and the mode transits to the stop mode.</li> </ul> |      |
| bit 7          | STP:<br>Stop mode bit                           | <ul> <li>This bit is used to transit the mode to the stop mode.</li> <li>When set to 0: No effect</li> <li>When set to 1: The mode is transits to the stop mode.</li> <li>When read: 1 is always read.</li> <li>This bit is initialized to 0 by a reset or external interrupt.</li> </ul>                                                                                                |      |

#### Table 3.8-1 Function of Each Bit of Low-power Consumption Mode Control Register (LPMCR)

et4U.com

| Notes: | • When transiting to a low-power consumption mode using the low-power consumption mode control            |  |  |  |  |  |  |
|--------|-----------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|        | register (LPMCR), use the instructions listed in Table 3.8-2.                                             |  |  |  |  |  |  |
|        | • The low-power consumption mode transition instruction in Table 3.8-2must always be followed by an       |  |  |  |  |  |  |
|        | array of instructions highlighted by a dotted line below.                                                 |  |  |  |  |  |  |
|        |                                                                                                           |  |  |  |  |  |  |
|        | MOV LPMCR, $\#H'_{XX}$ ; the low-power consumption mode transition instruction in Table 3.8-2             |  |  |  |  |  |  |
|        | NOP                                                                                                       |  |  |  |  |  |  |
|        | NOP                                                                                                       |  |  |  |  |  |  |
|        | JMP \$+3 ; jump to next instruction                                                                       |  |  |  |  |  |  |
|        |                                                                                                           |  |  |  |  |  |  |
|        |                                                                                                           |  |  |  |  |  |  |
|        | levices do not guarantee its operation after returning from the standby mode if you place an array        |  |  |  |  |  |  |
|        | of instructions other than the one enclosed in the dotted line.                                           |  |  |  |  |  |  |
|        | • To access the low-power consumption mode control register (LPMCR) with C language, refer to             |  |  |  |  |  |  |
|        | " Notes on Accessing the Low-Power Consumption Mode Control Register (LPMCR) to Enter the                 |  |  |  |  |  |  |
|        | Standby Mode" in the section "3.8.8 Precautions when Using Low-power Consumption Mode".                   |  |  |  |  |  |  |
|        |                                                                                                           |  |  |  |  |  |  |
|        | • When word-length is used for writing the low-power consumption mode control register, even              |  |  |  |  |  |  |
|        | addresses must be used. Using odd addresses to switch to a low-power consumption mode may result          |  |  |  |  |  |  |
|        | in a malfunction.                                                                                         |  |  |  |  |  |  |
|        | • To set a pin to high impedance when the pin is shared by a peripheral function and a port in stop mode, |  |  |  |  |  |  |
|        | watch mode or timebase timer mode, disable the output of peripheral functions, and set the STP bit of     |  |  |  |  |  |  |
|        |                                                                                                           |  |  |  |  |  |  |
|        | the low-power consumption mode control register (LPMCR) to 1 or set the TMD bit to 0.                     |  |  |  |  |  |  |
|        | This applies to the following pins:                                                                       |  |  |  |  |  |  |
|        | P14/PPG0, P15/PPG1, P16/PPG2, P17/PPG3, P21/TOT0, P23/TOT1                                                |  |  |  |  |  |  |

• There is no sub-clock in MB90F387S and MB90387S.

et4U.com

DataShe

#### Table 3.8-2 Instructions at Transition to Low-power Consumption Mode

| MOV io,#imm8      | MOV dir,#imm8   | MOV eam,#imm8   | MOV eam,Ri   |
|-------------------|-----------------|-----------------|--------------|
| MOV io,A          | MOV dir,A       | MOV addr16,A    | MOV eam,A    |
| MOV @RLi+disp8,A  |                 |                 |              |
| MOVW io,#imm16    | MOVW dir,#imm16 | MOVW eam,#imm16 | MOVW eam,RWi |
| MOVW io,A         | MOVW dir,A      | MOVW addr16,A   | MOVW eam,A   |
| MOVW @RLi+disp8,A |                 |                 |              |
| SETB io:bp        | SETB dir:bp     | SETB addr16:bp  |              |
| CLRB io:bp        | CLRB dir:bp     | CLRB addr16:bp  |              |

# 3.8.4 CPU Intermittent Operation Mode

# The CPU intermittent operation mode causes the CPU to operate intermittently with an operating clock supplied to the CPU or resources to reduce power consumption.

#### Operation in CPU Intermittent Operation Mode

The CPU intermittent operation mode halts the clock supplied to the CPU at every instruction execution when the CPU accesses registers, internal memory, I/O, or resources delaying to start the internal bus. Decreasing the CPU processing speed while supplying a high-speed clock to resources reduces the power consumption.

- The count of machine cycles in which clock supply to the CPU halts is set by the CG1 and CG0 bits in the low-power consumption mode control register (LPMCR).
- The instruction execution time in the CPU intermittent operation mode is determined by adding the "normal execution time" to the "compensation value" obtained by multiplying "count of accesses to registers, internal memory, and resources " by "halt cycle count."

Figure 3.8-5 shows the clock operation in the CPU intermittent operation mode.

#### Figure 3.8-5 Clock Operation in CPU Intermittent Operation Mode



DataShe

et4U.com

et4U.com

# 3.8.5 Standby Mode

# The standby mode causes the standby control circuit to either stop supplying an operation clock to the CPU and resources, or to stop the oscillation clock (HCLK) to reduce power consumption.

#### Operating State in Each Standby Mode

Table 3.8-3 shows the operating state in each standby mode.

Table 3.8-3 Operating State in Each Standby Mode

| Mode                   | Name               | Transition<br>Condition     | Oscillation<br>Clock<br>(HCLK) | Subclock<br>(SCLK) | Machine<br>Clock | CPU | Resource         | Pin                 | Cancellation                               |
|------------------------|--------------------|-----------------------------|--------------------------------|--------------------|------------------|-----|------------------|---------------------|--------------------------------------------|
| Sleep mode             | Main sleep<br>mode | MCS = 1 $SCS = 1$ $SLP = 1$ | О                              | О                  | 0                | Х   | О                | 0                   | External reset or interrupt                |
|                        | Sub-sleep<br>mode  | MCS = X $SCS = 0$ $SLP = 1$ | х                              | О                  | 0                | Х   | 0                | 0                   | External reset or interrupt                |
|                        | PLL sleep<br>mode  | MCS = 0 $SCS = 1$ $SLP = 1$ | 0                              | О                  | 0                | Х   | Ο                | 0                   | External reset or interrupt                |
| Timebase<br>timer mode | SPL = 0            | MCS = X $SCS = 1$ $TMD = 0$ | О                              | Dat <b>Q</b> Shee  | t4U. <b>x</b> om | Х   | $X *^1$          | \$                  | External reset or interrupt * <sup>4</sup> |
|                        | SPL = 1            | MCS = X $SCS = 1$ $TMD = 0$ | О                              | О                  | Х                | Х   | $X *^1$          | Hi-z * <sup>3</sup> | External reset or interrupt* <sup>4</sup>  |
| Watch mode             | SPL = 0            | MCS = X $SCS = 0$ $TMD = 0$ | Х                              | О                  | Х                | Х   | X * <sup>2</sup> | \$                  | External reset or interrupt * <sup>5</sup> |
|                        | SPL = 1            | MCS = X $SCS = 0$ $TMD = 0$ | Х                              | О                  | Х                | Х   | X * <sup>2</sup> | Hi-z * <sup>3</sup> | External reset or interrupt * <sup>5</sup> |
| Stop mode              | SPL = 0            | <b>STP</b> = 1              | Х                              | Х                  | Х                | Х   | Х                | \$                  | External reset or interrupt * <sup>6</sup> |
|                        | SPL = 1            | STP = 1                     | Х                              | Х                  | Х                | Х   | Х                | Hi-z * <sup>3</sup> | External reset or interrupt * <sup>6</sup> |

O: Operate X: Stop 💠 : Pre-transition state held Hi-z: High-impedance

\*1: The timebase timer and the watch timer operate.

\*2: The watch timer operates.

\*3: DTP/external interrupt input pins operates

\*4: Watch timer, timebase timer, and external interrupt

\*5: Watch timer and external interrupt.

\*6: External interrupt

MCS: PLL clock select bit of clock select register (CKSCR)

SCS: Subclock select bit of CKSCR

SPL: Pin state specify bit of low-power consumption mode control register (LPMCR)

SLP: Sleep mode bit of LPMCR

STP: Stop mode bit of LPMCR

TMD: Watch mode bit of LPMCR

### DataSheet4U.com

## 3.8.5.1 Sleep Mode

# The sleep mode stops the operating clock to the CPU during an operation in each clock mode. The CPU stops and the resources continue to operate.

#### ■ Transition to Sleep Mode

When the mode transits to the sleep mode by setting the low-power consumption mode control register (LPMCR: SLP = 1, STP = 0), the mode transits to the sleep mode according to the settings of the MCS and SCS bits in the clock select register (CKSCR).

Table 3.8-4 shows the settings of the MCS and SCS bits in the clock select register (CKSCR) and the sleep modes.

#### Table 3.8-4 Settings of MCS and SCS Bits in Clock Select Register (CKSCR) and Sleep Modes

| Clock Select Register (CKSCR) |           | Sleep Mode to be transited |  |
|-------------------------------|-----------|----------------------------|--|
| MCS                           | SCS       |                            |  |
| 1                             | 1         | Main sleep mode            |  |
| 0                             | 1         | PLL sleep mode             |  |
| 1                             | DataSheet | 4U.com<br>Sub-sleep mode   |  |
| 0                             | 0         | Sub-sicep mode             |  |

DataShe

Notes:

et4U.com

If both the STP and SLP bits in the low-power consumption mode control register (LPMCR) are set to 1 simultaneously, the STP bit is preferred and the mode transits to the stop mode.
If the SLP bit is set to 1 and the TMD bit is set to 0 at the same time, the TMD bit is preferred and the mode transits to the timebase timer mode or the watch mode.

• There is no sub-clock in MB90F387S and MB90387S.

#### Data hold function

In the sleep mode, data in the dedicated registers such as accumulators and internal RAM are held.

#### • Operation when interrupt request generated

If an interrupt request is generated when the SLP bit in the low-power consumption mode control register (LPMCR) is set to 1, the mode does not transit to the sleep mode. If the CPU is not ready to accept any interrupt request, the instruction next to the currently executing instruction is executed. If the CPU is ready to accept any interrupt request, an interrupt operation immediately branches to the interrupt processing routine.

#### Pin state

In the sleep mode, pins other than those used for bus input/output or bus control are held in the state before transiting to the sleep mode.

DataSheet4U.com

www.DataSheet4U.com

#### Return from Sleep Mode

The sleep mode is cancelled by a reset factor or when an interrupt is generated.

#### • Return by reset factor

When the sleep mode is cancelled by a reset factor, the mode transits to the main clock mode after the sleep mode is cancelled, transiting to the reset sequence.

| Notes: • | <ul> <li>When sub-sleep mode are returned to main clock mode using an external reset pin (RST pin), input level "L" for at least "the oscillation time of the oscillator(*) + 100µs + 16 machine cycles".</li> <li>*: The oscillation time of the oscillator is the time required to reach 90% of amplitude. It takes several to dozens of ms for crystal oscillators, hundreds of µs to several ms for FAR/ceramic oscillators, and 0 ms for external clocks.</li> </ul> |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| •        | There is no sub-clock in MB90F387S and MB90387S.                                                                                                                                                                                                                                                                                                                                                                                                                          |

#### Return by interrupt

When a higher interrupt request than the interrupt level (IL) of 7 is generated from the resources in the sleep mode, the sleep mode is cancelled. After the sleep mode is cancelled, as with normal interrupt processing, the generated interrupt request is identified according to the settings of the I flag in the condition code register (CCR), the interrupt level mask register (ILM), and the interrupt control register (ICR).

When the CPU is not ready to accept any interrupt request, the instruction next to the currently
executing instruction is executed.

DataShe

• When the CPU is ready to accept any interrupt request, it branches immediately to the interrupt processing routine.

Figure 3.8-6 shows the cancellation of sleep mode by an interrupt.



#### Figure 3.8-6 Cancellation of Sleep Mode by Interrupt

Note:

When an interrupt processing is executed, the CPU usually proceeds to the interrupt processing after executing the instruction next to the one specifying the sleep mode.

DataSheet4U.com

et4U.com

## 3.8.5.2 Watch mode

# The watch mode operates only the subclock (SCLK) and the watch timer. The main clock and PLL clock stop.

#### Transition to Watch mode

In the subclock mode, when 0 is written to the TMD bit in the LPMCR register according to the settings of the low-power consumption mode control register (LPMCR), the mode transits to the watch mode.

#### Data hold function

In the watch mode, data in the dedicated registers such as an accumulator and internal RAM are held.

#### Operation when interrupt request generated

When interrupt request is generated with the TMD bit of the low-power consumption mode control register (LPMCR) set to 0, the mode does not transit to the watch mode. If the CPU is not ready to accept any interrupt request, the instruction next to the currently executing instruction is executed. If the CPU is ready to accept any interrupt request, it immediately branches to the interrupt processing routine.

#### Pin state

et4U.com

DataShe

In the watch mode, the input/output pins can be set to the high-impedance state or held in the state before transiting to the watch mode according to the setting of the SPL bit in the low-power consumption mode control register (LPMCR).

 Notes:
 To set a pin to high impedance when the pin is shared by a peripheral function and a port in watch mode, disable the output of peripheral functions, and set the TMD bit to 0. This applies to the following pins: P14/PPG0, P15/PPG1, P16/PPG2, P17/PPG3, P21/TOT0, P23/TOT1
 There is no sub-clock in MB90F387S and MB90387S.

#### Return from Watch mode

The watch mode is cancelled by a reset factor or when an interrupt is generated.

#### Return by reset factor

When the watch mode is cancelled by a reset factor, the mode transits to the main clock mode after the watch mode is cancelled, transiting to the reset sequence.

- Notes: When watch mode are returned to main clock mode using an external reset pin ( $\overline{RST}$  pin), input level "L" for at least "the oscillation time of the oscillator(\*) +  $100\mu$ s + 16 machine cycles (main clock)". \*: The oscillation time of the oscillator is the time required to reach 90% of amplitude. It takes several to dozens of ms for crystal oscillators, hundreds of µs to several ms for FAR/ceramic oscillators, and 0 ms for external clocks. • There is no sub-clock in MB90F387S and MB90387S.

#### Return by an interrupt

When an interrupt request higher than the interrupt level (IL) of 7 is generated from the watch timer and external interrupt in the watch mode, the watch mode is cancelled. After the watch mode is cancelled, as with normal interrupt processing, the generated interrupt request is identified according to the settings of the I flag in the condition code register (CCR), the interrupt level mask register (ILM), and the interrupt control register (ICR). In the sub-watch mode, no oscillation stabilization wait time is generated and the interrupt request is identified immediately after return from the watch mode.

When the CPU is not ready to accept any interrupt request, the instruction next to the currently executing instruction is executed ataSheet4U.com

- When the CPU is ready to accept any interrupt request, it branches immediately to the interrupt processing routine.
- Notes: When an interrupt processing is executed, the CPU usually proceeds to the interrupt processing after executing the instruction next to the one specifying the watch mode. There is no sub-clock in MB90F387S and MB90387S.

et4U.com

## 3.8.5.3 Timebase Timer Mode

The timebase timer mode operates only the oscillation clock (HCLK), subclock (SCLK), timebase timer, and watch timer. Resources other than the timebase timer and watch timer stop.

#### Transition to Timebase Timer Mode

The mode transits to the timebase timer mode when 0 is written to the TMD bit of the low-power consumption mode control register (LPMCR) during operation in the PLL clock mode or the main clock mode (CKSCR: SCM = 1).

#### Data hold function

In the timebase timer mode, data in the dedicated registers such as an accumulator and internal RAM are held.

#### Operation when interrupts request generated

et4U.com

When an interrupt request is generated with the TMD bit of the low-power consumption mode control register (LPMCR) set to 0, the mode does not transit to the timebase timer mode. When the CPU is not ready to accept any interrupt request, the instruction next to the currently executing instruction is executed. When the CPU is ready to accept any interrupt request, it branches immediately to the interrupt processing routine.

#### DataShe

#### Pin state

In the timebase timer mode, the input/output pins can be set to the high-impedance state or held in the state before transiting to the timebase timer mode according to the setting of the SPL bit in the low-power consumption mode control register (LPMCR).

Note: To set a pin to high impedance when the pin is shared by a peripheral function and a port in timebase timer mode, disable the output of peripheral functions, and set the TMD bit to 0. This applies to the following pins: P14/PPG0, P15/PPG1, P16/PPG2, P17/PPG3, P21/TOT0, P23/TOT1

#### Return from Timebase Timer Mode

The timebase timer mode is cancelled by a reset factor or when an interrupt is generated.

#### Return by reset factor

When the timebase timer mode is cancelled by a reset factor, the mode transits to the main clock mode after the timebase timer mode is cancelled, transiting to the reset sequence.

Note: When the timebase timer mode is returned to main clock mode using an external reset pin ( $\overline{\text{RST}}$  pin), input level "L" for at least 100 $\mu$ s.

#### Return by an interrupt

When an interrupt request higher than interrupt level (IL) of 7 is generated from the watch timer, timebase timer, and external interrupt in the timebase timer mode, the timebase timer mode is cancelled. After the timebase timer mode is cancelled, as with normal interrupt processing, the generated interrupt request is identified according to the settings of the I flag in the condition code register (CCR), the interrupt level mask register (ILM), and the interrupt control register (ICR).

- When the CPU is not ready to accept any interrupt request, the instruction next to the currently executing instruction is executed.
- When the CPU is ready to accept any interrupt request, it branches immediately to the interrupt processing routine.
- The following two timebase timer modes are available:
  - Main clock <-- --> timebase timer mode<sup>4U.com</sup>
  - PLL clock <--- --> timebase timer mode

Notes:
 At interrupt processing, the CPU usually proceeds to the interrupt processing after executing the instruction next to the one specifying the timebase timer mode.
 When the timebase timer mode is networked by an interrupt, the interrupt processing is performed as

• When the timebase timer mode is returned by an interrupt, the interrupt processing is performed after the maximum 80 µs after the interrupt request is accepted.

et4U.com

# 3.8.5.4 Stop Mode

# The stop mode stops the oscillation clock (HCLK) and subclock (SCLK) during operation in each clock mode. Data can be held with the minimum power consumption.

#### Stop Mode

When 1 is written to the STP bit of the low-power consumption mode control register (LPMCR) during operation in the PLL clock mode (CKSCR : MCS=1, SCS=0), the mode transits to the stop mode according to the settings of the MCS bit and SCS bit in the clock select register (CKSCR).

Table 3.8-5 shows the settings of the MCS and SCS bits in the clock select register (CKSCR) and the stop modes.

#### Table 3.8-5 Settings of MCS and SCS Bits in Clock Select Register (CKSCR) and Stop Modes

| Clock Select Register (CKSCR) |           | Stop Mode to be Transited |  |
|-------------------------------|-----------|---------------------------|--|
| MCS                           | SCS       | Stop wode to be manated   |  |
| 1                             | 1         | Main stop mode            |  |
| 0                             | 1         | PLL stop mode             |  |
| 1                             | DataSheet | 4U.com<br>Sub-stop mode   |  |
| 0                             | 0         | Sub-stop mode             |  |

Notes:

et4U.com

• If both the STP and SLP bits in the low-power consumption mode control register (LPMCR) are set to 1 simultaneously, the STP bit is preferred and the mode transits to the stop mode.

• There is no sub-clock in MB90F387S and MB90387S.

Data hold function

In the stop mode, data in the dedicated registers such as accumulators and internal RAM are held.

• Operation when interrupt request generated

When an interrupt request is generated with the STP bit in the low-power consumption mode control register (LPMCR) set to 1, the mode does not transit to the stop mode. When the CPU is not ready to accept any interrupt request, the instruction next to the currently executing instruction is executed. If the CPU is ready to accept any interrupt request, it immediately branches to the interrupt processing routine.

#### Pin state

In the stop mode, the input/output pins can be set to the high-impedance state or held in the state before transiting to the stop mode according to the setting of the SPL bit in the low-power consumption mode control register (LPMCR).

Note:To set a pin to high impedance when the pin is shared by a peripheral function and a port in stop mode,<br/>disable the output of peripheral functions, and set the STP bit to 1.<br/>This applies to the following pins:<br/>P14/PPG0, P15/PPG1, P16/PPG2, P17/PPG3, P21/TOT0, P23/TOT1

#### Return from Stop Mode

The stop mode is cancelled by a reset factor or when an interrupt is generated. At return from the stop mode, the oscillation clock (HCLK) and the subclock (SCLK) stop, so the stop mode is cancelled after the elapse of the main clock oscillation stabilization wait time or the subclock oscillation stabilization wait time.

#### Return by reset factor

When the stop mode is cancelled by a reset factor, the main clock oscillation stabilization wait time is generated. After the termination of the main clock oscillation stabilization wait time, the stop mode is cancelled, transiting to the reset sequence.

Figure 3.8-7 shows the return from the sub-stop mode by an external reset.

www.DataSheet4U.com

#### RST pin Stop mode Oscillating Main clock Oscillation stabilization wait Oscillation stabilization wait Oscillating Subclock PLL clock · Oscillation Oscillating PLL clock Subclock CPU operation clock Main clock **CPU** operation Stop Reset sequence Normal processing Stop mode cancelled Reset cancelled

#### Figure 3.8-7 Return from the Sub-stop Mode by an External Reset

When stop mode are returned to main clock mode using an external reset pin (RST pin), input level "L" for at least "the oscillation time of the oscillator(\*) + 100µs + 16 machine cycles (main clock)".
 \*: The oscillation time of the oscillator is the time required to reach 90% of amplitude. It takes several to dozens of ms for crystal oscillators, hundreds of µs to several ms for FAR/ceramic oscillators, and 0 ms for external clocks.
 There is no sub-clock in MB90F387S and MB90387S.

DataSheet4U.com

et4U.com

142

#### Return by an interrupt

When an interrupt request higher than the interrupt level (IL) of 7 is generated from external interrupt in the stop mode, the stop mode is cancelled. In the stop mode, the main clock oscillation stabilization wait time or the subclock oscillation stabilization wait time or the subclock oscillation stabilization wait time or the subclock oscillation stabilization wait time is terminated, as with normal interrupt processing, the generated interrupt request is identified according to the settings of the I flag in the condition code register (CCR), the interrupt level mask register (ILM), and the interrupt control register (ICR).

- When the CPU is not ready to accept any interrupt request, the instruction next to the currently executing instruction is executed.
- When the CPU is ready to accept any interrupt request, it branches immediately to the interrupt processing routine.

# Notes: At interrupt processing, the CPU usually proceeds to the interrupt processing after executing the instruction next to the one specifying the stop mode. In PLL stop mode, the main clock and PLL multiplication circuit stop. During recovery from PLL stop mode, it is necessary to secure the main clock oscillation stabilization wait time and PLL clock oscillation stabilization wait time. The oscillation stabilization wait times for the main clock and PLL clock are counted simultaneously according to the value specified in the oscillation stabilization wait time selection bits (CKSCR: WS1, WS0) in the clock selection register. The oscillation stabilization wait time selection bits (CKSCR: WS1, WS0) in the clock oscillation stabilization wait time. The PLL clock oscillation stabilization wait time, however, requires 2<sup>14</sup>/HCLK or more. Set the oscillation stabilization wait time selection bits (CKSCR: WS1, WS0) in the clock selection register to "10<sub>B</sub>" or "11<sub>B</sub>".

## 3.8.6 State Transition in Standby Mode

The operating state and state transition in the clock mode and standby mode in the MB90385 series are shown in the diagram.

#### State Transition Diagram





In attempting to switch the clock mode, do not attempt to switch to another clock mode or low-power consumption mode until the first switching is completed. The MCM and SCM bits of the clock selection register (CKSCR) indicate that switching is completed. If the mode is switched to another clock mode or low-power-consumption mode before completion of switching, the mode may not be switched.

www.DataSheet4U.com

• There is no sub-clock in MB90F387S and MB90387S.

DataSheet4U.com

# 3.8.7 Pin State in Standby Mode, at Reset

# The state of input/output pins in the standby mode and at reset is shown in each access mode.

#### ■ State of Input/Output Pins (Single-chip Mode)

| Din Nama               | Sloop                               | Stop/Watch/Time                                | Reset                                       |                                |
|------------------------|-------------------------------------|------------------------------------------------|---------------------------------------------|--------------------------------|
| Fin Name               | Pin Name Sleep —                    |                                                | SPL = 1                                     | Reset                          |
| P07 to P10             |                                     |                                                |                                             |                                |
| P27 to P20             |                                     | Input cut off/                                 |                                             |                                |
| P37 to P35, p33 to p30 | Immediately-preceding state held *1 | immediately-preceding state held <sup>*1</sup> | Input cut off/<br>output Hi-Z <sup>*2</sup> | Input disabled/<br>output Hi-Z |
| P44 to P40             |                                     |                                                |                                             |                                |
| P57 to P50             |                                     |                                                |                                             |                                |

et4U.com

\*1: Indicates that state of pins output immediately before entering each standby mode is output as it is or "input disabled." "State of pins output is output as it is" means that if the resource output is in operation, the state of pins is output according to the state of the resource and if the state of output pins is output, it is held. "Input disabled" means that no pin value can be accepted internally because the operation of the input gates of pins is enabled but the internal circuit stops.

\*2: "Input cut off" means that operation of the input gates of pins is disabled and "output Hi-Z" means that the driving of pin driving transistors is disabled to set pins to the high-impedance state.

Note:To set a pin to high impedance when the pin is shared by a peripheral function and a port in stop mode,<br/>watch mode or timebase timer mode, disable the output of peripheral functions, and set the STP bit to 1 or<br/>set the TMD bit to 0.<br/>This applies to the following pins:<br/>P14/PPG0, P15/PPG1, P16/PPG2, P17/PPG3, P21/TOT0, P23/TOT1

www.DataSheet4U.com

# 3.8.8 Precautions when Using Low-power Consumption Mode

#### This section explains the precautions when using the low-power consumption modes.

#### Transition to Standby Mode

When an interrupt request is generated from the resource to the CPU, the mode does not transit to each standby mode even after setting the STP and SLP bits in the low-power consumption mode control register (LPMCR) to 1 and the TMD bit to 0 (and also even after interrupt processing).

If the CPU is in interrupt processing, the interrupt request flag during interrupt processing is cleared and the mode can transit to each standby mode if no other interrupt requests are generated.

#### Cancellation of Standby Mode by Interrupt

When an interrupt request higher than the interrupt level (IL) of 7 is generated from the resource and external interrupt during operation in the sleep mode, watch mode, timebase timer mode, or stop mode, the standby mode is cancelled. The standby mode is cancelled by an interrupt regardless of whether the CPU accept interrupts or not.

- Notes: Take measures, such as disabling interrupts, not to branch to the interrupt processing immediately after return from the standby mode.
  There is no sub-clock in MB90F387S and MB90387S.
- et4U.com

■ Notes on the Transition to Standby Mode DataSheet4U.com

To set a pin to high impedance when the pin is shared by a peripheral function and a port in stop mode, watch mode, or timebase timer mode, use the following procedure:

- 1. Disable the output of peripheral functions.
- 2. Set the SPL bit to "1", STP bit to "1", or TMD bit to "0" in the low-power consumption mode control register (LPMCR).

There is no sub-clock in MB90F387S and MB90387S.

#### Note on Cancelling Standby Mode

The standby mode can be cancelled by an input according to the settings of an input factor of an external interrupt. The system enters the stop mode. The input factor can be selected from High level, Low level, rising edge, and falling edge.

Note:

et4U.com

#### Oscillation Stabilization Wait Time

Oscillation stabilization wait time of main clock

In the subclock mode, watch mode, or stop mode, the oscillation of the main clock stops and the oscillation stabilization wait time of the main clock is required. The oscillation stabilization wait time of the main clock is set by the WS1 and WS0 bits in the clock select register (CKSCR).

#### Oscillation stabilization wait time of subclock

In the sub-stop mode, the oscillation of the subclock stops and the oscillation stabilization wait time of the subclock is required. The oscillation stabilization wait time of the subclock is fixed at  $2^{14}$ /SCLK (SCLK: subclock).

#### Oscillation stabilization wait time of PLL clock

In main clock mode, the PLL multiplication circuit stops. When changing to PLL clock mode, it is necessary to reserve the PLL clock oscillation stabilization wait time. The CPU runs in main clock mode till the PLL clock oscillation stabilization wait time has elapsed. When the main clock is switched to PLL clock mode, the PLL clock oscillation stabilization wait time is fixed at 2<sup>14</sup>/HCLK (HCLK: oscillation clock).

In subclock mode, the main clock and PLL multiplication circuit stop. When changing to PLL clock mode, it is necessary to reserve the main clock oscillation stabilization wait time and PLL clock oscillation stabilization wait time. The oscillation stabilization wait times for main clock and PLL clock are counted simultaneously according to the value specified in the oscillation stabilization wait time selection bits (CKSCR: WS1, WS0) in the clock selection register. The oscillation stabilization wait time selection bits (CKSCR: WS1, WS0) in the clock selection register must be selected accordingly to account for the longer of the main clock and PLL clock oscillation stabilization wait times. The PLL clock oscillation stabilization wait time, however, requires  $2^{14}$ /HCLK or more. Set the oscillation stabilization wait time selection wait time selection bits (CKSCR: WS1, WS0) in the clock selection register to "10<sub>B</sub>" or "11<sub>B</sub>".

In PLL stop mode, the main clock and PLL multiplication circuit stop. During recovery from PLL stop mode, it is necessary to secure the main clock oscillation stabilization wait time and PLL clock oscillation stabilization wait time. The oscillation stabilization wait times for the main clock and PLL clock are counted simultaneously according to the value specified in the oscillation stabilization wait time selection bits (CKSCR: WS1, WS0) in the clock selection register. The oscillation stabilization wait time selection bits (CKSCR: WS1, WS0) in the clock selection register must be selected accordingly to account for the longer of main clock and PLL clock oscillation stabilization wait time, however, requires  $2^{14}$ /HCLK or more. Set the oscillation stabilization wait time selection wait time selection bits (CKSCR: WS1, WS0) in the clock selection register to "10<sub>B</sub>" or "11<sub>B</sub>".

#### Transition of Clock Mode

When transiting a clock mode, do not transit a clock mode to any other clock mode or a low-power consumption mode until the completion of transition. Refer the MCM and SCM bits in the clock select register (CKSCR) to check that the transition of a clock mode is completed. If the mode is switched to another clock mode or low-power-consumption mode before completion of switching, the mode may not be switched.

| DataSheet4U.com | There is no sub-clock in MB90F387S and MB90387S. | www.DataSheet4U.com |
|-----------------|--------------------------------------------------|---------------------|
|                 |                                                  |                     |

#### Notes on Accessing the Low-Power Consumption Mode Control Register (LPMCR) to Enter the Standby Mode

- To access the low-power consumption mode control register (LPMCR) with assembler language
  - To set the low-power consumption mode control register (LPMCR) to enter the standby mode, use the instruction listed in Table 3.8-2.
  - The low-power consumption mode transition instruction in Table 3.8-2 must always be followed by an array of instructions highlighted by a dotted line below.

MOV LPMCR,#H'xx ; the low-power consumption mode transition instruction in Table 3.8-2 NOP NOP JMP \$+3 ; jump to next instruction MOV A,#H'10 ; any instruction

The devices do not guarantee its operation after returning from the standby mode if you place an array of instructions other than the one enclosed in the dotted line.

• To access the low-power consumption mode (LPMCR) with C language

To enter the standby mode using the low-power consumption mode control register (LPMCR), use one of the following methods (1) to (3) to access the register:

(1) Specify the standby mode transition instruction as a function and insert two \_wait\_nop() built-in functions after that instruction. If any interrupt other than the interrupt to return from the standby mode can occur within the function, optimize the function during compilation to suppress the LINK and UNLINK instructions from occurring.

Example: Watch mode or timebase timer mode transition function

- }
- (2) Define the standby mode transition instruction using \_asm statements and insert two NOP and JMP instructions after that instruction.

Example: Transition to sleep mode

```
_asm(" MOVI: _IO_LPMCR,#H'58); /* Set LPMCR SLP bit to "1" */
```

```
_asm(" NOP");
```

```
_asm(" NOP");
```

\_asm(" JMP \$+3");

- /\* Jump to next instruction \*/
- (3) Define the standby mode transition instruction between #pragma asm and #pragma endasm and insert two NOP and JMP instructions after that instruction.

Example: Transition to stop mode

| #pragma asm            |                                |                     |
|------------------------|--------------------------------|---------------------|
| MOV I: _IO_LPMCR,#H'98 | /* Set LPMCR STP bit to "1" */ |                     |
| NOP                    |                                |                     |
| NOP                    |                                |                     |
| JMP \$+3               | /* Jump to next instruction */ |                     |
| #pragma endasm         |                                | www.DataSheet4U.com |

et4U.com

```
DataSheet4U.com
```

148

## 3.9 CPU Mode

# The $F^2MC-16LX$ family enables the transition of operation modes and memory access modes to set the CPU operation and access modes and areas.

#### Classification of Modes

Table 3.9-1 shows the classification of operation modes and memory access modes for the  $F^2MC-16LX$  family. Each mode is set by mode pins (MD2 to MD0) in reset and mode-fetched mode data.

Table 3.9-1 Classification of Modes

| Operation Modes               | Memory Access Modes                                  |  |  |  |  |
|-------------------------------|------------------------------------------------------|--|--|--|--|
| Operation modes               | Bus Modes                                            |  |  |  |  |
| RUN modes                     | Single-chip mode<br>(Internal-ROM internal-bus mode) |  |  |  |  |
| Flash serial programming mode | -                                                    |  |  |  |  |
| Flash memory mode             | -                                                    |  |  |  |  |

et4U.com

DataShe

#### Operation Mode

The operation modes control the operating state of the device and are set by the mode pins (MD2 to MD0).

#### RUN mode

The RUN mode is the normal CPU operation mode. It provides various low-power consumption modes, such as the main clock mode, PLL clock mode, and subclock mode.

Reference: For details of the low-power consumption modes, see Section "3.8 Low-power Consumption Mode".

#### • Flash serial programming mode and flash memory mode

Some products in the MB90385 series have user-programmable flash memory.

The flash serial programming mode is that for serially programming data to flash memory.

#### Mode Pins (MD2 to MD0) 3.9.1

The mode pins are three external pins of MD2 to MD0, and enable a combination of these pins to set the following:

- Operation modes (RUN mode, flash serial programming mode, flash memory mode)
- Reading reset vectors and mode data

#### Setting of Mode Pins (MD2 to MD0)

Table 3.9-2 shows the settings of the mode pins.

#### Table 3.9-2 Setting of Mode Pins

|     | Mode Pin <sup>*</sup> |     | Mode Name                           |  |  |  |  |
|-----|-----------------------|-----|-------------------------------------|--|--|--|--|
| MD2 | MD1                   | MD0 | wode name                           |  |  |  |  |
| 0   | 0                     | 0   |                                     |  |  |  |  |
| 0   | 0                     | 1   | Setting disabled                    |  |  |  |  |
| 0   | 1                     | 0   |                                     |  |  |  |  |
| 0   | 1                     | 1   | Internal vector mode                |  |  |  |  |
| 1   | 0                     | 0   | DataSheet4U.com<br>Setting disabled |  |  |  |  |
| 1   | 0                     | 1   | Setting disabled                    |  |  |  |  |
| 1   | 1                     | 0   | Flash serial programming mode       |  |  |  |  |
| 1   | 1                     | 1   | Flash memory mode                   |  |  |  |  |

DataShe

Internal vector mode

Reset vectors are read from internal ROM.

\*: Set MD2 to MD0:  $0 = V_{SS}$  or  $1 = V_{CC}$ .

Flash serial programming mode

Flash serial programming cannot be performed just by the settings of the mode pins.

Reference: For details of flash serial programming, see "CHAPTER 19 FLASH SERIAL PROGRAMMING CONNECTION".

Flash memory mode

This mode is set when using a parallel writer.

et4U.com

#### Setting Mode Pins

Set the mode pins as shown in Figure 3.9-1.

"1"

# Figure 3.9-1 Flow of Mode Pin Setting Set mode pin NO Data programmed to flash memory YES Flash Internal vector



MD0 to MD2: Set 0 = Vss and 1 = Vcc. Do not set value except the value described above.

"0"

"1"

"1"

et4U.com

DataShe

DataSheet4U.com

www.DataSheet4U.com

## 3.9.2 Mode Data

# Mode data is used to set the memory access mode. It is automatically read to the CPU by mode fetch.

#### Mode Data

The values of the mode register can be changed only in the reset sequence. The changed mode register values are enabled after the reset sequence.





DataShe

#### Table 3.9-3 Function of Mode Register

|                  | Bit Name                        | Function                               |
|------------------|---------------------------------|----------------------------------------|
| bit 8 to bit 13  | Reserved: Reserved bits         | Always write 0 to these bits.          |
| bit 14<br>bit 15 | M1, M0:<br>Bus mode setting bit | Always set these bits to " $00_{B}$ ". |

DataSheet4U.com

et4U.com

#### Setting Mode Data

Set mode data according to Figure 3.9-3.

#### Figure 3.9-3 Flow of Mode Data Setting



et4U.com

DataShe

DataSheet4U.com

www.DataSheet4U.com

## 3.9.3 Memory Access Mode

#### The memory access mode is the following one mode: bus mode and external access mode. • Bus mode: Sets access area (internal)

#### Bus Mode

Figure 3.9-4 shows the memory map in the mode.





Reference: For details of the access area, see Section "3.1 Memory Space".

• Single-chip mode (internal-ROM internal-access)

- Only internal ROM and internal RAM are used and no external access occurs.
- Ports 1 to 3 can be used as general-purpose I/O ports.

# 3.9.4 Selection of Memory Access Mode

#### This section explains selection of the memory access mode in the reset sequence.

#### Selection of Memory Access Mode

After reset is cancelled, the CPU selects the memory access mode according to the procedure shown in Figure 3.9-5 by referencing the settings of the mode pins and mode data.



Figure 3.9-5 Selection of Memory Access Mode

DataSheet4U.com

et4U.com

www.DataSheet4U.com

et4U.com

DataSheet4U.com

DataSheet4U.com

DataSheet4U.com

DataShe

www.DataSheet4U.com

# CHAPTER 4 I/O PORT

This chapter describes the function and operation of the I/O port.

- 4.1 Overview of I/O Port
- 4.2 Registers of I/O Port
- 4.3 Port 1
- 4.4 Port 2
- 4.5 Port 3 DataSheet4U.com
- 4.6 Port 4
- 4.7 Port 5

et4U.com

www.DataSheet4U.com

## 4.1 Overview of I/O Port

# I/O ports can be used as general-purpose I/O ports (parallel I/O ports). In the MB90385 series, there are five ports (34 pins).

Each port also serves as a resource I/O pins.

#### ■ I/O Port Function

The I/O ports enable the port data register (PDR) to output data to the I/O pins from the CPU and fetch signals input to the I/O ports. These also enable the port direction register (DDR) to set a direction for the I/O pins in unit of bits.

The following shows the function of each port, and the resources that it also serves as:

- Port 1: Serves as both general-purpose I/O port and PPG timer output, or input capture input
- Port 2: Serves as both general-purpose I/O port and reload timer I/O, or external interrupt input pin
- Port 3: Serves as both general-purpose I/O port or A/D converter start trigger pin
- Port 4: Serves as both general-purpose I/O port and UART1 I/O or CAN controller transmit/receive pin
- Port 5: Serves as both general-purpose I/O port and analog input pin

Table 4.1-1 List of Each Port Functions

| 1.4 | 1.1 | _ | ~ | n | n  |  |
|-----|-----|---|---|---|----|--|
| +4  | 1.1 |   | U |   | 11 |  |
|     |     |   |   |   |    |  |

| Port<br>Name | Pin Name                             | Input Type           | Output<br>Type          | Function<br>DataS               | bit7<br>heet4U                  | bit6<br>.com | bit5          | bit4          | bit3 | bit2 | bit1 | bit0 |     |   |   |
|--------------|--------------------------------------|----------------------|-------------------------|---------------------------------|---------------------------------|--------------|---------------|---------------|------|------|------|------|-----|---|---|
| Port 1       | P10/IN0 to<br>P13/IN3                |                      | CMOS                    | General-<br>purpose I/O<br>port | P17                             | P16          | P15           | P14           | P13  | P12  | P11  | P10  |     |   |   |
|              | P14/PPG0 to<br>P17/PPG3              |                      | CMOS<br>high<br>current | Resource                        | PPG3                            | PPG2         | PPG1          | PPG0          | IN3  | IN2  | IN1  | IN0  |     |   |   |
| Port 2       | P20/TIN0 to<br>P27/INT7              |                      |                         | General-<br>purpose I/O<br>port | P27                             | P26          | P25           | P24           | P23  | P22  | P21  | P20  |     |   |   |
|              |                                      | CMOS<br>(hysteresis) |                         | Resource                        | INT7                            | INT6         | INT5          | INT4          | INT3 | INT2 | INT1 | INT0 |     |   |   |
| Port 3       | P30 to P33<br>P35/X0A to<br>P37/ADTG |                      |                         |                                 | General-<br>purpose I/O<br>port | P37          | P36* /<br>X1A | P35* /<br>X0A | _    | P33  | P32  | P31  | P30 |   |   |
|              | I ST/ADIO                            |                      |                         |                                 |                                 |              |               | Resource      | ADTG | -    | -    | -    | -   | - | - |
| Port 4       | P40/SIN1 to<br>P44/RX                |                      | CMOS                    | General-<br>purpose I/O<br>port | _                               | _            | _             | P44           | P43  | P42  | P41  | P40  |     |   |   |
|              |                                      |                      |                         | Resource                        | -                               | -            | -             | RX            | TX   | SOT1 | SCK1 | SIN1 |     |   |   |
| Port 5       | P50/AN0 to<br>P57/AN7                | Analog/<br>CMOS      |                         | General-<br>purpose I/O<br>port | P57                             | P56          | P55           | P54           | P53  | P52  | P51  | P50  |     |   |   |
| P57/A        | 1 <i>J    P</i> 111 /                | (hysteresis)         |                         | Analog<br>input pin             | AN7                             | AN6          | AN5           | AN4           | AN3  | AN2  | AN1  | AN0  |     |   |   |

\*. If the low-speed oscillation pin is selected (for MB90387 or MB90F387), P35 and P36 pins cannot be used. www.DataSheet4U.com

| Note: | Port 5 also serves as analog input pins. When using these ports as general-purpose ports, always set each |
|-------|-----------------------------------------------------------------------------------------------------------|
|       | bit of the analog input enable register (ADER) corresponding to each pin of the ports to 0. ADER bit is 1 |
|       | at a reset.                                                                                               |

et4U.com

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

CHAPTER 4 I/O PORT

# 4.2 Registers of I/O Port

#### The registers related to I/O port setting are listed as follows.

## Registers of I/O Ports

Table 4.2-1 lists the registers of each port.

#### Table 4.2-1 Registers of Each Port

| Register Name                              | Read/Write         | Address             | Reset Value           |
|--------------------------------------------|--------------------|---------------------|-----------------------|
| Port 1 data register (PDR1)                | R/W                | 000001 <sub>H</sub> | XXXXXXXXB             |
| Port 2 data register (PDR2)                | R/W                | 000002 <sub>H</sub> | XXXXXXXXB             |
| Port 3 data register (PDR3)                | R/W                | 000003 <sub>H</sub> | XXXXXXXXB             |
| Port 4 data register (PDR4)                | R/W                | 000004 <sub>H</sub> | XXXXXXXXB             |
| Port 5 data register (PDR5)                | R/W                | 000005 <sub>H</sub> | XXXXXXXXB             |
| Port 1 direction register (DDR1)           | R/W                | 000011 <sub>H</sub> | 00000000 <sub>B</sub> |
| Port 2 direction register (DDR2)           | R/W                | 000012 <sub>H</sub> | 00000000 <sub>B</sub> |
| Port 3 direction register (DDR3) DataSheet | 4U.con <b>R</b> /W | 000013 <sub>H</sub> | 000X0000 <sub>B</sub> |
| Port 4 direction register (DDR4)           | R/W                | 000014 <sub>H</sub> | XXX00000 <sub>B</sub> |
| Port 5 direction register (DDR5)           | R/W                | 000015 <sub>H</sub> | 00000000 <sub>B</sub> |
| Analog input enable register (ADER)        | R/W                | $00001B_{H}$        | 11111111 <sub>B</sub> |

et4U.com

R/W: Read/Write

X: Undefined value

www.DataSheet4U.com

# 4.3 Port 1

Port 1 is a general-purpose I/O port that serves as the resource I/O pin. When the singlechip mode is set, use port 1 by switching between the resource pin and the generalpurpose I/O port.

The function as a general-purpose I/O port is mainly described here. The configuration, pin assignment, block diagram of the pins, and registers for port 1 are shown below.

#### ■ Configuration of Port 1

Port 1 consists of the following three elements:

- General-purpose I/O port, resource I/O pin (P10/IN0 to P17/PPG3)
- Port 1 data register (PDR1)
- Port 1 direction register (DDR1)

#### Pin Assignment of Port 1

- When the single-chip mode is set, use port 1 by switching between the resource pin and the generalpurpose I/O port.
- Since port 1 serves as a resource pin, it cannot be used as a general-purpose I/O port when used as resources.
- When using port 1 as the input pin of the resource, set the pin corresponding to the resource in the DDR1 as an input port.
- When using port 1 as the output pin of the resource, set the output of the corresponding resource to "enabled". Port 1 functions as the output pin of the resource regardless of the settings of the DDR1

Table 4.3-1 shows the pin assignment of port 1.

| Port Pin Name |                                         | Po  | rt Function         | R      | esource             | I/O          | Circuit              |   |
|---------------|-----------------------------------------|-----|---------------------|--------|---------------------|--------------|----------------------|---|
| Name          | lame round round round round resource   |     | Input               | Output | Туре                |              |                      |   |
|               | P10/IN0                                 | P10 |                     | IN0    |                     |              |                      |   |
|               | P11/IN1                                 | P11 |                     | IN1    | Input capture       |              | CMOS                 | D |
|               | P12/IN2P12IN2inputP13/IN3P13General-IN3 |     | input               |        | CMOS                | D            |                      |   |
| Port 1        |                                         |     |                     | IN3    |                     | CMOS         |                      |   |
| FOILI         | P14/PPG0                                | P14 | purpose I/O<br>port | PPG0   |                     | (hysteresis) |                      |   |
|               | P15/PPG1                                | P15 |                     | PPG1   | PPG timer<br>output |              | CMOS<br>high current | G |
|               | P16/PPG2                                | P16 |                     | PPG2   |                     |              |                      | U |
|               | P17/PPG3                                | P17 |                     | PPG3   |                     |              |                      |   |

#### Table 4.3-1 Pin Assignment of Port 1

Reference:

For the circuit type, see Section "1.7 I/O Circuit".

DataSheet4U.com

et4U.com

www.DataSheet4U.com

#### CHAPTER 4 I/O PORT

#### Block Diagram of Port 1 Pins (in Single Chip Mode)



#### Figure 4.3-1 Block Diagram of Port 1 Pins

## ■ Registers for Port 1 (in Single Chip Mode)

- The registers for port 1 are PDR1 and DDR1.
- The bits composing each register correspond to the pins of port 1 one-to-one.

Table 4.3-2 shows the correspondence between the registers and pins of port 1.

| Table 4.3-2 | Correspondence between Registers and Pins for Port 1 |
|-------------|------------------------------------------------------|
|-------------|------------------------------------------------------|

| Port<br>Name | В                 | Bits of Related Registers and Corresponding Pins |       |       |       |       |       |       |       |
|--------------|-------------------|--------------------------------------------------|-------|-------|-------|-------|-------|-------|-------|
| Port 1       | PDR1, DDR1        | bit 7                                            | bit 6 | bit 5 | bit 4 | bit 3 | bit 2 | bit 1 | bit 0 |
| ron i        | Corresponding pin | P17                                              | P16   | P15   | P14   | P13   | P12   | P11   | P10   |

DataSheet4U.com

# 4.3.1 Registers for Port 1 (PDR1, DDR1)

#### The registers for port 1 are explained.

#### ■ Function of Registers for Port 1 (in Single Chip Mode)

- Port 1 data register (PDR1)
  - Port 1 data register indicates the state of the pins.
- Port 1 direction register (DDR1)
  - The port 1 direction register sets the input/output directions.
  - When the bit corresponding to the pin is set to 1, port 1 functions as an output port. When the bit is set to 0, port 1 functions as an input port.

Table 4.3-3 shows the functions of the registers for port 1.

| et4U.com | Register Name                                   | Data | At Read                                                                                                      | At Write                                                                                                      | Read/<br>Write | Register<br>Address   | Reset Value           | DeteChef |
|----------|-------------------------------------------------|------|--------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|----------------|-----------------------|-----------------------|----------|
|          | 0     state is       Port 1 data     Low level. |      | 0 is set for the output latch. When<br>the pin is an output port pin, the<br>Low level is output to the pin. | R/W                                                                                                           | 000001         | XXXXXXXX <sub>B</sub> | DataShee              |          |
|          | register (PDR1)                                 | 1    | The pin<br>state is<br>High level.                                                                           | 1 is set for the output latch. When<br>the pin is an output port pin, the<br>High level is output to the pin. | K/W            | 000001 <sub>H</sub>   | ΛΛΛΛΛΛΛΒ              |          |
|          | Port 1 direction                                | 0    | The<br>direction<br>latch is 0.                                                                              | The output buffer is set to OFF, and<br>the pin becomes an input port pin.                                    | DAV            | 000011 <sub>H</sub>   | 00000000 <sub>B</sub> |          |
|          | register (DDR1)                                 | 1    | The<br>direction<br>latch is 1.                                                                              | The output buffer is set to ON, and<br>the pin becomes an output port pin.                                    | R/W            | 000011 <sub>H</sub>   | 0000000B              |          |

Table 4.3-3 Function of Registers for Port 1

R/W: Read/Write

X: Undefined value

| References: | • | When using port 1 as the input pin of the resource, clear the bit in the DDR1 corresponding to the    |
|-------------|---|-------------------------------------------------------------------------------------------------------|
|             |   | input pin of the resource to 0 and set the input pin as an input port.                                |
|             | • | When using port 1 as the output pin of the resource, set the output of the corresponding resource to  |
|             |   | "enabled". Port 1 functions as the output pin of the resource regardless of the settings of the DDR1. |

DataSheet4U.com

www.DataSheet4U.com

CHAPTER 4 I/O PORT

#### 4.3.2 **Operation of Port 1**

The operation of port 1 is explained.

# Operation of Port 1 (in Single Chip Mode) Operation of output port • When the bit in the port 1 direction register (DDR1) corresponding to the output pin is set to 1, port 1 functions as an output port. • When the output buffer is turned ON and output data is written to the port 1 data register (PDR1), the data is retained in the output latch and output from the pin. • When the PDR1 is read, the state of the output latch in the PDR1 is read. Note: If read modify write instructions (such as the bit set instruction) are used to read the PDR, the pin set as an output port by the DDR outputs the desired data. However, the pin set as an input port outputs data after the input state is written to the output latch. When switching from the input port to the output port, write data to the PDR and set the pin as an output port in the DDR. Operation of input port • If the bit in the DDR corresponding to the input pin is set to 0, port 1 functions as an input port. • The output buffer is turned OFF and the pin enters the high impedance state. • When the PDR1 is read, the level value (Low or High) of the pin is read. Operation of resource output the DDR1. read. Operation of resource input • The state of the pin that serves as the resource input is input to the resource. pin of the resource to 0 and set the input pin as an input port. Operation at reset • When the CPU is reset, the value of the DDR1 is cleared to 0. Consequently, all output buffers are set to OFF (the pin becomes an input port pin), and the pin enters the high-impedance state.

• The PDR1 is not initialized by reset. Therefore, when using port 1 as an output port, it is necessary to set output data in the PDR1, and then set the bit in the DDR1 corresponding to the output pin to 1, and then, www.DataSheet4U.com to output.

et4U.com

164

DataShe

- When data is written to the PDR1, it is retained in the output latch in the PDR1 but not output to the pin.
- When using port 1 as the output pin of the resource, set the resource output to "enabled".
- Since the resource output is preferred enabled, the resource output functions regardless of the settings of
- When the pin state is read with the resource output set to "enabled", the output state of the resource is
- When using port 1 as the input pin of the resource, clear the bit in the DDR1 corresponding to the input

DataSheet4U.com

#### • Operation in stop mode, timebase timer mode or watch mode

When the pin state specification bit of the low power consumption mode control register (LPMCR: SPL) is 1, at a transition to the stop mode, timebase timer mode or watch mode, the pin enters the high-impedance state. Because the output buffer is forcibly set to OFF irrespective of the value of the DDR1.

Table 4.3-4 shows the state of the port 1 pins.

 Table 4.3-4
 State of Port 1 Pins

| Pin Name               | Normal Operation            | Sleep Mode                  | Stop Mode, Timebase Timer Mode or Watch<br>Mode |                                                                              |  |
|------------------------|-----------------------------|-----------------------------|-------------------------------------------------|------------------------------------------------------------------------------|--|
|                        |                             |                             | SPL=0                                           | SPL=1                                                                        |  |
| P10/IN0 to<br>P17/PPG3 | General-purpose I/O<br>port | General-purpose I/O<br>port | General-purpose I/O<br>port                     | Input cut off, and output<br>becomes Hi-Z (Pull-up<br>resistor disconnected) |  |

SPL: Pin state specification bit of low power consumption mode control register (LPMCR: SPL) Hi-Z: High impedance

| To set a pin to high impedance when the pin is shared by a peripheral function and a port in stop mode, watch mode or timebase timer mode, disable the output of peripheral functions, and set the STP bit to 1 or |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| set the TMD bit to 0.                                                                                                                                                                                              |
| This applies to the following pins:                                                                                                                                                                                |
| P14/PPG0, P15/PPG1, P16/PPG2, P17/PPG3                                                                                                                                                                             |
|                                                                                                                                                                                                                    |

DataSheet4U.com

DataSheet4U.com

et4U.com

www.DataSheet4U.com

# 4.4 Port 2

Port 2 is a general-purpose I/O port that serves as the resource I/O pin. Use port 2 by switching between the resource pin and the general-purpose I/O port. The function as a general-purpose I/O port is mainly described here. The configuration, pin assignment, block diagram of the pins, and registers for port 2 are shown below.

### ■ Configuration of Port 2

Port 2 consists of the following four elements:

- General-purpose I/O port, resource I/O pin (P20/TIN0 to P27/INT7)
- Port 2 data register (PDR2)
- Port 2 direction register (DDR2)
- High address control register (HACR)

### Pin Assignment of Port 2

- Use port 2 by switching between the resource pin and the general-purpose I/O port.
- Since port 2 serves as resource pin, when used as a resource pin, port 2 cannot be used as generalpurpose I/O port.
- When using port 2 as the input pin of the resource, set the pin corresponding to the resource in the DataSheet DDR2 as an input port.
   DataSheet4U.com
- When using port 2 as the output pin of the resource, set the output of the corresponding resource to "enabled". Port 2 functions as the output pin of the resource regardless of the settings of the DDR2.

Table 4.4-1 shows the pin assignment for port 2.

| Port   | Port Pin Name F   |                                          | t Function |          | Resource                     | I/O T <u>y</u> | Circuit |      |
|--------|-------------------|------------------------------------------|------------|----------|------------------------------|----------------|---------|------|
| Name   | 1 in Name         | 101                                      |            | Resource |                              | Input          | Output  | Туре |
|        | P20/TIN0          | P20                                      |            | TIN0     | 16-bit reload timer 0 input  |                |         |      |
|        | P21/TOT0          | P21                                      |            | TOT0     | 16-bit reload timer 0 output |                | CMOS    |      |
|        | P22/TIN1          | P22                                      |            | TIN1     | 16-bit reload timer 1 input  |                |         |      |
| Port 2 | P23/TOT1          | 125                                      | General-   | 1011     | 16-bit reload timer 1 output | CMOS           |         | D    |
| FOIT 2 | P24/INT4 P24 port | <ul> <li>purpose I/O<br/>port</li> </ul> | INT4       |          | (hysteresis)                 | CMOS           | D       |      |
|        | P25/INT5          | P25                                      |            | INT5     |                              |                |         |      |
|        | P26/INT6          | P26                                      |            | INT6     | External interrupt input     |                |         |      |
|        | P27/INT7          | P27                                      |            | INT7     |                              |                |         |      |
| 1      | 1                 | 1                                        | 1          | L        | 1                            | I              | 1       |      |

Table 4.4-1 Pin Assignment of Port 2

Reference: For the circuit type, see Section "1.7 I/O Circuit".

DataSheet4U.com

et4U.com

166

www.DataSheet4U.com

# ■ Block Diagram of Pins of Port 2 (General-purpose I/O Port)



### Figure 4.4-1 Block Diagram of Pins of Port 2

### Registers for Port 2

• The registers for port 2 are PDR2 and DDR2.

DataShe

• The bits composing each register correspond to the pins of port 2 one-to-one.

Table 4.4-2 shows the correspondence between the registers and pins of port 2.

| Table 4.4-2 | Correspondence between Registers and Pins for Port 2 |
|-------------|------------------------------------------------------|
|-------------|------------------------------------------------------|

| Port<br>Name | Bits o            | f Relate | d Regis | ters and | l Corres | ponding | Pins  |       |       |
|--------------|-------------------|----------|---------|----------|----------|---------|-------|-------|-------|
| Port 2       | PDR2, DDR2        | bit 7    | bit 6   | bit 5    | bit 4    | bit 3   | bit 2 | bit 1 | bit 0 |
| ron 2        | Corresponding pin | P27      | P26     | P25      | P24      | P23     | P22   | P21   | P20   |

# 4.4.1 Registers for Port 2 (PDR2, DDR2)

# The registers for port 2 are explained.

### ■ Function of Registers for Port 2

• Port 2 data register (PDR2)

Port 2 data register indicates the input/output state of the pins.

- Port 2 direction register (DDR2)
  - The port 2 direction register sets the input/output directions.
  - When the bit corresponding to the pin is set to 1, port 2 functions as an output port. When the bit is set to 0, port 2 functions as an input port.

Table 4.4-3 shows the functions of the registers for port 2.

Table 4.4-3 Function of Registers for Port 2

| et4U.com | Register Name    | Data | At Read                            | At Write                                                                                                          | Read/<br>Write | Register<br>Address | Reset Value                           | DataShe |
|----------|------------------|------|------------------------------------|-------------------------------------------------------------------------------------------------------------------|----------------|---------------------|---------------------------------------|---------|
|          | Port 2 data      | 0    | The pin<br>state is<br>Low level.  | 0 is set for the output latch, and<br>when the pin is an output port pin,<br>the Low level is output to the pin.  | R/W            | 000002 <sub>H</sub> | XXXXXXXX                              |         |
|          | register (PDR2)  | 1    | The pin<br>state is<br>High level. | 1 is set for the output latch, and<br>when the pin is an output port pin,<br>the High level is output to the pin. | K/ W           | 000002 <sub>H</sub> | A A A A A A A A A A A A A A A A A A A |         |
|          | Port 2 direction | 0    | The<br>direction<br>latch is 0."   | The output buffer is set to OFF, and the pin becomes an input port pin.                                           | D /W           | 000012 <sub>H</sub> | 00000000 <sub>B</sub>                 |         |
|          | register (DDR2)  | 1    | The<br>direction<br>latch is 1.    | The output buffer is set to ON, and the pin becomes an output port pin.                                           | R/W            | 000012 <sub>H</sub> | 0000000 <sub>B</sub>                  |         |

R/W: Read/Write

X: Undefined value

| References: | • | When using port 2 as the input pin of the resource, clear the bit in the DDR2 corresponding to the    |
|-------------|---|-------------------------------------------------------------------------------------------------------|
|             |   | input pin of the resource to 0 and set the input pin as an input port.                                |
|             | • | When using port 2 as the output pin of the resource, set the output of the corresponding resource to  |
|             |   | "enabled". Port 2 functions as the output pin of the resource regardless of the settings of the DDR2. |

DataSheet4U.com

168

#### 4.4.2 **Operation of Port 2**

# The operation of port 2 is explained.

|         | Operation of output port                                                                                                                                                                                                                                                                                                                                                                                      |     |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
|         | • When the bit in the port 2 direction register (DDR2) corresponding to the output pin is set to 1, port 2 functions as an output port.                                                                                                                                                                                                                                                                       |     |
|         | • When the output buffer is turned ON and output data is written to the port 2 data register (PDR2), the data is retained in the output latch and output from the pin.                                                                                                                                                                                                                                        |     |
|         | • When the PDR2 is read, the state of the output latch in the PDR2 is read.                                                                                                                                                                                                                                                                                                                                   |     |
| Note:   | If read modify write instructions (such as the bit set instruction) are used to read the PDR, the pin set as<br>an output port by the DDR outputs the desired data. However, the pin set as an input port outputs data<br>after the input state is written to the output latch. When switching from the input port to the output port,<br>write data to the PDR and set the pin as an output port in the DDR. |     |
|         | Operation of input port                                                                                                                                                                                                                                                                                                                                                                                       |     |
|         | <ul> <li>If the bit in the DDR2 corresponding to the input pin is set to 0, port 2 functions as an input port.</li> <li>The output buffer is turned OFF and the pin enters the high impedance state.</li> </ul>                                                                                                                                                                                               |     |
|         | • When data is written to the PDR2, it is retained in the output latch in the PDR2 but not output to the pin.                                                                                                                                                                                                                                                                                                 |     |
|         | • When the PDR2 is read, the level value (Low or High) of the pin is read.                                                                                                                                                                                                                                                                                                                                    |     |
|         | Operation of resource output                                                                                                                                                                                                                                                                                                                                                                                  |     |
|         | • When using port 2 as the output pin of the resource, set the resource output to "enabled".                                                                                                                                                                                                                                                                                                                  |     |
|         | • Since the resource output is preferred enabled, the resource output functions regardless of the settings of the DDR2.                                                                                                                                                                                                                                                                                       |     |
|         | • When the pin state is read with the resource output set to "enabled," the output state of the resource is read.                                                                                                                                                                                                                                                                                             |     |
|         | Operation of resource input                                                                                                                                                                                                                                                                                                                                                                                   |     |
|         | • The state of the pin that serves as the input of the resource is input to the resource.                                                                                                                                                                                                                                                                                                                     |     |
|         | • When using port 2 as the input pin of the resource, clear the bit in the DDR2 corresponding to the input pin of the resource to 0 and set the input pin to an input port.                                                                                                                                                                                                                                   |     |
|         | Operation at reset                                                                                                                                                                                                                                                                                                                                                                                            |     |
|         | • When the CPU is reset, the value of the DDR2 is initialized to 0. Consequently, all output buffers are set to OFF (the pin becomes an input port pin), and the pin enters the high-impedance state.                                                                                                                                                                                                         |     |
| t4U.com | • The PDR2 is not initialized by reset. Therefore, when using port 2 as an output port, it is necessary to set output data in the PDR2, and then set the bit in the DDR2 corresponding to the output pin to 1, and then, to output.                                                                                                                                                                           | et/ |

DataSheet4U.com

#### • Operation in stop mode, timebase timer mode or watch mode

When the pin state specification bit of the low power consumption mode control register (LPMCR: SPL) is 1, at a transition to the stop mode, timebase timer mode or watch mode, the pin enters the high-impedance state. Because the output buffer is set forcibly to OFF irrespective of the value of the DDR2.

Table 4.4-4 shows the state of the port 2 pins.

Table 4.4-4 State of Port 2 Pins

| Pin Name                | Normal Operation            | Sleep Mode                  | Stop Mode, Timebase Timer Mode or<br>Watch Mode |                                        |  |
|-------------------------|-----------------------------|-----------------------------|-------------------------------------------------|----------------------------------------|--|
|                         |                             |                             | SPL=0                                           | SPL=1                                  |  |
| P20/TIN0 to<br>P27/INT7 | General-purpose I/O<br>port | General-purpose I/O<br>port | General-purpose I/O<br>port                     | Input cut off, and output becomes Hi-Z |  |

SPL: Pin state specification bit of low power consumption mode control register (LPMCR: SPL) Hi-Z: High impedance

| Note: |                               | we when the pin is shared by a peripheral function and a port in stop mode,<br>r mode, disable the output of peripheral functions, and set the STP bit to 1 or |         |
|-------|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
|       | set the TMD bit to 0.         |                                                                                                                                                                | DeteCh  |
|       | This applies to the following | pins:                                                                                                                                                          | DataShe |
|       | P21/TOT0, P23/TOT1            | DataSheet4U.com                                                                                                                                                |         |

DataSheet4U.com

# 4.5 **Port 3**

Port 3 is a general-purpose I/O port that serves as the resource I/O pin. Use port 3 by switching between the resource pin and the general-purpose I/O port. The function as a general-purpose I/O port is mainly described here. The configuration, pin assignment, block diagram of the pins, and registers for port 3 are shown below.

### ■ Configuration of Port 3

Port 3 consists of the following three elements:

- General-purpose I/O port, resource input pin (P30 to P33, P35\*/X0A, P36\*/X1A, P37/ADTG)
- Port 3 data register (PDR3)
- Port 3 direction register (DDR3)

### Pin Assignment of Port 3

- Use port 3 by switching between the resource pin and the general-purpose I/O port.
- Since port 3 serves as a resource pin, when used as a resource pin, port 3 cannot be used as generalpurpose I/O port.
- When using port 3 as the resource input pin, set the pin corresponding to the resource in the DDR3 as an input port.

DataShe

```
DataSheet4U.com
```

Table 4.5-1 shows the pin assignment of port 3.

| Port Pin Name |            |      | Port Function         |      | Resource                                 | I/O T <u>-</u>       | Circuit |      |  |
|---------------|------------|------|-----------------------|------|------------------------------------------|----------------------|---------|------|--|
| Name          | FIII Maine | F    | ort Function Resource |      | Resource                                 | Input                | Output  | Туре |  |
|               | P30        | P30  |                       | -    | -                                        |                      |         |      |  |
|               | P31        | P31  |                       | -    | -                                        | CMOS<br>(hysteresis) | CMOS    | D    |  |
|               | P32        | P32  |                       | -    | -                                        |                      |         |      |  |
| Port 3        | P33        | P33  | General-purpose I/O   | -    | -                                        |                      |         |      |  |
| 1010 5        | P35/X0A    | P35* | port                  | -    | _                                        |                      |         | D/A  |  |
|               | P36/X1A    | P36* |                       | -    | _                                        |                      |         | D/A  |  |
|               | P37/ADTG   | P37  |                       | ADTG | External trigger input for A/D converter |                      |         | D    |  |

### Table 4.5-1 Pin Assignment of Port 3

\*: If the low-speed oscillation pin is selected (for MB90387 or MB90F387), P35 and P36 pins cannot be used.

Reference: For the circuit type, see Section "1.7 I/O Circuit".

# Block Diagram of Pins of Port 3



#### Figure 4.5-1 Block Diagram of Pins of Port 3

### Registers for Port 3

- The registers for port 3 are PDR3 and DDR3.
- The bits composing each register correspond to the pins of port 3 one-to-one.

Table 4.5-2 shows the correspondence between the registers and pins of port 3.

| Table 4.5-2 Correspondence between Registers and Pins for Port 5 | Table 4.5-2 | Correspondence between Registers and Pins for Port 3 |
|------------------------------------------------------------------|-------------|------------------------------------------------------|
|------------------------------------------------------------------|-------------|------------------------------------------------------|

| Port<br>Name | Bits              | s of Rela | ted Regi | sters and | d Corres | ponding | Pin   |       |       |
|--------------|-------------------|-----------|----------|-----------|----------|---------|-------|-------|-------|
| Port 3       | PDR3, DDR3        | bit 7     | bit 6    | bit 5     | bit 4    | bit 3   | bit 2 | bit 1 | bit 0 |
| FOILS        | Corresponding pin | P37       | P36*     | P35*      | _        | P33     | P32   | P31   | P30   |

\*: There are no P35 and P36 pins in MB90387 and MB90F387.

www.DataSheet4U.com

# 4.5.1 Registers for Port 3 (PDR3, DDR3)

# The registers for port 3 are explained.

### ■ Function of Registers for Port 3

- Port 3 data register (PDR3)
  - Port 3 data register indicates the state of the pins.
- Port 3 direction register (DDR3)
  - The port 3 direction register sets the input/output directions.
  - When the bit corresponding to the pin is set to 1, port 3 functions as an output port. When the bit is set to 0, port 3 functions as an input port.

Table 4.5-3 shows the functions of the registers for port 3.

Table 4.5-3 Function of Registers for Port 3

| et4U.com | Register Name    | Data | At Read                            | At Write                                                                                                          | Read/<br>Write | Register<br>Address | Reset Value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | DataShe |
|----------|------------------|------|------------------------------------|-------------------------------------------------------------------------------------------------------------------|----------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
|          | Port 3 data      | 0    | The pin<br>state is<br>Low level.  | 0 is set for the output latch, and<br>when the pin is an output port pin,<br>the Low level is output to the pin.  | R/W            | 000003 <sub>H</sub> | XXXXXXXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |         |
|          | register (PDR3)  | 1    | The pin<br>state is<br>High level. | 1 is set for the output latch, and<br>when the pin is an output port pin,<br>the High level is output to the pin. | K/ W           | 000003H             | And the the test of te |         |
|          | Port 3 direction | 0    | The<br>direction<br>latch is 0.    | The output buffer is set to OFF, and the pin becomes an input port pin.                                           | DAV            | 000013 <sub>H</sub> | 000X0000 <sub>B</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         |
|          | register (DDR3)  | 1    | The<br>direction<br>latch is 1.    | The output buffer is set to ON, and<br>the pin becomes an output port pin                                         | R/W            | 000015 <sub>H</sub> | 00020000 <sub>B</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         |

R/W: Read/Write

X: Undefined value

| References: | • When using port 3 as the input pin of the resource, clear the bit in the DDR3 corresponding to the   |
|-------------|--------------------------------------------------------------------------------------------------------|
|             | input pin of the resource to 0 and set the input pin as an input port.                                 |
|             | • When using port 3 as the output pin of the resource, set the output of the corresponding resource to |
|             | "enabled". Port 3 functions as the output pin of the resource regardless of the settings of the DDR3.  |

DataSheet4U.com

www.DataSheet4U.com

# 4.5.2 Operation of Port 3

# The operation of port 3 is explained. Operation of Port 3 (General - purpose I/O port) Operation of output port • When the bit in the port 3 direction register (DDR3) corresponding to the output pin is set to 1, port 3 functions as an output port. • When the output buffer is turned ON and output data is written to the port 3 data register (PDR3), the data is retained in the output latch and output from the pin. • When the PDR3 is read, the state of the output latch in the PDR3 is read. Note: If read modify write instructions (such as the bit set instruction) are used to read the port data register (PDR), the pin set as an output port by the port direction register (DDR) outputs the desired data. However, the pin set as an input port outputs data after the input state is written to the output latch. When switching from the input port to the output port, write data to the PDR and set the pin as an output port in the DDR. Operation of input port DataShe • If the bit in the DDR3 corresponding to the input pin is set to 0, port 3 functions as an input port. • The output buffer is turned OFF and the pin enter the high impedance state. • When data is written to the PDR3, it is retained in the output latch in the PDR3 but not output to the pin. When the PDR3 is read, the level value (Low or High) of the pin is read. Operation of resource input • The state of the pin that serves as a resource is input to the resource. • When using port 3 as the input pin of the resource, clear the bit in the DDR3 corresponding to the input pin of the resource to 0 and set the input pin as an input port. Operation at reset • When the CPU is reset, the value of the DDR3 is cleared to 0. Consequently, all output buffers are set to OFF (the pin becomes an input port pin), and the pin enters the high-impedance state. The PDR3 is not initialized by reset. Therefore, when using port 3 as an output port, it is necessary to set output data in the PDR3, and then set the bit in the DDR3 corresponding to the output pin to 1 and to output.

### • Operation in stop mode, timebase timer mode or watch mode

• When the pin state specification bit of the low power consumption mode control register (LPMCR: SPL) is 1, at a transition to the stop mode, timebase timer mode or watch mode, the pin enters the high-impedance state. The output buffer is forcibly set to OFF irrespective of the value of the DDR3 register.

Table 4.5-4 shows the state of the port 3 pins.

 Table 4.5-4
 State of Port 3 Pins

| Pin Name                               | Normal Operation            | Sleep Mode                  | Stop Mode, Timebase Timer Mode or<br>Watch Mode |                                           |  |  |
|----------------------------------------|-----------------------------|-----------------------------|-------------------------------------------------|-------------------------------------------|--|--|
|                                        |                             |                             | SPL=0                                           | SPL=1                                     |  |  |
| P30 to P33,<br>P35/X0A to P37/<br>ADTG | General-purpose I/O<br>port | General-purpose I/O<br>port | General-purpose I/O<br>port                     | Input cut off, and<br>output becomes Hi-Z |  |  |

SPL: Pin state specification bit of low power consumption mode control register (LPMCR: SPL) Hi-Z: High impedance

et4U.com

DataShe

DataSheet4U.com

# 4.6 **Port 4**

Port 4 is a general-purpose I/O port that serves as the resource I/O pin. Use port 4 by switching between the resource pin and the general-purpose I/O port. The function as a general-purpose I/O port is mainly described here. The configuration, pin assignment, block diagram of the pins, and registers for port 4 are shown below.

### ■ Configuration of Port 4

Port 4 consists of the following three elements:

- General-purpose I/O port, resource I/O pin (P40/SIN1 to P44/RX)
- Port 4 data register (PDR4)
- Port 4 direction register (DDR4)

#### Pin Assignment of Port 4

- Use port 4 by switching between the resource pin and the general-purpose I/O port.
- Since port 4 serves as a resource pin, it cannot be used as a general-purpose I/O port when used as a resource.
- When using port 4 as the input pin of the resource, set the pin corresponding to the resource in the DDR4 as an input port.
- When using port 4 as the output pin of the resource, set the output of the corresponding resource to "enabled". Port 4 functions as the output pin of the resource regardless of the settings of the DDR4.

Table 4.6-1 shows the pin assignment of port 4.

| Port   | Pin Name | e Port Function |                         | R      | lesource                           | І/О Тур      | Circuit |   |
|--------|----------|-----------------|-------------------------|--------|------------------------------------|--------------|---------|---|
| Name   |          |                 | Input                   | Output | Туре                               |              |         |   |
|        | P40/SIN1 | P40             |                         | SIN1   | UART1 serial data input            |              | CMOS    | D |
|        | P41/SCK1 | P41             |                         | SCK1   | UART1 serial<br>clock I/O          |              |         |   |
| Port 4 | P42/SOT1 | P42             | General-<br>purpose I/O | SOT1   | UART1 serial<br>data output        | CMOS         |         |   |
|        | P43/TX   | P43             | port                    | TX     | CAN<br>controller<br>send output   | (hysteresis) |         |   |
|        | P44/RX   | P44             |                         | RX     | CAN<br>controller<br>receive input |              |         |   |

 Table 4.6-1
 Pin Assignment of Port 4

Reference: For the circuit type, see Section "1.7 I/O Circuit".

DataSheet4U.com

et4U.com

### Block Diagram of Pins of Port 4



#### Figure 4.6-1 Block Diagram of Pins of Port 4

et4U.com

### Registers for Port 4

DataSheet4U.com

- The registers for port 4 are PDR4 and DDR4.
- The bits composing each register correspond to the pins of port 4 one-to-one.

Table 4.6-2 shows the correspondence between the registers and pins of port 4.

| Table 4.6-2 | Correspondence between Registers and Pins for Port 4 |
|-------------|------------------------------------------------------|
|-------------|------------------------------------------------------|

| Port<br>Name | Bits c            | Bits of Related Registers and Corresponding Pins |   |   |       |       |       |       |       |  |  |  |  |
|--------------|-------------------|--------------------------------------------------|---|---|-------|-------|-------|-------|-------|--|--|--|--|
| Port 4       | PDR4, DDR4        | -                                                | - | - | bit 4 | bit 3 | bit 2 | bit 1 | bit 0 |  |  |  |  |
| 10114        | Corresponding pin | -                                                | - | I | P44   | P43   | P42   | P41   | P40   |  |  |  |  |

www.DataSheet4U.com

# 4.6.1 Registers for Port 4 (PDR4, DDR4)

### The registers for port 4 are explained.

### ■ Function of Registers for Port 4

- Port 4 data register (PDR4)
  - Port 4 data register indicates the state of the pins.
- Port 4 direction register (DDR4)
  - The port 4 direction register sets the input/output directions.
  - When the bit corresponding to the pin is set to 1, port 4 functions as an output port. When the bit is set to 0, port 4 functions as an input port.

Table 4.6-3 shows the functions of the registers for port 4.

| et4U.com | Register Name    | Data                              | At Read                            | At Write                                                                                                     | Read/<br>Write | Register<br>Address | Reset Value           | DataShe  |
|----------|------------------|-----------------------------------|------------------------------------|--------------------------------------------------------------------------------------------------------------|----------------|---------------------|-----------------------|----------|
| 5140.000 | Port 4 data      | 0                                 | The pin<br>state is<br>Low level.  | 0 is set for the output latch. When<br>the pin is an output port pin, the<br>Low level is output to the pin. | R/W            | 000004 <sub>H</sub> | XXXXXXXX              | DataShee |
|          | register (PDR4)  | 1                                 | The pin<br>state is<br>High level. | the pin is an output port pin, the                                                                           |                | 00000+H             | лллллл <sub>В</sub>   |          |
|          | Port 4 direction | 0 The<br>direction<br>latch is 0. |                                    | The output buffer is set to OFF, and the pin becomes an input port pin.                                      | DAV            | 000014              | XXX00000 <sub>B</sub> |          |
|          | register (DDR4)  | 1                                 | The<br>direction<br>latch is 1.    | The output buffer is set to ON, and the pin becomes an output port pin.                                      | R/W            | 000014 <sub>H</sub> | AAAUUUUUB             |          |

### Table 4.6-3 Function of Registers for Port 4

R/W: Read/Write

X: Undefined value

| References: | • | When using port 4 as the input pin of the resource, clear the bit in the DDR4 corresponding to the    |
|-------------|---|-------------------------------------------------------------------------------------------------------|
|             |   | input pin of the resource to 0 and set the input pin as an input port.                                |
|             | ٠ | When using port 4 as the output pin of the resource, set the output of the corresponding resource to  |
|             |   | "enabled". Port 4 functions as the output pin of the resource regardless of the settings of the DDR4. |

# 4.6.2 Operation of Port 4

The operation of port 4 is explained. Operation of Port 4 Operation of output port • When the bit in the port 4 direction register (DDR4) corresponding to the output pin is set to 1, port 4 functions as an output port. • When the output buffer is turned ON and output data is written to the port 4 data register (PDR4), the data is retained in the output latch and output from the pin. • When the port 4 data register (PDR4) is read, the state of the output latch in the port 4 data register (PDR4) is read. Note: If read modify write instructions (such as the bit set instruction) are used to read the PDR, the pin set as an output port by the DDR outputs the desired data. However, the pin set as an input port outputs data after the input state is written to the output latch. When switching from the input port to the output port, write data to the PDR and set the pin as an output port in the DDR. et4U.com • Operation of input port DataShe • If the bit in the DDR4 corresponding to the input pin is set to 0, port 4 functions as an input port. The output buffer is turned OFF and the pin enters the high impedance state. • When data is written to the PDR4, it is retained in the output latch in the PDR4 but not output to the pin. When the PDR4 is read, the level value (Low or High) of the pin is read. Operation of resource output When using port 4 as the output pin of the resource, set the output of the corresponding resource to "enabled". • Since the resource output is preferred enabled, the resource output functions regardless of the settings of the DDR4. • When the pin state is read with the resource output set to "enabled", the output state of the resource is read Operation of resource input • The state of the pin that serves as the input of the resource is input to the resource. When using port 4 as the input pin of the resource, clear the bit in the DDR4 corresponding to the input pin of the resource to 0 and set the input pin as an input port.

DataSheet4U.com

www.DataSheet4U.com

• Operation at reset

- When the CPU is reset, the value of the DDR4 is initialized to 0. Consequently, all output buffers are set to OFF (the pin becomes an input port pin), and the pin enters the high-impedance state.
- The PDR4 is not initialized by reset. Therefore, when using port 4 as an output port, it is necessary to set output data in the PDR4, and then set the bit in the DDR4 corresponding to the output pin to 1 and to output.
- Operation in stop mode, timebase timer mode and watch mode

If the pin state specify bit (SPL) of the low-power consumption mode control register (LPMCR) is set to "1" when the CPU operation mode switches to stop mode, timebase timer mode or watch mode, the pin enters the high-impedance state. In this case, the output buffer is forcibly set to "OFF" regardless of the values of the Port 4 direction register (DDR4).

Table 4.6-4 shows the state of the port 4 pins.

 Table 4.6-4
 State of Port 4 Pins

| Pin Name              | Normal Operation            | Sleep Mode                                  | Stop Mode, Timebase Timer Mode or<br>Watch Mode |                                                                                 |  |  |
|-----------------------|-----------------------------|---------------------------------------------|-------------------------------------------------|---------------------------------------------------------------------------------|--|--|
|                       |                             |                                             | SPL=0 SPL=1                                     | SPL=1                                                                           |  |  |
| P40/SIN1 to<br>P47/RX | General-purpose I/O<br>port | General-purpose I/O<br>port DataSheet4U.cor | General-purpose I/O<br><sub>1</sub> port        | Input cut off, and<br>output becomes Hi-Z<br>(Pull-up resistor<br>disconnected) |  |  |

SPL: Pin state specification bit of low power consumption mode control register (LPMCR: SPL) Hi-Z: High impedance

# 4.7 Port 5

Port 5 is a general-purpose I/O port that serves as the analog input pin. Use port 5 by switching between the analog input pin and the general-purpose I/O port. The function as a general-purpose I/O port is mainly described here. The configuration, pin assignment, block diagram of the pins, and registers for port 5 are shown below.

# ■ Configuration of Port 5

Port 5 consists of the following four elements:

- General-purpose I/O port, analog input pins (P50/AN0 to P57AN7)
- Port 5 data register (PDR5)
- Port 5 direction register (DDR5)
- Analog input enable register (ADER)

### ■ Pin Assignment of Port 5

- Use port 5 by switching between the analog input pin and the general-purpose I/O port.
- Since port 5 serves as an analog input pin, it cannot be used as a general-purpose I/O port when used as an analog input pin.
  - When using port 5 as an analog input pin, set the pin corresponding to the analog input in the DDR5 as DataSheet an input port.
  - When using port 5 as a general-purpose I/O port, do not input any analog signal.

Table 4.7-1 shows the pin assignment of port 5.

| Port    | Pin Name | Port F | unction             |       | Resource               | I/О Тур                       | Circuit |   |
|---------|----------|--------|---------------------|-------|------------------------|-------------------------------|---------|---|
| Name    | Name     |        | Resource            | Input | Output                 | Туре                          |         |   |
|         | P50/AN0  | P50    |                     | AN0   | Analog input channel 0 |                               |         |   |
|         | P51/AN1  | P51    |                     | AN1   | Analog input channel 1 |                               | CMOS    | Е |
|         | P52/AN2  | P52    |                     | AN2   | Analog input channel 2 |                               |         |   |
| Devit 5 | P53/AN3  | P53    | General-            | AN3   | Analog input channel 3 | CMOS                          |         |   |
| Port 5  | P54/AN4  | P54    | purpose<br>I/O port | AN4   | Analog input channel 4 | (hysteresis/<br>analog input) |         |   |
|         | P55/AN5  | P55    |                     | AN5   | Analog input channel 5 |                               |         |   |
|         | P56/AN6  | P56    |                     | AN6   | Analog input channel 6 |                               |         |   |
|         | P57/AN7  | P57    |                     | AN7   | Analog input channel 7 |                               |         |   |

 Table 4.7-1
 Pin Assignment of Port 5

Reference: For the circuit type, see Section "1.7 I/O Circuit".

DataSheet4U.com

et4U.com

www.DataSheet4U.com

# Block Diagram of Pins of Port 5





### Registers for Port 5

• The registers for port 5 are PDR5, DDR5, and ADER.

DataShe

www.DataSheet4U.com

- The ADER sets input of an analog signal to the analog input pin to "enabled" or "disabled".
- The bits composing each register correspond to the pins of port 5 one-to-one.

Table 4.7-2 shows the correspondence between the registers and pins of port 5.

| Port<br>Name | Bits of Related Registers and Corresponding Pins |       |       |       |       |       |       |       |       |
|--------------|--------------------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|
|              | PDR5, DDR5                                       | bit 7 | bit 6 | bit 5 | bit 4 | bit 3 | bit 2 | bit 1 | bit 0 |
| Port 5       | ADER                                             | ADE7  | ADE6  | ADE5  | ADE4  | ADE3  | ADE2  | ADE1  | ADE0  |
|              | Corresponding pin                                | P57   | P56   | P55   | P54   | P53   | P52   | P51   | P50   |

DataSheet4U.com

# 4.7.1 Registers for Port 5 (PDR5, DDR5, ADER)

| ■ Fund | ction of Registers for Port 5                                                                                                                                                            |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | Port 5 data register (PDR5)                                                                                                                                                              |
|        | • Port 5 data register indicates the state of the pins.                                                                                                                                  |
| (      | Port 5 direction register (DDR5)                                                                                                                                                         |
|        | • The port 5 direction register sets the input/output directions.                                                                                                                        |
|        | • When the bit corresponding to the pin is set to 1, port 5 functions as an output port. When the bit is set to 0, port 5 functions as an input port.                                    |
| (      | Analog input enable register (ADER)                                                                                                                                                      |
|        | • The analog input enable register (ADER) sets the general-purpose I/O ports and analog input pin in unit of ports.                                                                      |
|        | • When the ADE bit corresponding to the analog input pin is set to 1, port 5 functions as an analog input pin. When the bit is set to 0, port 5 functions as a general-purpose I/O port. |
|        | Table 4.7-3 shows the functions of the registers for port 5.                                                                                                                             |

DataSheet4U.com

| Register Name             | Data | At Read                            | At Write                                                                                                      | Read/<br>Write | Register<br>Address | Reset Value           |  |
|---------------------------|------|------------------------------------|---------------------------------------------------------------------------------------------------------------|----------------|---------------------|-----------------------|--|
| Port 5 data               | 0    | The pin<br>state is<br>Low level.  | 0 is set for the output latch. When<br>the pin is an output port pin, the<br>Low level is output to the pin.  | R/W            | 000005 <sub>H</sub> | XXXXXXXX <sub>B</sub> |  |
| register (PDR5)           | 1    | The pin<br>state is<br>High level. | 1 is set for the output latch. When<br>the pin is an output port pin, the<br>High level is output to the pin. |                | 000003H             |                       |  |
| Port 5 direction          | 0    | The<br>direction<br>latch is 0.    | The output buffer is set to OFF, and<br>the pin becomes an input port pin.                                    | R/W            | 000015 <sub>H</sub> | 00000000 <sub>B</sub> |  |
| register (DDR5)           | 1    | The<br>direction<br>latch is 1.    | The output buffer is set to ON, and the pin becomes an input port pin.                                        |                | 000015H             |                       |  |
| Analog input              | 0    | General-pur                        | pose I/O port                                                                                                 | R/W            | 00001D              |                       |  |
| enable register<br>(ADER) | 1    | Analog inpu                        | t mode                                                                                                        |                | 00001B <sub>H</sub> | 11111111 <sub>B</sub> |  |
| R/W: Read/Write           |      |                                    |                                                                                                               |                |                     |                       |  |

### Table 4.7-3 Function of Registers for Port 5

et4U.com

X: Undefined value

### DataSheet4U.com

DataShe

• When using port 5 as the analog input pin, clear the bit in the DDR5 corresponding to the analog input pin to 0 and set the input pin as an input port.

• When using port 5 as the input pin of the resource, clear the bit in the DDR5 corresponding to the input pin of the resource to 0 and set the input pin as an input port.

# 4.7.2 Operation of Port 5

### The operation of port 5 is explained.

# Operation of Port 5 Operation of output port • When the bit in the port 5 direction register (DDR5) corresponding to the output pin is set to 1, port 5 functions as an output port. • When the output buffer is turned ON and output data is written to the port 5 data register (PDR5), the data is retained in the output latch and output from the pin. • When the port 5 data register (PDR5) is read, the state of the output latch in the PDR5 is read. Note: If read modify write instructions (such as the bit set instruction) are used to read the PDR, the pin set as an output port by the DDR outputs the desired data. However, the pin set as an input port outputs data after the input state is written to the output latch. When switching from the input port to the output port, write data to the PDR and set the pin as an output port in the DDR. Operation of input port • If the bit in the DDR5 corresponding to the input pin is set to 0, port 5 functions as an input port. • The output buffer is turned OFF and the pin enters the high impedance state. • When data is written to the port 5 data register (PDR5), it is retained in the output latch in the PDR5 but not output to the pin. ٠ When the PDR5 is read, the level value (Low or High) of the pin is read. Operation of analog input

- When using port 5 as an analog input pin, set the bit in the ADER corresponding to the analog input pin to 1. Port 5 is disabled to operate as a general-purpose I/O port, and functions as an analog input pin.
- When the PDR5 is read with the bit set to "analog input enabled," the read value is 0.

### • Operation at reset

- When the CPU is reset, the value of the DDR5 is initialized to 0. Consequently, all output buffers are set to OFF (the pin becomes an input port pin), and the pin enters the high-impedance state.
- The PDR5 is not initialized by reset. Therefore, when using port 5 as an output port, it is necessary to set output data in the PDR5, and then set the bit in the DDR5 corresponding to the output pin to 1 and to output.

#### • Operation in stop mode, timebase timer mode or watch mode

When the pin state specification bit of the low power consumption mode control register (LPMCR: SPL) is 1, at a transition to the stop mode, timebase timer mode or watch mode, the pin enters the high-impedance state. The output buffer is set forcibly to OFF irrespective of the value of the DDR5.

Table 4.7-4 shows the state of the port 5 pins.

Table 4.7-4 State of Port 5 Pins

| Pine Name | Normal Operation | Sleep Mode                  | Stop Mode, Timebase Timer Mode or<br>Watch Mode |                                           |  |  |
|-----------|------------------|-----------------------------|-------------------------------------------------|-------------------------------------------|--|--|
|           |                  |                             | SPL=0                                           | SPL=1                                     |  |  |
|           |                  | General-purpose I/O<br>port | General-purpose I/O<br>port                     | Input cut off, and<br>output becomes Hi-Z |  |  |

SPL: Pin state specification bit of low power consumption mode control register (LPMCR: SPL) Hi-Z: High impedance

et4U.com

DataShe

DataSheet4U.com

# CHAPTER 5 TIMEBASE TIMER

This chapter describes the function and operation of the timebase timer.

- 5.1 Overview of Timebase Timer
- 5.2 Block Diagram of Timebase Timer
- 5.3 Configuration of Timebase Timer
- 5.4 Timebase Timer Interrupt
- 5.5 Explanation of Operation of Timebase Timer
- 5.6 Precautions when Using Timebase Timer
- 5.7 Program Example of Timebase Timer

et4U.com

www.DataSheet4U.com

CHAPTER 5 TIMEBASE TIMER

# 5.1 **Overview of Timebase Timer**

The timebase timer is an 18-bit free-run counter (timebase timer counter) that increments in synchronization with the main clock (2-divided frequency of main oscillation clock).

- Four interval times can be selected and an interrupt request can be generated for each interval time.
- An operation clock is supplied to the oscillation stabilization wait time timer and other resources.

### Functions of Interval Timer

- When the timebase timer counter reaches the interval time set by the interval time select bits (TBTC: TBC1, TBC0), an overflow occurs (TBTC: TBOF = 1) and an interrupt request is generated.
- When an interrupt is enabled due to an overflow (carry) (TBTC: TBIE = 1), an overflow occurs (TBTC: TBOF = 1) and an interrupt is generated.
- The timebase timer has four interval times that can be selected. Table 5.1-1 shows the interval times of the timebase timer.

### Table 5.1-1 Interval Times of Timebase Timer

| Count Clock     | DataSheet4 | U.com Interval Time                      |  |  |
|-----------------|------------|------------------------------------------|--|--|
|                 |            | 2 <sup>12</sup> /HCLK (approx. 1.0 ms)   |  |  |
| 2/HCLK(0.5 µs)  |            | 2 <sup>14</sup> /HCLK (approx. 4.1 ms)   |  |  |
| 2/IICLK(0.5 µs) |            | 2 <sup>16</sup> /HCLK (approx. 16.4 ms)  |  |  |
|                 |            | 2 <sup>19</sup> /HCLK (approx. 131.1 ms) |  |  |

HCLK: Oscillation clock

The parenthesized values are provided at 4-MHz oscillation clock.

DataShe

DataSheet4U.com

# ■ Clock Supply

The timebase timer supplies an operation clock to the resources such as an oscillation stabilization wait time timer, PPG timer, and watchdog timer. Table 5.1-2 shows the clock cycles supplied from the timebase timer.

| Where to Supply Clock               | Clock Cycle                              |
|-------------------------------------|------------------------------------------|
|                                     | 2 <sup>10</sup> /HCLK (approx. 256 μs)   |
| Oscillation stabilization wait time | 2 <sup>13</sup> /HCLK (approx. 2.0 ms)   |
| Oscillation stabilization wait time | 2 <sup>15</sup> /HCLK (approx. 8.2 ms)   |
|                                     | 2 <sup>17</sup> /HCLK (approx. 32.8 ms)  |
|                                     | 2 <sup>12</sup> /HCLK (approx. 1.0 ms)   |
| Wetch do a timor                    | 2 <sup>14</sup> /HCLK (approx. 4.1 ms)   |
| Watchdog timer                      | 2 <sup>16</sup> /HCLK (approx. 16.4 ms)  |
|                                     | 2 <sup>19</sup> /HCLK (approx. 131.1 ms) |
| PPG Timer DataSheet4                | U2 <sup>9</sup> /HCLK (approx. 128 μs)   |

| Table 5.1-2 | <b>Clock Cycles Supplied from Timebase Timer</b> |
|-------------|--------------------------------------------------|
|-------------|--------------------------------------------------|

et4U.com

HCLK: Oscillation clock

The parenthesized values are provided at 4-MHz oscillation clock.

**Note:** Since the oscillation cycle is unstable immediately after oscillation starts, the oscillation stabilization wait time values are given as a guide.

CHAPTER 5 TIMEBASE TIMER

# 5.2 Block Diagram of Timebase Timer

The timebase timer consists of the following blocks:

- Timebase timer counter
- Counter clear circuit
- Interval timer selector
- Timebase timer control register (TBTC)

### Block Diagram of Timebase Timer



#### Figure 5.2-1 Block Diagram of Timebase Timer

The actual interrupt request number of the timebase timer is as follows:

Interrupt request number:  $#16(10_{\rm H})$ 

www.DataSheet4U.com

DataShe

DataSheet4U.com

et4U.com

190

#### Timebase timer counter

The timebase timer counter is an 18-bit up counter that uses a clock with 2-divided frequency of the oscillation clock (HCLK) as a count clock.

Counter clear circuit

The counter clear circuit clears the value of the timebase timer counter by the following factors:

- Timebase timer counter clear bit in the timebase timer control register (TBTC: TBR = 0)
- Power-on reset
- Transition to main stop mode or PLL stop mode (CKSCR: SCS = 1, LPMCR: STP = 1)
- Clock mode switching (from main clock mode to PLL clock mode, from subclock mode to PLL clock mode, or from subclock mode to main clock mode)
- Interval timer selector

The interval timer selector selects the output of the timebase timer counter from four types. When incrementing causes the selected interval time bit to overflow (carrying), an interrupt request is generated.

• Timebase timer control register (TBTC)

The timebase timer control register (TBTC) selects the interval time, clears the timebase timer counter, enables or disables interrupts, and checks and clears the state of an interrupt request.

DataShe

DataSheet4U.com

www.DataSheet4U.com

DataSheet4U.com

CHAPTER 5 TIMEBASE TIMER

# 5.3 Configuration of Timebase Timer

This section explains the registers and interrupt factors of the timebase timer.

### ■ List of Registers and Reset Values of Timebase Timer

|                                        | bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
|----------------------------------------|-----|----|----|----|----|----|----|---|---|
| Timebase timer control register (TBTC) |     | 1  | Х  | Х  | 0  | 0  | 1  | 0 | 0 |

# Generation of Interrupt Request from Timebase Timer

When the selected interval timer counter bit reaches the interval time, the overflow interrupt request flag bit in the timebase timer control register (TBTC: TBOF) is set to 1. If the overflow interrupt request flag bit is set (TBTC: TBOF = 1) when the interrupt is enabled (TBTC: TBIE = 1), the timebase timer generates an interrupt request.

et4U.com

DataShe

DataSheet4U.com

www.DataSheet4U.com

#### 5.3.1 **Timebase Timer Control Register (TBTC)**

The timebase timer control register (TBTC) provides the following settings:

- Selecting the interval time of the timebase timer
- Clearing the count value of the timebase timer
- Enabling or disabling the interrupt request when an overflow occurs
- Checking and clearing the state of the interrupt request flag when an overflow occurs

### Timebase Timer Control Register (TBTC)





|                  | Bit Name                                        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |      |
|------------------|-------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| bit 8<br>bit 9   | TBC1, TBC0:<br>Interval time select bits        | <ul> <li>These bits set the cycle of the interval timer in the timebase timer counter.</li> <li>The interval time of the timebase timer is set according to the setting of the TBC1 and TBC0 bits.</li> <li>Four interval times can be set.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |
| bit 10           | TBR:<br>Timebase timer counter<br>clear bit     | <ul> <li>This bit clears all the bits in the timebase timer counter.</li> <li>When set to 0: All the bits in the timebase timer counter are cleared to 0. The TBOF bit is also cleared.</li> <li>When set to 1: Disabled. The state remains unchanged.</li> <li>Read: 1 is always read.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |
| bit 11           | TBOF:<br>Overflow interrupt<br>request flag bit | <ul> <li>This bit indicates an overflow (carrying) in the interval timer bit in the timebase timer counter.</li> <li>When an overflow (carrying) occurs (TBOF = 1) with interrupts enabled (TBIE = 1), an interrupt request is generated.</li> <li>When set to 0: The bit is cleared.</li> <li>When set to 1: Disabled. The state remains unchanged.</li> <li>Reading by read-modify-write type instructions always reads "1".</li> <li>Notes: 1. To clear the TBOF bit, disable interrupts (TBIE = 0) or mask interrupts using the interrupt mask register (ILM) in the processor status.</li> <li>2. The TBOF bit is cleared when 0 is written to the bit, a transition to main stop mode, a transition to PLL stop mode, a transition from Subclock mode to main clock mode, or a transition from main clock mode to PLL clock mode, or a transition from main clock mode to PLL clock mode occurs, 0 is written to the timebase timer counter clear bit (TBR), or by a reset.</li> </ul> | Data |
| bit 12           | TBIE:<br>Overflow interrupt<br>enable bit       | This bit enables or disables an interrupt when the interval timer bit in the timebase timer counter overflows.<br>When set to 0: No interrupt request is generated at an overflow (TBOF = 1).<br>When set to 1: An interrupt request is generated at an overflow (TBOF = 1).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      |
| bit 13<br>bit 14 | Unused bits                                     | Read: The value is undefined.<br>Write: No effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |
| bit 15           | Reserved: Reserved bit                          | Always set this bit to 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |      |

## Table 5.3-1 Functions of Timebase Timer Control Register (TBTC)

DataSheet4U.com

# 5.4 Timebase Timer Interrupt

# The timebase timer generates an interrupt request when the interval time bit in the timebase timer counter corresponding to the interval time set by the timebase timer control register overflows (carries) (interval timer function).

# Timebase Timer Interrupt • The timebase timer continues incrementing for as long as the main clock (with 2-divided frequency of the oscillation clock) is input. • When the interval time set by the interval time select bits in the timebase timer control register (TBTC: TBC1, TBC2) is reached, the interval time select bit corresponding to the interval time selected in the timebase timer counter overflows. When the interval time select bit overflows, the overflow interrupt request flag bit in the timebase timer control register (TBTC: TBOF) is set to 1. • When the overflow interrupt request flag bit in the timebase timer control register is set (TBTC: TBOF = 1) with an interrupt enabled (TBTC: TBIE = 1), an interrupt request is generated. • When the selected interval time is reached, the overflow interrupt request flag bit in the timebase timer control register (TBTC: TBOF) is set regardless of whether an interrupt is enabled or disabled (TBTC: TBIE). To clear the overflow interrupt request flag bit (TBTC: TBOF), disable a timebase timer interrupt at interrupt processing (TBTC : TBIE=0) or mask a timebase timer interrupt by using the ILM bit in the processor status (PS) to write 0 to the TBOF bit. Note: When an interrupt is enabled (TBTC: TBIE = 1) with the overflow interrupt request flag bit in the timebase timer control register set (TBTC: TBOF = 1), an interrupt request is generated immediately. Correspondence between Timebase Timer Interrupt and El<sup>2</sup>OS

- The timebase timer does not correspond to  $EI^2OS$ .
- For details of the interrupt number, interrupt control register, and interrupt vector address, see "3.5 Interrupt".

# 5.5 Explanation of Operation of Timebase Timer

# The timebase timer operates as an interval timer or an oscillation stabilization wait time timer, and supplies a clock to resources.

### Interval Timer Function

Interrupt generation at every interval time enables the timebase timer to be used as an interval timer. Operating the timebase timer as an interval timer requires the settings shown in Figure 5.5-1.





#### Operation as interval timer function

The timebase timer can be used as an interval timer by generating an interrupt at every set interval time.

- The timebase timer continues incrementing in synchronization with the main clock (2-divided frequency of the oscillation clock) while the oscillation clock is active.
- When the timebase timer counter reaches the interval time set by the interval time select bits in the timebase timer control register (TBTC: TBC1, TBC0), it causes an overflow (carrying) and the overflow interrupt request flag bit (TBTC: TBOF) is set to 1.
- When the overflow interrupt request flag bit is set (TBTC: TBOF = 1) with interrupts enabled (TBTC: TBIE = 1), an interrupt request is generated.

Note: The interval time may become longer than the one set by clearing the timebase timer counter.

et4U.com

#### Example of operation of timebase timer

Figure 5.5-2 gives an example of the operation that the timebase timer performs under the following conditions:

- A power-on reset occurs.
- The mode transits to the sleep mode during the operation of the interval timer.
- The mode transits to the stop mode during the operation of the interval timer.
- A request to clear the timebase timer counter is issued.

At transition to the stop mode, the timebase timer counter is cleared to stop counting. At return from the stop mode, the timebase timer counts the oscillation stabilization wait time of the main clock.



#### Figure 5.5-2 Example of Operation of Timebase Timer

### Operation as Oscillation Stabilization Wait Time Timer

The timebase timer can be used as the oscillation stabilization wait time timer of the main clock and PLL clock.

• The oscillation stabilization wait time is the time elapsed from when the timebase timer counter increments from 0 until the set oscillation stabilization wait time select bit overflows (carrying).

DataSheet4U.com

et4U.com

www.DataSheet4U.com

### CHAPTER 5 TIMEBASE TIMER

Table 5.5-1 shows clearing conditions and oscillation stabilization wait time of timebase timer.

| Table 5.5-1 Clearing Conditions and Oscillation Stabilization Wait Time of Timebase Time |
|------------------------------------------------------------------------------------------|
|------------------------------------------------------------------------------------------|

| Operation                                                  | Counter<br>Clear | TBOF<br>Clear       | Oscillation Stabilization Wait Time                                                                |
|------------------------------------------------------------|------------------|---------------------|----------------------------------------------------------------------------------------------------|
| Writing 0 to timebase timer counter clear bit (TBTC: T BR) | 0                | 0                   |                                                                                                    |
| Reset                                                      |                  |                     |                                                                                                    |
| Power on reset                                             | 0                | 0                   | Transition to main clock mode after oscillation stabilization<br>wait time of main clock completed |
| Watchdog reset                                             | Х                | 0                   | Not provided                                                                                       |
| External reset                                             | Х                | 0                   | Not provided                                                                                       |
| Software reset                                             | Х                | 0                   | Not provided                                                                                       |
| Switching between clock modes                              |                  |                     |                                                                                                    |
| Main clock> PLL clock<br>(CKSCR: MCS = 1> 0)               | 0                | 0                   | Transition to PLL clock mode after oscillation stabilization wait time of PLL clock completed      |
| Main clock> subclock<br>(CKSCR: SCS = 1> 0)                | Х                | X                   | Transition to subclock mode after oscillation stabilization wait<br>time of subclock completed     |
| Subclock> main clock<br>(CKSCR: SCS = 0> 1)                | 0                | 0                   | Transition to main clock mode after oscillation stabilization<br>wait time of main clock completed |
| Subclock> PLL clock<br>(CKSCR: MCS = 0, SCS = 0> 1)        | 0                | 0                   | Transition to PLL clock mode after oscillation stabilization wait time of main clock completed     |
| PLL clock> main clock<br>(CKSCR: MCS = 0> 1)               | x D              | ataSh <u>e</u> et4L | Not provided                                                                                       |
| PLL clock> subclock<br>(CKSCR: MCS = 0, SCS = 1> 0)        | Х                | X                   | Not provided                                                                                       |
| Cancellation of stop modes                                 |                  |                     |                                                                                                    |
| Cancellation of main stop mode                             | 0                | 0                   | Transition to main clock mode after oscillation stabilization<br>wait time of main clock completed |
| Cancellation of sub-stop mode                              | Х                | X                   | Transition to subclock mode after oscillation stabilization wait<br>time of subclock completed     |
| Cancellation of PLL stop mode                              | 0                | 0                   | Transition to PLL clock mode after oscillation stabilization wait time of main clock completed     |
| Cancellation of watch mode                                 |                  |                     |                                                                                                    |
| Cancellation of sub-watch mode                             | Х                | X                   | Not provided                                                                                       |
| Cancellation of timebase timer modes                       |                  |                     |                                                                                                    |
| Return to main clock mode                                  | Х                | X                   | Not provided                                                                                       |
| Return to subclock mode                                    | Х                | X                   | Not provided                                                                                       |
| Return to PLL clock mode                                   | Х                | X                   | Not provided                                                                                       |
| Cancellation of sleep modes                                |                  |                     |                                                                                                    |
| Cancellation of main sleep mode                            | Х                | X                   | Not provided                                                                                       |
| Cancellation of sub-sleep mode                             | Х                | X                   | Not provided                                                                                       |
| Cancellation of PLL sleep mode                             | Х                | X                   | Not provided                                                                                       |

et4U.com

DataSheet4U.com

www.DataSheet4U.com

# Supply of Operation Clock

The timebase timer supplies an operation clock to the PPG timers (PPG01, PPG23) and the watchdog timer.

 Note:
 Clearing the timebase timer counter may affect the operation of the resources such as the watchdog timer and PPG timers using the output of the timebase timer.

 Reference:
 For details of the PPG timers, see "CHAPTER 10 8-/16-BIT PPG TIMER".

For details of the watchdog timer, see "CHAPTER 6 WATCHDOG TIMER".

et4U.com

DataShe

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

CHAPTER 5 TIMEBASE TIMER

# 5.6 Precautions when Using Timebase Timer

# This section explains the precautions when using the timebase timer.

# Precautions when Using Timebase Timer

• Clearing interrupt request

To clear the overflow interrupt request flag bit in the timebase timer control register (TBTC: TBOF = 0), disable interrupts (TBTC: TBIE = 0) or mask the timebase timer interrupt by using the interrupt level mask register in the processor status.

Clearing timebase timer counter

Clearing the timebase timer counter affects the following operations:

- When the timebase timer is used as the interval timer (interval interrupt).
- When the watchdog timer is used.
- When the clock supplied from the timebase timer is used as the operation clock of the PPG timer.
- Using timebase timer as oscillation stabilization wait time timer
  - After power on or in the main stop mode, PLL stop mode, and subclock mode, the oscillation clock stops. Therefore, when oscillation starts; the timebase timer requires the oscillation stabilization wait time of the main clock. An appropriate oscillation stabilization wait time must be selected according to the types of oscillators connected to high-speed oscillation input pins.

Reference: For details of the oscillation stabilization wait time, see "3.7.5 Oscillation Stabilization Wait Time".

- Resources to which timebase timer supplies clock
  - At transition to operation modes (PLL stop mode, subclock mode, and main stop mode) in which the oscillation clock stops, the timebase timer counter is cleared and the timebase timer stops.
  - When the timebase timer counter is cleared, an after-clearing interval time is needed. It may cause the clock supplied from the timebase timer to have a short High level or a 1/2 cycle longer Low level.
  - The watchdog timer performs normal counting because the watchdog timer counter and timebase timer counter are cleared simultaneously.

et4U.com

## 5.7 Program Example of Timebase Timer

This section gives a program example of the timebase timer.

## ■ Program Example of Timebase Timer

### Processing specification

The  $2^{12}$ /HCLK (HCLK: oscillation clock) interval interrupt is generated repeatedly. In this case, the interval time is approximately 1.0 ms (at 4-MHz operation).

### • Coding example

et4U.com

| ICR02  | EQU   | 0000B2H          | ; Timebase timer interrupt control register |       |
|--------|-------|------------------|---------------------------------------------|-------|
| TBTC   | EQU   | 0000A9H          | ; Timebase timer control register           |       |
| TBOF   | EQU   |                  | ; Interrupt request flag bit                |       |
|        |       |                  | ; Interrupt enable bit                      |       |
|        |       | rogram           | -                                           |       |
| CODE   | CSEG  | -                |                                             |       |
| START: |       |                  | ; Stack pointer (SP) already initialized    |       |
|        | AND   | CCR,#0BFH        | ; Interrupts disabled                       |       |
|        |       |                  | ; Interrupt level 0 (highest)               | DataS |
|        | MOV   | I:TBTC,#1000000B | ; Upper 3 bits fixed                        |       |
|        |       |                  | ; TBOF cleared,                             |       |
|        |       |                  | ; Counter cleare interval time              |       |
|        |       |                  | ; 2 <sup>12</sup> /HCLK selected            |       |
|        | SETB  | I:TBIE           | ; Interrup enabled                          |       |
|        | MOV   | ILM,#07H         | ; ILM in PS set to level 7                  |       |
|        | OR    | CCR,#40H         | ; Interrupts enabled                        |       |
| LOOP:  | MOV   | A,#00H           | ; Infinite loop                             |       |
|        | MOV   | A,#01H           |                                             |       |
|        | BRA   | LOOP             |                                             |       |
| ;I1    | nterr | upt program      |                                             |       |
| WARI:  |       |                  |                                             |       |
|        | CLRB  | I:TBIE           | ; Interrupt enabled bit cleared             |       |
|        | CLRB  | I:TBOF           | ; Interrupt request flag cleared            |       |
|        | :     |                  |                                             |       |
|        | Proce | essing by user   |                                             |       |
|        | :     |                  |                                             |       |
|        | SETB  | I:TBIE           | ; Interrupt enabled                         |       |
|        | RETI  |                  | ; Return from interrupt                     |       |
| CODE   | ENDS  |                  |                                             |       |
| ;Ve    | ector | setting          |                                             |       |
| VECT   | CSEG  | ABS=0FFH         |                                             |       |
|        | ORG   | 0FFBCH           | ; Vector set to interrupt #16 (10H)         |       |
|        | DSL   | WARI             |                                             |       |
|        | ORG   | 0 FFDCH          | ; Reset vector set                          |       |
|        | DSL   | START            |                                             |       |
|        | DB    | 00H              | ; Set to single-chip mode                   |       |
| VECT   | ENDS  |                  |                                             |       |
|        | END   | START            |                                             |       |
|        |       |                  |                                             |       |

www.DataSheet4U.com

## CHAPTER 5 TIMEBASE TIMER

et4U.com

DataSheet4U.com

DataSheet4U.com

202

DataSheet4U.com

DataShe

www.DataSheet4U.com

# CHAPTER 6 WATCHDOG TIMER

This chapter describes the function and operation of the watchdog timer.

- 6.1 Overview of Watchdog Timer
- 6.2 Configuration of Watchdog Timer
- 6.3 Watchdog Timer Registers
- 6.4 Explanation of Operation of Watchdog Timer
- 6.5 Precautions when Using Watchdog Timer
- 6.6 Program Examples of Watchdog Timer

et4U.com

DataSheet4U.com

www.DataSheet4U.com

## 6.1 **Overview of Watchdog Timer**

## The watchdog timer is a 2-bit counter that uses the timebase timer or watch timer as a count clock. If the counter is not cleared within a set interval time, the CPU is reset.

## Functions of Watchdog Timer

- The watchdog timer is a timer counter that is used to prevent program malfunction. When the watchdog timer is started, the watchdog timer counter must continue to be cleared within a set interval time. If the set interval time is reached without clearing the watchdog timer counter, the CPU is reset.
- The interval time of the watchdog timer depends on the clock cycle input as a count clock and a watchdog reset occurs between the minimum and maximum times.
- The clock source output destination is set by the watchdog clock select bit in the watch timer control register (WTC: WDCS).
- The interval time of the watchdog timer is set by the timebase timer output select bit/watch timer output select bit in the watchdog timer control register (WDTC: WT1, WT0).

Table 6.1-1 lists the interval times of the watchdog timer.

| Table 6.1-1 | Interval | I ime of | watchdog | limer |  |
|-------------|----------|----------|----------|-------|--|
|             |          |          |          |       |  |

.....

| Min.              | Max.              | Clock cycle               | Min.             | Max.             | Clock cycle               | DataShe |
|-------------------|-------------------|---------------------------|------------------|------------------|---------------------------|---------|
| Approx. 3.58 ms   | Approx.4.61 ms    | $2^{14} \pm 2^{11}$ /HCEK | ∪Approx. 0.457 s | Approx. 0.576 s  | $2^{12} \pm 2^9$ /SCLK    |         |
| Approx. 14.33 ms  | Approx. 18.3 ms   | $2^{16} \pm 2^{13}$ /HCLK | Approx. 3.584 s  | Approx. 4.608 s  | $2^{15} \pm 2^{12}$ /SCLK |         |
| Approx. 57.23 ms  | Approx. 73.73 ms  | $2^{18} \pm 2^{15}$ /HCLK | Approx. 7.168 s  | Approx. 9.216 s  | $2^{16} \pm 2^{13}$ /SCLK |         |
| Approx. 458.75 ms | Approx. 589.82 ms | $2^{21} \pm 2^{18}$ /HCLK | Approx. 14.336 s | Approx. 18.432 s | $2^{17} \pm 2^{14}$ /SCLK |         |

HCLK: Oscillation clock (4 MHz), SLCK: Subclock (8.192 kHz)

• If the timebase timer output (carry signal) is used as a count clock to the watchdog timer, the timebase timer is cleared and the time for the watchdog reset to occur may be long.

• If the subclock is used as a machine clock, always set the watchdog timer clock source select bit (WDCS) in the watch timer control register (WTC) to 0 to select the watch timer output.

et4U.com

## 6.2 Configuration of Watchdog Timer

The watchdog timer consists of the following blocks:

- Count clock selector
- Watchdog timer counter (2-bit counter)
- Watchdog reset generator
- Counter clear controller
- Watchdog timer control register (WDTC)

## Block Diagram of Watchdog Timer



## Figure 6.2-1 Block Diagram of Watchdog Timer

www.DataSheet4U.com

## CHAPTER 6 WATCHDOG TIMER

### • Count clock selector

The count clock selector selects the timebase timer output or watch timer output as a count clock input to the watchdog timer. Each timer output has four time intervals that can be set.

#### Watchdog timer counter (2-bit counter)

The watchdog timer counter is a 2-bit up counter that uses the timebase timer output or watch timer output as a count clock. The clock source output destination is set by the watchdog clock select bit in the watch timer control register (WTC: WDCS).

#### • Watchdog reset generator

The watchdog reset generator generates a reset signal when the watchdog timer overflows (carrying).

### • Counter clear controller

The counter clear controller clears the watchdog timer counter.

### • Watchdog timer control register (WDTC)

The watchdog timer control register starts and clears the watchdog timer, sets the interval time, and holds reset factors.

et4U.com

DataSheet4U.com

www.DataSheet4U.com

## 6.3 Watchdog Timer Registers

This section explains the registers used for setting the watchdog timer.

## ■ List of Registers and Reset Values of Watchdog Timer

| bit                                    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------------------------------|---|---|---|---|---|---|---|---|
| Watchdog timer control register (WDTC) | Х | x | Х | Х | Х | 1 | 1 | 1 |
| X: Undefined                           |   |   | 1 | 1 | 1 | 1 | 1 |   |

Figure 6.3-1 List of Registers and Reset Values of Watchdog Timer

et4U.com

DataShe

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

DataSheet4U.com

207

## 6.3.1 Watchdog Timer Control Register (WDTC)

The watchdog timer control register starts and clears the watchdog timer, sets the interval time, and holds reset factors.

## Watchdog Timer Control Register (WDTC)





DataSheet4U.com

et4U.com

www.DataSheet4U.com

|                      | Bit name                                        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------|-------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0,<br>bit 1      | WT1, WT0:<br>Interval time select bits          | <ul> <li>These bits set the interval time of the watchdog timer.</li> <li>The time interval when the watch timer is used as the clock source to the watchdog timer (watchdog clock select bit WDCS = 0) is different from when the main clock mode or the PLL clock mode is selected as the clock mode and the WDCS bit in the watch timer control register (WTC) is set to 1 as shown in Figure 6.3-2 according to the settings of the WTC register.</li> <li>Only data when the watchdog timer is started is enabled.</li> <li>Write data after the watchdog timer is started is ignored.</li> <li>These are write-only bits.</li> </ul> |
| bit 2                | WTE:<br>Watchdog timer control<br>bit           | This bit starts or clears the watchdog timer.<br>When set to 0 (first time after reset): The watchdog timer is started.<br>When set to 0 (second or subsequent after reset): The watchdog timer is cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                |
| bit6                 | Unused bits                                     | Read: The value is undefined.<br>Write: No effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| bit 3<br>to<br>bit 7 | PONR, WRST, ERST,<br>SRST:<br>Reset factor bits | <ul> <li>These bits indicate reset factors.</li> <li>When a reset occurs, the bit corresponding to the reset factor is set to 1. After a reset, the reset factor can be checked by reading the watchdog timer control register (WDTC).</li> <li>These bits are cleared after the watchdog timer control register (WDTC) is read.</li> <li>Note: No bit value other than the PONR bit after power-on reset is assured. If the PONR bit is set at read, other bit values should be ignored.</li> </ul>                                                                                                                                       |

## Table 6.3-1 Function of Watching Timer Control Register (WDTC)

et4U.com

DataSheet4U.com

www.DataSheet4U.com

## 6.4 Explanation of Operation of Watchdog Timer

## After starting, when the watchdog timer reaches the set interval time without the counter being cleared, a watchdog reset occurs.

## Operation of Watchdog Timer

The operation of the watchdog timer requires the settings shown in Figure 6.4-1.



Figure 6.4-1 Setting of Watchdog Timer

• Selecting clock input source

• The timebase timer or watch timer can be selected as the clock input source of the count clock to the watchdog timer. When the watchdog clock select bit (WTC: WDCS) is set to 1, the timebase timer is selected. When the bit is set to 0, the watch timer is selected. After a reset, the bit returns to 1.

DataShe

www.DataSheet4U.com

- During operation in the subclock mode, set the WDCS bit to 0 to select the watch timer.
- Setting interval time
  - Set the interval time select bits (WDTS: WT1, WT0) to select the interval time for the watchdog timer.
  - Set the interval time concurrently with starting the watchdog timer. Writing to the bit is ignored after the watchdog timer is started.
- Starting watchdog timer
  - When 0 is written to the watchdog timer control bit (WDTC: WTE) after a reset, the watchdog timer is started and starts incrementing.

et4U.com

## Clearing watchdog timer

- When 0 is written once again to the watchdog timer control bit (WDTC: WTE) within the interval time after starting the watchdog timer, the watchdog timer is cleared. If the watchdog timer is not cleared within the interval time, it overflows and the CPU is reset.
- A reset, or transitions to the standby modes (sleep mode, stop mode, watch mode, timebase timer mode) clear the watchdog timer.
- During operation in the timebase timer mode or watch mode, the watchdog timer counter is cleared. However, the watchdog timer remains in the activation state.
- Figure 6.4-2 shows the relationship between the clear timing and the interval time of the watchdog timer. The interval time varies with the timing of clearing the watchdog timer.

et4U.com

DataSheet4U.com

DataShe

www.DataSheet4U.com

## CHAPTER 6 WATCHDOG TIMER

### • Checking reset factors

The reset factor bits in the watchdog timer control register (WDTC: PONR, WRST, ERST, SRST) can be read after a reset to check the reset factors.



DataSheet4U.com

www.DataSheet4U.com

## 212

## 6.5 Precautions when Using Watchdog Timer

Take the following precautions when using the watchdog timer.

## Precautions when Using Watchdog Timer

• Stopping watchdog timer

The watchdog timer is stopped by all the reset sources.

- Interval time
  - The interval time uses the carry signal of the timebase timer or watch timer as a count clock. If the timebase timer or watch timer is cleared, the interval time of the watchdog timer may become long. The timebase timer is also cleared by writing zero to the timebase timer counter clear bit (TBR) in the timebase timer control register (TBTC); transition from main clock mode to PLL clock mode; transition from subclock mode to main clock mode; and transition from subclock mode to PLL clock mode.
  - Set the interval time concurrently with starting the watchdog timer. Setting the interval time except starting the watchdog timer is ignored.

#### Precautions when creating program

When clearing the watchdog timer repeatedly in the main loop, set a shorter processing time for the main loop including interrupt processing than the interval time of watchdog timer.

et4U.com

DataSheet4U.com

www.DataSheet4U.com

CHAPTER 6 WATCHDOG TIMER

## 6.6 Program Examples of Watchdog Timer

## Program example of watchdog timer is given below:

## Program Example of Watchdog Timer

- Processing specification
  - The watchdog timer is cleared each time in loop of the main program.
  - The main program must be executed once within the minimum interval time of the watchdog timer.
- Coding example

| WD1 | TC EQU | 0000A8H           | ; | Watchdog timer control register                    |         |
|-----|--------|-------------------|---|----------------------------------------------------|---------|
| WTI | e equ  | WDTC:2            | ; | Watchdog control bit                               |         |
| i   |        |                   |   |                                                    |         |
| ;   | Main   | program           |   |                                                    |         |
| COI | DE     | CSEG              |   |                                                    |         |
| STA | ART:   |                   | ; | Stack pointer (SP), already initialized            |         |
|     | MOV    | I:WDTC,#00000011B |   | Watchdog timer started                             |         |
|     |        |                   | ; | Interval time of $2^{21} + 2^{18}$ cycles selected | D-t-Cho |
| LOC | OP:    |                   |   |                                                    | DataShe |
|     | CLR    | B I:WTE           | ; | Watchdog timer cleared                             |         |
|     | :      |                   |   |                                                    |         |
|     | Pro    | cessing by user   |   |                                                    |         |
|     | :      |                   |   |                                                    |         |
|     | BRA    | LOOP              |   |                                                    |         |
| ;   | Vecto  | r setting         |   |                                                    |         |
| VEC | CT CSE | G ABS=0FFH        |   |                                                    |         |
|     | ORG    | 00FFDCH           | ; | Reset vector set                                   |         |
|     | DSL    | START             |   |                                                    |         |
|     | DB     | 00H               | ; | Set to single-chip mode                            |         |
| VEC | CT END | S                 |   |                                                    |         |
|     | END    | START             |   |                                                    |         |

et4U.com

This chapter explains the function and operation of 16bit input/output timer.

et4U.com

- 7.1 Overview of 16-bit Input/Output Timer
- 7.2 Block Diagram of 16-bit Input/Output Timer
- 7.3 Configuration of 16-bit Input/Output Timer
- 7.4 Interrupts of 16-bit Input/Output Timer
- 7.5 Explanation of Operation of 16-bit Free-run Timer
- 7.6 Explanation of Operation of Input Capture
- 7.7 Precautions when Using 16-bit Input/Output Timer
- 7.8 Program Example of 16-bit Input/Output Timer

## 7.1 Overview of 16-bit Input/Output Timer

# The 16-bit input/output timer is a complex module that consists of a 16-bit free-run timer (x 1 unit) and an input capture (x 2 units/4 input pins). The clock cycle of an input signal and a pulse width can be measured based on the 16-bit free-run timer.

## Configuration of 16-bit Input/Output Timer

The 16-bit input/output timer consists of the following modules:

- 16-bit free-run timer (× 1 unit)
- Input capture (× 2 units with 2 input pins each)

## Functions of 16-bit Input/Output Timer

• Functions of 16-bit free-run timer

The 16-bit free-run timer consists of a 16-bit up counter, a timer counter control status register, and a prescaler. The 16-bit up counter increments in synchronization with the division ratio of the machine clock.

- Count clock is selected from eight machine clock division ratios. Count clock : φ, φ/2, φ/4, φ/8, φ/16, φ/32, φ/64, φ/128
- An overflow in the count value generates an interrupt.

www.DataSheet4U.com

- Interrupt generation starts the extended intelligent I/O service (EI<sup>2</sup>OS).
- Either a reset or software reset by the timer count clear bit (TCCS: CLR) clears the count value of the 16-bit free-run timer to "0000<sub>H</sub>".
- The count value of the 16-bit free-run timer is output to the input capture and can be used as the base time for capture operation.
- Functions of input capture

When the input capture detects the edge of the external signal input to the input pins, it stores the count value of the 16-bit free-run timer in the input capture data registers. The input capture consists of the input capture data registers corresponding to four input pins, an input capture control status register, and an edge detection circuit.

- The detected edge can be selected from among the rising edge, falling edge, and both edges.
- Detecting the edge of the input signal generates an interrupt request to the CPU.
- Interrupt generation starts the EI<sup>2</sup>OS.
- Four input pins and four input capture data registers of the input capture can be used to measure up to four events.

DataSheet4U.com

et4U.com

## 7.2 Block Diagram of 16-bit Input/Output Timer

The 16-bit input/output timer consists of the following modules:

- 16-bit free-run timer
- Input capture

## Block Diagram of 16-bit Input/Output Timer



## Figure 7.2-1 Block Diagram of 16-bit Input/Output Timer

#### • 16-bit free-run timer

The count value of the 16-bit free-run timer can be use as the base time for the input capture.

#### Input capture

The input capture detects the rising edge, falling edge, or both edges of the external signal input to the input pins to retain the count value of the 16-bit free-run timer. Detecting the edge of the input signal generates an interrupt.

## 7.2.1 Block Diagram of 16-bit Free-run Timer

The 16-bit free-run timer consists of the following blocks:

- Prescaler
- Timer counter data register (TCDT)
- Timer counter control status register (TCCS)

Block Diagram of 16-bit Free-run Timer



Figure 7.2-2 Block Diagram of 16-bit Free-run Timer

## Details of Pins in Block Diagram

The 16-bit input/output timer has one 16-bit free-run timer.

The interrupt request number of the 16-bit free-run timer is as follows:

Interrupt request number:  $19(13_{\rm H})$ 

## Prescaler

The prescaler divides the frequency of machine clock to supply a count clock to the 16-bit up counter. Any of eight machine clock division ratios are selected by setting the timer counter control status register (TCCS).

## Timer counter data register (TCDT)

The timer counter data register (TCDT) is a 16-bit up counter. At read, the current count value of the 16-bit free-run timer can be read. Writing while the counter is stopped enables any count value to be set.

DataSheet4U.com

et4U.com

218

## Timer counter control status register (TCCS)

The timer counter control status register (TCCS) selects the division ratio of the machine clock, clears the count value by software, enables or disables the count operation, checks and clears the overflow generation flag, and enables or disables interrupts.

et4U.com

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

## 7.2.2 Block Diagram of Input Capture

The input capture consist of the following blocks:

- Input capture data registers (IPCP0 to IPCP3)
- Input capture control status registers (ICS01, ICS23)
- Edge detection circuit

## Block Diagram of Input Capture



Figure 7.2-3 Block Diagram of Input Capture

DataSheet4U.com

et4U.com

220

DataSheet4U.com

www.DataSheet4U.com

## Details of Pins in Block Diagram

The 16-bit input/output timer has four input capture input pins.

The actual pin names and interrupt request numbers of the input capture are shown in Table 7.2-1.

Table 7.2-1 Pins and Interrupt Request Numbers of 16-bit Input/Output Timer

| Input Pin | Actual Pin Name | Interrupt Request Number |
|-----------|-----------------|--------------------------|
| IN0       | P10/IN0         | #23 (17 <sub>H</sub> )   |
| IN1       | P11/IN1         | #25 (19 <sub>H</sub> )   |
| IN2       | P12/IN2         | #30 (1E <sub>H</sub> )   |
| IN3       | P13/IN3         | #30 (ILH)                |

#### Input capture data registers 0 to 3 (IPCP0 to IPCP3)

The counter value of the 16-bit free-run timer actually read when the edge of the external signal input to the input pins (IN0 to IN3) is detected is stored in the input capture data registers (IPCP0 to IPCP3) corresponding to the input pins (IN0 to IN3) to which the signal is input.

#### Input capture control status registers (ICS01, ICS23)

et4U.com

The input capture control status registers (ICS01, ICS23) start and stop the capture operation of each input capture, check and clear the valid edge detection flag when the edge is detected, and enable or disable an interrupt. The ICS01 register sets the input capture corresponding to the input pins IN0 and IN1, and the ICS23 register sets the input capture corresponding to the input pins IN2 and IN3.

#### Edge detector

The edge detection circuit detects the edge of the external signal input to the input pins. The detected edge can be selected from the rising edge, falling edge, and both edges.

## 7.3 Configuration of 16-bit Input/Output Timer

## This section explains the pins, registers, and interrupt factors of the 16-bit input/output timer.

## ■ Pins of 16-bit Input/Output Timer

The pins of the 16-bit input/output timer serve as general-purpose I/O ports. Table 7.3-1 shows the pin functions and the pin settings required to use the 16-bit input/output timer.

#### Table 7.3-1 Pins of 16-bit Input/Output Timer

| Pin<br>Name | Pin Function                            | Pin Setting Required for Use of 16-bit Input/Output Timer |
|-------------|-----------------------------------------|-----------------------------------------------------------|
| IN0         | General-purpose I/O port, capture input | Set as input port in port direction register (DDR).       |
| IN1         | General-purpose I/O port, capture input | Set as input port in port direction register (DDR).       |
| IN2         | General-purpose I/O port, capture input | Set as input port in port direction register (DDR).       |
| IN3         | General-purpose I/O port, capture input | Set as input port in port direction register (DDR).       |

et4U.com

## Block Diagram of Pins for 16-bit Input/Output Timer

For the block diagram of the pins, see "CHAPTER 4 I/O PORT".

www.DataSheet4U.com

## ■ List of Registers and Reset Values of 16-bit Input/Output Timer

|                                                    | bit | 7      | 6                      | 5               | 4  | 3  | 2  | 1 | 0 |
|----------------------------------------------------|-----|--------|------------------------|-----------------|----|----|----|---|---|
| Timer counter control status register (TCCS)       |     | 0      | 0                      | 0               | 0  | 0  | 0  | 0 | 0 |
|                                                    | bit | 15     | 14                     | 13              | 12 | 11 | 10 | 9 | 8 |
| Timer counter data register (High)<br>(TCDT: H)    |     | 0      | 0                      | 0               | 0  | 0  | 0  | 0 | 0 |
|                                                    | bit | 7      | 6                      | 5               | 4  | 3  | 2  | 1 | 0 |
| Timer counter data register (Low) (TCDT: L)        |     | 0      | 0                      | 0               | 0  | 0  | 0  | 0 | 0 |
|                                                    | bit | 7      | 6                      | 5               | 4  | 3  | 2  | 1 | 0 |
| Input capture control status register (ICS01)      |     | 0      | 0                      | 0               | 0  | 0  | 0  | 0 | 0 |
|                                                    | bit | 15     | 14                     | 13              | 12 | 11 | 10 | 9 | 8 |
| Input capture data register 0 (High) (IPCP0: H)    |     | Х      | Х                      | Х               | Х  | Х  | Х  | Х | Х |
|                                                    | bit | 7      | 6                      | 5               | 4  | 3  | 2  | 1 | 0 |
| Input capture data register 0 (Low) (IPCP0: L)     |     | Х      | Х                      | Х               | Х  | Х  | Х  | Х | Х |
|                                                    | bit | 15     | 14                     | 13              | 12 | 11 | 10 | 9 | 8 |
| Input capture data register 1 (High)<br>(IPCP1: H) |     | DataSh | eet <mark>x</mark> U.c | x <sup>no</sup> | Х  | Х  | Х  | Х | Х |
|                                                    | bit | 7      | 6                      | 5               | 4  | 3  | 2  | 1 | 0 |
| Input capture data register 1 (Low) (IPCP1: L)     |     | Х      | Х                      | Х               | Х  | Х  | Х  | Х | Х |
|                                                    | bit | 7      | 6                      | 5               | 4  | 3  | 2  | 1 | 0 |
| Input capture control status register (ICS23)      |     | 0      | 0                      | 0               | 0  | 0  | 0  | 0 | 0 |
|                                                    | bit | 15     | 14                     | 13              | 12 | 11 | 10 | 9 | 8 |
| Input capture data register 2 (High)<br>(IPCP2: H) |     | Х      | Х                      | Х               | Х  | Х  | Х  | Х | Х |
|                                                    | bit | 7      | 6                      | 5               | 4  | 3  | 2  | 1 | 0 |
| Input capture data register 2 (Low) (IPCP2: L)     |     | Х      | Х                      | Х               | х  | Х  | Х  | Х | Х |
|                                                    | bit | 15     | 14                     | 13              | 12 | 11 | 10 | 9 | 8 |
| Input capture data register 3 (High)<br>(IPCP3: H) |     | Х      | Х                      | Х               | Х  | Х  | Х  | Х | Х |
|                                                    | bit | 7      | 6                      | 5               | 4  | 3  | 2  | 1 | 0 |
| Input capture data register 3 (Low) (IPCP3: L)     |     | Х      | Х                      | Х               | Х  | Х  | Х  | Х | Х |

## Figure 7.3-1 List of Registers and Reset Values of 16-bit Input/Output Timer

et4U.com

DataSheet4U.com

www.DataSheet4U.com

## Generation of Interrupt Request from 16-bit Input/Output Timer

The 16-bit input/output timer can generate an interrupt request as a result of the following factors:

#### • Overflow in 16-bit free-run timer

In the 16-bit input/output timer, when the 16-bit free-run timer overflows, the overflow generation flag bit in the timer counter control status register (TCCS: IVF) is set to 1. When an overflow interrupt is enabled (TCCS: IVFE = 1), an interrupt request is generated.

#### Edge detection by capture function

When the edge of the external signal input to the input pins (IN0 to IN3) is detected, the input capture valid edge detection flag bit in the input capture control status register (ICS: ICP) corresponding to the input pin as the edge is detected is set to 1. When the input capture interrupt corresponding to the channel generating an interrupt request is enabled (ICS: ICE), an interrupt request is generated.

et4U.com

DataSheet4U.com

DataShe

www.DataSheet4U.com

## 7.3.1 Timer Counter Control Status Register (TCCS)

The timer counter control status register (TCCS) selects the count clock and conditions for clearing the counter, clears the counter, enables the count operation or interrupt, and checks the interrupt request flag.

## ■ Timer Counter Control Status Register (TCCS)





DataSheet4U.com

et4U.com

www.DataSheet4U.com

|                         | Bit Name                                     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |      |
|-------------------------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| bit 0<br>bit 1<br>bit 2 | CLK2, CLK1, CLK0:<br>Count clock select bits | <ul> <li>These bits set the count clock to the 16-bit free-run time.</li> <li>Note: 1. Set the count clock after stopping the count operation (STOP = 1).</li> <li>2. When rewriting the count clock, write 1 to the timer count clear bit (CLR) and clear the counter value.</li> </ul>                                                                                                                                                                                                                                                                                    |      |
| bit 3                   | CLR:<br>Timer count clear bit                | <ul> <li>This bit clears the counter value of the 16-bit free-run timer.</li> <li>When set to 1: Clears timer counter data register (TCDT) to "0000<sub>H</sub>"</li> <li>When set to 0: No effect</li> <li>Read: 0 is always read.</li> <li>When the counter value changes, the CLR bit is cleared.</li> <li>When clearing the counter value while stopping the count operation, write "0000<sub>H</sub>" to the timer counter data register (TCDT).</li> </ul>                                                                                                            |      |
| bit 4                   | Reserved: Reserved bit                       | Always set this bit to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |      |
| bit 5                   | STOP:<br>Timer count bit                     | This bit enables or disables (stops) the count operation of the 16-bit free-run<br>timer.<br>When set to 0: Enables count operation<br>The 16-bit timer counter data register (TCDT) starts incrementing in<br>synchronization with the count clock selected by the count clock select bits<br>(CLK1 and CLK0).<br>When set to 1: Stops count operation                                                                                                                                                                                                                     | Data |
| bit 6                   | IVFE:<br>Overflow interrupt<br>enable bit    | This bit enables or disables an interrupt request generated when the 16-bit free-<br>run timer overflows.<br>When set to 0: No interrupt request generated at overflow (IVF = 1)<br>When set to 1: Generates interrupt request at overflow (IVF = 1)                                                                                                                                                                                                                                                                                                                        |      |
| bit 7                   | IVF:<br>Overflow generation flag<br>bit      | <ul> <li>This bit indicates that the 16-bit free-run timer has overflowed.</li> <li>If the 16-bit free-run timer overflows or mode setting causes a compare match with the compare register 0 to clear the counter, this bit is set to 1.</li> <li>When an overflow occurs (IVF=1) with an overflow interrupt enabled (IVFE = 1), an interrupt request is generated.</li> <li>When set to 0: Clears bit</li> <li>When set to 1: No effect</li> <li>When El<sup>2</sup>OS started: Bit cleared</li> <li>Read by read modify write instructions: 1 is always read.</li> </ul> |      |

## Table 7.3-2 Functions of Timer Counter Control Status Register (TCCS)

et4U.com

et4U.com

## 7.3.2 Timer Counter Data Register (TCDT)

The timer counter data register (TCDT) is a 16-bit up counter. At read, the register value being counted is read. At write, while the counter is stopped, any counter value can be set.

## ■ Timer Counter Data Register (TCDT)

|                                            | <u> </u> |        |        |        |        | <u> </u> | · /   |       |                       |
|--------------------------------------------|----------|--------|--------|--------|--------|----------|-------|-------|-----------------------|
|                                            | bit 15   | bit 14 | bit 13 | bit 12 | bit 11 | bit 10   | bit 9 | bit 8 | Reset value           |
| Timer counter data register (TCDT): High   | T15      | T14    | T13    | T12    | T11    | T10      | Т9    | Т8    | 00000000 <sub>B</sub> |
|                                            | R/W      | R/W    | R/W    | R/W    | R/W    | R/W      | R/W   | R/W   |                       |
|                                            | bit 7    | bit 6  | bit 5  | bit 4  | bit 3  | bit 2    | bit 1 | bit 0 | Reset value           |
| Timer counter data<br>register (TCDT): Low | SCM      | МСМ    | WS1    | WS0    | SCS    | MCS      | CS1   | CS0   | 00000000 <sub>B</sub> |
|                                            | R        | R      | R/W    | R/W    | R/W    | R/W      | R/W   | R/W   |                       |
| R/W: Read/<br>Write                        |          |        |        |        |        |          |       |       |                       |

Figure 7.3-3 Timer Counter Data Register (TCDT)

## ■ Count Operation of Timer Counter Data Register (TCDT)

- When the timer counter data register (TCDT) is read during the count operation, the counter value of the 16-bit free-run timer is read.
- When the counter value of the timer counter data register (TCDT) increments from "FFFF<sub>H</sub>" to " $0000_{\text{H}}$ ", an overflow occurs and the overflow generation flag bit (TCCS: IVF) is also set to 1.
- When an overflow occurs (TCCS: IVF = 1) with an overflow interrupt enabled (TCCS: IVFE = 1), an overflow interrupt request is generated.
- The counter value of the timer counter data register (TCDT) is retained while the count operation is stopped.
- When stopping the count operation of the timer counter data register (TCDT), write 1 to the timer count operation bit (TCCS: STOP).
- When the count operation stops (TCCS: STOP = 1), the counter value of the timer counter data register (TCDT) can be set to any value.
- Factors clearing timer counter data register

The timer counter data register (TCDT) is cleared to  $"0000_{\text{H}}"$  by the following factors:

of the following events, the overflow clears the register in synchronization with the count clock and each of the other events clears the register on occurrence of that event.

- Reset
- Writing 1 to the timer count clear bit (TCCS: CLR) (possible even during count operation)
- Writing "0000<sub>H</sub>" to timer counter data register (TCDT) while count operation stopped

• Overflow in 16-bit free-run timer

www.DataSheet4U.com

Note: Always use a word instruction (MOVW) to set the timer counter data register (TCDT).

et4U.com

DataSheet4U.com

DataSheet4U.com

228

DataSheet4U.com

www.DataSheet4U.com

## Input Capture Control Status Registers (ICS01 and 7.3.3 **ICS23)**

The input capture control status registers sets the operation of input captures. The ICS01 register sets the operation of input captures 0 and 1 and the ICS23 sets the operation of input captures 2 and 3.

The input capture control status registers provides the following settings:

- Selecting the edge to be detected
- Enabling or disabling an interrupt when the edge is detected
- Checking and clearing the valid edge detection flag when the edge is detected

## Input Capture Control Status Registers (ICS01 and ICS23)





DataSheet4U.com

www.DataSheet4U.com

| Table 7.3-3 Functions of | f Input Capture | <b>Control Status</b> | Register | (ICS01) | (1/2) |
|--------------------------|-----------------|-----------------------|----------|---------|-------|
|--------------------------|-----------------|-----------------------|----------|---------|-------|

|                                                                 | Bit Name                                            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |
|-----------------------------------------------------------------|-----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| bit0<br>bit1                                                    | EG01, CEG00:<br>Input capture 0 edge<br>select bits | These bits enable or disable the operation of input capture 0.The edge detected by input capture 0 is selected when the operation of inputcapture 0 is enabled.EG01, EG00 = "00 <sub>B</sub> ":The operation of input capture 0 is disabled and no edge is detected.EG01, EG00 "00 <sub>B</sub> ":The operation of input capture 0 is enabled and no edge is detected.EG01, EG00 "00 <sub>B</sub> ":The operation of input capture 0 is enabled and the edge is detected.                                                                                                                                                            |      |
| bit 2<br>bit 3                                                  | EG11, EG10:<br>Input capture 1 edge<br>select bits  | These bits enable or disable the operation of input capture 1.<br>The edge detected by input capture 1 is selected when the operation of input<br>capture 1 is enabled.<br><b>EG01, EG00 = "00<sub>B</sub>":</b><br>The operation of input capture 1 is disabled and no edge is detected.<br><b>EG01, EG00 "00<sub>B</sub>":</b><br>The operation of input capture 1 is enabled and the edge is detected.                                                                                                                                                                                                                            |      |
| bit 4                                                           | ICE0:<br>Input capture 0 interrupt<br>enable bit    | This bit enables or disables an interrupt when the edge is detected by input capture 0.         When set to 0:         No interrupt is generated even when the valid edge is detected by input capture 0.         When set to 1:         No interrupt is generated even when the valid edge is detected by input capture 0.         When set to 2:         An interrupt is generated when the valid edge is detected by input capture 0.                                                                                                                                                                                             | Data |
| bit 5                                                           | ICE1:<br>Input capture 1 interrupt<br>enable bit    | <ul> <li>This bit enables or disables an interrupt when the edge is detected by input capture 1.</li> <li>When set to 0: <ul> <li>No interrupt is generated even when the edge is detected by input capture 1.</li> </ul> </li> <li>When set to 1: <ul> <li>An interrupt is generated when the edge is detected by input capture 1.</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                           |      |
| bit 6 ICP0:<br>Input capture 0 valid<br>edge detection flag bit |                                                     | <ul> <li>This bit indicates the edge detection by input capture 0.</li> <li>When the valid edge selected by the input capture 0 edge select bits (EG01, EG00) is detected, the ICP0 bit is set to 1.</li> <li>When the valid edge is detected by input capture 0 (ICP0 = 1) when an interrupt due to the edge detection by input capture 0 is enabled (ICE0 = 1), an interrupt is generated.</li> <li>When set to 0:<br/>The bit is cleared.</li> <li>When set to 1:<br/>No effect</li> <li>When EI<sup>2</sup>OS started:<br/>The bit is cleared.</li> <li>Read by read modify write instructions:<br/>1 is always read.</li> </ul> |      |

et4U.com

|       | Bit Name                                                  | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|-----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 7 | ICP1:<br>Input capture 1 valid<br>edge detection flag bit | <ul> <li>This bit indicates the edge detection by input capture 1.</li> <li>When the valid edge selected by the input capture 1 edge select bits (EG11, EG10) is detected, the ICP1 bit is set to 1.</li> <li>When the valid edge is detected by input capture 1 (ICP1 = 1) when an interrupt due to the edge detection by input capture 1 is enabled (ICE1 = 1), an interrupt is generated.</li> <li>When set to 0:     The bit is cleared.</li> <li>When set to 1:     No effect</li> <li>When EI<sup>2</sup>OS started:     The bit is cleared.</li> <li>Read by read modify write instructions:     1 is always read.</li> </ul> |

| Table 7 3-3 | Functions of | Innut Canture | Control Status | Register (ICS01) | (2/2) |
|-------------|--------------|---------------|----------------|------------------|-------|
| Table 7.3-3 | Functions of | input Capture | Control Status | Register (ICSUI) | (2/2) |

et4U.com

DataShe

DataSheet4U.com

## 7.3.4 Input Capture Data Registers 0 to 3 (IPCP0 to IPCP3)

The input capture data registers 0 to 3 (IPCP0 to IPCP3) store the counter value of the 16-bit free-run timer read in the timing with the edge detection by the input capture. The counter value of the 16-bit free-run timer is stored in the input capture data registers (IPCP0 to IPCP3) corresponding to the input pins (IN0 to IN3) to which an external signal is input.



• At the same time that the edges of signals input from the input pins (IN0 to IN3) of the 16-bit input/ output timer are detected, the counter value of the 16-bit free-run timer is stored in the input capture data registers 0 to 3 (IPCP0 to IPCP3) corresponding to the input pins (IN0 to IN3).

Note: Always use a word instruction (MOVW) to read the input capture data registers 0 to 3 (IPCP0 to IPCP3).

## 7.4 Interrupts of 16-bit Input/Output Timer

The interrupt factors of the 16-bit input/output timer include an overflow in the 16-bit free-run timer and edge detection by the input capture. Interrupt generation starts El<sup>2</sup>OS.

## ■ Interrupt Control Bits and Interrupt Factors of 16-bit Input/Output Timer

Table 7.4-1 shows the interrupt control bits and interrupt factors of the 16-bit input/output timer.

Table 7.4-1 Interrupt Control Bits and Interrupt Factors of 16-bit Input/Output Timer

| Interrupt Name             | Overflow Interrupt                                 | Input Capture Interrupt                                      |             |             |             |
|----------------------------|----------------------------------------------------|--------------------------------------------------------------|-------------|-------------|-------------|
| Interrupt factor           | Overflow in counter value of 16-bit free-run timer | Valid edge input to input pins (IN0 to IN3) of input capture |             |             |             |
| Interrupt factor           |                                                    | IN0                                                          | IN1         | IN2         | IN3         |
| Interrupt request flag bit | TCCS: IVF                                          | ICS01: ICP0                                                  | ICS01: ICP1 | ICS23: ICP0 | ICS23: ICP1 |
| Interrupt enable bit       | TCCS: IVFE                                         | ICS01: ICE0                                                  | ICS01: ICE1 | ICS23: ICE0 | ICS23: ICF  |

### 16-bit free-run timer interrupt

• When the counter value of the timer counter data register (TCDT) increments from "FFFF<sub>H</sub>" to DataSheet4U.com"0000<sub>H</sub>", an overflow occurs and the overflow generation flag bit (TCCS: IVF) is set simultaneously to 1.

• When an overflow occurs (TCCS: IVF = 1) with an overflow interrupt enabled (TCCS: IVFE = 1), an overflow interrupt is generated.

## Input capture interrupt

- When the valid edge selected by the input capture edge select bit (ICS: EG) is detected, the input capture interrupt request flag bits (ICS01, ICS23: ICP1, ICP0) corresponding to the input pins (IN0 to IN3) are set to 1.
- When the valid edge is detected by the input captures corresponding to the input pins (IN0 to IN3) with the input capture interrupts corresponding to the input pins (IN0 to IN3) enabled, an input capture interrupt is generated.

## Correspondence between 16-bit Input/Output Timer Interrupt and El<sup>2</sup>OS

For details of the interrupt number, interrupt control register, and interrupt vector address, see "3.5 Interrupt".

## ■ 16-bit Input/Output Timer Interrupts and El<sup>2</sup>OS Function

The 16-bit input/output timer corresponds to the EI<sup>2</sup>OS function. The generation of enabled interrupt starts the EI<sup>2</sup>OS. However, it is necessary to disable generation of interrupt requests by resources sharing the interrupt control register (ICR) with the 16-bit input/output timer.

## 7.5 Explanation of Operation of 16-bit Free-run Timer

After a reset, the 16-bit free-run timer starts incrementing from " $0000_{H}$ ". When the counter value is incremented from "FFFF<sub>H</sub>" to " $0000_{H}$ ", an overflow occurs.

## Setting of 16-bit Free-run Timer

Operation of the 16-bit free-run timer requires the setting shown in Figure 7.5-1.



et4U.com

## Operation of 16-bit Free-run Timer

- After a reset, the 16-bit free-run timer starts incrementing from " $0000_{\text{H}}$ " in synchronization with the count clock selected by the count clock select bits (TCCS: CLK2, CLK1, CLK0).
- When the counter value of the timer counter data register (TCDT) is incremented from "FFFF<sub>H</sub>" to "0000<sub>H</sub>", an overflow occurs. When an overflow occurs, the overflow generation flag bit (TCCS: IVF) is set to 1 and the 16-bit free-run timer starts incrementing again from "0000<sub>H</sub>".
- When an overflow occurs (TCCS: IVF = 1) with an overflow interrupt enabled (TCCS: IVFE = 1), an overflow interrupt is generated.
- When stopping the count operation of the timer counter data register (TCDT), write 1 to the timer count bit (TCCS: STOP).
- Set the counter value in the timer counter data register (TCDT) after stopping the count operation of the 16-bit free-run timer. After completing setting of the counter value, enable the count operation of the 16-bit free-run timer (TCCS: STOP = 0).

DataShe

DataSheet4U.com

## ■ Operation Timing of 16-bit Free-run Timer

Figure 7.5-2 shows counter clearing at an overflow.



## Figure 7.5-2 Counter Clearing at an Overflow

et4U.com

DataSheet4U.com

DataSheet4U.com

DataShe

www.DataSheet4U.com

## 7.6 Explanation of Operation of Input Capture

When the input capture detects the edge of the external signal input to the input pin, it stores the counter value of the 16-bit free-run timer in the input capture data register.

## Setting of Input Capture

Operation of the input capture requires the setting shown in Figure 7.6-1.



Figure 7.6-1 Setting of Input Capture

#### Operation of Input Capture

- When the valid edges of the external signals input to the input pins (IN0 to IN3) are detected, the input capture valid edge detection flag bit (ICS: ICP) corresponding to the input pin is set to 1. At the same time, the counter value of the 16-bit free-run timer is stored in the input capture data registers (IPCP) corresponding to the input pins (IN0 to IN3).
- The edge to be detected can be selected from the rising edge, falling edge and both edges by setting the input capture edge select bit in the input capture control status register (ICS: EG).
- When the effective edge is detected by the input captures corresponding to the input pins (IN0 to IN3) when the input captures corresponding to the input pins (IN0 to IN3) are enabled for interrupts, an input capture interrupt is generated.
- The input capture valid edge detection flag bit (ICS: ICP) is set when the valid edge is detected, regardless of the interrupt enable settings (ICS01, ICS23: ICE1, ICE0).
- Table 7.6-1 shows the correspondence between the input pins and input captures.

| Input Pin | Interrupt Request Flag<br>Bit of Input Capture | Interrupt Output Enable<br>Bit of Input Capture | Input Capture Data<br>Register |
|-----------|------------------------------------------------|-------------------------------------------------|--------------------------------|
| IN0       | ICS01: ICP0                                    | ICS01: ICE0                                     | IPCP0                          |
| IN1       | ICS01: ICP1                                    | ICS01: ICE1                                     | IPCP1                          |
| IN2       | ICS23: ICPOSheet4L                             | I.com ICS23: ICE0                               | IPCP2                          |
| IN3       | ICS23: ICP1                                    | ICS23: ICE1                                     | IPCP3                          |

#### Table 7.6-1 Correspondence between Input Pins and Input Captures

et4U.com

www.DataSheet4U.com

#### Operation Timing of Input Capture

Figure 7.6-2 shows the timing of reading the counter value of the 16-bit free-run timer.

Figure 7.6-2 Timing of Reading Counter Value of Input Capture



Figure 7.6-3 shows the timing of the capture operation depending on the edge type.





DataSheet4U.com

et4U.com

238

www.DataSheet4U.com

## 7.7 Precautions when Using 16-bit Input/Output Timer

#### This section explains the precautions when using the 16-bit input/output timer.

#### Precautions when 16-bit Input/Output Timer

- Precautions when setting 16-bit free-run timer
  - Do not change the count clock select bits (TCCS: CLK2, CLK1, CLK0) during the count operation (TCCS: STOP = 0).
  - The counter value of the 16-bit free-run timer is cleared to " $0000_{\text{H}}$ " by reset. The 16-bit free-run timer can be set by writing any count value to the timer counter data register (TCDT) while the count operation is stopped (TCCS: STOP = 1).
  - Always use a word instruction (MOVW) to set the timer counter data register (TCDT).
- Precautions on interrupts
  - When an overflow interrupt or an input capture interrupt is enabled, clear only the set bit of the overflow generation flag bit or the input capture valid edge detection flag bit. For example, when clearing the flag bit for the factor that accepted an interrupt, avoid unconditional clearing of the interrupt request flag bits other than those for the factor accepting the interrupt, otherwise another input capture interrupt may be generated.

#### DataSheet4U.com

• If the interrupt request flag bits in the 16-bit input/output timer (TCCS: IVF, ICS01, ICS23: ICP1, ICP0) are set to 1 and interrupts corresponding to the set interrupt request flag bits are enabled (TCCS: IVFE = 1, ICS01, ICS23: ICE1 = 1, ICE0 = 1), it is impossible to return from interrupt processing. Always clear the interrupt request flag bits. When using the  $EI^2OS$ , the set interrupt request flag bits are cleared automatically when the  $EI^2OS$  is started.

DataSheet4U.com

et4U.com

www.DataSheet4U.com

### 7.8 Program Example of 16-bit Input/Output Timer

#### This section gives a program example of the 16-bit input/output timer.

#### ■ Processing of Program for Measuring Cycle Using Input Capture

- The cycle of a signal input to the INO pin is measured.
- The 16-bit free-run timer and input capture 0 are used.
- The rising edge is selected as the edge to be detected.
- The machine clock ( $\phi$ ) is 16 MHz and the count clock is  $\phi/4$  (0.25 µs).
- The overflow interrupt and input capture interrupt of input capture 0 are used.
- The overflow interrupt of the 16-bit free-run timer is counted beforehand and used for the cycle calculation.
- The cycle can be determined from the following equation:

 $Cycle = (overflow count \times 10000_{H} + nth IPCP0 value - (n-1)th IPCP0 value) \times count clock cycle$ 

= (overflow count  $\times$  10000<sub>H</sub>+ nth IPCP0 value - (n-1)th IPCP0 value)  $\times$  0.25µs

#### Coding example

et4U.com

DDR1 EQU 000011H ; Port direction register TCCS EQU 000058H ; Timer counter control status register TCDT EQU 000056H ; Timer counter data register ICS01 EQU 000054H ; Input capture control status register 01 LCPO EQU ICS01:6 ICR04 EQU 0000B4H ICR06 EQU 0000B6H DATA DSEG ABS=00H ORG 01001 ; Input capture data register 0 ; Overflow interrupt enable bit ; Input capture 0 interrupt request flag bit ; 16-bit free-run timer interrupt control register ; 16-bit input capture interrupt control register ; Overflow counter DATA ENDS ;-----Main program-----CODE CSEG ABS=0FFH START: ; Stack pointer (SP) ; already initialized : AND CCR, #0BFH ; Interrupt disabled MOV I:ICR04,#00H MOVI:ICR04,#00H; Interrupt level 0 (highest)MOVI:ICR06,#00H; Interrupt level 0 (highest) MOV I:DDR1,#0000000B ; Pin set as input

MOV I:TCCS, #00110100B ; Count operation enabled, counter cleared, ; Overflow, interrupt enabled ; Count clock of  $\phi/4$  selected MOV I:ICS01,#00010001B ; INO pin selected ; IPCP0 set to rising edge ; IPCP1 set to no edge detection ; Each interrupt request flag cleared ; Input capture interrupt request enabled MOV ILM,#07 OR CCR,#40H ; Interrupt mask level set and interrupt enabled ; Interrupt enabled : ;-----Interrupt program------WARI1 CLRB I:ICP0 ; Input capture 0 interrupt request ; flag cleared • User Processing (such as cycle calculation) : MOV A,0 ; Overflow because of next cycle measurement ; Counter cleared MOV D:OV\_CNT, A RETI WARI2 CLRB I:IVFE INC D:OV\_CNT ; Return from interrupt ; Return from interrupt ; Overflow interrupt request flag cleared ; Overflow counter incremented by one RETI CODE ENDS ;-----Vector setting------DataShe ORGOFFA0; Vector set to interrupt number #23 (17H)DSLWARI1; Input capture 0 interruptORGOFFB0; Vector set to interrupt number #19 (13H)DSLWARI2; Overflow interrupt VECT CSEG ABS=0FFH ORG OFFDCH DSL START ; Reset vector set DSL START DB 00H ; Set to single-chip mode ENDS VECT END START

et4U.com

DataSheet4U.com

DataSheet4U.com

242

DataSheet4U.com

DataShe

www.DataSheet4U.com

This chapter explains the functions and the operations of 16-bit reload timer.

- 8.1 Overview of 16-bit Reload Timer
- 8.2 Block Diagram of 16-bit Reload Timer
- 8.3 Configuration of 16-bit Reload Timer
- 8.4 Interrupts of 16-bit Reload Timer
- 8.5 Explanation of Operation of 16-bit Reload Timer
- 8.6 Precautions when Using 16-bit Reload Timer
- 8.7 Program Example of 16-bit Reload Timer

et4U.com

www.DataSheet4U.com

### 8.1 Overview of 16-bit Reload Timer

The 16-bit reload timer has the following functions:

- The count clock can be selected from three internal clocks and external event clocks.
- A software trigger or external trigger can be selected as the start trigger.
- If the 16-bit timer register (TMR) underflows, an interrupt can be generated to the CPU. The 16-bit reload timer can be used as an interval timer by using an interrupt.
- If the TMR underflows, either the one-shot mode for stopping the TMR count operation, or the reload mode for reloading the value of the 16-bit reload register (TMRLR) to the TMR to continue the TMR count operation can be selected.
- The 16-bit reload timer corresponds to the El<sup>2</sup>OS.
- The MB90385 series has two channels of 16-bit reload timers.

#### Operation Modes of 16-bit Reload Timer

Table 8.1-1 indicates the operation modes of the 16-bit reload timer.

#### Table 8.1-1 Operation Modes of 16-bit Reload Timer

| Count Clock         | Start Trigger                        | Operation Performed upon Underflow |
|---------------------|--------------------------------------|------------------------------------|
| Internal clock mode | Software trigger<br>External trigger | One-shot mode<br>Reload mode       |
| Event count mode    | Software trigger                     | One-shot mode<br>Reload mode       |

#### ■ Internal Clock Mode

- When the count clock select bits in the timer control status register (TMCSR: CSL1, CSL0) are set to "00<sub>B</sub>", "01<sub>B</sub>" or "10<sub>B</sub>", the 16-bit reload timer is set in the internal clock mode.
- In the internal clock mode, the 16-bit reload timer decrements in synchronization with the internal clock.
- The count clock select bits in the timer control status register (TMCSR: CSL1, CSL0) can be used to select three count clock cycles.
- The start trigger sets the edge detection for a software trigger or an external trigger.

#### Event Count Mode

- When the count clock select bits in the timer control status register (TMCSR: CSL1, CSL0) are set to "11<sub>B</sub>", the 16-bit reload timer is set to the event count mode.
- In the event count mode, the 16-bit reload timer decrements in synchronization with the edge detection of the external event clock input to the TIN pin.
- A software trigger is selected as the start trigger.
- The 16-bit reload timer can be used as an interval timer by using a fixed cycle of the external clock.

et4U.com

#### Operation at Underflow

When the start trigger is input, the value set in the 16-bit reload register (TMRLR) is reloaded to the 16-bit timer register, starts decrementing in synchronization with the count clock. When the 16-bit timer register (TMR) is decremented from " $0000_{\text{H}}$ " to "FFFF<sub>H</sub>", an underflow occurs.

- When an underflow occurs with an underflow interrupt enabled (TMCSR: INTE = 1), an underflow interrupt is generated.
- The 16-bit reload timer operation when an underflow occurs is set by the reload select bit in the timer control status register (TMCSR: RELD).

#### [One-shot mode (TMCSR: RELD = 0)]

When an underflow occurs, the TMR count operation is stopped. When the next start trigger is input, the value set in the TMRLR is reloaded in the TMR, starting the TMR count operation.

- In the one-shot mode, during the TMR count operation, a High-level or Low-level rectangular wave is output from the TOT pin.
- The pin output level select bit in the timer control status register (TMCSR: OUTL) can be set to select the level (High or Low) of the rectangular wave.

#### [Reload mode (TMCSR: RELD = 1)]

When an underflow occurs, the value set in the TMRLR is reloaded to the TMR, continuing the TMR count operation.

• In the reload mode, a toggle wave inverting the output level of the TOT pin is output each time an underflow occurs during the TMR count operation.

- The pin output level select bit in the timer control status register (TMCSR: OUTL) can be set to select the level (High or Low) of a toggle wave.
- The 16-bit reload timer can be used as an interval timer by using an underflow interrupt.

#### Table 8.1-2 Interval Time of 16-bit Reload Timer

| Count Clock         | Count Clock Cycle           | Interval Time        |  |  |  |  |
|---------------------|-----------------------------|----------------------|--|--|--|--|
|                     | 2 <sup>1</sup> T (0.125 μs) | 0.125 µs to 8.192 ms |  |  |  |  |
| Internal clock mode | $2^{3}$ T (0.5 µs)          | 0.5 µs to 32.768 ms  |  |  |  |  |
|                     | $2^{5}$ T (2.0 µs)          | 2.0 µs to 131.1 ms   |  |  |  |  |
| Event count mode    | $2^{3}$ T or more           | 0.5 µs               |  |  |  |  |

T: Machine cycle

The values in interval time and the parenthesized values are provided when the machine clock operates at 16 MHz.

Reference: The 16-bit reload timer 1 can be used as the clock input source of the UART1 and the start trigger of the A/D converter.

### 8.2 Block Diagram of 16-bit Reload Timer

The 16-bit reload timers 0 and 1 are composed of the following seven blocks:

- Count clock generator
- Reload controller
- Output controller
- Operation controller
- 16-bit timer register (TMR)
- 16-bit reload register (TMRLR)
- Timer control status register (TMCSR)

#### ■ Block Diagram of 16-bit Reload Timer

#### Figure 8.2-1 Block Diagram of 16-bit Reload Timer



DataSheet4U.com

246

www.DataSheet4U.com

#### Details of pins in block diagram

There are two channels for 16-bit reload timer.

The actual pin names, outputs to resources, and interrupt request numbers for each channel are as follows:

#### 16-bit reload timer 0:

TIN pin: P20/TIN0

TOT pin: P21/TOT0

Interrupt request number:  $#17 (11_{\rm H})$ 

#### 16-bit reload timer 1:

TIN pin: P22/TIN1

TOT pin: P23/TOT1

Output to resources: Clock input source of UART1 and start trigger of A/D converter Interrupt request number:  $#36 (24_{\rm H})$ 

#### Count clock generator

The count clock generator generates a count clock supplied to the 16-bit timer register (TMR) on the basis of the machine clock or external event clock.

#### Reload controller

When the 16-bit reload timer starts operation or the TMR underflows, the reload controller reloads the value set in the 16-bit reload register (TMRLR) to the TMR.

#### Output controller

The output controller inverts and enables or disables the output of the TOT pin at underflow.

#### • Operation controller

The operation controller starts or stops the 16-bit reload timer.

#### 16-bit timer register (TMR)

The 16-bit timer register (TMR) is a 16-bit down counter. At read, the value being counted is read.

#### 16-bit reload register (TMRLR)

The 16-bit reload register (TMRLR) sets the interval time of the 16-bit reload timer. When the 16-bit reload timer starts operation or the 16-bit timer register (TMR) underflows, the value set in the TMRLR is reloaded to the TMR.

#### Timer control status register (TMCSR)

The timer control status register (TMCSR) selects the operation mode, sets the operation conditions, selects the start trigger, performs a start using the software trigger, selects the reload operation mode, enables or disables an interrupt request, sets the output level of the TOT pin, and sets the TOT output pin.

## 8.3 Configuration of 16-bit Reload Timer

#### This section explains the pins, registers, and interrupt factors of the 16-bit reload timer.

#### Pins of 16-bit Reload Timer

The pins of the 16-bit reload timer serve as general-purpose I/O ports. Table 8.3-1 shows the pin functions and the pin settings required to use the 16-bit reload timer.

| Pin Name | Pin Function                                            | Pin Setting Required for Use in<br>16-bit Reload Timer |
|----------|---------------------------------------------------------|--------------------------------------------------------|
| TIN0     | General-purpose I/O port,<br>16-bit reload timer input  | Set as input port in port direction register (DDR).    |
| ТОТ0     | General-purpose I/O port,<br>16-bit reload timer output | Set timer output enable (TMCSR0: OUTE = 1).            |
| TIN1     | General-purpose I/O port,<br>16-bit reload timer input  | Set as input port in port direction register (DDR).    |
| TOT1     | General-purpose I/O port,<br>16-bit reload timer output | Set timer output enable (TMCSR1: OUTE = 1).            |

#### Table 8.3-1 Pins of 16-bit Reload Timer

et4U.com

■ Block Diagram for Pins of 16-bit Reload Timer

For details of the block diagram for pins, see "CHAPTER 4 I/O PORT".

DataShe

248

et4U.com

#### ■ List of Registers and Reset Values of 16-bit Reload Timer

• Registers of 16-bit reload timer 0

|                                               | bit | 15   | 14      | 13    | 12 | 11 | 10 | 9 | 8 |
|-----------------------------------------------|-----|------|---------|-------|----|----|----|---|---|
| Timer control status register (Hi (TMCSR0)    | gh) | Х    | Х       | Х     | Х  | 0  | 0  | 0 | 0 |
|                                               | bit | 7    | 6       | 5     | 4  | 3  | 2  | 1 | 0 |
| Timer control status register (Lo<br>(TMCSR0) | ow) | 0    | 0       | 0     | 0  | 0  | 0  | 0 | 0 |
|                                               | bit | 15   | 14      | 13    | 12 | 11 | 10 | 9 | 8 |
| 16-bit timer register (High)<br>(TMR0)        |     | Х    | Х       | Х     | Х  | Х  | Х  | Х | Х |
|                                               | bit | 7    | 6       | 5     | 4  | 3  | 2  | 1 | 0 |
| 16-bit timer register (Low)<br>(TMR0)         |     | Х    | Х       | Х     | Х  | Х  | Х  | Х | Х |
|                                               | bit | 15   | 14      | 13    | 12 | 11 | 10 | 9 | 8 |
| 16-bit reload register (High)<br>(TMRLR0)     |     | Х    | Х       | Х     | Х  | Х  | Х  | Х | Х |
|                                               | bit | 7    | 6       | 5     | 4  | 3  | 2  | 1 | 0 |
| 16-bit reload register (Low)<br>(TMRLR0)      |     | Х    | Х       | Х     | Х  | Х  | Х  | Х | Х |
| X: Undefined                                  | -   | Data | Sheet4l | J.com |    |    |    |   |   |

#### Figure 8.3-1 List of Registers and Reset Values of 16-bit Reload Timer 0

• Registers of 16-bit reload timer 1

#### Figure 8.3-2 List of Registers and Reset Values of 16-bit Reload Timer 1

|                                             | bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  |      |
|---------------------------------------------|-------|----|----|----|----|----|----|---|----|------|
| Timer control status register (<br>(TMCSR1) | High) | Х  | Х  | Х  | Х  | 0  | 0  | 0 | 0  |      |
|                                             | bit   | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0  |      |
| Timer control status register (<br>(TMCSR1) | Low)  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0  |      |
|                                             | bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  |      |
| 16-bit timer register (High)<br>(TMR1)      | [     | Х  | Х  | Х  | Х  | Х  | Х  | Х | Х  |      |
|                                             | bit   | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0  |      |
| 16-bit timer register (Low)<br>(TMR1)       | [     | Х  | Х  | Х  | Х  | Х  | Х  | Х | Х  |      |
|                                             | bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  |      |
| 16-bit reload register (High)<br>(TMRLR1)   |       | Х  | Х  | Х  | Х  | Х  | Х  | Х | Х  |      |
|                                             | bit   | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0  |      |
| 16-bit reload register (Low)<br>(TMRLR1)    |       | Х  | Х  | Х  | Х  | Х  | Х  | Х | Х  |      |
| X: Undefined                                | _     |    |    |    |    |    |    |   | WW | w.Da |

#### ■ Generation of Interrupt Request from 16-bit Reload Timer

When the 16-bit reload timer is started and the count value of the 16-bit timer register is decremented from " $0000_{\text{H}}$ " to "FFFF<sub>H</sub>", an underflow occurs. When an underflow occurs, the UF bit in the timer control status register is set to 1 (TMCSR: UF). If an underflow interrupt is enabled (TMCSR: INTE = 1), an interrupt request is generated.

et4U.com

DataSheet4U.com

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

## 8.3.1 Timer Control Status Registers (High) (TMCSR0: H, TMCSR1: H)

The timer control status registers (High) (TMCSR0: H, TMCSR1: H) set the operation mode and count clock.

This section also explains the bit 7 in the timer control status registers (Low) (TMCSR0: L, TMCSR1: L).





Figure 8.3-3 Timer Control Status Registers (High) (TMCSR0: H, TMCSR1: H)

DataShe

DataSheet4U.com

www.DataSheet4U.com

|                  | Bit Name                                           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |
|------------------|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| bit 7 to bit 9   | MOD2, MOD1, MOD0:<br>Operation mode select<br>bits | These bits set the operation conditions of the 16-bit reload timer.<br><b>[Internal clock mode]</b><br>The MOD2 bit is used to select the function of the input pin.<br><b>When MOD2 bit set to 0:</b><br>The input pin functions as a trigger input.<br>The MOD1 and MOD0 bits are used to select the edge to be detected.<br>When the edge is detected, the value set in the 16-bit reload register<br>(TMRLR) is reloaded in the 16-bit timer register (TMR), starting the count<br>operation of the TMR.<br><b>When MOD2 set to 1:</b><br>The input pin functions as a gate input.<br>The MOD1 bit is not used. The MOD0 bit is used to select the signal level<br>(High or Low) to be detected. The count operation of the 16-bit timer register<br>(TMR) is performed only when the signal level is input.<br><b>[Event count mode]</b><br>The MOD1 and MOD0 bits are used to select the edge to be detected. |      |
| bit 10<br>bit 11 | CSL1, CSL0:<br>Count clock select bits             | These bits select the count clock of the 16-bit reload timer.<br>When set to anything other than "11 <sub>B</sub> ": This bits count by the internal<br>clock (internal clock mode).<br>When set to "11 <sub>B</sub> ": The edge of the external event clock is counted (event<br>count mode)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Data |
| bit 12 to bit 15 | Unused bits                                        | DataSheet4U.com           Read: The value is undefined.           Write: No effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      |

#### Table 8.3-2 Functions of Timer Control Status Registers (High) (TMCSR0: H, TMCSR1: H)

## 8.3.2 Timer Control Status Registers (Low) (TMCSR0: L, TMCSR1: L)

The timer control status registers (Low) (TMCSR0: L, TMCSR1: L) enables or disables the timer operation, checks the generation of a software trigger or an underflow, enables or disables an underflow interrupt, selects the reload mode, and sets the output of the TOT pin.



|       | Bit Name                                    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1     |
|-------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| bit 0 | TRG:<br>Software trigger bit                | <ul> <li>This bit starts the 16-bit reload timer by software.</li> <li>The software trigger function works only when the timer operation is enabled (CNTE = 1).</li> <li>When set to 0: Disabled. The state remains unchanged.</li> <li>When set to 1: Reloads value set in 16-bit reload register (TMRLR) to 16-bit timer register (TMR), starting TMR count operation Read: 0 is always read.</li> </ul>                                                                                                                                                   |       |
| bit 1 | CNTE:<br>Timer operation enable<br>bit      | This bit enables or disables the operation of the 16-bit reload timer.<br><b>When set to1:</b> 16-bit reload timer enters start trigger wait state.<br>When the start trigger is input, the timer register restarts count operation.<br><b>When set to 0:</b> Stops count operation                                                                                                                                                                                                                                                                          |       |
| bit 2 | UF:<br>Underflow generation<br>flag bit     | This bit indicates that the TMR underflows.<br>When set to 0: Clears this bit<br>When set to 1: No effect<br>Read by read modify write instructions: 1 is always read.                                                                                                                                                                                                                                                                                                                                                                                       |       |
| bit 3 | INTE:<br>Underflow interrupt<br>enable bit  | This bit enables or disables an underflow interrupt.<br>When an underflow occurs (TMCSR: $UF = 1$ ) with an underflow interrupt<br>enabled (TMCSR: INTE = 1), an interrupt request is generated.                                                                                                                                                                                                                                                                                                                                                             | Datas |
| bit 4 | RELD:<br>Reload select bit                  | This bit sets the reload operation at underflow.<br><b>When set to 1:</b> At underflow, reloads value set in TMRLR to TMR, continuing count operation (reload mode)<br><b>When set to 0:</b> At underflow, stops count operation (one-shot mode)                                                                                                                                                                                                                                                                                                             |       |
| bit 5 | OUTL:<br>TOT Pin output level<br>select bit | <ul> <li>This bit sets the output level of the output pin of the 16-bit reload timer.</li> <li><one-shot (reld="0)" mode=""></one-shot></li> <li>When set to 0: Outputs High-level rectangular wave during TMR count operation</li> <li>When set to 1: Outputs Low-level rectangular wave during TMR count operation</li> <li><reload (reld="1)" mode=""></reload></li> <li>When set to 0: Outputs Low-level toggle wave when 16-bit reload timer started</li> <li>When set to 1: Outputs High-level toggle wave when 16-bit reload timer started</li> </ul> |       |
| bit 6 | OUTE:<br>TOT Output enable bit              | This bit sets the function of the TOT pin of the 16-bit reload timer.<br>When set to 0: Functions as general-purpose I/O port<br>When set to 1: Functions as TOT pin of 16-bit reload timer                                                                                                                                                                                                                                                                                                                                                                  |       |

#### Table 8.3-3 Timer Control Status Registers (Low) (TMCSR0: L, TMCSR1: L)

et4U.com

DataSheet4U.com

## 8.3.3 16-bit Timer Registers (TMR0, TMR1)

## The 16-bit timer registers (TMR0, TMR1) are 16-bit down counters. At read, the value being counted is read.

#### ■ 16-bit Timer Registers (TMR0, TMR1)

| Figure 8.3-5 16-bit Timer Registers (TMR0, TMR1) |     |     |     |     |     |     |    |    |             |
|--------------------------------------------------|-----|-----|-----|-----|-----|-----|----|----|-------------|
|                                                  | 15  | 14  | 13  | 12  | 11  | 10  | 9  | 8  | Reset value |
| TMR0<br>TMR1                                     | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | XXXXXXXXB   |
|                                                  | R   | R   | R   | R   | R   | R   | R  | R  | L           |
|                                                  | 7   | 6   | 5   | 4   | 3   | 2   | 1  | 0  | Reset value |
| TMR0<br>TMR1                                     | D7  | D6  | D5  | D4  | D3  | D2  | D1 | D0 | XXXXXXXXB   |
|                                                  | R   | R   | R   | R   | R   | R   | R  | R  | 1           |
| R: Read only<br>X: Undefined                     |     |     |     |     |     |     |    |    |             |

DataShe

When the timer operation is enabled (TMCSR: CNTE = 1) and the start trigger is input, the value set in the 16-bit reload register (TMRLR) is reloaded to the 16-bit timer register (TMR), starting the TMR count operation.

When the timer operation is disabled (TMCSR: CNTE = 0), the TMR value is retained.

When the TMR value is counted down from " $0000_{\text{H}}$ " to "FFFF<sub>H</sub>" during the TMR count operation, an underflow occurs.

#### [Reload mode]

When the TMR underflows, the value set in the TMRLR is reloaded to the TMR, starting the TMR count operation.

#### [One-shot mode]

When the TMR underflows, the TMR count operation is stopped, entering the start trigger input wait state. The TMR value is retained to " $FFFF_H$ ".

|  |   | The TMR can be read during the TMR count operation. However, always use the word instruction (MOVW).                                                                                     |
|--|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  | • | The TMR and the TMRLR are assigned to the same address. At write, the set value can be written to the TMRLR without affecting the TMR. At read, the TMR value being counted can be read. |

## 8.3.4 16-bit Reload Registers (TMRLR0, TMRLR1)

The 16-bit reload registers (TMRLR0, TMRLR1) set the value to be reloaded to the 16-bit timer register (TMR). When the start trigger is input, the value set in the 16-bit reload registers (TMRLR0, TMRLR1) is reloaded to the TMR, starting the TMR count operation.

#### ■ 16-bit Reload Registers (TMRLR0, TMRLR1)

|                                  | Figure                          | 8.3-6 1                                         | 6-bit R                              | eload R                           | egister                          | s (TMR                        | LR0, T               | MRLR1)                 | )                                                                                                     |  |
|----------------------------------|---------------------------------|-------------------------------------------------|--------------------------------------|-----------------------------------|----------------------------------|-------------------------------|----------------------|------------------------|-------------------------------------------------------------------------------------------------------|--|
|                                  | 15                              | 14                                              | 13                                   | 12                                | 11                               | 10                            | 9                    | 8                      | Reset value                                                                                           |  |
| TMRLR0<br>TMRLR1                 | D15                             | D14                                             | D13                                  | D12                               | D11                              | D10                           | D9                   | D8                     | XXXXXXXX <sub>B</sub>                                                                                 |  |
|                                  | W                               | W                                               | W                                    | W                                 | W                                | W                             | W                    | W                      | L                                                                                                     |  |
| _                                | 7                               | 6                                               | 5                                    | 4                                 | 3                                | 2                             | 1                    | 0                      | Reset value                                                                                           |  |
| TMRLR0<br>TMRLR1                 | D7                              | D6                                              | D5                                   | D4                                | D3                               | D2                            | D1                   | D0                     | XXXXXXXX <sub>B</sub>                                                                                 |  |
| -                                | W                               | W                                               | W                                    | W                                 | W                                | W                             | W                    | W                      |                                                                                                       |  |
| 0). After                        |                                 | g setting                                       |                                      |                                   |                                  |                               | -                    |                        | operation (TMCSR: CNT<br>1), enable the timer opera                                                   |  |
| When the operation               |                                 | ger is inp                                      | ut, the v                            | alue set i                        | in the TN                        | ARLR is                       | reloade              | d to the T             | ΓMR, starting the TMR co                                                                              |  |
| CNT<br>• The<br>the 7<br>• Instr | E = 0). Al<br>TMRLR a<br>MRLR w | ways use<br>nd the T<br>ithout af<br>ich as the | e the wor<br>MR are a<br>fecting the | rd instrue<br>assigned<br>he TMR. | ction (M<br>to the sa<br>At read | OVW).<br>ume addr<br>, the TM | ess. At v<br>R value | write, the<br>being co | reload timer (TMCSR:<br>e set value can be written t<br>punted is read.<br>dify write (RMW) operation |  |

et4U.com

DataSheet4U.com

## 8.4 Interrupts of 16-bit Reload Timer

## The 16-bit reload timer generates an interrupt request when the 16-bit timer register (TMR) underflows.

#### ■ Interrupts of 16-bit Reload Timer

When the value of the TMR is decremented from " $0000_{\text{H}}$ " to "FFFF<sub>H</sub>" during the TMR count operation, an underflow occurs. When an underflow occurs, the underflow generation flag bit in the timer control status register (TMCSR: UF) is set to 1. When an underflow interrupt is enabled (TMCSR: INTE = 1), an interrupt request is generated.

|                              | 16-bit Reload Timer 0 | 16-bit Reload Timer 1 |
|------------------------------|-----------------------|-----------------------|
| Interrupt request flag bit   | TMCSR0: UF            | TMCSR1: UF            |
| Interrupt request enable bit | TMCSR0: INTE          | TMCSR1: INTE          |
| Interrupt factor             | Underflow in TMR0     | Underflow in TMR1     |

#### Table 8.4-1 Interrupt Control Bits and Interrupt Factors of 16-bit Reload Timer

#### <sup>om</sup> Correspondence between 16-bit Reload Timer Interrupt and El<sup>2</sup>OS

DataShe

For details of the interrupt number, interrupt control register, and interrupt vector address, see "3.5 Interrupt".

#### ■ El<sup>2</sup>OS Function of 16-bit Reload Timer

The 16-bit reload timer corresponds to the EI<sup>2</sup>OS function. An underflow in the TMR starts the EI<sup>2</sup>OS.

The  $EI^2OS$  is available only when other resources sharing the interrupt control register (ICR) do not use interrupts. When using the  $EI^2OS$  in the 16-bit reload timers 0 and 1, it is necessary to disable generation of interrupt requests by resources sharing the interrupt control register (ICR) with the 16-bit reload timers 0 and 1.

## 8.5 Explanation of Operation of 16-bit Reload Timer

## This section explains the setting of the 16-bit reload timer and the operation state of the counter.

#### Setting of 16-bit Reload Timer

Setting of internal clock mode

Counting the internal clock requires the setting shown in Figure 8.5-1.



Setting of event count mode

Inputting an external event to operate the 16-bit reload timer requires the setting shown in Figure 8.5-2.

#### Figure 8.5-2 Setting of Event Count Mode



DataSheet4U.com

258

www.DataSheet4U.com

#### Operating State of 16-bit Timer Register

The operating state of the 16-bit timer register is determined by the timer operation enable bit in the timer control status register (TMCSR: CNTE) and the WAIT signal. The operating states include the stop state, start trigger input wait state (WAIT state), and RUN state.

Figure 8.5-3 shows the state transition diagram for the 16-bit timer registers.

Figure 8.5-3 State Transition Diagram



DataShe

et4U.com

www.DataSheet4U.com

## 8.5.1 Operation in Internal Clock Mode

In the internal clock mode, three operation modes can be selected by setting the operation mode select bits in the timer control status register (TMCSR: MOD2 to MOD0). When the operation mode and reload mode are set, a rectangular wave or a toggle wave is output from the TOT pin.

| Settin | g of Internal Clock Mode                                                                                                                                                                           |       |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|        | • By setting the count clock select bits (CSL1, CSL0) in the timer control status register to $"00_B"$ , $"01_B"$ or $"10_B"$ , the 16-bit reload timer (TMRLR) is set to the internal clock mode. |       |
|        | • In the internal clock mode, the 16-bit timer register (TMR) decrements in synchronization with the internal clock.                                                                               |       |
|        | • In the internal clock mode, three count clock cycles can be selected by setting the count clock select bits in the timer control status register (TMCSR: CSL1, CSL0).                            |       |
|        | [Setting a reload value to TMR]                                                                                                                                                                    |       |
|        | After the 16-bit reload timer is started, the value set in the TMRLR is reloaded to the TMR.                                                                                                       |       |
|        | 1. Disables the timer operation (TMCSR: $CNTE = 0$ ).                                                                                                                                              |       |
| m      | 2. Sets a reload value to the TMR in the TMRLR.                                                                                                                                                    | Datas |
|        | 3. Enables the timer operation (TMCSR: CNTE = 1).<br>DataSheet4U.com                                                                                                                               |       |
| Note:  | It takes 1 machine cycle (time) to reload the value set in the TMRLR to the TMR after the start trigger is input.                                                                                  |       |

#### Operation as 16-bit Timer Register Underflows

When the value of the 16-bit timer register (TMR) is decremented from " $0000_{\text{H}}$ " to "FFFF<sub>H</sub>" during the TMR count operation, an underflow occurs.

- When an underflow occurs, the underflow generation flag bit in the timer control status register (TMCSR: UF) is set to 1.
- When the underflow interrupt enable bit in the timer control status register (TMCSR: INTE) is set to 1, an underflow interrupt is generated.
- The reload operation when an underflow occurs is set by the reload select bit in the timer control status register (TMCSR: RELD).

#### [One-shot mode (TMCSR: RELD = 0)]

When an underflow occurs, the count operation of the TMR is stopped, entering the start trigger input wait state. When the next start trigger is input, the TMR count operation is restarted.

In the one-shot mode, a rectangular wave is output from the TOT pin during the TMR count operation. The pin output level select bit in the timer control status register (TMCSR: OUTL) can be set to select the level (High or Low) of a rectangular wave.

#### [Reload mode (TMCSR: RELD = 1)]

When an underflow occurs, the value set in the 16-bit reload timer register (TMRLR) is reloaded to the TMR, continuing the TMR count operation.

In the reload mode, a toggle wave inverting the output level of the TOT pin is output each time an underflow occurs during the TMR count operation. The pin output level select bit in the timer control status register (TMCSR: OUTL) can be set to select the level (High or Low) of a toggle wave as the 16-bit reload timer is started.

DataShee

#### Operation in Internal Clock Mode

In the internal clock mode, the operation mode select bits in the timer control status register (TMCSR: MOD2 to MOD0) can be used to select the operation mode. Disable the timer operation by setting the timer operation enable bit in the timer control status register (TMCSR: CNTE).

#### [Software trigger mode (MOD2 to MOD0 ="000<sub>B</sub>")]

If the software trigger mode is set, start the 16-bit reload timer by setting the software trigger bit in the timer control status register (TMCSR: TRG) to 1. When the 16-bit reload timer is started, the value set in the TMRLR is reloaded to the TMR, starting the TMR count operation.

Note: When both the timer operation enable bit in the timer control status register (TMCSR: CNTE) and the software trigger bit in the timer control status register (TMCSR: TRG) are set to 1, the 16-bit reload timer and the count operation of the TMR are started simultaneously.



Figure 8.5-4 Count Operation in Software Trigger Mode (One-shot Mode)

Figure 8.5-5 Count Operation in Software Trigger Mode (Reload Mode)



DataShe

#### [External trigger mode (MOD2 to MOD0 =" $001_B$ ", " $010_B$ ", " $011_B$ ")]

When the external trigger mode is set, the 16-bit reload timer is started by inputting the external valid edge to the TIN pin. When the 16-bit reload timer is started, the value set in the 16-bit reload register (TMRLR) is reloaded to the 16-bit timer register (TMR), starting the TMR count operation.

• By setting the operation mode select bits in the timer control status register (TMCSR: MOD2 to MOD0), the detected edge can be selected from the rising edge, falling edge, and both edges.

Note: The trigger pulse width of the edge to be input to the TIN pin should be 2 machine cycles (time) or more.



#### Figure 8.5-6 Count Operation in External Trigger Mode (One-shot Mode)

#### Figure 8.5-7 Count Operation in External Trigger Mode (Reload Mode)

| Count clock                 | ллл             |                       |                        |                    |               |
|-----------------------------|-----------------|-----------------------|------------------------|--------------------|---------------|
| Counter                     | Reload data - 1 | Keload data -1        | X0000H Reload data -1  | Keload data        | <u>-1</u> X   |
| Data load signa<br>UF bit   | al ∏            | <u>1</u>              | Ì                      | <u>1</u>           |               |
| CNTE bit                    |                 |                       |                        |                    |               |
| TIN pin                     | → <b>←</b>      |                       |                        |                    |               |
| TOT pin                     | 2T to 2.5T*     |                       | ·····-                 |                    |               |
| T: Machine<br>*: It takes 2 |                 | cycles (time) to load | data of reload registe | er from external t | rigger input. |

www.DataSheet4U.com

#### [External gate input mode (MOD2 to MOD0 = "1x0<sub>B</sub>", "1x1<sub>B</sub>")]

When the external gate input mode is set, start the 16-bit reload timer by setting the software trigger bit in the timer control status register (TMCSR: TRG) to 1. When the 16-bit reload timer is started, the value set in the 16-bit reload register (TMRLR) is reloaded to the 16-bit timer register (TMR).

- After the 16-bit reload timer is started, the count operation of the TMR is performed while the set gate input level is input to the TIN pin.
- The gate input level (High or Low) can be selected by setting the operation mode select bits in the timer control status register (TMCSR: MOD2 to MOD0).



#### Figure 8.5-8 Count Operation in External Gate Input Mode (One-shot Mode)

DataShe

#### Figure 8.5-9 Count Operation in External Gate Input Mode (Reload Mode)

| Count clock _            |                                                                                     |
|--------------------------|-------------------------------------------------------------------------------------|
| Counter                  | X Reload data X -1 X -1 X -1 X0000⊮X Reload data X -1 X -1                          |
| Data load signal         | ſ ſ                                                                                 |
| UF bit                   | Λ                                                                                   |
| CNTE bit                 |                                                                                     |
| TRG bit                  |                                                                                     |
| TIN pin                  | → T* ←                                                                              |
| TOT pin                  |                                                                                     |
| T: Machine *: It takes 1 | cycle<br>I machine cycle (time) to load data of reload register from trigger input. |

## 8.5.2 Operation in Event Count Mode

In the event count mode, after the 16-bit reload timer is started, the edge of the signal input to the TIN pin is detected to perform the count operation of the 16-bit timer register (TMR). When the operation mode and the reload mode are set, a rectangular wave or a toggle wave is output from the TOT pin.

#### Setting of Event Count Mode

- The 16-bit reload timer is placed in the event count mode by setting the count clock select bits in the timer control status register (TMCSR: CSL1, CSL0) to "11<sub>B</sub>".
- In the event count mode, the TMR decrements in synchronization with the edge detection of the external event clock input to the TIN pin.

#### [Setting initial value of counter]

After the 16-bit reload timer is started, the value set in the TMRLR is reloaded to the TMR.

- 1. Disables the operation of the 16-bit reload timer (TMCSR: CNTE = 0).
- 2. Sets a reload value to the TMR in the TMRLR.
- 3. Enables the operation of the 16-bit reload timer (TMCSR: CNTE = 1).

 Note:
 It takes 1 machine cycle (time) to load the value set in the TMRLR to the TMR after the start trigger is input.

 DataSheet4U.com

et4U.com

DataShee

265

#### Operation as 16-bit Timer Register Underflows

When the value of the 16-bit timer register (TMR) is decremented from " $0000_{\text{H}}$ " to "FFFF<sub>H</sub>" during the TMR count operation, an underflow occurs.

- When an underflow occurs, the underflow generation flag bit in the timer control status register (TMCSR: UF) is set to 1.
- When the underflow interrupt enable bit in the timer control status register (TMCSR: INTE) is set to 1, an underflow interrupt is generated.
- The reload operation when an underflow occurs is set by the reload select bit in the timer control status register (TMCSR: RELD).

#### [One-shot mode (TMCSR: RELD = 0)]

When an underflow occurs, the TMR count operation is stopped, entering the start trigger input wait state. When the next start trigger is input, the TMR count operation is restarted.

In the one-shot mode, a rectangular wave is output from the TOT pin during the TMR count operation. The pin output level select bit in the timer control status register (TMCSR: OUTL) can be set to select the level (High or Low) of the rectangular wave.

#### [Reload mode (TMCSR: RELD = 1)]

When an underflow occurs, the value set in the TMRLR is reloaded to the TMR, continuing the TMR count operation.

In the reload mode, a toggle wave inverting the output level of the TOT pin is output each time an underflow occurs during the TMR count operation. The pin output level select bit in the timer control status register (TMCSR: OUTL) can be set to select the level (High or Low) of the toggle wave when the 16-bit reload timer is started.

DataShee

DataSheet4U.com

#### Operation in Event Count Mode

The operation of the 16-bit reload timer is enabled by setting the timer operation enable bit in the timer control status register (TMCSR: CNTE) to 1. When the software trigger bit in the timer control status register (TMCSR: TRG) is set to 1, the 16-bit reload timer is started. When the 16-bit reload timer is started, the value set in the 16-bit reload register (TMRLR) is reloaded to the 16-bit timer register (TMR), starting the TMR count operation. After the 16-bit reload timer is started, the edge of the external event clock input to the TIN pin is detected to perform the TMR count operation.

• By setting the operation mode select bits in the timer control status register (TMCSR: MOD2 to MOD0), the detected edge can be selected from the rising edge, falling edge, and both edges.

Note: The level width of external event clock to be input to the TIN pin should be 4 machine cycles (time) or more.



#### Figure 8.5-10 Count Operation in Event Count Mode (One-shot Mode)





DataSheet4U.com

et4U.com

www.DataSheet4U.com

## 8.6 Precautions when Using 16-bit Reload Timer

This section explains the precautions when using the 16-bit reload timer.

#### Precautions when Using 16-bit Reload Timer

- Precautions when setting by program
  - Set the 16-bit reload register (TMRLR) after disabling the timer operation (TMCSR: CNTE = 0)
  - The 16-bit timer register (TMR) can be read during the TMR count operation. However, always use the word instruction (MOVW).
  - Change the CSL1 and CSL0 bits in the TMCSR after disabling the timer operation (TMCSR: CNTE = 0).

#### Precautions on interrupt

- When the UF bit in the TMCSR is set to 1 and the underflow interrupt output is enabled (TMCSR: INTE = 1), it is impossible to return from interrupt processing. Always clear the UF bit. However, when the EI<sup>2</sup>OS is used, the UF bit is cleared automatically.
- When using the EI<sup>2</sup>OS in the 16-bit reload timer, it is necessary to disable generation of interrupt requests by resources that share the interrupt control register (ICR) with the 16-bit reload timer.

DataSheet4U.com

et4U.com

DataSheet4U.com

268

www.DataSheet4U.com

## 8.7 Program Example of 16-bit Reload Timer

## This section gives a program example of the 16-bit reload timer operated in the internal clock mode and the event count mode:

#### Program Example in Internal Clock Mode

- Processing specification
  - The 25-ms interval timer interrupt is generated by the 16-bit reload timer 0.
  - The repeated interrupts are generated in the reload mode.
  - The timer is started using the software trigger instead of the external trigger input.
  - EI<sup>2</sup>OS is not used.
  - The machine clock is 16 MHz; the count clock is  $2 \,\mu s$ .

et4U.com

DataSheet4U.com

#### • Coding example

| ICR03      | EQU    | 0000B3H         | ; Interrupt control register for 16-bit reload timer  |          |
|------------|--------|-----------------|-------------------------------------------------------|----------|
| TMCSR0     | EQU    | 000066H         | ; Timer control status register                       |          |
| TMR0       | EQU    | 003900H         | ; 16-bit timer register                               |          |
| TMRLR0     | EQU    | 003900H         | ; 16-bit reload register                              |          |
| UF0        | EQU    | TMCSR0:2        | ; Interrupt request flag bit                          |          |
| CNTE0      | EQU    | TMCSR0:1        | ; Counter operation enable bit                        |          |
| TRG0       | EQU    | TMCSR0:0        | ; Software trigger bit                                |          |
| ;N         | lain p | rogram          |                                                       |          |
| CODE       | CSEG   | -               |                                                       |          |
| ;          | :      |                 | ; Stack pointer (SP), already initialized             |          |
|            | AND    | CCR,#0BFH       | ; Interrupts disabled                                 |          |
|            | MOV    | I:ICR03,#00H    | ; Interrupt level 0 (highest)                         |          |
|            | CLRB   | I:CNTE0         | ; Counter suspended                                   |          |
|            | MOVW   | I:TMRLR0,#30D4H | ; Data set for 25-ms timer                            |          |
|            | MOVW   | I:TMCSR0,#00001 | 0000011011B                                           |          |
|            |        |                 | ; Operation of interval timer, clock = 2 ms.          |          |
|            |        |                 | ; External trigger disabled, external output disabled |          |
|            |        |                 | ; Reload mode selected, interrupt enabled             |          |
|            |        |                 | ; Interrupt flag cleared, count started               |          |
|            | MOV    | ILM,#07H        | ; ILM in PS set to level 7                            |          |
|            | OR     | CCR,#40H        | ; Interrupts enabled                                  |          |
| LOOP:      |        |                 |                                                       |          |
|            | :      |                 |                                                       |          |
|            | Proc   | essing by user  |                                                       | DataShee |
|            | :      |                 |                                                       | DataShe  |
|            | BRA    | LOOP            |                                                       |          |
| ;I         | nterr  | upt program     |                                                       |          |
| WARI:      |        |                 |                                                       |          |
|            | CLR    | I:UF0           | ; Interrupt request flag cleared                      |          |
|            | :      |                 |                                                       |          |
|            | Proc   | essing by user  |                                                       |          |
|            | :      |                 |                                                       |          |
|            | RETI   |                 | ; Return from interrupt                               |          |
| CODE       | ENDO   |                 |                                                       |          |
| CODE       | ENDS   |                 |                                                       |          |
| ;v<br>VECT |        | -               |                                                       |          |
| VECI       |        | ABS=0FFH        | Nector get to interrupt #17 (1111)                    |          |
|            |        | 00FFB8H         | ; Vector set to interrupt #17 (11H)                   |          |
|            |        | WARI            | · Peget wester set                                    |          |
|            |        | 00FFDCH         | ; Reset vector set                                    |          |
|            |        | START           | Orther simple ship male                               |          |
| 1 ID OT    | DB     | 00H             | ; Set to single-chip mode                             |          |
| VECT       | ENDS   |                 |                                                       |          |
|            | END    | START           |                                                       |          |
|            |        |                 |                                                       |          |

et4U.com

DataSheet4U.com

#### Program Example in Event Count Mode

- Processing specification
  - An interrupt is generated when rising edges of the pulse input to the external event input pin are counted 10000 times by the 16-bit reload timer 0.
  - Operation is performed in the one-shot mode.
  - The rising edge is selected for the external trigger input.
  - EI<sup>2</sup>OS is not used.

et4U.com

DataSheet4U.com

#### • Coding example

| тароз         | FOIT     | 0000020             |   | Interment control register for 16 bit relead timer |          |
|---------------|----------|---------------------|---|----------------------------------------------------|----------|
| ICR03         |          | 0000B3H             |   | Interrupt control register for 16-bit reload timer |          |
| TMCSR         |          |                     |   | Timer control status register                      |          |
|               |          |                     |   | 16-bit timer register                              |          |
| DDR2          |          |                     |   | 16-bit reload register                             |          |
| UF0           |          |                     |   | Port data register                                 |          |
|               |          |                     |   | Interrupt request flag bit                         |          |
| CNTE0<br>TRG0 | ~        |                     |   | Counter operation enable bit                       |          |
|               | ~        |                     |   | Software trigger bit                               |          |
| CODE          | -        | rogram<br>CSEG      |   |                                                    |          |
| ;             | :        | CDEG                |   | Stack pointer (SP), already initialized            |          |
| /             |          | CCR,#0BFH           |   | Interrupts disabled                                |          |
|               |          |                     |   | Interrupt level 0 (highest)                        |          |
|               |          |                     |   | Sets P20/TINO pin to input                         |          |
|               |          |                     |   | Counter suspended                                  |          |
|               |          |                     |   | load value set to 10000 times                      |          |
|               |          | I:TMCSR0,#0000110   |   |                                                    |          |
|               | 110 1 10 | 1.11105100,#0000110 |   | Counter operation, external trigger,               |          |
|               |          |                     |   | rising edge, and external output disabled          |          |
|               |          |                     |   | One-shot mode selected, interrupt enabled          |          |
|               |          |                     |   | Interrupt flag cleared, count started              |          |
|               | MOV      | ILM,#07H            |   | ILM in PS set to level 7                           |          |
|               |          |                     |   | Interrupts enabled                                 |          |
| LOOP:         |          |                     | ' |                                                    | DataShee |
|               | :        |                     |   |                                                    | DataShe  |
|               | Proc     | essing by user      |   |                                                    |          |
|               | :        |                     |   |                                                    |          |
|               | BRA      | LOOP                |   |                                                    |          |
| ;             | -Interr  | upt program         |   |                                                    |          |
| WARI:         |          |                     |   |                                                    |          |
|               | CLR      | I:UF0               | ; | Interrupt request flag cleared                     |          |
|               | :        |                     |   |                                                    |          |
|               | Proc     | essing by user      |   |                                                    |          |
|               | :        |                     |   |                                                    |          |
|               | RETI     |                     | ; | Return from interrupt                              |          |
|               |          |                     |   |                                                    |          |
| CODE          | ENDS     |                     |   |                                                    |          |
|               |          |                     |   |                                                    |          |
| VECT          |          | ABS=0FFH            |   |                                                    |          |
|               |          |                     | ; | Vector set to interrupt #17 (11H)                  |          |
|               |          | WARI                |   |                                                    |          |
|               |          |                     | ; | Reset vector set                                   |          |
|               |          | START               |   |                                                    |          |
|               | DB       | 00H                 | ; | Set to single-chip mode                            |          |
| VECT          | ENDS     |                     |   |                                                    |          |
|               | END      | START               |   |                                                    |          |
|               |          |                     |   |                                                    |          |

et4U.com

DataSheet4U.com

# CHAPTER 9 WATCH TIMER

This section describes the functions and operations of the watch timer.

- 9.1 Overview of Watch Timer
- 9.2 Block Diagram of Watch Timer
- 9.3 Configuration of Watch Timer
- 9.4 Watch Timer Interrupt
- 9.5 Explanation of Operation of Watch Timer
- 9.6 Program Example of Watch Timer

et4U.com

www.DataSheet4U.com

CHAPTER 9 WATCH TIMER

## 9.1 Overview of Watch Timer

The watch timer is a 15-bit free-run counter that increments in synchronization with the subclock.

- 8 interval times can be selected and an interrupt request can be generated for each interval time.
- An operation clock can be supplied to the oscillation stabilization wait time timer of the subclock and the watchdog timer.
- The subclock is always used as a count clock regardless of the settings of the clock select register (CKSCR).

#### Interval Timer Function

- When the watch timer reaches the interval time set by the interval time select bits (WTC: WTC2 to WTC0), the bit corresponding to the interval time of the watch timer counter overflows (carries) and the overflow flag bit is set (WTC: WTOF = 1).
- When the overflow flag bit is set (WTC: WTOF = 1) with interrupt enabled when an overflow occurs (WTC: WTIE = 1), an interrupt request is generated.
- The interval time of the watch timer can be selected from 8 types shown in Table 9.1-1.

Table 9.1-1 Interval Times of Watch Timer

| Subclock Cycle | Interval Time                   |
|----------------|---------------------------------|
| SCLK (122 µs)  | 2 <sup>8</sup> /SCLK (31.25 ms) |
|                | 2 <sup>9</sup> /SCLK (62.5 ms)  |
|                | 2 <sup>10</sup> /SCLK (125 ms)  |
|                | 2 <sup>11</sup> /SCLK (250 ms)  |
|                | 2 <sup>12</sup> /SCLK (500 ms)  |
|                | 2 <sup>13</sup> /SCLK (1.0 s)   |
|                | 2 <sup>14</sup> /SCLK (2.0 s)   |
|                | 2 <sup>15</sup> /SCLK (4.0 s)   |

SCLK: Subclock frequency

The parenthesized values are provided when the subclock operates at 8.192 kHz.

et4U.com

www.DataSheet4U.com

DataShe

DataSheet4U.com

#### ■ Cycle of Clock Supply

The watch timer supplies an operation clock to the oscillation stabilization wait time timer of the subclock and the watchdog timer. Table 9.1-2 shows the cycles of clocks supplied from the watch timer.

Table 9.1-2 Cycle of Clock Supply from Watch Timer

| Where to Supply Clock                                        | Clock Cycle                     |  |
|--------------------------------------------------------------|---------------------------------|--|
| Timer for oscillation stabilization wait time<br>of subclock | 2 <sup>14</sup> /SCLK (2.000 s) |  |
|                                                              | 2 <sup>10</sup> /SCLK (125 ms)  |  |
| Watchdog timer                                               | 2 <sup>13</sup> /SCLK (1.000 s) |  |
|                                                              | 2 <sup>14</sup> /SCLK (2.000 s) |  |
|                                                              | 2 <sup>15</sup> /SCLK (4.000 s) |  |

SCLK: Subclock frequency

The parenthesized values are provided when the subclock operates at 8.192 kHz.

et4U.com

DataShe

DataSheet4U.com

www.DataSheet4U.com

CHAPTER 9 WATCH TIMER

## 9.2 Block Diagram of Watch Timer

The watch timer consists of the following blocks:

- Watch timer counter
- Counter clear circuit
- Interval timer selector
- Watch timer control register (WTC)

#### Block Diagram of Watch Timer



Figure 9.2-1 Block Diagram of Watch Timer

The actual interrupt request number of the watch timer is as follows:

Interrupt request number:  $#28 (1C_H)$ 

#### Watch timer counter

The watch timer counter is a 15-bit up counter that uses the subclock (SCLK) as a count clock.

#### Counter clear circuit

The counter-clear circuit clears the watch timer counter.

DataShee

DataSheet4U.com

et4U.com

#### Interval timer selector

The interval timer selector sets the overflow flag bit when the watch timer counter reaches the interval time set in the watch timer control register (WTC).

Watch timer control register (WTC)

The watch timer control register (WTC) selects the interval time, clears the watch timer counter, enables or disables an interrupt, checks the overflow (carries) state, and clears the overflow flag bit.

et4U.com

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

CHAPTER 9 WATCH TIMER

## 9.3 Configuration of Watch Timer

This section explains the registers and interrupt factors of the watch timer.

■ List of Registers and Reset Values of Watch Timer

| Figure 9.3-1 List of Registers and Reset Values of Watch Timer |   |   |   |   |   |   |   |   |
|----------------------------------------------------------------|---|---|---|---|---|---|---|---|
| bit                                                            | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 16-bit reload register (Low)<br>(TMRLR1)                       | 1 | Х | 0 | 0 | 0 | 0 | 0 | 0 |
| X: Undefined                                                   |   |   |   |   |   |   |   |   |

#### ■ Generation of Interrupt Request from Watch Timer

- When the interval time set by the interval time select bits (WTC: WTC2 to WTC0) is reached, the overflow flag bit (WTC: WTOF) is set to 1.
- When the overflow flag bit is set (WTC: WTOF = 1) with interrupt enabled when the watch timer counter overflows (carries) (WTC: WTIE = 1), an interrupt request is generated.

et4U.com

DataShe

DataSheet4U.com

DataSheet4U.com

278

www.DataSheet4U.com

#### Watch Timer Control Register (WTC) 9.3.1

This section explains the functions of the watch timer control register (WTC).

#### Watch Timer Control Register (WTC)



Figure 9.3-2 Watch Timer Control Register (WTC)

DataSheet4U.com

#### CHAPTER 9 WATCH TIMER

|                   | Bit Name                                               | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------------|--------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 2 to<br>bit 0 | WTC2, WTC1, WTC0:<br>Interval time select bits         | <ul> <li>These bits set the interval time of the watch timer.</li> <li>When the interval time set by the WTC2 to WTC0 bits is reached, the corresponding bit of the watch timer counter overflows (carries) and the overflow flag bit is set (WTC: WTOF = 1).</li> <li>To set the WTC2 to WTC0 bits, set the WTOF bit to 0.</li> </ul>                                                                                                                                                                                                                                                                                                                                                |
| bit 3             | WTR:<br>Watch timer clear bit                          | This bit clears the watch timer counter.<br><b>When set to 0:</b> Clears watch timer counter to "0000 <sub>H</sub> "<br><b>When set to 1:</b> No effect<br><b>Read:</b> 1 is always read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| bit 4             | WTOF:<br>Overflow flag bit                             | <ul> <li>This bit is set to 1 when the counter value of the watch timer reaches the value set by the interval time select bit.</li> <li>When an overflow (carries) occurs (WTOF = 1) with interrupt request enabled (WTIE = 1), an interrupt request is generated.</li> <li>When set to 0: Clears this bit</li> <li>When set to 1: No effect</li> <li>The overflow flag bit is set to 1 when the bit of the watch timer counter corresponding to the interval time set by the interval time select bits (WTC2 to WTC0) overflows (carries).</li> </ul>                                                                                                                                |
| bit 5             | WTIE:<br>Overflow interrupt<br>enable bit              | This bit enables or disables generation of an interrupt request when the watch timer counter overflows (carries).<br>When set to 0: Interrupt request not generated even at overflow (WTOF = 1)<br>When set to 1: Interrupt request generated at overflow (WTOF = 1)                                                                                                                                                                                                                                                                                                                                                                                                                  |
| bit 6             | SCE:<br>Oscillation stabilization<br>wait time end bit | <ul> <li>This bit indicates that the oscillation stabilization wait time of the subclock ends.</li> <li>When cleared to 0: Subclock in oscillation stabilization wait state</li> <li>When set to 1: Subclock oscillation stabilization wait time ends</li> <li>The oscillation stabilization wait time of the subclock is fixed at 2<sup>14</sup>/SCLK (SCLK: subclock frequency).</li> </ul>                                                                                                                                                                                                                                                                                         |
| bit 7             | WDCS:<br>Watchdog clock select<br>bit                  | <ul> <li>This bit selects the operation clock of the watchdog timer.</li> <li><main clock="" mode="" or="" pll=""></main></li> <li>When set to 0: Selects output of watch timer as operation clock of watchdog timer.</li> <li>When set to 1: Selects output of timebase timer as operation clock of watchdog timer.</li> <li><subclock mode=""></subclock></li> <li>Always set this bit to 0 to select the output of the watch timer.</li> <li>Note: The watch timer and the timebase timer operate asynchronously. When the WDCS bit is changed from 0 to 1, the watchdog timer may run fast. The watchdog timer must be cleared before and after changing the WDCS bit.</li> </ul> |

#### Table 9.3-1 Functions of Watch Timer Control Register (WTC)

et4U.com

DataSheet4U.com

## 9.4 Watch Timer Interrupt

# When the interval time is reached with the watch timer interrupt enabled, the overflow flag bit is set to 1 and an interrupt request is generated.

#### Watch Timer Interrupt

Table 9.4-1 shows the interrupt control bits and interrupt factors of the watch timer.

#### Table 9.4-1 Interrupt Control Bits of Watch Timer

|                             | Watch Timer                          |  |
|-----------------------------|--------------------------------------|--|
| Interrupt factor            | Interval time of watch timer counter |  |
| Interrupt request flag bit  | WTC: WTOF (overflow flag bit)        |  |
| Interrupt factor enable bit | WTC: WTIE                            |  |

- When the value set by the interval time select bits (WTC2 to WTC0) in the watch timer control register (WTC) is reached, the overflow flag bit in the WTC register is set to 1 (WTC: WTOF = 1).
- When the overflow flag bit is set (WTC: WTOF = 1) with the watch timer interrupt enabled (WTC: WTIE = 1), an interrupt request is generated.
- At interrupt processing, set the WTOF bit to 0 and cancel the interrupt request.

### ■ Watch Timer Interrupt and El<sup>2</sup>OS Function

- The watch timer does not correspond to the EI<sup>2</sup>OS function.
- For details of the interrupt number, interrupt control register, and interrupt vector address, see Section "3.5 Interrupt".

et4U.com

281

CHAPTER 9 WATCH TIMER

## 9.5 Explanation of Operation of Watch Timer

## The watch timer operates as an interval timer or an oscillation stabilization wait time timer of subclock. It also supplies an operation clock to the watchdog timer.

#### Watch Timer Counter

The watch timer counter continues incrementing in synchronization with the subclock (SCLK) while the subclock (SCLK) is operating.

Clearing watch timer counter

The watch timer counter is cleared to " $0000_{\text{H}}$ " when:

- A power-on reset occurs.
- The mode transits to the stop mode.
- The watch timer clear bit (WTR) in the watch timer control register (WTC) is set to 0.

Note:When the watch timer counter is cleared, the interrupts of the watchdog timer and interval timer that use<br/>the output of the watch timer counter are affected.<br/>To clear the watch timer by writing zero to the watch timer clear bit (WTR) in the watch timer control

register (WTC), set the overflow interrupt enable bit (WTIE) to "0" and set the watch timer to interrupt inhibited state. Before permitting an interrupt, clear the interrupt request issued by writing zero to the overflow flag bit (WTOF) in the WTCTegister. Com

DataShee

#### Interval Timer Function

The watch timer can be used as an interval timer by generating an interrupt at each interval time.

• Settings when using watch timer as interval timer

Operating the watch timer as an interval timer requires the settings shown in Figure 9.5-1.

|                       | •    | garoon |      | ng or ma |     | /    |      |      |
|-----------------------|------|--------|------|----------|-----|------|------|------|
|                       | bit7 | 6      | 5    | 4        | 3   | 2    | 1    | bit0 |
| WTC                   | WDCS | SCE    | WTIE | WTOF     | WTR | WTC2 | WTC1 | WTC0 |
|                       | Х    | Х      | 0    | 0        | 0   | 0    | 0    | 0    |
| $\bigcirc$ : Used bit |      |        |      |          |     |      |      |      |
| X: Undefined          |      |        |      |          |     |      |      |      |

Figure 9.5-1 Setting of Watch Timer

• When the value set by the interval time select bits (WTC1, WTC0) in the watch timer control register (WTC) is reached, the overflow flag bit in the WTC register is set to 1 (WTC: WTOF = 1).

- When the overflow flag bit is set (WTC: WTOF = 1) with the overflow interrupt of the watch timer counter enabled (WTC: WTIE = 1), an interrupt request is generated.
- The overflow flag bit (WTC: WTOF) is set when the interval time is reached at the starting point of the timing at which the watch timer is finally cleared.

DataSheet4U.com

et4U.com

282

#### • Clearing overflow flag bit (WTC: WTOF)

When the mode is switched to the stop mode, the watch timer is used as an oscillation stabilization wait time timer of subclock. The WTOF bit is cleared concurrently with mode switching.

#### Setting Operation Clock of Watchdog Timer

The watchdog clock select bit (WDCS) in the watch timer control register (WTC) can be used to set the clock input source of the watchdog timer.

When using the subclock as the machine clock, always set the WDCS bit to 0 and select the output of the watch timer.

#### Oscillation Stabilization Wait Time Timer of Subclock

When the watch timer returns from the power-on reset and the stop mode, it functions as an oscillation stabilization wait time timer of subclock.

• The subclock oscillation stabilization wait time is fixed at  $2^{14}$ /SCLK (SCLK: subclock frequency).

DataSheet4U.com

CHAPTER 9 WATCH TIMER

## 9.6 **Program Example of Watch Timer**

#### This section gives a program example of the watch timer.

#### Program Example of Watch Timer

#### Processing specifications

An interval interrupt at  $2^{13}$ /SCLK (SCLK: subclock) is generated repeatedly. The interval time is approximately 1.0s (when subclock operates at 8.192 kHz).

#### Coding example

```
ICR07EQU0000B7H; Interrupt control registerWTCEQU0000AAH; Watch timer control registerWTOFEQUWTC:4; Overflow flag bit
                           ;
                           ;-----Main program-----
                           CODE
                                 CSEG
                           START:
                                  : ; Stack pointer (SP) already initialized
AND CCR,#0BFH ; Interrupt disabled
MOV I:ICR07,#00H ; Interrupt level 0 (highest)
                           ;
et4U.com
                                                                                                             DataShe
                                   MOV I:WTC, #10100101B ; Interrupt enabled
                                                        ; Overflow flag bit cleared
                                                        ; Watch timer counter cleared
                                                        ; 2<sup>13</sup>/SCLK (approx. 1.0 s)
                                   MOVILM,#07H; ILM in PS set to level 7ORCCR,#40H; Interrupt enabled
                           LOOP:
                                   Processing by user
                                   BRA LOOP
                            ;-----Interrupt program------
                           WARI:
                                   CLRB I:WTOF ; Overflow flag cleared
                                    .
                                   Processing by user
                                    .
                                   RETI
                                                        ; Return from interrupt processing
                           CODE
                                   ENDS
                            ;-----Vector setting------
                           VECT
                                  CSEG ABS=0FFH
                                   ORG 00FF8CH
                                                       ; Vector set to interrupt #28 (1CH)
                                   DSL WARI
                                   ORG 00FFDCH
                                                       ; Reset vector set
                                   DSL START
                                   DB 00H
                                                       ; Set to single-chip mode
                                   ENDS
                           VECT
                                   END START
```

DataSheet4U.com

284

www.DataSheet4U.com

This section describes the functions and operations of the 8-/16-bit PPG timer.

- 10.1 Overview of 8-/16-bit PPG Timer
- 10.2 Block Diagram of 8-/16-bit PPG Timer
- 10.3 Configuration of 8-/16-bit PPG Timer
- 10.4 Interrupts of 8-/16-bit PPG Timer
- 10.5 Explanation of Operation of 8-/16-bit PPG Timer
- 10.6 Precautions when Using 8-/16-bit PPG Timer

et4U.com

DataSheet4U.com

www.DataSheet4U.com

## 10.1 Overview of 8-/16-bit PPG Timer

The 8-/16-bit PPG timer is a reload timer module with two channels (PPG0 and PPG1) that outputs a pulse in any cycle and at any duty ratio. A combination of two channels provides:

- 8-bit PPG output 2-channel independent operation mode
- 16-bit PPG output operation mode
- 8 + 8-bit PPG output operation mode

The MB90385 series has two 8-/16-bit PPG timers. This section explains the functions of PPG0/1. PPG2/3 has the same functions as PPG0/1.

#### Functions of 8-/16-bit PPG Timer

The 8-/16-bit PPG timer consists of four 8-bit reload registers (PRLH0, PRLL0, PRLH1, and PRLL1) and two PPG down counters (PCNT0 and PCNT1).

- Individual setting of High and Low widths in output pulse enables an output pulse of any cycle and duty ratio.
- The count clock can be selected from six internal clocks.
- The 8-/16-bit PPG timer can be used as an interval timer by generating an interrupt request at each interval time.

DataShee

• An external circuit enables the 8-716-bit PPG timer to be used as a D/A converter.

#### Operation Modes of 8-/16-bit PPG Timer

8-bit PPG output 2-channel independent operation mode

The 8-bit PPG output 2-channel independent operation mode causes the 2-channel modules (PPG0 and PPG1) to operate as each independent 8-bit PPG timer.

Table 10.1-1 shows the interval times in the 8-bit PPG output 2-channel independent operation mode.

DataSheet4U.com

et4U.com

| Count Clock Cyclo             | PPG0, PPG1                                    |                                                |  |  |
|-------------------------------|-----------------------------------------------|------------------------------------------------|--|--|
| Count Clock Cycle             | Interval Time                                 | Output Pulse Time                              |  |  |
| 1/\$\phi\$ (62.5 ns)          | 1/φ to 2 <sup>8</sup> /φ                      | $2/\phi$ to $2^9/\phi$                         |  |  |
| 2/\$ (125 ns)                 | 2/\$ to 2 <sup>9</sup> /\$                    | $2^2/\phi$ to $2^{10}/\phi$                    |  |  |
| $2^{2}/\phi$ (250 ns)         | $2^2/\phi$ to $2^{10}/\phi$                   | $2^{3}/\phi$ to $2^{11}/\phi$                  |  |  |
| 2 <sup>3</sup> /\$ (500 ns)   | $2^{3}/\phi$ to $2^{11}/\phi$                 | $2^4/\phi$ to $2^{12}/\phi$                    |  |  |
| 2 <sup>4</sup> /\$ (1 µs)     | $2^4/\phi$ to $2^{12}/\phi$                   | $2^5/\phi$ to $2^{13}/\phi$                    |  |  |
| 2 <sup>9</sup> /HCLK (128 μs) | 2 <sup>9</sup> /HCLK to 2 <sup>17</sup> /HCLK | 2 <sup>10</sup> /HCLK to 2 <sup>18</sup> /HCLK |  |  |

#### Table 10.1-1 Interval Times in 8-bit PPG Output 2-channel Independent Operation Mode

HCLK: Oscillation clock

φ: Machine clock frequency

The parenthesized values are provided when the oscillation clock operates at 4 MHz and the machine clock operates at 16 MHz.

#### 16-bit PPG output operation mode

et4U.com

The 16-bit PPG output operation mode concatenates the 2-channel modules (PPG0 and PPG1) to operate as DataShee a 16-bit 1-channel PPG timer. Table 10.1-2 shows the interval times in this mode.

#### Table 10.1-2 Interval Times in 16-bit PPG Output Operation Mode

| Count clock cycle             | Interval time                                 | Output pulse time                              |
|-------------------------------|-----------------------------------------------|------------------------------------------------|
| 1/φ (62.5 ns)                 | $1/\phi$ to $2^{16}/\phi$                     | $2/\phi$ to $2^{17}/\phi$                      |
| 2/\$ (125 ns)                 | $2/\phi$ to $2^{17}/\phi$                     | $2^2/\phi$ to $2^{18}/\phi$                    |
| $2^{2}/\phi$ (250 ns)         | $2^2/\phi$ to $2^{18}/\phi$                   | $2^{3}/\phi$ to $2^{19}/\phi$                  |
| $2^{3}/\phi$ (500 ns)         | $2^{3}/\phi$ to $2^{19}/\phi$                 | $2^4/\phi$ to $2^{20}/\phi$                    |
| 2 <sup>4</sup> /φ (1 μs)      | $2^4/\phi$ to $2^{20}/\phi$                   | $2^{5}/\phi$ to $2^{21}/\phi$                  |
| 2 <sup>9</sup> /HCLK (128 µs) | 2 <sup>9</sup> /HCLK to 2 <sup>25</sup> /HCLK | 2 <sup>10</sup> /HCLK to 2 <sup>26</sup> /HCLK |

HCLK: Oscillation clock

φ: Machine clock frequency

The parenthesized values are provided when the oscillation clock operates at 4 MHz and the machine clock operates at 16 MHz.

#### 8 + 8-bit PPG output operation mode

The 8 + 8-bit PPG output operation mode causes the PPG0 of the 2-channel modules (PPG0 and PPG1) to operate as an 8-bit prescaler and the underflow output of the PPG0 to operate as the count clock of the PPG1.

Table 10.1-3 shows the interval times in this mode.

| Count                         | PP                                               | G0                                                | PPG1                                             |                                                   |  |
|-------------------------------|--------------------------------------------------|---------------------------------------------------|--------------------------------------------------|---------------------------------------------------|--|
| Clock Cycle                   | Interval<br>Time                                 | Output Pulse<br>Time                              | Interval<br>Time                                 | Output Pulse<br>Time                              |  |
| 1/\$\phi\$ (62.5 ns)          | $1/\phi$ to $2^8/\phi$                           | $2/\phi$ to $2^9/\phi$                            | $1/\phi$ to $2^{16}/\phi$                        | $2/\phi$ to $2^{17}/\phi$                         |  |
| 2/\$\phi\$ (125 ns)           | $2/\phi$ to $2^9/\phi$                           | $2^2/\phi$ to $2^{10}/\phi$                       | $2/\phi$ to $2^{17}/\phi$                        | $2^2/\phi$ to $2^{18}/\phi$                       |  |
| $2^{2}/\phi$ (250 ns)         | $2^2/\phi$ to $2^{10}/\phi$                      | $2^{3}/\phi$ to $2^{11}/\phi$                     | $2^2/\phi$ to $2^{18}/\phi$                      | $2^{3}/\phi$ to $2^{19}/\phi$                     |  |
| $2^{3}/\phi$ (500 ns)         | $2^{3}/\phi$ to $2^{11}/\phi$                    | $2^4/\phi$ to $2^{12}/\phi$                       | $2^{3}/\phi$ to $2^{19}/\phi$                    | $2^4/\phi$ to $2^{20}/\phi$                       |  |
| $2^{4}/\phi$ (1 µs)           | $2^4/\phi$ to $2^{12}/\phi$                      | $2^{5}/\phi$ to $2^{13}/\phi$                     | $2^4/\phi$ to $2^{20}/\phi$                      | $2^{5}/\phi$ to $2^{21}/\phi$                     |  |
| 2 <sup>9</sup> /HCLK (128 μs) | 2 <sup>9</sup> /HCLK to<br>2 <sup>17</sup> /HCLK | 2 <sup>10</sup> /HCLK to<br>2 <sup>18</sup> /HCLK | 2 <sup>9</sup> /HCLK to<br>2 <sup>25</sup> /HCLK | 2 <sup>10</sup> /HCLK to<br>2 <sup>26</sup> /HCLK |  |

Table 10.1-3 Interval Times in 8+8-bit PPG Output Operation Mode

et4U.com

HCLK: Oscillation clock

φ: Machine clock frequency

The parenthesized values are provided when the oscillation clock operates at 4 MHz and the machine clock operates at 16 MHz.

www.DataSheet4U.com

## 10.2 Block Diagram of 8-/16-bit PPG Timer

The MB90385 series contains two 8/16-bit PPG timer (each with two channels).

One 8-/16-bit PPG timer consists of 8-bit PPG timers with two channels.

This section shows the block diagrams for the 8-/16-bit PPG timer 0 and 8-/16-bit PPG timer 1.

The PPG2 has the same function as the PPG0, and PPG3 has the same function as PPG1.

#### Channels and PPG Pins of PPG Timers

Figure 10.2-1 shows the relationship between the channels and the PPG pins of the 8-/16-bit PPG timers in the MB90385 series.



Figure 10.2-1 Channels and PPG Pins of PPG Timers

www.DataSheet4U.com

#### 10.2.1 Block Diagram for 8-/16-bit PPG Timer 0

#### The 8-/16-bit PPG timer 0 consists of the following blocks.

#### Block Diagram of 8-/16-bit PPG Timer 0





DataSheet4U.com

et4U.com

290

www.DataSheet4U.com

#### • Details of pins in block diagram

Table 10.2-1 lists the actual pin names and interrupt request numbers of the 8-/16-bit PPG timer.

#### Table 10.2-1 Pins and Interrupt Request Numbers in Block Diagram

| Channel | Output Pin | Interrupt Request Number |  |
|---------|------------|--------------------------|--|
| PPG0    | P14/PPG0   | #22 (16)                 |  |
| PPG1    | P15/PPG1   | #22 (16 <sub>H</sub> )   |  |
| PPG2    | P16/PPG2   | #26 (1A <sub>H</sub> )   |  |
| PPG3    | P17/PPG3   | π20 (IAH)                |  |

#### PPG operation mode control register 0 (PPGC0)

This register enables or disables operation of the 8-/16-bit PPG timer 0, the pin output, and an underflow interrupt. It also indicates the occurrence of an underflow.

• PPG0/1 count clock select register (PPG01)

This register sets the count clock of the 8-/16-bit PPG timer 0.

#### PPG0 reload registers (PRLH0 and PRLL0)

DataShe

These registers set the High width or Low width of the output pulse. The values set in these registers are reloaded to the PPG0 down counter (PCNT0) when the 8-/16-bit PPG timer 0 is started.

#### PPG0 down counter (PCNT0)

This counter is an 8-bit down counter that alternately reloads the values set in the PPG0 reload registers (PRLH0 and PRLL0) to decrement. When an underflow occurs, the pin output is inverted. This counter is concatenated for use as a single-channel 16-bit PPG down counter.

#### PPG0 temporary buffer (PRLBH0)

This buffer prevents deviation of the output pulse width caused at writing to the PPG reload registers (PRLH0 and PRLL0). This buffer stores the PRLH0 value temporarily and enables it in synchronization with the timing of writing to the PRLL0.

#### Reload register L/H selector

This selector detects the current pin output level to select which register value, Low reload register (PRLL0) or High reload register (PRLH0), should be reloaded to the PPG0 down counter.

#### Count clock selector

This selector selects the count clock to be input to the PPG0 down counter from five frequency-divided clocks of the machine clock or the frequency-divided clocks of the timebase timer.

DataSheet4U.com

• PPG output control circuit

This circuit inverts the pin output level and the output when an underflow occurs.

et4U.com

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

#### 10.2.2 Block Diagram of 8-/16-bit PPG Timer 1

The 8-/16-bit PPG timer 1 consists of the following blocks.

#### Block Diagram of 8-/16-bit PPG Timer 1



Figure 10.2-3 Block Diagram of 8-/16-bit PPG Timer 1

DataSheet4U.com

#### Details of pins in block diagram

Table 10.2-2 lists the actual pin names and interrupt request numbers of the 8-/16-bit PPG timer.

#### Table 10.2-2 Pins and Interrupt Request Numbers in Block Diagram

| Channel | Output Pin | Interrupt Request Number |  |
|---------|------------|--------------------------|--|
| PPG0    | P14/PPG0   | #22 (16)                 |  |
| PPG1    | P15/PPG1   | #22 (16 <sub>H</sub> )   |  |
| PPG2    | P16/PPG2   | #26 (1A <sub>H</sub> )   |  |
| PPG3    | P17/PPG3   | #20 (IAH)                |  |

#### PPG operation mode control register 1 (PPGC1)

This register sets the operation mode of the 8-/16-bit PPG timer, enables or disables the operation of the 8-/ 16-bit PPG timer 1, the pin output and an underflow interrupt, and also indicates the generation of an underflow.

#### PPG2/3 count clock select register (PPG23)

This register sets the count clock of the 8-/16-bit PPG timer 1.

#### • PPG1 reload registers (PRLH1 and PRLL1)

These registers set the High width of Low width of the output pulse. The values set in these registers are reloaded to the PPG1 down counter (PCNT1) when the 8-/16-bit PPG timer 1 is started.

#### • PPG1 down counter (PCNT1)

This counter is an 8-bit down counter that alternately reloads the values set in the PPG1 reload registers (PRLH1 and PRLL1) to decrement. When an underflow occurs, the pin output is inverted. The 2-channel PPG down counters (PPG0 and PPG1) can also be connected for use as a single-channel 16-bit PPG down counter.

#### PPG1 temporary buffer (PRLBH1)

This buffer prevents deviation of the output pulse width caused at writing to the PPG reload registers (PRLH1 and PRLL1). It stores the PRLH1 value temporarily and enables it in synchronization with the timing of writing to the PRLL1.

#### Reload register L/H selector

This selector detects the current pin output level to select which register value, Low reload register (PRLL1) or High reload register (PRLH1), should be reloaded to the PPG1 down counter.

#### Count clock selector

This selector selects the count clock to be input to the PPG1 down counter from five frequency-divided clocks of the machine clock or the frequency-divided clocks of the timebase timer.

DataSheet4U.com

#### • PPG output control circuit

This circuit inverts the pin output level and the output when an underflow occurs.

et4U.com

DataSheet4U.com

DataSheet4U.com

DataShe

www.DataSheet4U.com

## 10.3 Configuration of 8-/16-bit PPG Timer

#### This section explains the pins, registers and interrupt factors of the 8-/16-bit PPG timer.

#### Pins of 8-/16-bit PPG Timer

The pins of the 8-/16-bit PPG timer serve as general-purpose I/O ports. Table 10.3-1 indicates the pin functions and pin settings required to use the 8-/16-bit PPG timer.

| Channel | Pin Name        | Pin Function                                 | Pin Setting Required for Use of 8-<br>/16-bit PPG Timer |
|---------|-----------------|----------------------------------------------|---------------------------------------------------------|
| PPG0    | PPG0 output pin | General-purpose I/O port,<br>PPG0 output pin | Set PPG0 pin output to "enabled"<br>(PPGC0: PE=1)       |
| PPG1    | PPG1 output pin | General-purpose I/O port,<br>PPG1 output pin | Set PPG1 pin output to "enabled"<br>(PPGC1: PE1=1)      |
| PPG2    | PPG2 output pin | General-purpose I/O port,<br>PPG2 output pin | Set PPG2 pin output to "enabled"<br>(PPGC2: PE0=1)      |
| PPG3    | PPG3 output pin | General-purpose I/O port,<br>PPG3 output pin | Set PPG3 pin output to "enabled"<br>(PPGC3: PE1=1)      |

#### Table 10.3-1 Pins of 8-/16-bit PPG Timer

et4U.com

■ Block Diagram of 8-/16-bit PPG Timer Pins

See "CHAPTER 4 I/O PORT" for the pin block diagram.

www.DataSheet4U.com

#### ■ List of Registers and Reset Values of 8-/16-bit PPG Timer

|                                                 | bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
|-------------------------------------------------|-----|----|----|----|----|----|----|---|---|
| PPG0 operation mode control register: H (PPGC1) |     | 0  | 0  | 0  | 0  | 0  | 0  | 0 | C |
|                                                 | bit | 7  | 6  | 5  | 4  | 3  | 2  | 1 | C |
| PPG0 OPERATION MODE CONTROL REGISTER (PPGC0)    |     | 0  | 0  | 0  | 0  | 0  | 0  | 0 | C |
|                                                 | bit | 7  | 6  | 5  | 4  | 3  | 2  | 1 | C |
| PPG0/1 COUNT CLOCK SELECT REGISTER (PPG01)      |     | 0  | 0  | 0  | 0  | 0  | 0  | 0 | C |
|                                                 | bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| PPG0 reload register: H (PRLH0)                 | Γ   | Х  | Х  | Х  | Х  | Х  | Х  | Х | X |
|                                                 | bit | 7  | 6  | 5  | 4  | 3  | 2  | 1 | C |
| PPG0 reload register: L (PRLL0)                 | Γ   | Х  | Х  | Х  | Х  | Х  | Х  | Х | X |
|                                                 | bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| PPG1 reload register: H (PRLH1)                 |     | Х  | Х  | Х  | Х  | Х  | Х  | Х | X |
|                                                 | bit | 7  | 6  | 5  | 4  | 3  | 2  | 1 | C |
| PPG1 reload register: L (PRLL1)                 |     | Х  | Х  | Х  | Х  | Х  | Х  | Х | X |

#### Figure 10.3-1 List of Registers and Reset Values of 8-/16-bit PPG Timer

DataShe

#### ■ Generation of Interrupt Request from 8-/16-bit PPG Timer

In the 8-/16-bit PPG timer, the underflow generation flag bits in the PPG operation mode control registers (PPGC0: PUF0, PPGC1: PUF1) are set to 1 when an underflow occurs. If the underflow interrupts of channels causing an underflow are enabled (PPGC0: PIE0=1, PPGC1: PIE1=1), an underflow interrupt request is generated to the interrupt controller.

et4U.com

## **10.3.1 PPG0 Operation Mode Control Register (PPGC0)**

The PPG0 operation mode control register (PPGC0) provides the following settings:

- Enabling or disabling operation of 8-/16-bit PPG timer
- Switching between pin functions (enabling or disabling pulse output)
- Enabling or disabling underflow interrupt
- Setting underflow interrupt request flag

### ■ PPG0 Operation Mode Control Register (PPGC0)





DataShe

298

|                | Bit Name                                   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |
|----------------|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| bit 0          | Reserved: Reserved bit                     | Always set this bit to 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |
| bit 1<br>bit 2 | Unused bits                                | Read: The value is undefined.<br>Write: No effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |    |
| bit 3          | PUF0:<br>Underflow generation<br>flag bit  | <ul> <li>8-bit PPG output 2-channel independent operation mode, 8+8-bit PPG output operation mode: When the value of the PPG0 down counter is decremented from "00<sub>H</sub>" to "FF<sub>H</sub>", an underflow occurs (PUF0 = 1).</li> <li>16-bit PPG output operation mode: When the values of the PPG0 and PPG1 down counters are decremented from "0000<sub>H</sub>" to" FFFF<sub>H</sub>", an underflow occurs (PUF0 = 1).</li> <li>When an underflow occurs (PUF0 = 1) with an underflow interrupt enabled (PIE0 = 1), an interrupt request is generated.</li> <li>When set to 0: Clears this bit</li> <li>When set to 1: No effect</li> <li>Read by read modify write instructions: 1 read</li> </ul> |    |
| bit 4          | PIE0:<br>Underflow interrupt<br>enable bit | This bit enables or disables an interrupt.<br><b>When set to 0:</b> No interrupt request generated even at underflow (PUF0 = 1).<br><b>When set to 1:</b> Interrupt request generated at underflow (PUF0 = 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Da |
| bit 5          | PE0:<br>PPG0 pin output enable<br>bit      | <ul> <li>This bit switches between PPG0 pin functions and enables or disables the pulse output.</li> <li>When set to 0: PPG0 pin functions as general-purpose I/O port.<br/>The pulse output is disabled.</li> <li>When set to 1: PPG0 pin functions as PPG0 output pin.<br/>The pulse output is enabled.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                           |    |
| bit 6          | Unused bit                                 | Read: The value is undefined.<br>Write: No effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |    |
| bit 7          | PEN0:<br>PPG0 operation enable<br>bit      | <ul> <li>This bit enables or disables the count operation of the 8-/16-bit PPG timer 0.</li> <li>When set to 0: Count operation disabled</li> <li>When set to 1: Count operation enabled</li> <li>When the count operation is disabled (PEN0 = 0), the output is held at a Low level.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                               |    |

#### Table 10.3-2 Functions of PPG0 Operation Mode Control Register (PPGC0)

et4U.com

## **10.3.2 PPG1 Operation Mode Control Register (PPGC1)**

The PPG1 operation mode control register (PPGC1) provides the following settings:

- Enabling or disabling operation of 8-/16-bit PPG timer
- Switching between pin functions (enabling or disabling pulse output)
- Enabling or disabling underflow interrupt
- Setting underflow interrupt request flag
- Setting the operation mode of the 8-/16-bit PPG timer

#### ■ PPG1 Operation Mode Control Register (PPGC1)



#### Figure 10.3-3 PPG1 Operation Mode Control Register (PPGC1)

DataSheet4U.com

300

DataSheet4U.com

www.DataSheet4U.com

|                 | Bit Name                                   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------|--------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 8           | Reserved:<br>Reserved bit                  | Always set this bit to 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| bit 9<br>bit 10 | MD1, MD0:<br>Operation mode select<br>bits | <ul> <li>These bits set the operation mode of the 8-/16-bit PPG timer.</li> <li>[Any mode other than 8-bit PPG output 2-channel independent operation mode]</li> <li>Use a word instruction to set the PPG operation enable bits (PEN0 and PEN1) at one time.</li> <li>Do not set operation of only one of the two channels (PEN1 = 0/PEN0 = 1 or PEN1 = 1/PEN0 = 0).</li> <li>Note: Do not set the MD1 and MD0 bits to "10<sub>B</sub>".</li> </ul>                                                                                                                                                                                                                                                                                    |
| pit 11          | PUF1:<br>Underflow generation<br>flag bit  | <ul> <li>8-bit PPG output 2-channel independent operation mode, 8+8-bit PPG output operation mode: When the value of the PPG1 down counter is decremented from "00<sub>H</sub>" to "FF<sub>H</sub>", an underflow occurs (PUF1 = 1).</li> <li>16-bit PPG output operation mode: <ul> <li>When the values of the PPG0 and PPG1 down counters are decremented from "0000<sub>H</sub>" to "FFFF <sub>H</sub>", an underflow occurs (PUF1 = 1).</li> </ul> </li> <li>When an underflow occurs (PUF1 = 1) with an underflow interrupt enabled (PIE1 = 1) an interrupt request is generated.</li> <li>When set to 0: Clears this bit</li> <li>When set to 1: No effect</li> <li>Read by read modify write instructions: 1 is read.</li> </ul> |
| oit 12          | PIE1:<br>Underflow interrupt<br>enable bit | This bit enables or disables an interrupt.<br><b>When set to 0:</b> No interrupt request is generated even at underflow (PUF1 = 1)<br><b>When set to 1:</b> Interrupt request is generated at underflow (PUF1 = 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| bit 13          | PE1:<br>PPG1 Pin output enable<br>bit      | <ul> <li>This bit switches between PPG1 pin functions and enables or disables the pulse output.</li> <li>When set to 0: PPG1 pin functions as general-purpose I/O port. The pulse output is disabled.</li> <li>When set to 1: PPG1 pin functions as PPG1 output pin. The pulse output is enabled.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                            |
| bit 14          | Unused bit                                 | Read: The value is undefined.<br>Write: No effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| bit 15          | PEN1:<br>PPG1 operation enable<br>bit      | <ul> <li>This bit enables or disables the count operation of the 8-/16-bit PPG timer 1.</li> <li>When set to 0: Count operation disabled</li> <li>When set to 1: Count operation enabled</li> <li>When the count operation is disabled (PEN1 = 0), the output is held at a Low level.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                        |

#### Table 10.3-3 Functions of PPG1 Operation Mode Control Register (PPGC1)

DataSheet4U.com

et4U.com

www.DataSheet4U.com

## 10.3.3 PPG0/1 Count Clock Select Register (PPG01)

## The PPG0/1 count clock select register (PPG01) selects the count clock of the 8-/16-bit PPG timer.

#### ■ PPG0/1 Count Clock Select Register (PPG01)



Figure 10.3-4 PPG0/1 Count Clock Select Register (PPG01)

DataShe

DataSheet4U.com

|                | Bit Name                                         | Function                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|--------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0<br>bit 1 | Unused bits                                      | Read: The value is undefined.<br>Write: No effect                                                                                                                                                                                                                                                                                                                                                                            |
| bit 2 to bit 4 | PCM2 to PCM0:<br>PPG0 count clock select<br>bit  | <ul> <li>These bits set the count clock of the 8-/16-bit PPG timer 0.</li> <li>The count clock can be selected from five frequency-divided clocks of the machine clock and the frequency-divided clocks of the timebase timer.</li> </ul>                                                                                                                                                                                    |
| bit 5 to bit 7 | PCS2 to PCS0:<br>PPG1 count clock select<br>bits | <ul> <li>These bits set the count clock of the 8-/16-bit PPG timer 1.</li> <li>The count clock can be selected from five frequency-divided clocks of the machine clock and the frequency-divided clocks of the timebase timer.</li> <li>The settings of the PPG1 count clock select bits (PCS2 to PCS0) are enabled only in the 8-bit PPG output 2-channel independent mode (PPGC1: MD1, MD0 = "00<sub>B</sub>").</li> </ul> |

| Table 10.3-4 Functions of PPG0/1 Count Clock Select Register (PPG01) | G0/1 Count Clock Select Register (PPG01) |
|----------------------------------------------------------------------|------------------------------------------|
|----------------------------------------------------------------------|------------------------------------------|

et4U.com

DataSheet4U.com

DataShe

DataSheet4U.com

## 10.3.4 PPG Reload Registers (PRLL0/PRLH0, PRLL1/PRLH1)

The value (reload value) from which the PPG down counter starts counting is set in the PPG reload registers, which are an 8-bit register at Low level and an 8-bit register at High level.

#### PPG Reload Registers (PRLL0/PRLH0, PRLL1/PRLH1)



#### Figure 10.3-5 PPG Reload Registers (PRLL0/PRLH0, PRLL1/PRLH1)

Table 10.3-5 indicates the functions of the PPG reload registers.

#### Table 10.3-5 Functions of PPG Reload Registers

| Function                                | 8-/16-bit PPG Timer 0 | 8-/16-bit PPG Timer 1 |
|-----------------------------------------|-----------------------|-----------------------|
| Retains reload value on Low-level side  | PRLLO                 | PRLL1                 |
| Retains reload value on High-level side | PRLH0                 | PRLH1                 |

Notes:

et4U.com

• In the 16-bit PPG output operation mode (PPGC1: MD1, MD0 = " $11_B$ "), use a long-word instruction to set the PPG reload registers or the word instruction to set the PPG0 and PPG1 in this order.

• In the 8 + 8-bit PPG output operation mode (PPGC1: MD1, MD0 = "01<sub>B</sub>"), set the same value in both the Low-level and High-level PPG reload registers (PRTLL0/PRLH0) of the 8-/16-bit PPG timer 0. Setting a different value in the Low-level and High-level PPG reload registers may cause the 8-/16-bit PPG timer 1 to have different PPG output waveforms at each clock cycle.

## 10.4 Interrupts of 8-/16-bit PPG Timer

# The 8-/16-bit PPG timer can generate an interrupt request when the PPG down counter underflows. It corresponds to the EI<sup>2</sup>OS.

#### ■ Interrupts of 8-/16-bit PPG Timer

Table 10.4-1 shows the interrupt control bits and interrupt factor of the 8-/16-bit PPG timer.

#### Table 10.4-1 Interrupt Control Bits of 8-/16-bit PPG Timer

|                              | PPG0                           | PPG1                           |
|------------------------------|--------------------------------|--------------------------------|
| Interrupt request flag bit   | PPPGC0: PUF0                   | PPGC1: PUF1                    |
| Interrupt request enable bit | PPGC0: PIE0                    | PPGC1: PIE1                    |
| Interrupt factor             | Underflow in PPG0 down counter | Underflow in PPG1 down counter |

#### [8-bit PPG output 2-channel independent operation mode or 8 + 8-bit PPG output operation mode]

- In the 8-bit PPG output 2-channel independent operation mode or the 8 + 8-bit PPG output operation mode, the PPG0 and PPG1 timers can generate an interrupt independently.
- When the value of the PPG0 or PPG1 down counter is decremented from " $00_{\text{H}}$ " to "FF<sub>H</sub>", an underflow occurs. When an underflow occurs, the underflow generation flag bit in the channel causing an underflow is set (PPGC0: PUF0 = 1 or PPGC1: PUF1 = 1).

• If an interrupt request from the channel that causes an underflow is enabled (PPGC0: PIE0 = 1 or PPGC1: PIE1 = 1), an interrupt request is generated.

#### [16-bit PPG output operation mode]

- In the 16-bit PPG output operation mode, when the values of the PPG0 and PPG1 down counters are decremented from " $0000_{\text{H}}$ " to "FFFF<sub>H</sub>", an underflow occurs. When an underflow occurs, the underflow generation flag bits in the two channels are set at one time (PPGC0: PUF0 = 1 and PPGC1: PUF1 = 1).
- When an underflow occurs with either of the two channel of the interrupt requests enabled (PPGC0: PIE1 = 0, PPGC1: PIE1 = 1 or PPGC0: PIE1 = 1, PPGC1: PIE1 = 0), an interrupt request is generated.
- To prevent duplication of interrupt requests, disable either of the two channel of the underflow interrupt enable bits (PPGC0: PIE1 = 0, PPGC1: PIE1 = 1 or PPGC0: PIE1 = 1, PPGC1: PIE1 = 0).
- When the two channels of the underflow generation flag bits are set (PPGC0: PUF0 = 1 and PPGC1: PUF1 = 1), clear the two channels at the same time.

#### ■ Correspondence between 8-/16-bit PPG Timer Interrupt and El<sup>2</sup>OS

For details of the interrupt number, interrupt control register, and interrupt vector address, see "3.5 Interrupt".

## ■ 8-/16-bit PPG Timer Interrupt and El<sup>2</sup>OS Function

The 8-/16-bit PPG timer corresponds to the  $EI^2OS$  function. Generation of an enabled interrupt factor starts the  $EI^2OS$ . However, it is necessary to disable generation of interrupt requests by resources sharing the interrupt control register (ICR) with the 8-/16-bit PPG timer.

et4U.com

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

## 10.5 Explanation of Operation of 8-/16-bit PPG Timer

# The 8-/16-bit PPG timer outputs a pulse width at any frequency and at any duty ratio continuously.

#### ■ Operation of 8-/16-bit PPG Timer

• Output operation of 8-/16-bit PPG timer

- The 8-/16-bit PPG timer has two (Low-level and High-level) 8-bit reload registers (PRLL0/PRLH0 and PRLL1/PRLH1) for each channel.
- The values set in the 8-bit reload registers (PRLL0/PRLH0 and PRLL1/PRLH1) are reloaded alternately to the PPG down counters (PCNT0 and PCNT1).
- After reloading the values in the PPG down counters, decrementing is performed in synchronization with the count clocks set by the PPG count clock select bits (PPG01: PCM2 to PCM0 and PCS1 and PCS0).
- If the values set in the reload registers are reloaded to the PPG down counters when an underflow occurs, the pin output is inverted.

Figure 10.5-1 shows the output waveform of the 8-/16-bit PPG timer.

 Operation start
 Operation stop

 PPG operation enable bit (PEN)
 I 

 PPG output pin
 I 

  $T \times (L + 1)$   $T \times (H + 1)$  

 L : Value of PPG reload register (PRLL)

 H : Value of PPG reload register (PRLH)

 T : Count clock cycle

#### Figure 10.5-1 Output Waveform of 8-/16-bit PPG Timer

DataShe

#### • Operation modes of 8-/16-bit PPG timer

As long as the operation of the 8-/16-bit PPG timer is enabled (PPGC0: PEN0 = 1, PPGC1: PEN1 = 1), a pulse waveform is output continuously from the PPG output pin. A pulse width of any frequency and duty ratio can be set.

The pulse output of the 8-/16-bit PPG timer is not stopped until operation of the 8-/16-bit PPG timer is stopped (PPGC0: PEN0 = 0, PPGC1: PEN1 = 0).

- 8-bit PPG output 2-channel independent operation mode
- 16-bit PPG output operation mode
- 8 + 8-bit PPG output operation mode

DataSheet4U.com

et4U.com

#### 10.5.1 8-bit PPG Output 2-channel Independent Operation Mode

In the 8-bit PPG output 2-channel independent operation mode, the 8-/16-bit PPG timer is set as an 8-bit PPG timer with two independent channels. PPG output operation and interrupt request generation can be performed independently for each channel.

#### Setting for 8-bit PPG Output 2-channel Independent Operation Mode

Operating the 8-/16-bit PPG timer in the 8-bit PPG output 2-channel independent operation mode requires the setting shown in Figure 10.5-2.

|                                                                                             | bit15 | 14  | 13     | 12     | 11      | 10              | 9              | bit8         | bit7 | 6    | 5      | 4        | 3       | 2        | 1     | bitC       |
|---------------------------------------------------------------------------------------------|-------|-----|--------|--------|---------|-----------------|----------------|--------------|------|------|--------|----------|---------|----------|-------|------------|
| PPGC1/PPGC0                                                                                 | PEN1  | -   | PE1    | PIE1   | PUF1    | MD1             | MD0            | Reser<br>ved | PEN0 | -    | PE0    | PIE0     | PUF0    | -        | -     | Res<br>vec |
|                                                                                             | 1     |     | Ø      | Ø      | O       | 0               | 0              | 1            | 1    |      | O      | O        | O       |          |       | 1          |
| PPG01                                                                                       |       |     | (F     | Reserv | ed are  | a)              |                |              | PCS2 | PCS1 | PCS0   | PCM<br>2 | PCM     | PCM<br>0 | -     | -          |
|                                                                                             | •     |     |        |        |         |                 |                | 1            | O    | O    | O      | 0        | Ô       | Ø        |       | _1         |
| PRLH0/PRLL0                                                                                 | PF    | PG0 | Set Hi | gh lev | el side | reload          | l value        | s.           | Р    | PG0  | Set Lo | w leve   | el side | reload   | value | es.        |
| PRLH1/PRLL1                                                                                 | PF    | PG1 | Set Hi | gh lev | el side | DataS<br>reload | heet/<br>Value | IU.cor<br>s. |      | PG1  | Set Lo | w leve   | el side | reload   | value | es.        |
| <ul> <li>© : Used bit</li> <li>-: Unused bit</li> <li>1: Set 1</li> <li>0: Set 0</li> </ul> |       |     |        |        |         |                 |                |              |      |      |        |          |         |          |       |            |

Figure 10.5-2 Setting for 8-bit PPG Output 2-channel Independent Operation Mode

Note:

Use the word instruction to set both High-level and Low-level PPG reload registers (PRLL0/PRLH0 and PRLL1/PRLH1) at the same time.

www.DataSheet4U.com

Operation in 8-bit PPG output 2-channel independent operation mode

- The 8-bit PPG timer with two channels performs an independent PPG operation.
- When the pin output is enabled (PPGC0: PE0 = 1, PPGC1: PE1 = 1), the PPG0 pulse wave is output from the PPG0 pin and the PPG1 pulse wave is output from the PPG1 pin.
- When the reload value is set in the PPG reload registers (PRLL0/PRLH0 and PRLL1/PRLH1) to enable the operation of the PPG timer (PPGC0: PEN0 = 1, PPGC1: PEN1 = 1), the PPG down counter of the enabled channel starts counting.
- To stop the count operation of the PPG down counter, disable the operation of the PPG timer of the channel to be stopped (PPGC0: PEN0 = 0, PPGC1: PEN1 = 0). The count operation of the PPG down counter is stopped and the output of the PPG output pin is held at a Low level.
- When the PPG down counter of each channel underflows, the reload values set in the PPG reload registers (PRLL0/PRLH0 and PRLL1/PRLH1) are reloaded to the PPG down counter that underflows.
- When an underflow occurs, the underflow generation flag bit in the channel that causes an underflow is set (PPGC0: PUF0 = 1, PPGC1: PUF1 = 1). If an interrupt request is enabled at the channel that causes an underflow (PPGC0: PIE0 = 1, PPGC1: PIE1 = 1), the interrupt request is generated.
- Output waveform in 8-bit PPG output 2-channel independent operation mode
  - The High and Low pulse widths to be output are determined by adding 1 to the value in the PPG reload register and multiplying it by the count clock cycle. For example, if the value in the PPG reload register is " $00_{\text{H}}$ ", the pulse width has one count clock cycle, and if the value is "FF<sub>H</sub>", the pulse width has 256 count clock cycles.

DataShe

The equations for calculating the pulse width are shown below:

 $P_{L} = T x (L + 1)$ 

 $\mathbf{P}_{\mathbf{H}} = \mathbf{T} \mathbf{x} (\mathbf{H} + 1)$ 

P<sub>L</sub>: Low width of output pulse

P<sub>H</sub>: High width of output pulse

L: Values of 8 bits in PPG reload register (PRLL0 or PRLL1)

H: Values of 8 bits in PPG reload register (PRLH0 or PRLH1)

T: Count clock cycle

Figure 10.5-3 shows the output waveform in the 8-bit PPG output 2-channel independent operation mode.

#### Figure 10.5-3 Output Waveform in 8-bit PPG Output 2-channel Independent Operation Mode



DataSheet4U.com

et4U.com

### 10.5.2 16-bit PPG Output Operation Mode

# In the 16-bit PPG output operation mode, the 8-/16-bit PPG timer is set as a 16-bit PPG timer with one channel.

### Setting for 16-bit PPG Output Operation Mode

Operating the 8-/16-bit PPG timer in the 16-bit PPG output operation mode requires the setting shown in Figure 10.5-4.

| PPGC1/PPGC0          | bit15<br>PEN1 | 14    | 13<br>PE1 | 12<br>PIE1 | 11<br>PUF1 | 10<br>MD1 | 9<br>MD0 | bit8<br>Reser | bit7<br>PEN0 | 6     | 5<br>PE0   | 4<br>PIE0  | 3<br>PUF0 | 2        | 1       | bit<br>Res |
|----------------------|---------------|-------|-----------|------------|------------|-----------|----------|---------------|--------------|-------|------------|------------|-----------|----------|---------|------------|
|                      | I LINI        | _     |           |            |            |           | WDU      | ved           | -            | _     |            |            |           | _        |         | veo        |
|                      | 1             |       | O         | 0          | O          | 1         | 1        | 1             | 1            |       | Ø          | O          | Ô         |          |         | 1          |
| PPG01                |               |       | (F        | Reserv     | ved are    | a)        |          |               | PCS2         | PCS1  | PCS0       | PCM<br>2   | PCM       | PCM<br>0 | _       | _          |
|                      |               |       |           |            |            |           |          |               | Х            | Х     | Х          | ©          | Ô         | Ô        |         |            |
| PRLH1/PRLL1          | PPG           | 1 Set | high lev  | el side i  | reload va  | lues of   | upper 8  | bits.         | PP           | G1 Se | t low leve | el side re | eload val | ues of u | ipper 8 | bits.      |
| ©: Used bit          |               |       |           |            |            | Data      | Shee     | t4U.c         | om           |       |            |            |           |          |         |            |
| X: Undefined bit     | t             |       |           |            |            |           |          |               |              |       |            |            |           |          |         |            |
| -: Unused bit        |               |       |           |            |            |           |          |               |              |       |            |            |           |          |         |            |
| 1: Set 1<br>0: Set 0 |               |       |           |            |            |           |          |               |              |       |            |            |           |          |         |            |
|                      |               |       |           |            |            |           |          |               |              |       |            |            |           |          |         |            |
|                      |               |       |           |            |            |           |          |               |              |       |            |            |           |          |         |            |

### Figure 10.5-4 Setting for 16-bit PPG Output Operation Mode

Use a long-word instruction to set the values in the PPG reload registers or a word instruction to set the PPG0 and PPG1 (PRLL0 --> PRLL1 or PRLH0 --> PRLH1) in this order.

et4U.com

| ration in 16-bit PPG output operation mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| • When either PPG0 pin output or PPG1 pin output is enabled (PPGC0: PE0 = 1, PPGC1: PE1 = 1), the same pulse wave is output from both the PPG0 and PPG1 pins.                                                                                                                                                                                                                                                                                                                                                                                                         |
| • When the reload value is set in the PPG reload registers (PRLL0/PRLH0 and PRLL1/PRLH1) to enable operation of the PPG timer (PPGC0: PEN0 = 1 and PPGC1: PEN1 = 1) simultaneously, the PPG down counters start counting as 16-bit down counters (PCNT0 + PCNT1).                                                                                                                                                                                                                                                                                                     |
| • To stop the count operation of the PPG down counters, disable the operation of the PPG timers of bot channels (PPGC0: PEN0 = 0 and PPGC1: PEN1 = 0) simultaneously. The count operation of the PPG down counters is stopped and the output of the PPG output pin is held at a Low level.                                                                                                                                                                                                                                                                            |
| • If the PPG1 down counter underflows, the reload values set in the PPG0 and PPG1 reload register (PRLL0/PRLH0 and PRLL1/PRLH1) are reloaded simultaneously to the PPG down counters (PCNT0 PCNT1).                                                                                                                                                                                                                                                                                                                                                                   |
| • When an underflow occurs, the underflow generation flag bits in both channels are set simultaneousl (PPGC0: PUF0 = 1, PPGC1: PUF1 = 1). If an interrupt request is enabled at either channel (PPGC0: PIE0 = 1, PPGC1: PIE1 = 1), an interrupt request is generated.                                                                                                                                                                                                                                                                                                 |
| <ul> <li>In the 16-bit PPG output operation mode, the underflow generation flag bits in the two channels are set simultaneously when an underflow occurs (PPGC0: PUF0 = 1 and PPGC1: PUF1 = 1). To prevent duplication of interrupt requests, disable either of the underflow interrupt enable bits in the two channels (PPGC0: PIE0 = 0, PPGC1: PIE1 = 1 or PPGC0: PIE0 = 1, PPGC1: PIE1 = 0).</li> <li>If the underflow generation flag bits in the two channels are set (PPGC0: PUF0 = 0 and PPGC1: PUF1 = 0), clear the two channels at the same time.</li> </ul> |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

DataSheet4U.com

DataSheet4U.com

et4U.com

www.DataSheet4U.com

### CHAPTER 10 8-/16-BIT PPG TIMER

#### Output waveform in 16-bit PPG output operation mode

• The High and Low pulse widths to be output are determined by adding 1 to the value in the PPG reload register and multiplying it by the count clock cycle. For example, if the value in the PPG reload register is " $0000_{\text{H}}$ ", the pulse width has one count clock cycle, and if the value is "FFFF<sub>H</sub>", the pulse width has 65,536 count clock cycles.

The equations for calculating the pulse width are shown below:

PL=T x (L+1)

PH=T x (H+1)

PL: Low width of output pulse

PH: High width of output pulse

L: Values of 16 bits in PPG reload register (PRLL0 + PRLL1)

H: Values of 16 bits in PPG reload register (PRLH0 + PRLH1)

T: Count clock cycle

Figure 10.5-5 shows the output waveform in the 16-bit PPG output operation mode.

#### Figure 10.5-5 Output Waveform in 16-bit PPG Output Operation Mode



DataShe

et4U.com

### 10.5.3 8+8-bit PPG Output Operation Mode

In the 8+8-bit PPG output operation mode, the 8-/16-bit PPG timer is set as an 8-bit PPG timer. The PPG0 operates as an 8-bit prescaler and the PPG1 operates using the PPG output of the PPG0 as a clock source.

### Setting for 8+8-bit PPG Output Operation Mode

Operating the 8-/16-bit PPG timer in the 8+8-bit PPG output operation mode requires the setting shown in Figure 10.5-6.

| PPGC1/PPGC0                                   | bit15<br>PEN1 | 14  | 13<br>PE1 | 12<br>PIE1 | 11<br>PUF1 | 10<br>MD1 | 9<br>MD0 | bit8<br>Reser | bit7<br>PEN0 | 6    | 5<br>PE0 | 4<br>PIE0 | 3<br>PUF0 | 2        | 1     | TF  |
|-----------------------------------------------|---------------|-----|-----------|------------|------------|-----------|----------|---------------|--------------|------|----------|-----------|-----------|----------|-------|-----|
| 1100//11000                                   |               |     |           |            | 1 01 1     |           | MEO      | ved           | 1 EINO       |      | 1 20     | 1 120     | 1 01 0    |          |       |     |
|                                               | 1             |     | O         | O          | O          | 0         | 1        | 1             | 1            |      | O        | O         | O         |          |       |     |
| PPG01                                         | ,<br>,<br>,   |     | (F        | Reserv     | ed are     | a)        |          |               | PCS2         | PCS1 | PCS0     | PCM<br>2  | PCM       | PCM<br>0 | -     | Τ   |
|                                               | •             |     |           |            |            |           |          |               | X            | Х    | Х        | 0         | 0         | ©        |       |     |
| PRLH1/PRLL1                                   | PF            | °G1 | Set Hi    | gh lev     | el side    | reload    | d value  | s.            | P            | PG1  | Set Lo   | w leve    | el side   | reload   | value | es. |
| © : Used bit                                  |               |     |           |            |            |           |          |               | •            |      |          |           |           |          |       |     |
| X: Undefined bi                               | t             |     |           |            |            |           |          |               |              |      |          |           |           |          |       |     |
| <ul> <li>Unused bit</li> <li>Set 1</li> </ul> |               |     |           |            |            |           |          |               |              |      |          |           |           |          |       |     |
| 0: Set 0                                      |               |     |           |            |            |           |          |               |              |      |          |           |           |          |       |     |
|                                               |               |     |           |            |            |           |          |               |              |      |          |           |           |          |       |     |

DataSheet4U.com

### CHAPTER 10 8-/16-BIT PPG TIMER

| •      | Operation in 8+8-bit PPG output operation mode                                                                                                                                                                                                                                                     |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | • The PPG0 operates as the prescaler of the PPG1 timer and the PPG1 operates using the PPG0 output a a count clock.                                                                                                                                                                                |
|        | • When pin output is enabled (PPGC0: PE0 = 1, PPGC1: PE1 = 1), the PPG0 pulse wave is output from the PPG0 pin and the PPG1 pulse wave is output form the PPG1 pin.                                                                                                                                |
|        | • When the reload value is set in the PPG reload registers (PRLL0/PRLH0, PRLL1/PRLH1) to enable operation of the PPG timer (PPGC0: PEN0 = 1 and PPGC1: PEN1 = 1), the PPG down counter starts counting.                                                                                            |
|        | • To stop the count operation of the PPG down counters, disable the operation of the PPG timers of both channels (PPGC0: PEN0 = 0 and PPGC1: PEN1 = 0) at the same time. The count operation of the PPG down counters is stopped and the output of the PPG output pin is held at a Low level.      |
|        | • If the PPG down counter of each channel underflows, the reload values set in the PPG reload registers (PRLL0/PRLH0, PRLL1/PRLH1) are reloaded to the PPG down counter that underflows.                                                                                                           |
|        | • When an underflow occurs, the underflow generation flag bit in the channel that causes an underflow (PPGC0: PUF0 = 1, PPGC1: PUF1 = 1) is set. If an interrupt request is enabled at the channel that causes an underflow (PPGC0: PIE0 = 1, PPGC1: PIE1 = 1), an interrupt request is generated. |
| Notes: | <ul> <li>Do not operate PPG1 (PPGC1: PEN1 = 1) when PPG0 is stopped (PPGC0: PEN0 = 0).</li> <li>It is recommended to set the same value in both Low-level and High-level PPG reload registers (PRLL0/PRLH0, PRLL1/PRLH1).</li> </ul>                                                               |

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

Output waveform in 8+8-bit PPG output operation mode

• The High and Low pulse widths to be output are determined by adding 1 to the value in the PPG reload register and multiplying it by the count clock cycle.

The equations for calculating the pulse width are shown below:

 $PL = T x (L_0 + 1) x (L_1 + 1)$ 

 $PH = T x (H_0 + 1) x (H_1 + 1)$ 

PL: Low width of output pulse of PPG1 pin

PH: High width of output pulse of PPG1 pin

L<sub>0</sub>: Values of 8 bits in PPG reload register (PRLL0)

H<sub>0</sub>: Values of 8 bits in PPG reload register (PRLH0)

L<sub>1</sub>: Values of 8 bits in PPG reload register (PRLL1)

H<sub>1</sub>: Values of 8 bits in PPG reload register (PRLH1)

T: Count clock cycle

Figure 10.5-7 shows the output waveform in the 8+8-bit PPG output operation mode.



#### Figure 10.5-7 Output Waveform in 8+8-bit PPG Output Operation Mode

### 10.6 Precautions when Using 8-/16-bit PPG Timer

### This section explains the precautions when using the 8-/16-bit PPG timer.

### Precautions when Using 8-/16-bit PPG Timer

- Effect on 8-/16-bit PPG timer when using timebase timer output
  - If the output signal of the timebase timer is used as the input signal for the count clock of the 8-/16-bit PPG timer (PPG01: PCM2 to PCM0 = " $111_B$ ", PCS2 to PCS0 = " $111_B$ "), deviation may occur in the first count cycle in which the PPG timer is started by trigger input or in the count cycle immediately after the PPG timer is stopped.
  - When the timebase timer counter is cleared during the count operation of the PPG down counter, deviation may occur in the count cycle.
- Setting of PPG reload registers when using 8-bit PPG timer
  - The Low-level and High-level pulse widths are determined at the timing of reloading the values in the Low-level PPG reload registers (PRLL0, PRLL1) to the PPG down counter.
  - If the 8-bit PPG timer is used in the 8-bit PPG output 2-channel independent operation mode or the 8 + 8-bit PPG output operation mode, use a word instruction to set both High-level and Low-level PPG reload registers (PRLL0/PRLH0, PRLL1/PRLH1) at the same time.

DataShe

www.DataSheet4U.com

Using a byte instruction may cause an unexpected pulse to be generated.

#### [Example of rewriting PPG reload registers using byte instruction]

Immediately before the signal level of the PPG pin switches from High to Low, if the value in the Highlevel PPG reload register (PRLH) is rewritten after the value in the Low-level PPG reload register (PRLL) is rewritten using the byte instruction, a Low-level pulse width is generated after rewriting and a High-level pulse width is generated before rewriting.

Figure 10.6-1 shows the waveform as the values in the PPG reload registers are rewritten using the byte instruction.





DataSheet4U.com

et4U.com

316

### Setting of PPG reload registers when using 16-bit PPG timer

• Use a long-word instruction to set the PPG reload registers (PRLL0/PRLH0, PRLL1/PRLH1) or a word instruction to set the PPG0 and PPG1 (PRLL0 --> PRLL1 or PRLH0 --> PRLH1) in this order.

### [Reload timing in 16-bit PPG output operation mode]

In the 16-bit PPG output operation mode, the reload values written to the PPG0 reload registers (PRLL0/PRLH0) are written temporarily to the temporary latch, written to the PPG1 reload registers (PRLL1/PRLH1), and then transferred to the PPG0 reload registers (PRLL0/PRLH0). Therefore, when setting the reload value in the PPG1 reload registers (PRLL1/PRLH1), it is necessary to set the reload value in the PPG0 reload registers (PRLL0/PRLH0) simultaneously or set the reload value in the PPG0 reload registers (PRLL0/PRLH0) before setting it in the PPG1 reload registers (PRLL1/PRLH1).

Figure 10.6-2 shows the reload timing in the 16-bit PPG output operation mode.

#### Figure 10.6-2 Reload Timing in 16-bit PPG Output Operation Mode



DataShe

et4U.com

317

### CHAPTER 10 8-/16-BIT PPG TIMER

et4U.com

DataSheet4U.com

DataSheet4U.com

318

DataSheet4U.com

DataShe

# CHAPTER 11 DELAYED INTERRUPT GENERATION MODULE

This chapter explains the functions and operations of the delayed interrupt generation module.

et4U.com

- 11.1 Overview of Delayed Interrupt Generation Module
- 11.2 Block Diagram of Delayed Interrupt Generation Module
- 11.3 Configuration of Delayed Interrupt Generation Module
- 11.4 Explanation of Operation of Delayed Interrupt Generation Module
- 11.5 Precautions when Using Delayed Interrupt Generation Module
- 11.6 Program Example of Delayed Interrupt Generation Module

CHAPTER 11 DELAYED INTERRUPT GENERATION MODULE

### 11.1 Overview of Delayed Interrupt Generation Module

### The delayed interrupt generation module generates the interrupt for task switching. The hardware interrupt request can be generated/cancelled by software.

### Overview of Delayed Interrupt Generation Module

By using the delayed interrupt generation module, a hardware interrupt request can be generated or cancelled by software.

Table 11.1-1 shows the overview of the delayed interrupt generation module.

Table 11.1-1 Overview of Delayed Interrupt Generate Module

|                    | Function and Control                                                                                                                                                                                                                                                                   |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Interrupt factor   | An interrupt request is generated by setting the R0 bit in the delayed interrupt request generate/cancel register to 1 (DIRR: $R0 = 1$ ).<br>An interrupt request is cancelled by setting the R0 bit in the delayed interrupt request generate/cancel register to 0 (DIRR: $R0 = 0$ ). |
| Interrupt number   | #42 (2A <sub>H</sub> )                                                                                                                                                                                                                                                                 |
| Interrupt control  | An interrupt is not enabled by the DIRR register.                                                                                                                                                                                                                                      |
| Interrupt flag     | The interrupt flag is held in the R0 bit in the DIRR register.                                                                                                                                                                                                                         |
| EI <sup>2</sup> OS | The DIRR register does not correspond to the EI <sup>2</sup> OS.                                                                                                                                                                                                                       |

et4U.com

www.DataSheet4U.com

### 11.2 Block Diagram of Delayed Interrupt Generation Module

The delayed interrupt generation module consists of the following blocks:

- Interrupt request latch
- Delayed interrupt request generate/cancel register (DIRR)

### Block Diagram of Delayed Interrupt Generation Module

Figure 11.2-1 Block Diagram of Delayed Interrupt Generation Module



#### Interrupt request latch

This latch keeps the settings (delayed interrupt request generation or cancellation) of the delayed interrupt request generate/cancel register (DIRR).Sheet4U.com

Delayed interrupt request generate/cancel register (DIRR)

This register generates or cancels a delayed interrupt request.

### Interrupt Number

The interrupt number used in the delayed interrupt generation module is as follows:

Interrupt number #42  $(2A_H)$ 

et4U.com

CHAPTER 11 DELAYED INTERRUPT GENERATION MODULE

### 11.3 Configuration of Delayed Interrupt Generation Module

This section lists registers and reset values in the delayed interrupt generation module.

■ List of Registers and Reset Values in Delayed Interrupt Generation Module

### Figure 11.3-1 List of Registers and Reset Values in Delayed Interrupt Generation Module

| bit                                                        | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
|------------------------------------------------------------|----|----|----|----|----|----|---|---|
| Delayed interrupt request generate/ cancel register (DIRR) | Х  | Х  | Х  | Х  | Х  | Х  | Х | 0 |
| X: Undefined                                               |    |    |    |    |    |    |   |   |

et4U.com

DataSheet4U.com

DataShe

DataSheet4U.com

322

### 11.3.1 Delayed Interrupt Request Generate/Cancel Register (DIRR)

The delayed interrupt request generate/cancel register (DIRR) generates or cancels a delayed interrupt request.

### Delayed Interrupt Request Generate/Cancel Register (DIRR)



et4U.com

DataShe

### Table 11.3-1 Functions of Delayed Interrupt Request Generate/Cancel Register (DIRR)

|                 | Bit Name                                         | Function                                                                                                                                                             |
|-----------------|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 8           | R0:<br>Delayed interrupt request<br>generate bit | This bit generates or cancels a delayed interrupt request.<br>When set to 0: Cancels delayed interrupt request<br>When set to 1: Generates delayed interrupt request |
| bit 9 to bit 15 | Unused bits                                      | Read: The value is undefined<br>Write: No effect                                                                                                                     |

### 11.4 Explanation of Operation of Delayed Interrupt Generation Module

# The delayed interrupt generation module has a function for generating or canceling an interrupt request by software.

### Explanation of Operation of Delayed Interrupt Generation Module

Using the delayed interrupt generation module requires the setting shown in Figure 11.4-1.

Figure 11.4-1 Setting for Delayed Interrupt Generation Module

|               | bit15 | 14 | 13 | 12 | 11 | 10 | 9 | bit8    |   |
|---------------|-------|----|----|----|----|----|---|---------|---|
| PDIRR         | -     | -  | -  | -  | -  | -  | - | R0      |   |
|               |       |    |    |    |    |    | • | $\odot$ | • |
| -: Unused bit |       |    |    |    |    |    |   |         |   |
| : ©:Used bit  |       |    |    |    |    |    |   |         |   |

When the R0 bit in the delayed interrupt request generate/cancel register (DIRR) is set to 1 (DIRR: R0 = 1), an interrupt request is generated. There is no interrupt request enable bit.

et4U.com

### • Operation of delayed interrupt generation module

DataShe

www.DataSheet4U.com

- When the R0 bit in the delayed interrupt request generate/cancel register (DIRR) is set to 1, the interrupt request latch is set to 1 and an interrupt request is generated to the interrupt controller.
- When an interrupt request is preferred to other requests by the interrupt controller, the interrupt request is generated to the CPU.
- When the level of an interrupt request (ICR: IL) is preferred to that of the interrupt level mask bit (ILM) in the processor status (PS), the CPU delays interrupt processing until completion of execution of the current instruction.
- At interrupt processing, the user program sets the R0 bit to 0, cancels the interrupt request, and changes the task.

Figure 11.4-2 shows the operation of the delayed interrupt generation module.

### Figure 11.4-2 Operation of Delayed Interrupt Generation Module



DataSheet4U.com

324

### 11.5 Precautions when Using Delayed Interrupt Generation Module

This section explains the precautions when using the delayed interrupt generation module.

### Precautions when Using Delayed Interrupt Generation Module

- The interrupt processing is restarted at return from interrupt processing without setting the R0 bit in the delayed interrupt request generate/cancel register (DIRR) to 0 within the interrupt processing routine.
- Unlike software interrupts, interrupts in the delayed interrupt generation module are delayed.

et4U.com

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

CHAPTER 11 DELAYED INTERRUPT GENERATION MODULE

### 11.6 Program Example of Delayed Interrupt Generation Module

This section gives a program example of the delayed interrupt generation module.

### Program Example of Delayed Interrupt Generation Module

Processing specifications

The main program writes 1 to the R0 bit in the delayed interrupt request generate/cancel register (DIRR), generates a delayed interrupt request, and changes the task.

Coding example

et4U.com

```
ICR15EQU0000BFH; Interrupt control registerDIRREQU00009FH; Delayed interrupt request generate/cancel registerDIRR_R0EQUDIRR:0; Delayed interrupt request generate bit
;-----Main program-----
CODE CSEG
START: ; Stack pointer (SP) already initialized
AND CCR,#0BFH ; Interrupt disabled
MOV I:ICR15,#00H ; Interrupt level 0 (highest)
MOV ILM,#07H ; ILM in PS set to level 7
OR CCR, #40H ; Interrupt enabled
SETB I:DIRR_R0 ; Delayed interrupt request generated
LOOP MOV A,#00H ; Infinite loop
MOV A.#01H
                                                                                                  DataShe
        MOV A,#01H
         BRA LOOP
;-----Interrupt program------
WARI:
        CLRB I:DIRR_R0 ; Interrupt request flag cleared
          :
         Processing by user
;
          :
;
         RETI
                                ; Return from interrupt
CODE
         ENDS
;-----Vector setting------
VECT CSEG ABS=0FFH
         ORG 00FF54H
                                ; Vector set to interrupt #42 (2AH)
         DSL WARI
         ORG OFFDCH ; Reset vector set
         DSL START
                        ; Set to single-chip mode
         DB 00H
         ENDS
VECT
         END START
```

# CHAPTER 12 DTP/EXTERNAL INTERRUPT

This chapter explains the functions and operations of DTP/external interrupt.

- 12.1 Overview of DTP/External Interrupt
- 12.2 Block Diagram of DTP/External Interrupt
- 12.3 Configuration of DTP/External Interrupt
- 12.4 Explanation of Operation of DTP/External Interrupt
- 12.5 Precautions when Using DTP/External Interrupt
- 12.6 Program Example of DTP/External Interrupt Circuit

et4U.com

DataSheet4U.com

www.DataSheet4U.com

### CHAPTER 12 DTP/EXTERNAL INTERRUPT

#### **Overview of DTP/External Interrupt** 12.1

The DTP/external interrupt sends interrupt requests from external peripheral devices or data transfer requests to the CPU to generate an external interrupt request, or starts the El<sup>2</sup>OS. RX input of CAN controller can be used as external interrupt input.

### DTP/External Interrupt Function

The interrupt request inputted to external interrupt input pins (INT7 to INT4) and RX input from external peripheral devices generates an external interrupt request, or starts the EI<sup>2</sup>OS as an interrupt request from peripheral function.

If the  $EI^2OS$  is disabled in the interrupt control register (ICR: ISE = 0), the external interrupt function is enabled, branching to interrupt processing.

If the  $EI^2OS$  is enabled (ICR: ISE = 1), the DTP function is enabled and automatic data transfer is performed, branching to interrupt processing after the completion of data transfer for the specified number of times.

Table 12.1-1 shows an overview of the DTP/external interrupt.

Table 12.1-1 Overview of DTP/External Interrupt

|                      | External Interrupt                                                                                        | DTP Function                                                                                                                                                          |  |  |  |  |  |
|----------------------|-----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Input pin            | 5 pins (RX, INT4 to INT7)                                                                                 |                                                                                                                                                                       |  |  |  |  |  |
|                      | The interrupt factor is set in unit of pins using the                                                     | ne detection level setting registers (ELVR).                                                                                                                          |  |  |  |  |  |
| Interrupt factor     | Input of High level, Low level,<br>rising edge, or falling edge                                           | Input of High level or Low level                                                                                                                                      |  |  |  |  |  |
| Interrupt number     | $\#15 (0F_{\rm H}), \#24 (18_{\rm H}), \#27 (1B_{\rm H})$                                                 |                                                                                                                                                                       |  |  |  |  |  |
| Interrupt control    | The interrupt request output is enabled/disabled using the DTP/external interrupt enable register (ENIR). |                                                                                                                                                                       |  |  |  |  |  |
| Interrupt flag       | The interrupt factor is held using the DTP/exter                                                          | nal interrupt factor register (EIRR)                                                                                                                                  |  |  |  |  |  |
| Processing selection | The EI <sup>2</sup> OS is disabled.<br>(ICR: ISE=0)                                                       | The EI <sup>2</sup> OS is enabled.<br>(ICR: ISE=1)                                                                                                                    |  |  |  |  |  |
| Processing contents  | A branch is caused to the external interrupt processing.                                                  | EI <sup>2</sup> OS performs auto data transfer and<br>completes the specified number of timer for<br>data transfers, causing a branch to the interrupt<br>processing. |  |  |  |  |  |

### 12.2 Block Diagram of DTP/External Interrupt

The block diagram of the DTP/external interrupt is shown below.

### Block Diagram of DTP/External Interrupt



### Figure 12.2-1 Block Diagram of DTP/External Interrupt

DataSheet4U.com

et4U.com

### CHAPTER 12 DTP/EXTERNAL INTERRUPT

### • DTP/external interrupt input detector

This circuit detects interrupt requests or data transfer requests generated from external peripheral devices.

The interrupt request flag bit corresponding to the pin whose level or edge set by the detection level setting register (ELVR) is detected is set to 1 (EIRR: ER).

### Detection level setting register (ELVR)

This register sets the level or edge of input signals from external peripheral devices that cause DTP/external interrupt factors.

### • DTP/external interrupt factor register (EIRR)

This register holds DTP/external interrupt factors.

If an enable signal is input to the DTP/external interrupt pin, the corresponding DTP/external interrupt request flag bit is set to 1.

• DTP/external interrupt enable register (ENIR)

This register enables or disables DTP/external interrupt requests from external peripheral devices.

### Details of Pins and Interrupt Numbers

Table 12.2-1 shows the pins and interrupt numbers used in the DTP/external interrupt.

#### et4U.com

### Table 12.2-1 Pins and Interrupt Numbers Used by DTP/External Interrupt

DataShe

| Pin      | DataSh <b>@hánne</b> tm | Interrupt Number       |  |  |
|----------|-------------------------|------------------------|--|--|
| P44/RX   | RX                      | #15 (0F <sub>H</sub> ) |  |  |
| P24/INT4 | 4                       | #24 (18 <sub>H</sub> ) |  |  |
| P25/INT5 | 5                       | π2+ (10H)              |  |  |
| P26/INT6 | 6                       | #27 (1B <sub>H</sub> ) |  |  |
| P27/INT7 | 7                       | #27 (IDH)              |  |  |

### 12.3 Configuration of DTP/External Interrupt

# This section lists and details the pins, interrupt factors, and registers in the DTP/ external interrupt.

### Pins of DTP/External Interrupt

The pins used by the DTP/external interrupt serve as general-purpose I/0 ports. Table 12.3-1 lists the pin functions and the pin setting required for use in the DTP/external interrupt

| Table 12.3-1 | Pins of DTP/External Interrupt |  |
|--------------|--------------------------------|--|
|              |                                |  |

| Pin Name | Pin Function                                      | Pin Settings Required for Use in<br>DTP/External Interrupt |
|----------|---------------------------------------------------|------------------------------------------------------------|
| P44/RX   | General-purpose I/O ports,<br>CAN reception input |                                                            |
| P24/INT4 |                                                   |                                                            |
| P25/INT5 | General-purpose I/O ports,                        | Set as input ports in port direction register (DDR)        |
| P26/INT6 | DTP external interrupt inputs                     |                                                            |
| P27/INT7 | Delegier (41)                                     |                                                            |

et4U.com

DataSheet4U.com

DataShe

### ■ Block Diagram of Pins

See "CHAPTER 4 I/O PORT" for the block diagram of pins.

### ■ List of Registers and Reset Values in DTP/External Interrupt

| Figure 12.3-1 | List of Registers and Reset Values in DTP/External Interrupt |
|---------------|--------------------------------------------------------------|
|---------------|--------------------------------------------------------------|

| bit                                           | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
|-----------------------------------------------|----|----|----|----|----|----|---|---|
| DTP/external interrupt factor register (EIRR) | Х  | Х  | Х  | Х  | Х  | Х  | Х | Х |
| bit                                           | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
| DTP/external interrupt enable register (ENIR) | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 |
| bit                                           | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Detection level setting register: High (ELVR) | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 |
| bit                                           | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
| Detection level setting register: Low (ELVR)  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 |
| X: Undefined                                  |    |    |    |    |    |    |   |   |
|                                               |    |    |    |    |    |    |   |   |

DataSheet4U.com

### 12.3.1 DTP/External Interrupt Factor Register (EIRR)

The DTP/external interrupt factor register (EIRR) holds DTP/external interrupt factors. When a valid signal is input to the DTP/external interrupt pin and the RX pin, the corresponding interrupt request flag bit is set to 1.

### ■ DTP/External Interrupt Factor Register (EIRR)



### Figure 12.3-2 DTP/External Interrupt Factor Register (EIRR)

et4U.com

### Table 12.3-2 Function of DTP/External Interrupt Factor Register (EIRR)

| Bit Name                   |                                                                 | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |
|----------------------------|-----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| bit 8,<br>bit 12 to bit 15 | ER7 to ER4, ER0:<br>DTP/External interrupt<br>request flag bits | These bits are set to 1 when the edges or level signals set by the detection<br>condition select bits in the detection level setting register (ELVR: LB, LA)<br>are input to the DTP/external interrupt pins and RX pin.<br>When set to 1: When the DTP/external interrupt request enable bit (ENIR:<br>EN) is set to 1, an interrupt request is generated to the corresponding DTP/<br>external interrupt channel.<br>When set to 0: Cleared<br>When set to 1: No effect<br>Note: Reading by read-modify-write type instructions always reads "1".<br>If more than one DTP/external interrupt request is enabled (ENIR:<br>EN = 1), clear only the bit in the channel that accepts an interrupt<br>(EIRR: $ER = 0$ ). No other bits must be cleared unconditionally.<br>Reference: When the $EI^2OS$ is started, the interrupt request flag bit is<br>automatically cleared after the completion of data transfer<br>(EIRR: $ER = 0$ ) |  |  |  |  |  |  |  |  |  |
| bit 9 to bit11             | Unused bit                                                      | Read: The value is undefined<br>Write: No effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |  |

### 12.3.2 DTP/External Interrupt Enable Register (ENIR)

The DTP/external interrupt enable register (ENIR) enables/disables the DTP/external interrupt request for external interrupt pins (INT7 to INT4) and the RX pin respectively.

### ■ DTP/External Interrupt Enable Register (ENIR)



et4U.com

DataSheet4U.com

### Table 12.3-3 Functions of DTP/External Interrupt Enable Register (ENIR)

| Bit Name                 |                                                                      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |
|--------------------------|----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| bit 0,<br>bit 4 to bit 7 | EN7 to EN4, EN0:<br>DTP/external<br>interrupt request<br>enable bits | The DTP/external interrupt enable register (ENIR) enables/disables the DTP/<br>external interrupt request for DTP/external interrupt pins (INT7 to INT4) and the<br>RX pin.<br>If the DTP/external interrupt request enable bit (ENIR: EN) and the DTP/external<br>interrupt request flag bit (EIRR: ER) are set to 1, the interrupt request is generated to<br>the corresponding DTP/external interrupt pins or the RX pin.<br><b>Reference:</b> The state of the DTP/external interrupt pin and the RX pin can be read<br>directly using the port data register irrespective of the setting of the<br>DTP/external interrupt request enable bit. |  |  |  |  |  |  |  |  |

| Table 12.3-4         Correspondence among DTP/External Interrupt Pins, DTP/External Interrupt |
|-----------------------------------------------------------------------------------------------|
| Request Flag Bits, and DTP/External Interrupt Request Enable Bits                             |

| DTP/External Interrupt Pins | DTP/External Interrupt<br>Request Flag Bits | DTP/External Interrupt<br>Request Enable Bits |  |  |  |  |
|-----------------------------|---------------------------------------------|-----------------------------------------------|--|--|--|--|
| RX                          | ER0                                         | EN0                                           |  |  |  |  |
| INT4                        | ER4                                         | EN4                                           |  |  |  |  |
| INT5                        | ER5                                         | EN5                                           |  |  |  |  |
| INT6                        | ER6                                         | EN6                                           |  |  |  |  |
| INT7                        | ER7                                         | EN7                                           |  |  |  |  |

DataSheet4U.com

www.DataSheet4U.com

### 12.3.3 Detection Level Setting Register (ELVR) (High)

The detection level setting register (High) sets the levels or edges of input signals that cause interrupt factors in INT7 to INT4 of the DTP/external interrupt pins.

### Detection Level Setting Register (ELVR) (High)



et4U.com

DataSheet4U.com

### Table 12.3-5 Functions of Detection Level Setting Register (ELVR) (High)

| Bit Name        |                                                             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
|-----------------|-------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| bit 8 to bit 15 | LB7, LA7 to LB4, LA4:<br>Detection condition<br>select bits | <ul> <li>These bits set the levels or edges of input signals from external peripheral devices that cause interrupt factors in the DTP/external interrupt pins.</li> <li>Two levels or two edges are selectable for external interrupts, and two levels are selectable for the EI<sup>2</sup>OS.</li> <li><b>Reference:</b> When the set detection signal is input to the DTP/external interrupt pins, the DTP/external interrupt request flag bits are set to 1 even if DTP/external interrupt requests are disabled (ENIR: EN = 0).</li> </ul> |  |  |  |  |  |  |  |

### Table 12.3-6 Correspondence between Detection Level Setting Register (ELVR) (High) and Channels

| DTP/External Interrupt Pin | Bit Name |
|----------------------------|----------|
| INT4                       | LB4, LA4 |
| INT5                       | LB5, LA5 |
| INT6                       | LB6, LA6 |
| INT7                       | LB7, LA7 |

www.DataSheet4U.com

DataShe

DataSheet4U.com

334

### 12.3.4 Detection Level Setting Register (ELVR) (Low)

The detection level setting register (ELVR) (Low) sets the levels or edges of input signals that cause interrupt factors in the RX pin.

### Detection Level Setting Register (ELVR) (Low)



### Figure 12.3-5 Detection Level Setting Register (ELVR) (Low)

DataShe

### Table 12.3-7 Functions of Detection Level Setting Register (ELVR) (Low)

| Bit Name       |                                                 | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0 to bit 1 | LB3, LA0:<br>Detection condition<br>select bits | <ul> <li>These bits set the levels or edges of input signals from external peripheral devices that cause interrupt factors in the RX pin.</li> <li>Two levels or two edges are selectable for external interrupts, and two levels are selectable for the EI<sup>2</sup>OS.</li> <li><b>Reference:</b> When the set detection signal is input to the RX pin, the DTP/ external interrupt request flag bits are set to 1 even if DTP/ external interrupt requests are disabled (ENIR: EN = 0).</li> </ul> |

## Table 12.3-8 Correspondence between Detection Level Setting Register (ELVR) (Low) and Channels

| DTP/External Interrupt Pin | Bit Name |
|----------------------------|----------|
| RX                         | LB0, LA0 |

DataSheet4U.com

et4U.com

#### **Explanation of Operation of DTP/External Interrupt** 12.4

### The DTP/external interrupt has an external interrupt function and a DTP function. The setting and operation of each function are explained.

### Setting of DTP/External Interrupt

Using the DTP/external interrupt requires, the setting shown in Figure 12.4-1.

|                                   |            | гig     | ure i      | Z.4-1  | Set      | ung d      | וסוכ  |            | terna         | imte          | inup          |               |               |               |               |      |
|-----------------------------------|------------|---------|------------|--------|----------|------------|-------|------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|------|
|                                   | bit15      | 14      | 13         | 12     | 11       | 10         | 9     | bit8       | bit7          | 6             | 5             | 4             | 3             | 2             | 1             | bit0 |
| ICR interrupt<br>control register | ICS3       | ICS2    | ICS1       | ICS0   | ISE      | IL2        | IL1   | ILO        | ICS3          | ICS2          | ICS1          | ICS0          | ISE           | IL2           | IL1           | IL0  |
| External interrup                 |            | -       | -          | -      | 0        | 0          | 0     | O          | -             | -             | -             | -             | 0             | 0             | O             | O    |
| DTF                               | <b>°</b> 0 | Ø       | O          | 0      | 1        | O          | Ø     | O          | O             | O             | Ø             | O             | 1             | O             | 0             | O    |
| EIRR/ENIR                         | ER7        | ER6     | ER5        | ER4    | -        | -          | -     | ER0        | EN7           | EN6           | EN5           | EN4           | Re-<br>served | Re-<br>served | Re-<br>served | ENC  |
|                                   | 0          | O       | 0          | 0      | -        | -          | -     | O          | 0             | 0             | 0             | 0             | 0             | 0             | 0             | 0    |
| ELVR                              | LB7        | LA7     | LB6        | LA6    | LB5      | LA5        | LB4   | LA4        | Re-<br>served | Re-<br>served | Re-<br>served | Re-<br>served | Re-<br>served | Re-<br>served | LB0           | LAC  |
|                                   | 0          | Ø       | O          | O      | Ø        | O          | O     | O          | 0             | 0             | 0             | 0             | 0             | 0             | O             | Ø    |
| DDR port direction register       |            |         | $\searrow$ |        | $\times$ | $\searrow$ |       | $\searrow$ |               |               |               |               |               |               |               |      |
|                                   | Set t      | he bit  | corre      | espon  | ding     | to pir     | n use | d for      | DTP/          | exter         | nal in        | terrup        | ot inp        | ut to         | 0.            |      |
| <ul> <li>Unused bit</li> </ul>    |            |         |            |        |          |            |       |            |               |               |               |               |               |               |               |      |
| O: Used bit                       |            |         |            |        |          |            |       |            |               |               |               |               |               |               |               |      |
| O: Set the bit corre              | spond      | ling to | used       | pin to | 1        |            |       |            |               |               |               |               |               |               |               |      |
| 0: Set 0                          |            |         |            |        |          |            |       |            |               |               |               |               |               |               |               |      |
| 1: Set 1                          |            |         |            |        |          |            |       |            |               |               |               |               |               |               |               |      |

Figure 42.4.4. Softing of DTD/External Interrunt

### Setting procedure

To use the DTP/external interrupt, set each register by using the following procedure:

- 1. Set the interrupt request enable bit corresponding to the DTP/external interrupt channel to be used to 0 (ENIR: EN).
- 2. Use the detection condition select bit corresponding to the DTP/external interrupt pin and the RX pin to be used to set the edge or level to be detected (ELVR: LA, LB).
- 3. Set the interrupt request flag bit corresponding to the DTP/external interrupt channel to be used to 0 (EIRR: ER).
- 4. Set the interrupt request enable bit corresponding to the DTP/external interrupt channel to be used to 1 (ENIR: EN).
- When setting the registers for the DTP/external interrupt, the external interrupt request must be disabled in advance (ENIR: EN = 0).
- When enabling the DTP/external interrupt request (ENIR: EN = 1), the corresponding DTP/external interrupt request flag bit must be cleared in advance (EIRR: ER = 0). These actions prevent the mistaken interrupt request from occurring when setting the register.

DataSheet4U.com

### CHAPTER 12 DTP/EXTERNAL INTERRUPT

### Selecting of DTP or external interrupt function

Whether the DTP function or the external interrupt function is executed depends on the setting of the EI<sup>2</sup>OS enable bit in the corresponding interrupt control register (ICR: ISE).

If the ISE bit is set to 1, the EI<sup>2</sup>OS is enabled and the DTP function is executed.

If the ISE bit is set to 0, the  $EI^2OS$  is disabled and the external interrupt function is executed.

- All interrupt requests assigned to one interrupt control register have the same interrupt levels (IL2 to IL0).
  - If two or more interrupt requests are assigned to one interrupt control register and the EI<sup>2</sup>OS is used in one of them, other interrupt requests cannot be used.

### DTP/External Interrupt Operation

The control bits and the interrupt factors for the DTP/external interrupt are shown in Table 12.4-1.

#### Table 12.4-1 Control Bits and Interrupt Factors for DTP/External Interrupt

|                              | DTP/External Interrupt                             |
|------------------------------|----------------------------------------------------|
| Interrupt request flag bit   | EIRR: ER7 to ER4, ER0                              |
| Interrupt request enable bit | ENIR: EN7 to EN4, EN0                              |
| Interrupt factor             | Input of valid edge/level to INT7 to INT4, RX pins |

DataShe

If the interrupt request from the DTP/external interrupt is output to the interrupt controller and the EI<sup>2</sup>OS enable bit in the interrupt control register (ICR: ISE) is set to 0, the interrupt processing is executed. This bit is set to 1, the EI<sup>2</sup>OS is executed.

DataSheet4U.com

et4U.com

### CHAPTER 12 DTP/EXTERNAL INTERRUPT

Figure 12.4-2 shows the operation of the DTP/external interrupt.



Figure 12.4-2 Operation of DTP/External Interrupt

et4U.com

DataSheet4U.com

338

### 12.4.1 External Interrupt Function

The DTP/external interrupt has an external interrupt function for generating an interrupt request by detecting the signal (edge or level) in the DTP/external interrupt pin and the RX pin.

|          | External Interrupt Function |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |         |
|----------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
|          |                             | • When the signal (edge or level) set in the detection level setting register is detected in the DTP/external interrupt pin and the RX pin, the interrupt request flag bit in the DTP/external interrupt factor register (EIRR: ER) is set to 1.                                                                                                                                                                                                                                                                                                                                          |         |
|          |                             | • If the interrupt request enable bit in the DTP/external interrupt enable register is enabled (ENIR: EN = 1) and the interrupt request flag bit set to 1, the interrupt is implemented to the interrupt controller.                                                                                                                                                                                                                                                                                                                                                                      |         |
|          |                             | • If an interrupt request is preferred to other interrupt request by the interrupt controller, the interrupt request is generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |         |
|          |                             | • If the level of an interrupt request (ICR: IL) is higher than that of the interrupt level mask bit (TLM) in the processor status (PS) and the interrupt enable bit is enabled (PS: CCR: $I = 1$ ), the CPU performs interrupt processing after completion of the current instruction execution and branches to interrupt processing.                                                                                                                                                                                                                                                    |         |
| et4U.com |                             | At interrupt processing, set the corresponding DTP/external interrupt request flag bit to 0 and clear the DTP/external interrupt request.     DataSheet4U.com                                                                                                                                                                                                                                                                                                                                                                                                                             | DataShe |
|          | Notes:                      | <ul> <li>When the DTP/external interrupt start factor is generated, the DTP/external interrupt request flag bit (EIRR: ER) is set to 1, regardless of the setting of the DTP/external interrupt request enable bit (ENIR: EN).</li> <li>When the interrupt processing is started, clear the DTP/external interrupt request flag bit that caused the start factor. Control cannot be returned from the interrupt while the DTP/external interrupt request flag bit is set to 1. When clearing, do not clear any flag bit other than the accepted DTP/external interrupt factor.</li> </ul> |         |

### 12.4.2 DTP Function

# The DTP/external interrupt has the DTP function that detects the signal of the external peripheral device from the DTP/external interrupt pin and the RX pin to start the El<sup>2</sup>OS.

### DTP Function

The DTP function detects the signal level set by the detection level setting register of the DTP/external interrupt function to start the EI<sup>2</sup>OS.

- When the EI<sup>2</sup>OS operation is already enabled (ICR: ISE = 1) at the point when the interrupt request is accepted by the CPU, the DTP function starts the EI<sup>2</sup>OS and starts data transfer.
- When transfer of one data item is completed, the descriptor is updated and the DTP/external interrupt request flag bit is cleared to prepare for the next request from the DTP/external interrupt pin and the RX pin.
- When the EI<sup>2</sup>OS completes transfer of all the data, control branches to the interrupt processing.



### Figure 12.4-3 Example of Interface with External Peripheral Device

DataShe

et4U.com

### 12.5 Precautions when Using DTP/External Interrupt

This section explains the precautions when using the DTP/external interrupt.

### Precautions when Using DTP/External Interrupt

• Condition of external-connected peripheral device when DTP function is used

- When using the DTP function, the peripheral device must automatically clear a data transfer request when data transfer is performed.
- Inactivate the transfer request signal within three machine cycles after starting data transfer. If the transfer request signal remains active, the DTP/external interrupt regards the transfer request signal as a generation of next transfer request.
- External interrupt input polarity
  - When the edge detection is set in the detection level setting register, the pulse width for edge detection must be at least three machine cycles.
  - When a level causing an interrupt factor is input with level detection set in the detection level setting register, the interrupt request flag bit (EIRR:ER) of the DTP/external interrupt factor register is set to 1 and the factor is held as shown in Figure 12.5-1.

With the factor held in the interrupt request flag bit (EIRR:ER), the request to the interrupt controller remains active if the interrupt request is enabled (ENIR: EN = 1) even after the DTP/external interrupt factor is cancelled. To cancel the request to the interrupt controller, clear the interrupt request flag bit (EIRR:ER) as shown in Figure 12.5-2.

### Figure 12.5-1 Clearing Interrupt Request Flag Bit (EIRR:ER) when Level Set



### Figure 12.5-2 DTP/External Interrupt Factor and Interrupt Request Generated when Interrupt Request Enabled



DataSheet4U.com

www.DataSheet4U.com

DataShe

et4U.com

### CHAPTER 12 DTP/EXTERNAL INTERRUPT

### Precautions on interrupts

- When the DTP/external interrupt is used as the external interrupt function, no return from interrupt processing can be made with the DTP/external interrupt request flag bit set to 1 (EIRR: ER) and the DTP/external interrupt request set to "enabled" (ENIR: EN = 1). Always set the DTP/external interrupt request flag bit to 0 (EIRR: ER) at interrupt processing.
- When the level detection is set in the detection level setting register and the level that becomes the interrupt factor remains input, the DTP/external interrupt request flag bit is reset immediately even when cleared (EIRR: ER = 0). Disable the DTP/external interrupt request output as needed (ENIR: EN = 0), or cancel the interrupt factor itself.

et4U.com

DataSheet4U.com

DataShe

### 12.6 Program Example of DTP/External Interrupt Circuit

This section gives a program example of the DTP/external interrupt function.

### ■ Program Example of DTP/External Interrupt Function

#### Processing specifications

An external interrupt is generated by detecting the rising edge of the pulse input to the INT4 pin.

#### Coding example

```
et4U.com
```

```
ICR06EQU0000B6H; DTP/external interrupt control registerDDR2EQU000012H; Port 2 direction registerENIREQU000030H; DTP/external interrupt enable registerEIRREQU000031H; DTP/external interrupt factor registerELVRLEQU000032H; Detection level setting register: LELVRHEQU000033H; Detection level setting register: HER0EQUEIRR:0; INT4 Interrupt request flag bitEN0EQUENIR:0; INT4 Interrupt request enable bit
;
;-----Main program-----
                                                                                                   DataShe
CODE
       CSEG
START:
                                   ; Stack pointer (SP) already initialized
         MOV I:DDR2,#0000000B ; DDR2 set to input port
         AND CCR, #0BFH ; Interrupts disabled
         MOV I:ICR06,#00H ; Interrupt level 0 (highest)
CLRB I:ER4 ; INT4 disabled using ENIR
         MOV I:ELVRL, #00000010B ; Rising edge selected for INT4
         CLRB I:ER4 ; INT4 interrupt request flag
                                   ; cleared using EIRR
         SETB I:EN4
MOV ILM, #07H
OR CCR, #40H
                                  ; INT4 interrupt request enabled using ENIR
                                  ; ILM in PS set to level 7
                                   ; Interrupts enabled
LOOP:
         Processing by user
         BRA LOOP
;-----Interrupt program------
WARI:
         CLRB I:ER4
                                   ; Interrupt request flag cleared
         Processing by user
          .
         RETT
                                   ; Return from interrupt processing
CODE
         ENDS
;-----Vector setting-----
VECT CSEG ABS=0FFH
         ORG 00FFC0H
                                   ; Vector set to interrupt number #15 (0F_H)
         DSL WARI
         ORG 00FFDCH
                                   ; Reset vector set
         DSL START
         DB 00H
                                   ; Set to single-chip mode
VECT
         ENDS
                                                                                    www.DataSheet4U.com
         END START
```

DataSheet4U.com

#### CHAPTER 12 DTP/EXTERNAL INTERRUPT

### Program Example of DTP Function

- Processing specification
  - Channel 0 of the EI<sup>2</sup>OS is started by detecting the High level of the signal input to the INT4 pin.
  - RAM data is output to port 1 by performing DTP processing (EI<sup>2</sup>OS).
- Coding example

```
ICR06EQU0000B6H; DTP/external interrupt control registerDDR1EQU000011H; Port 1 direction registerDDR5EQU000015H; Port 5 direction registerENIREQU000030H; DTP/external interrupt enable registerEIRREQU000031H; DTP/external interrupt factor registerELVRLEQU000032H; Detection level setting register: LELVRHEQU000033H; Detection level setting register: HER4EQUEINR:0; INT4 interrupt request flag bit....
 ;
;

BAPL EQU 000100H ; Buffer address pointer lower

BAPM EQU 000101H ; Buffer address pointer middle

BAPH EQU 000102H ; Buffer address pointer higher

ISCS EQU 000103H ; EI<sup>2</sup>OS status register

IOAL EQU 000104H ; I/O address register lower

IOAH EQU 000105H ; I/O address register higher

DCTL EQU 000106H ; Data counter lower

DCTH EQU 000107H ; Data counter higher
                                                                                                                                                      DataShe
 ;-----Main program-----
 CODE CSEG
 START:
                                                    ; Stack pointer (SP) already initialized
              MOV I:DDR1,#1111111B ; DDR1 set to output port
              MOV I:DDR5,#0000000B; DDR5 set to input port
              AND CCR,#0BFH ; Interrupts disabled
MOV I:ICR06,#08H ; Interrupt level 0 (highest) EI<sup>2</sup>OS
                                                    ; Channel 0
 ; Deta bank register (DTB) = 00H
 ;
              MOV BAPH,#00H
              MOV ISCS, #12H ; Byte transfer, buffer address + 1
                                                   ; I/O address fixed,
                                                  ; transfer from memory to I/O
             ; transfer from memory to 1/0MOV IOAL,#00H; Port 0 (PDR0) set asMOV IOAH,#00H; transfer destination address pointerMOV DCTL,#0AH; Transfer count set to 10
              MOV DCTH, #00H
 ;
              CLRB I:EN4 ; INT4 disabled using ENIR
              MOV I:ELVRL,#00010000B; H level detection set for INT4
             SEIB 1:EN4; INT4 interrupt request flag cleared usingMOV ILM,#07H; ILM in PS set to level 7OR CCR,#40H; Interrupts creation
              CLRB I:ER4 ; INT4 interrupt request flag cleared using EIRR
SETB I:EN4 ; INT4 interrupt request enabled using ENIR
                                                                                                                               www.DataSheet4U.com
```

DataSheet4U.com

et4U.com

#### CHAPTER 12 DTP/EXTERNAL INTERRUPT

LOOP: . Processing by user . BRA LOOP ;-----Interrupt program------WARI: CLRB I:ER4 ; INT4 interrupt request flag cleared . Processing by user . RETI ; Return from interrupt processing CODE ENDS ;-----Vector setting------VECT CSEG ABS = 0FFH ORG 00FF9CH ; Vector set to interrupt number  $\#24~(18_{\rm H})$ DSL WARI ORG 00FFDCH ; Reset vector set DSL START DB 00H ; Set to single-chip mode set VECT ENDS END START

et4U.com

DataShe

DataSheet4U.com

#### CHAPTER 12 DTP/EXTERNAL INTERRUPT

et4U.com

DataSheet4U.com

DataSheet4U.com

346

DataSheet4U.com

DataShe

www.DataSheet4U.com

# CHAPTER 13 8-/10-BIT A/D CONVERTER

This chapter explains the functions and operation of 8-/ 10-bit A/D converter.

- 13.1 Overview of 8-/10-bit A/D Converter
- 13.2 Block Diagram of 8-/10-bit A/D Converter
- 13.3 Configuration of 8-/10-bit A/D Converter
- 13.4 Interrupt of 8-/10-bit A/D Converter
- 13.5 Explanation of Operation of 8-/10-bit A/D Converter
- 13.6 Precautions when Using 8-/10-bit A/D Converter

et4U.com

DataSheet4U.com

www.DataSheet4U.com

## 13.1 Overview of 8-/10-bit A/D Converter

The 8-/10-bit A/D converter converts the analog input voltage to a 8- or 10-bit digital value by using the RC sequential-comparison converter system.

- An input signal can be selected from the input signals of the analog input pins for 8 channels.
- The start trigger can be selected from a software trigger, internal timer output, and an external trigger.

#### ■ Function of 8-/10-bit A/D Converter

The 8-/10-bit A/D converter converts the analog voltage (input voltage) input to the analog input pin into an 8- or 10-bit digital value (A/D conversion).

The 8-/10-bit A/D converter has the following functions:

- A/D conversion time is a minimum of  $6.12 \,\mu s^*$  per channel including sampling time.
- Sampling time is a minimum of 2.0 μs per channel.<sup>\*</sup>
- RC sequential-comparison converter system with sample & hold circuit
- Setting of 8-bit or 10-bit resolution enabled
- Analog input pin can be used up to 8 channels.

www.DataSheet4U.com

- Generates interrupt request by storing A/D conversion results in A/D data register
- Starts El<sup>2</sup>OS if interrupt request generated. Use of the El<sup>2</sup>OS prevents data loss even at continuous conversion.
- Selects start trigger from software trigger, internal timer output, and external trigger (falling edge)
- \*: When the machine clock frequency operates at 16 MHz

#### ■ Conversion Modes of 8-/10-bit A/D Converter

There are conversion modes of 8-/10-bit A/D converter as shown below:

#### Table 13.1-1 Conversion Modes of 8-/10-bit A/D Converter

| Conversion<br>Mode                                                                                                                                                                                                    | Description                                                                                                                                                                                                            |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Single conversion mode                                                                                                                                                                                                | A/D conversion is performed sequentially from the start channel to the end channel. When A/D conversion for the end channel is terminated, it stops.                                                                   |
| Continuous<br>conversion modeA/D conversion is performed sequentially from the start channel to the<br>channel. When A/D conversion for the end channel is terminated, it is<br>after returning to the start channel. |                                                                                                                                                                                                                        |
| Pause-conversion<br>mode                                                                                                                                                                                              | A/D conversion is performed sequentially from the start channel to the end channel. When A/D conversion for the end channel is terminated, A/D conversion and pause are repeated after returning to the start channel. |

DataSheet4U.com

et4U.com

## 13.2 Block Diagram of 8-/10-bit A/D Converter

#### The 8-/10-bit A/D converter consists of following blocks.

#### Block Diagram of 8-/10-bit A/D Converter



#### Figure 13.2-1 Block Diagram of 8-/10-bit A/D Converter

DataSheet4U.com

www.DataSheet4U.com

#### CHAPTER 13 8-/10-BIT A/D CONVERTER

#### • Details of pins in block diagram

Table 13.2-1 shows the actual pin names and interrupt request numbers of the 8-/10-bit A/D converter

|                             | terrupt Request Number in<br>Block Diagram | Actual Pin Name/Interrupt Request Number        |
|-----------------------------|--------------------------------------------|-------------------------------------------------|
| ADTG                        | Trigger input pin                          | P37/ADTG                                        |
| ТО                          | Internal timer output                      | TO (16-bit reload timer, 16-bit free-run timer) |
| AN0                         | Analog input pin ch 0                      | P50/AN0                                         |
| AN1                         | Analog input pin ch 1                      | P51/AN1                                         |
| AN2                         | Analog input pin ch 2                      | P52/AN2                                         |
| AN3                         | Analog input pin ch 3                      | P53/AN3                                         |
| AN4                         | Analog input pin ch 4                      | P54/AN4                                         |
| AN5                         | Analog input pin ch 5                      | P55/AN5                                         |
| AN6                         | Analog input pin ch 6                      | P56/AN6                                         |
| AN7                         | Analog input pin ch 7                      | P57/AN7                                         |
| AVR                         | Vref+ Input pin                            | AVR                                             |
| AV <sub>CC</sub>            | V <sub>CC</sub> Input pinDataSheet4U.co    | nAV <sub>CC</sub>                               |
| AV <sub>SS</sub>            | V <sub>SS</sub> Input pin                  | AV <sub>SS</sub>                                |
| Interrupt<br>request output |                                            | #18 (12 <sub>H</sub> )                          |

Table 13.2-1 Pins and Interrupt Request Numbers in Block Diagram

#### A/D control status registers (ADCS)

This register starts the A/D conversion function by software, selects the start trigger for the A/D conversion function, selects the conversion mode, enables or disables an interrupt request, checks and clears the interrupt request flag, temporarily stops A/D conversion and checks the state during conversion, and sets the start and end channels for A/D conversion.

#### • A/D data registers (ADCR)

This register stores the A/D conversion results, and selects the comparison time, sampling time, and resolution of A/D conversion.

• Start selector

This selector selects the trigger to start A/D conversion. An internal timer output or external pin input can be set as the start trigger.

DataSheet4U.com

350

#### Decoder

This decoder sets the A/D conversion start channel select bits and the A/D conversion end channel select bits in the A/D control status register (ADCS: ANS2 to ANS0 and ANE2 to ANE0) to select the analog input pin to be used for A/D conversion.

#### Analog channel selector

This selector selects the pin to be used for A/D conversion from the 8-channel analog input pins by receiving a signal from the decoder.

#### Sample & hold circuit

This circuit holds the input voltage selected by the analog channel selector. By holding the input voltage immediately after A/D conversion is started, A/D conversion is performed without being affected by the fluctuation of the input voltage during A/D conversion.

#### • D/A converter

This converter generates the reference voltage which is compared with the input voltage held in the sample & hold circuit.

#### Comparator

DataSheet4U.com

#### • Controller

This circuit determines the A/D conversion value by receiving the signal indicating the amount of voltage determined by the comparator. When the A/D conversion results are determined, the result data is stored in the A/D data register. If an interrupt request is enabled, an interrupt is generated.

et4U.com

## 13.3 Configuration of 8-/10-bit A/D Converter

#### This section explains the pins, registers, and interrupt factors of the A/D converter.

#### ■ Pins of 8-/10-bit A/D Converter

The pins of the 8-/10-bit A/D converter serve as general-purpose I/O ports. Table 13.3-1 shows the pin functions and the setting required for use of the 8-/10-bit A/D converter.

| Function<br>Used | Pin<br>Name | Pin Function                                        | Setting Required for Use of<br>8-/10-bit A/D Converter                                                                                     |  |  |
|------------------|-------------|-----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Trigger input    | ADTG        | General-purpose I/O port,<br>external trigger input | Set as input port in port direction register (DDR).                                                                                        |  |  |
| Channel 0        | AN0         |                                                     |                                                                                                                                            |  |  |
| Channel 1        | AN1         |                                                     |                                                                                                                                            |  |  |
| Channel 2        | AN2         |                                                     |                                                                                                                                            |  |  |
| Channel 3        | AN3         | General-purpose I/O ports,                          | Set as input ports in port direction<br>register (DDR).<br>Input of analog signal enabled (ADER:<br>ADE7 to ADE0 = 11111111 <sub>B</sub> ) |  |  |
| Channel 4        | AN4         | analog inputs                                       |                                                                                                                                            |  |  |
| Channel 5        | AN5         | DataSheet4U.com                                     | D,                                                                                                                                         |  |  |
| Channel 6        | AN6         |                                                     |                                                                                                                                            |  |  |
| Channel 7        | AN7         |                                                     |                                                                                                                                            |  |  |

et4U.com

Reference: See CHAPTER 4 "I/O PORT" for the block diagram of pins.

#### ■ List of Registers and Reset Values of 8-/10-bit A/D Converter

|                                                 | bit | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
|-------------------------------------------------|-----|----|----|----|----|----|----|---|---|
| A/D control status register (High)<br>(ADCS: H) |     | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 |
|                                                 | bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| A/D control status register (Low)<br>(ADCS: L)  |     | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 |
|                                                 | bit | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
| A/D data register (High)<br>(ADCR: H)           |     | 0  | 0  | 1  | 0  | 1  | Х  | Х | Х |
|                                                 | bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| A/D data register (Low)<br>(ADCR: L)            |     | Х  | Х  | Х  | Х  | Х  | Х  | Х | Х |
|                                                 | bit | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
| Analog input enable register (ADER)             |     | 1  | 1  | 1  | 1  | 1  | 1  | 1 | 1 |
| X: Undefined                                    |     |    |    |    |    |    |    |   |   |

#### Figure 13.3-1 Register and Reset Value of 8-/10-bit A/D Converter

#### ■ Generation of Interrupt from 8-/10-bit A/D Converter

et4U.com

In the 8-/10-bit A/D converter, when the A/D conversion results are stored in the A/D data register (ADCR), the interrupt request flag bit in the A/D control status register (ADCS: INT) is set to 1. When an interrupt request is enabled (ADCS: INTErect), an interrupt is generated.

DataShee

www.DataSheet4U.com

## 13.3.1 A/D Control Status Register (High) (ADCS: H)

The A/D control status register (High) (ADCS: H) provides the following settings:

- Starting A/D conversion function by software
- Selecting start trigger for A/D conversion
- Storing A/D conversion results in A/D data register to enable or disable interrupt request
- Storing A/D conversion results in A/D data register to check and clear interrupt request flag
- Pausing A/D conversion and checking state during conversion





Figure 13.3-2 A/D Control Status Register (High) (ADCS: H)

DataSheet4U.com

www.DataSheet4U.com

DataShe

354

| Bit Name         |                                                            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------|------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 8            | Reserved: Reserved bit                                     | Always set this bit to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| bit 9            | STRT:<br>A/D conversion software<br>start bit              | <ul> <li>This bit starts the 8-/10-bit A/D converter by software.</li> <li>When set to 1: Starts 8-/10-bit A/D converter</li> <li>If A/D conversion pauses in the pause-conversion mode, it is resumed by writing 1 to the STRT bit.</li> <li>When set to 0: Invalid. The state remains unchanged.</li> <li>Read: The byte/word command reads "1". The read-modify-write series commands read "0".</li> <li>Note: Do not perform forcible termination (BUSY = 0) and software start (STRT = 1) of the 8-/10-bit A/D converter simultaneously.</li> </ul>                                    |
| bit 10<br>bit 11 | STS1, STS0:<br>A/D conversion start trigger<br>select bits | These bits select the trigger to start the 8-/10-bit A/D converter.<br>If two or more start triggers are set (STS1, STS0 "00 <sub>B</sub> "), the 8-/10-bit A/D converter is<br>started by the first-generated start trigger.<br>Note: Start trigger setting should be changed when the operation of resource generating a<br>start trigger is stopped.                                                                                                                                                                                                                                     |
| bit 12           | PAUS:<br>Pause flag bit                                    | <ul> <li>This bit indicates the A/D conversion operating state when the EI<sup>2</sup>OS function is used.</li> <li>The PAUS bit is enabled only when the EI<sup>2</sup>OS function is used.</li> <li>A/D conversion pauses while the A/D conversion results are transferred from the A/D data register (ADCR) to memory. When A/D conversion pauses, the PAUS bit is set to 1.</li> <li>After transfer of the A/D conversion results to memory, the 8-/10-bit A/D converter automatically resumes A/D conversion. When A/D conversion is started, the PAUS bit is cleared to 0.</li> </ul> |
| bit 13           | INTE:<br>Interrupt request enable bit                      | <ul> <li>This bit enables or disables output of an interrupt request.</li> <li>When the interrupt request flag bit is set (INT=1) with an interrupt request enabled (INTE = 1), an interrupt request is generated.</li> <li>Note: Always set this bit to 1 when the EI<sup>2</sup>OS function is used.</li> </ul>                                                                                                                                                                                                                                                                           |
| bit 14           | INT:<br>Interrupt request flag bit                         | <ul> <li>This bit indicates that an interrupt request is generated.</li> <li>When A/D conversion is terminated and its results are stored in the A/D data register (ADCR), the INT bit is set to 1.</li> <li>When the interrupt request flag bit is set (INT = 1) with an interrupt request enabled (INTE = 1), an interrupt request is generated.</li> <li>When set to 0: Cleared</li> <li>When set to 1: No effect</li> <li>When El<sup>2</sup>OS function started: Cleared</li> <li>Note: To clear the INT bit, write 0 when the 8-/10-bit A/D converter is stopped.</li> </ul>          |
| bit 15           | BUSY:<br>A/D conversion-on flag bit                        | <ul> <li>This bit forcibly terminates the 8-/10-bit A/D converter. When read, this bit indicates whether the 8-/10-bit A/D converter is operating or stopped.</li> <li>When set to 0: Forcibly terminates 8-/10-bit A/D converter</li> <li>When set to 1: No effect</li> <li>Read: 1 is read when the 8-/10-bit A/D converter is operating and 0 is written when the converter is stopped.</li> <li>Note: Do not perform forcibly termination (BUSY=0) and software start (STRT=1) of the 8-/10-bit A/D converter simultaneously.</li> </ul>                                                |

#### Table 13.3-2 Function of Each Bit of A/D Control Status Register (High) (ADCS: H)

DataSheet4U.com

et4U.com

## 13.3.2 A/D Control Status Register (Low) (ADCS: L)

The A/D control status register (Low) (ADCS: L) provides the following settings:

- Selecting A/D conversion mode
- Selecting start channel and end channel of A/D conversion

#### A/D Control Status Register (Low) (ADCS: L)



Figure 13.3-3 A/D Control Status Register Low (ADCS: L)

DataSheet4U.com

356

| Bit Name       |                                                              | Function                                                                                                                                                                                                                                                                                                                                                                                          |    |
|----------------|--------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| bit 0 to bit 2 | ANE2 to ANE0:                                                | These bits set the channel at which A/D conversion is terminated.                                                                                                                                                                                                                                                                                                                                 | 1  |
|                | A/D conversion end<br>channel select bits                    | Start channel < end channel: A/D conversion starts at channel set by A/D conversion<br>start channel select bits (ANS2 to ANS0) and terminates<br>channel set by A/D conversion end channel select bits<br>(ANE2 to ANE0)                                                                                                                                                                         |    |
|                |                                                              | Start channel = end channel: A/D conversion is performed only for one channel set by A/D converter end (= start) channel select bits (ANE2 to ANE0 = ANS2 to ANS0).                                                                                                                                                                                                                               |    |
|                |                                                              | Start channel > end channel: A/D conversion is performed from channel set by A/D<br>conversion start channel select bits (ANS2 to ANS0) to<br>AN7, and from AN0 to channel set by A/D conversion<br>end channel select bits (ANE2 to ANE0).                                                                                                                                                       |    |
|                |                                                              | Continuous conversion mode and pause-conversion mode:                                                                                                                                                                                                                                                                                                                                             |    |
|                |                                                              | When A/D conversion terminated at the channel set by the A/D conversion end channel select bits (ANE2 to ANE0), it returns to the channel set by the A/D conversion start channel select bits (ANS2 to ANS0).                                                                                                                                                                                     |    |
|                |                                                              | Note: Do not set the A/D conversion end channel select bits (ANE2 to ANE0) during A/<br>D conversion.                                                                                                                                                                                                                                                                                             |    |
| bit 3 to bit 5 | ANS2 to ANS0:<br>A/D conversion start<br>channel select bits | These bits set the channel at which A/D conversion start. At read, the channel number under A/D conversion or A/D-converted immediately before A/D conversion pauses can be checked. And before A/D conversion starts, the previous conversion channel number will be read even if these bits have been already set to the new value. These bits are initialized to "000 <sub>B</sub> " at reset. | Da |
|                |                                                              | Start channel < end channel: A/D conversion starts at channel set by A/D conversion<br>start channel select bits (ANS2 to ANS0) and terminates<br>at channel set by A/D conversion end channel select bits<br>(ANE2 to ANE0).                                                                                                                                                                     |    |
|                |                                                              | Start channel = end channel: A/D conversion is performed only for one channel set by<br>A/D conversion (= end) channel select bits (ANS2 to<br>ANS0 = ANE2 to ANE0).                                                                                                                                                                                                                              |    |
|                |                                                              | Start channel > end channel: A/D conversion is performed from channel set by A/D<br>conversion start channel select bits (ANS2 to ANS0) to<br>AN7, and from AN0 to channel set by A/D conversion<br>end channel select bits (ANE2 to ANE0).                                                                                                                                                       |    |
|                |                                                              | <b>Continuous conversion mode and pause-conversion mode:</b><br>When A/D conversion terminates at the channel set by the A/D conversion end<br>channel select bits (ANE2 to ANE0), it returns to the channel set by the A/D<br>conversion start channel select bits (ANS2 to ANS0).                                                                                                               |    |
|                |                                                              | <b>Read (During A/D conversion):</b> The channel numbers (7 to 0) under A/D conversion are read.                                                                                                                                                                                                                                                                                                  |    |
|                |                                                              | Read (During Pause-conversion mode and temporary stop):<br>At read during a pause, the channel number A/D-converted immediately before a pause is read.                                                                                                                                                                                                                                           |    |
|                |                                                              | <b>Note:</b> Do not set the A/D conversion start channel bits (ANS2 to ANS0) during A/D conversion.                                                                                                                                                                                                                                                                                               |    |

#### Table 13.3-3 Function of Each Bit of A/D Control Status Register (Low) (ADCS: L) (1/2)

et4U.com

#### CHAPTER 13 8-/10-BIT A/D CONVERTER

|          |                | Bit Name                                        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------|----------------|-------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| et4U.com | bit 6<br>bit 7 | MD1, MD0:<br>A/D conversion mode<br>select bits | <ul> <li>These bits set the A/D conversion mode.</li> <li>Single conversion mode 1: <ul> <li>The analog inputs from the start channel (ADCS: ANS2 to ANS0) to the end channel (ADCS: ANE2 to ANE0) are A/D-converted continuously.</li> <li>The A/D conversion pauses after A/D conversion for the end channel.</li> <li>This mode can be restarted during A/D conversion.</li> </ul> </li> <li>Single conversion mode 2: <ul> <li>The analog inputs from the start channel (ADCS: ANS2 to ANS0) to the end channel (ADCS: ANE2 to ANE0) are A/D-converted continuously.</li> <li>The A/D conversion after A/D conversion for the end channel.</li> <li>This mode cannot be restarted during A/D conversion.</li> </ul> </li> <li>Continuous conversion after A/D conversion for the end channel.</li> <li>This mode cannot be restarted during A/D conversion.</li> <li>Continuous conversion mode: <ul> <li>The analog inputs from the start channel (ADCS: ANS2 to ANS0) to the end channel (ADCS: ANE2 to ANE0) are A/D-converted continuously.</li> <li>When A/D conversion for the end channel is terminated, it is continued after returning to the analog input for the start channel.</li> <li>To terminate A/D conversion forcibly, write 0 to the A/D conversion-on flag bit in the A/D control status register (ADCS: BUSY).</li> <li>This mode cannot be restarted during A/D conversion.</li> </ul> </li> <li>Pause conversion mode: <ul> <li>A/D conversion for the start channel (ADCS: ANS2 to ANS0) starts. The A/D conversion for the start channel.</li> <li>A/D conversion for the start channel (ADCS: ANS2 to ANS0) starts. The A/D conversion pauses at termination of A/D conversion for the next channel is started.</li> <li>A/D conversion pauses at the termination of A/D conversion for the end channel.</li> <li>When A/D conversion pauses at the termination of A/D conversion for the end channel.</li> <li>When A/D conversion pauses at the termination of A/D conversion for the end channel.</li> <li>When A/D conversion pauses at the termination of A/D conversion for the end chann</li></ul></li></ul> |

## 13.3.3 A/D Data Register (High) (ADCR: H)

The higher five bits in the A/D data register (ADCR: H) select the compare time, sampling time and resolution of A/D conversion.

Bits 9 and 8 in the A/D data register (ADCR) are explained in Section "13.3.4 A/D Data Register (Low) (ADCR: L)".

#### ■ A/D Data Register (High) (ADCR: H)



Figure 13.3-4 A/D Data Register (High) (ADCR: H)

DataShe

www.DataSheet4U.com

#### CHAPTER 13 8-/10-BIT A/D CONVERTER

| Bit Name         |                                        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|------------------|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| bit 11<br>bit 12 | CT1, CT0:<br>Compare time select bits  | These bits set the A/D conversion compare time.<br>• These bits set the time required from when analog input is A/D-converted<br>until it is stored in the data bits (D9 to D0).<br>Note: The setting of CT1 and CT0 = $"00_B"$ is based on operation at 8 MHz.<br>Setting based on operation at 16 MHz does not assure normal operation.<br>When these bits are read, $"00_B"$ is read.                                                                                                                                    |  |  |  |
| bit 13<br>bit 14 | ST1, ST0:<br>Sampling time select bits | <ul> <li>These bits set the A/D conversion sampling time.</li> <li>These bits set the time required from when A/D conversion starts until the input analog voltage is sampled and held by the sample &amp; hold circuit.</li> <li>Note: The setting of ST1 and ST0 = "00<sub>B</sub>" is based on operation at 8 MHz. Setting based on operation at 16 MHz does not assure normal operation. When these bits are read, "00<sub>B</sub>" is read.</li> </ul>                                                                 |  |  |  |
| bit 15           | S10:<br>Resolution select bit          | <ul> <li>This bit selects the A/D conversion resolution.</li> <li>When set to 0: Sets A/D conversion resolution in 10 bits from A/D conversion data bits D9 to D0.</li> <li>When set to 1: Sets A/D conversion resolution in 8 bits from A/D conversion data bits D7 to D0.</li> <li>Note: Change the S10 bit in the pausing state before starting A/D conversion. Changing the S10 bit after A/D conversion starts disables the A DataShD conversion results stored in the A/D conversion data bits (D9 to D0).</li> </ul> |  |  |  |

#### Table 13.3-4 Functions of A/D Data Register (High) (ADCR: H)

et4U.com

## 13.3.4 A/D Data Register (Low) (ADCR: L)

The A/D data register (Low) (ADCR: L) stores the A/D conversion results. Bits 8 and 9 in the A/D data register (ADCR) are explained in this section.

### ■ A/D Data Register (Low) (ADCR: L)



#### Table 13.3-5 Functions of A/D Data Register (Low) (ADCR: L)

| Bit Name       |                          | Function                                                                     |
|----------------|--------------------------|------------------------------------------------------------------------------|
| bit 0 to bit 9 | D9 to D0:                | These bits store the A/D conversion results.                                 |
|                | A/D conversion data bits | When resolution set in 10 bits (S10 = 0):Conversion data is stored in the 10 |
|                |                          | bits from D9 to D0.                                                          |
|                |                          | When resolution set in 8 bits (S10 = 1): Conversion data is stored in the 8  |
|                |                          | bits from D7 to D0.                                                          |
|                |                          | Note: Use a word instruction (MOVW) to read the A/D conversion results       |
|                |                          | stored in the A/D conversion data bits (D9 to D0).                           |

www.DataSheet4U.com

## 13.3.5 Analog Input Enable Register (ADER)

The analog input enable register (ADER) enables or disables the analog input pins to be used in the 8-/10-bit A/D converter.

#### Analog Input Enable Register (ADER)





DataSheet4U.com

362

| Bit Name       |                                                                                                                                     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0 to bit 7 | ADE7 to ADE0:<br>Analog input enable bits                                                                                           | These bits enable or disable the analog input of the pin to be used for A/D conversion.<br>When set to 0: Disables analog input<br>When set to 1: Enables analog input                                                                                                                                                                                                                                                                                       |
| Notes:         | <ul><li>analog input pin, switch<br/>register (DDR5) and the</li><li>When using the pin as a<br/>corresponding to the pin</li></ul> | erve as a general-purpose I/O port of the port 5. When using the pin as an<br>in the pin to analog input pin according to the setting of the port 5 direction<br>e analog input enable register (ADER).<br>an analog input pin, write 0 to the bit in the port 5 direction register (DDR5)<br>in to be used and turn off the output transistor. Also write 1 to the bit in the<br>ister (ADER) corresponding to the pin to be used and set the pin to analog |

#### Table 13.3-6 Functions of Analog Input Enable Register (ADER)

et4U.com

DataSheet4U.com

CHAPTER 13 8-/10-BIT A/D CONVERTER

#### 13.4 Interrupt of 8-/10-bit A/D Converter

When A/D conversion is terminated and its results are stored in the A/D data register (ADCR), the 8-/10-bit A/D converter generates an interrupt request. The El<sup>2</sup>OS function can be used.

#### Interrupt of A/D Converter

When A/D conversion of the analog input voltage is terminated and its results are stored in the A/D data register (ADCR), the interrupt request flag bit in the A/D control status register (ADCS: INT) is set to 1. When the interrupt request flag bit is set (ADCS: INT = 1) with an interrupt request output enabled (ADCS: INTE = 1), an interrupt request is generated.

#### ■ 8-/10-bit A/D Converter Interrupt and El<sup>2</sup>OS

See Section "3.5 Interrupt" for details of the interrupt number, interrupt control register, and interrupt vector address.

#### ■ El<sup>2</sup>OS Function of 8-/10-bit A/D Converter

In the 8-/10-bit A/D converter, the EI<sup>2</sup>OS function can be used to transfer the A/D conversion results from the A/D data register (ADCR) to memory. If the EI<sup>2</sup>OS function is used, the A/D-converted data protection function is activated to cause A/D conversion to pause during memory transfer and prevent data loss as A/D conversion is performed continuously. DataSheet4U.com

et4U.com

www.DataSheet4U.com

## 13.5 Explanation of Operation of 8-/10-bit A/D Converter

The 8-/10-bit A/D converter has the following A/D conversion modes. Set each mode according to the setting of the A/D conversion mode select bits in the A/D control status register (ADCS: MD1, MD0).

- Single conversion mode (restartable/not-restartable during A/D conversion)
- Continuous conversion mode (not-restartable during A/D conversion)
- Pause conversion mode (not-restartable during A/D conversion)

#### Single Conversion Mode (ADCS: MD1, MD0 = $"00_B"$ or $"01_B"$ )

- When the start trigger is input, the analog inputs from the start channel (ADCS: ANS2 to ANS0) to the end channel (ADCS: ANE2 to ANE0) are A/D-converted continuously.
- The A/D conversion stops at the termination of the A/D conversion for the end channel.
- To terminate A/D conversion forcibly, write 0 to the A/D conversion-on flag bit in the A/D control status register (ADCS: BUSY).
- When the A/D conversion mode select bits (MD1, MD0) are set to " $00_B$ ", this mode can be restarted during A/D conversion. If the bits are set to  $01_B$ , this mode cannot be restarted during A/D conversion.

#### Com ■ Continuous Conversion Mode (ADCS: MD1, MD0 = "10<sub>B</sub>")

- When the start trigger is input, the analog inputs from the start channel (ADCS: ANS2 to ANS0) to the end channel (ADCS: ANE2 to ANE0) are A/D-converted continuously.
- When A/D conversion for the end channel is terminated, it is continued after returning to the analog input for the start channel.
- To terminate A/D conversion forcibly, write 0 to the A/D conversion-on flag bit in the A/D control status register (ADCS: BUSY).
- This mode cannot be restarted during A/D conversion.

#### Pause-conversion Mode (ADCS: MD1, MD0 = "11<sub>B</sub>")

- When the start trigger is input, A/D conversion starts for the start channel (ADCS: ANS2 to ANS0). The A/D conversion pauses at the termination of A/D conversion for one channel. When the start trigger is input while A/D conversion pauses, A/D conversion is performed for the next channel.
- The A/D conversion pauses at termination of A/D conversion for the end channel. When the start trigger is input while A/D conversion pauses, A/D conversion is continued after returning to the analog input for the start channel.
- To terminate A/D conversion forcibly, write 0 to the A/D conversion-on flag bit in the A/D control status register (ADCS: BUSY).
- This mode cannot be restarted during A/D conversion.

## 13.5.1 Single Conversion Mode

# In the Single conversion mode, A/D conversion is performed sequentially from the start channel to the end channel. The A/D conversion stops at the termination of A/D conversion for the end channel.

#### Setting of Single Conversion Mode

Operating the 8-/10-bit A/D converter in the Single conversion mode requires the setting shown in Figure 13.5-1.



#### Figure 13.5-1 Setting of Single Conversion Mode

#### Operation of Single Conversion Mode

- When the start trigger is input, A/D conversion starts from the channel set by the A/D conversion start channel select bits (ANS2 to ANS0) and is performed continuously up to the channel set by the A/D conversion end channel select bits (ANE2 to ANE0).
- The A/D conversion stops at the termination of the A/D conversion for the channel set by the A/D conversion end channel select bits (ANE2 to ANE0).
- To terminate A/D conversion forcibly, write 0 to the A/D conversion-on flag bit in the A/D control status register (ADCS: BUSY).
- When the A/D conversion mode select bits (MD1, MD0) are set to "00<sub>B</sub>", this mode can be restarted during A/D conversion. If the bits are set to "01<sub>B</sub>", this mode cannot be restarted during A/D conversion.

#### [When start and end channels are the same]

• If the start and end channels have the same channel number (ADCS: ANS2 to ANS0 = ADCS: ANE2 to ANE0), only one A/D conversion for one channel set as the start channel (= end channel) is performed and terminated.

et4U.com

#### CHAPTER 13 8-/10-BIT A/D CONVERTER

#### [Conversion order in single conversion mode]

Table 13.5-1 gives an example of the conversion order in the single conversion mode.

| Start Channel                                | End Channel                                  | Conversion Order             |
|----------------------------------------------|----------------------------------------------|------------------------------|
| AN0 pin<br>(ADCS: ANS = "000 <sub>B</sub> ") | AN3 pin<br>(ADCS: ANE = "011 <sub>B</sub> ") | AN0> AN1> AN2> AN3> End      |
| AN6 pin<br>(ADCS: ANS = "110 <sub>B</sub> ") | AN2 pin<br>(ADCS: ANE = "010 <sub>B</sub> ") | AN6> AN7> AN0> AN1> AN2> End |
| AN3 pin<br>(ADCS: ANS = "011 <sub>B</sub> ") | AN3 pin<br>(ADCS: ANE = " $011_B$ ")         | AN3> End                     |

et4U.com

DataShe

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

#### **Continuous Conversion Mode** 13.5.2

In the continuous conversion mode, A/D conversion is performed sequentially from the start channel to the end channel.

When A/D conversion for the end channel is terminated, it is continued after returning to the start channel.

#### Setting of Continuous Conversion mode

Operating the 8-/10-bit A/D converter in the continuous conversion mode requires the setting shown in Figure 13.5-2.



#### Figure 13.5-2 Setting of Continuous Conversion Mode

#### Operation of Continuous Conversion Mode

- When the start trigger is input, A/D conversion starts from the channel set by the A/D conversion start channel select bits (ANS2 to ANS0) and is performed continuously up to the channel set by the A/D conversion end channel select bits (ANE2 to ANE0).
- When A/D conversion for the channel set by the A/D conversion end channel select bits (ANE2 to ANE0) is terminated, it is continued after returning to the channel set by the A/D conversion start channel select bits (ANS2 to ANS0).
- To terminate A/D conversion forcibly, write 0 to the A/D conversion-on flag bit in the A/D control status register (ADCS: BUSY).
- This mode cannot be restarted during A/D conversion.

#### [When start and end channels are the same]

If the start and end channels have the same channel number (ADCS: ANS2 to ANS0 = ADCS: ANE2 to ANE0), A/D conversion for one channel set as the start channel (= end channel) is repeated.

#### [Conversion order in continuous conversion mode]

Table 13.5-2 gives an example of the conversion order in the continuous conversion mode.

| Start Channel                                | End Channel                                  | Conversion Order         |
|----------------------------------------------|----------------------------------------------|--------------------------|
| AN0 pin                                      | AN3 pin                                      | AN0> AN1> AN2> AN3> AN0> |
| (ADCS: ANS = "000 <sub>B</sub> ")            | (ADCS: ANE = "011 <sub>B</sub> ")            | Repeat                   |
| AN6 pin                                      | AN2 pin                                      | AN6> AN7> AN0> AN1> AN2> |
| (ADCS: ANS = " $110_B$ ")                    | (ADCS: ANE = "010 <sub>B</sub> ")            | AN6> Repeat              |
| AN3 pin<br>(ADCS: ANS = "011 <sub>B</sub> ") | AN3 pin<br>(ADCS: ANE = "011 <sub>B</sub> ") | AN3> AN3> Repeat         |

et4U.com

DataShe

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

## 13.5.3 Pause-conversion Mode

In the pause-conversion mode, A/D conversion starts and pauses repeatedly for each channel. When the start trigger is input after the A/D conversion pauses at the termination of the A/D conversion for the end channel, A/D conversion is continued after returning to the start channel.

#### Setting of Pause-conversion Mode

Operating the 8-/10-bit A/D converter in the pause-conversion mode requires the setting shown in Figure 13.5-3.



#### Operation of Pause-conversion Mode

- When the start trigger is input, A/D conversion starts at the channel set by the A/D conversion start channel select bits (ANS2 to ANS0). The A/D conversion pauses at the termination of the A/D conversion for one channel. When the start trigger is input while A/D conversion pauses, A/D conversion for the next channel is performed.
- The A/D conversion pauses at the termination of the A/D conversion for the channel set by the A/D conversion end channel select bits (ANE2 to ANE0). When the start trigger is input while A/D conversion pauses, A/D conversion is continued after returning to the channel set by the A/D conversion start channel select bits (ANS2 to ANS0).
- To restart this mode while A/D conversion pauses, input the start trigger set by the A/D start trigger select bits in the A/D control status register (ADCS: STS1, STS0).
- To terminate A/D conversion forcibly, write 0 to the A/D conversion-on flag bit in the A/D control status register (ADCS: BUSY).
- This mode cannot be restarted during A/D conversion.

www.DataSheet4U.com

#### [When start and end channels are the same]

• If the start and end channels have the same channel number (ADCS: ANS2 to ANS0 = ADCS: ANE2 to ANE0), A/D conversion for one channel set as the start channel (= end channel), and pause are repeated.

#### [Conversion order in pause-conversion mode]

Table 13.5-3 gives an example of the conversion order in the pause-conversion mode.

#### Table 13.5-3 Conversion Order in Pause-conversion Mode

| Start Channel                                | End Channel                                | Conversion Order                                                                                            |
|----------------------------------------------|--------------------------------------------|-------------------------------------------------------------------------------------------------------------|
| AN0 pin<br>(ADCS: ANS = "000 <sub>B</sub> ") | AN3 pin<br>(ADCS: ANE="011 <sub>B</sub> ") | AN0> Stop, Start> AN1> Stop, Start><br>AN2> Stop, Start> AN3> Stop, Start><br>AN0> Repeat                   |
| AN6 pin<br>(ADCS: ANS = "110 <sub>B</sub> ") | AN2 pin<br>(ADCS: ANE="010 <sub>B</sub> ") | AN6> Stop, Start> AN7> Stop, Start><br>AN0> Stop, Start> AN1> Stop, Start><br>AN2> Stop, Start> AN6> Repeat |
| AN3 pin<br>(ADCS: ANS = "011 <sub>B</sub> ") | AN3 pin<br>(ADCS: ANE="011 <sub>B</sub> ") | AN3> Stop, Start> AN3> Stop, Start><br>Repeat                                                               |

et4U.com

DataSheet4U.com

## **13.5.4** Conversion Using El<sup>2</sup>OS Function

## The 8-/10-bit A/D converter can transfer the A/D conversion result to memory by using the El<sup>2</sup>OS function.

### ■ Conversion Using El<sup>2</sup>OS

The use of the EI<sup>2</sup>OS enables the A/D-converted data protection function to transfer multiple data to memory without the loss of converted data even if A/D conversion is performed continuously.

The conversion flow when the  $EI^2OS$  is used is shown in Figure 13.5-4.





## 13.5.5 A/D-converted Data Protection Function

## A/D conversion with the output an interrupt request enabled activates the A/D conversion data protection function.

#### A/D-converted Data Protection Function in 8-/10-bit A/D Converter

The 8-/10-bit A/D converter has only one A/D data register (ADCR) where A/D-converted data is stored. When the A/D conversion results are determined after the termination of A/D conversion, data in the A/D data register is rewritten. Therefore, the A/D conversion results may be lost if the A/D conversion results already stored are not read before data in the A/D data register is rewritten. The A/D-converted data protection function in the 8-/10-bit A/D converter is activated to prevent data loss. This function automatically causes A/D conversion to pause when an interrupt request is generated (ADCS: INT = 1) with an interrupt request enabled (ADCS: INT = 1).

- A/D-converted data protection function when El<sup>2</sup>OS not used
  - When the A/D conversion results are stored in the A/D data register (ADCR) after the analog input is A/ D-converted, the interrupt request flag bit in the A/D control status register (ADCS: INT) is set to 1.
  - A/D conversion pauses for data protection while the interrupt request flag bit in the A/D control status register (ADCS: INT) is set.
  - When the INT bit is set with an interrupt request from the A/D control status register enabled (ADCS: INTE = 1), an interrupt request is generated. When the INT bit is cleared by the generated interrupt processing, the pause of A/D conversion is cancelled.

DataShe

- A/D-converted data protection function when El<sup>2</sup>OS used
  - A/D conversion pauses for data protection while the EI<sup>2</sup>OS function is used to transfer the A/D conversion results to memory from the A/D data register after A/D conversion. When A/D conversion pauses, the pause flag bit in the A/D control status register (ADCS: PAUS) is set to 1.
  - When the transfer of the A/D conversion results to memory by the EI<sup>2</sup>OS function is terminated, the pause of A/D conversion is cancelled and the pause flag bit (ADCS: PAUS) is cleared to 0. If A/D conversion is performed continuously, it is restarted.
- Processing flow of A/D conversion data protection function when El<sup>2</sup>OS used

Figure 13.5-5 shows the processing flow of the A/D conversion data protection function when the  $EI^2OS$  is used.

et4U.com

373

#### CHAPTER 13 8-/10-BIT A/D CONVERTER



#### Figure 13.5-5 Processing Flow of A/D Conversion Data Protection Function when Using El<sup>2</sup>OS

• The A/D conversion data protection function is activated only when an interrupt request is enabled. Set the interrupt request enable bit in the A/D control status register (ADCS: INTE) to 1.

- When the EI<sup>2</sup>OS function is used to transfer the A/D conversion results to memory, do not disable output of an interrupt request. If output of an interrupt request is disabled during a pause of A/D conversion (ADCS: INTE = 0), A/D conversion may be restarted to rewrite data being transferred.
- When the EI<sup>2</sup>OS function is used to transfer the A/D conversion results to memory, do not restart. Restarting during a pause of A/D conversion may cause loss of the A/D conversion results.

DataSheet4U.com

Notes:

## 13.6 Precautions when Using 8-/10-bit A/D Converter

Precautions when using the 8-/10-bit A/D converter are given below:

#### Precautions when Using 8-/10-bit A/D Converter

- Analog input pin
  - The analog input pins serve as general-purpose I/O ports of port 5. When using the pin as an analog input pin, switch the pin to "analog input pin" according to the setting of the port 5 direction register (DDR5) and the analog input enable register (ADER).
  - When using the pin as an analog input pin, write 0 to the bit in the DDR5 corresponding to the pin to be used and turn off the output transistor. Also write 1 to the bit in the ADER corresponding to the pin to be used and set the pin to "analog input enable."
  - When an intermediate-level signal is input with the pin set as a general-purpose I/O port, the input leakage current flows in the gate. When using the pin as an analog input pin, always set the pin to "analog input enable".
- Precaution when starting by internal timer or external trigger
- et4U.com

• The input value at which the 8-/10-bit A/D converter is started by the internal timer output or external trigger should be set to "inactive" (High for external trigger). Holding the input value for the start trigger active may cause the 8-/10-bit A/D converter to start concurrently with the setting of the A/D start trigger select bits in the A/D control status register (ADCS: STS1, STS0).

Procedure of 8-/10-bit A/D converter and analog input power-on

- Always apply a power to the A/D converter power (AV<sub>CC</sub>, AVR) and the analog input (AN0 to AN7) after or concurrently with the digital power (V<sub>CC</sub>)-on.
- Always turn off the A/D converter power and the analog input before or concurrently with the digital power ( $V_{CC}$ )-down. Note that AVR should not exceed AV<sub>CC</sub> at power on or power down. (There is no problem to turn on or off the analog power and digital power concurrently.)
- Power supply voltage of 8-/10-bit A/D converter
  - To prevent latch up, note that the 8-/10-bit A/D converter power (AV<sub>CC</sub>) should not exceed the digital power (V<sub>CC</sub>) voltage.

375

#### CHAPTER 13 8-/10-BIT A/D CONVERTER

et4U.com

DataSheet4U.com

DataSheet4U.com

376

DataSheet4U.com

DataShe

www.DataSheet4U.com

# CHAPTER 14 UART1

This chapter explains the function and operation of the UART.

- 14.1 Overview of UART1
- 14.2 Block Diagram of UART1
- 14.3 Configuration of UART1
- 14.4 Interrupt of UART1
- 14.5 Baud Rate of UART1
- 14.6 Explanation of Operation of UART1
- 14.7 Precautions when Using UART1
- 14.8 Program Example for UART1

et4U.com

www.DataSheet4U.com

et4U.com

CHAPTER 14 UART1

## 14.1 Overview of UART1

The UART1 is a general-purpose serial-data communication interface for synchronous or asynchronous communication with external devices.

- Incorporates a bidirectional communication function (clock synchronous and asynchronous modes)
- Incorporates a master/slave type communication function (in multiprocessor mode: only master)
- Capable of generating an interrupt request at completion of transmit completion and receive completion, and at detection of a receive error
- Supports expansion intelligent I/O service (El<sup>2</sup>OS)

#### Function of UART1

Function of UART1

The UART1 is a general-purpose serial-data communication interface, which transmits/receives serial data with external devices. UART1 has functions listed in Table 14.1-1.

Table 14.1-1 Function of UART1

| D                                                                                 | ataSheet4U.com Function                                                                                                                                                                                                                               |  |  |  |
|-----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Data buffer                                                                       | Full-duplicate double-buffer                                                                                                                                                                                                                          |  |  |  |
| Transfer mode                                                                     | <ul> <li>Synchronous to clock (without start bit/stop bit and parity bit)</li> <li>Asynchronous (start-stop synchronization to clock)</li> </ul>                                                                                                      |  |  |  |
| Baud rate                                                                         | <ul> <li>Dedicated baud-rate generator (The baud rate can be selected from among eight types.)</li> <li>Any baud rate can be set by external clock.</li> <li>A clock supplied from the internal clock (16-bit reload timer 1) can be used.</li> </ul> |  |  |  |
| Data length                                                                       | <ul><li> 7 bits (for asynchronous normal mode only)</li><li> 8 bits</li></ul>                                                                                                                                                                         |  |  |  |
| Signal type                                                                       | NRZ (Non Return to Zero) type                                                                                                                                                                                                                         |  |  |  |
| Detection of receive error                                                        | <ul> <li>Framing error</li> <li>Overrun error</li> <li>Parity error (not supported for operation mode 1)</li> </ul>                                                                                                                                   |  |  |  |
| Interrupt request                                                                 | <ul> <li>Receive interrupt (receive, detection of receive error)</li> <li>Transmit interrupt (transmit)</li> <li>Both the transmission and reception support EI<sup>2</sup>OS.</li> </ul>                                                             |  |  |  |
| Master/slave type communication<br>function (asynchronous<br>multiprocessor mode) | This function enables communications between 1 (only use master)<br>and n (slave) (This function is used only as the master side)                                                                                                                     |  |  |  |

Note: DataSheet4U.com At the clock synchronous transfer, the UART only transfers data, not affixing the start and stop bits.

| Operation Mode |                                    | Data Length |           | Synchronous/ | Length of             |
|----------------|------------------------------------|-------------|-----------|--------------|-----------------------|
|                |                                    | With Parity | No Parity | Asynchronous | Stop Bit              |
| 0              | Asynchronous mode<br>(Normal mode) | 7 or 8 bits |           | Asynchronous | 1 bit or 2 bits $*^2$ |
| 1              | Multiprocessor mode                | 8 + 1 *1    | -         | Asynchronous |                       |
| 2              | Synchronous mode                   | 8           | _         | Synchronous  | None                  |

#### Table 14.1-2 Operation Mode of UART1

-: Setting disabled

\*1: +1 is the address/data select bit (SCR1 register bit 11: A/D) used for controlling communications.

\*2: During reception, only one bit can be detected as the stop bit.

et4U.com

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

CHAPTER 14 UART1

## 14.2 Block Diagram of UART1

#### The UART1 consists of the following block.

#### Block Diagram of UART1





DataSheet4U.com

380

#### Details of pins, etc., in block diagram

The actual pin names and interrupt request numbers used in the UART1 are as follows:

SIN1 pin: P40/SIN1 SCK1 pin: P41/SCK1 SOT1 pin: P42/SOT1 Transmit interrupt number 1: #38 (26<sub>H</sub>) Receive interrupt number 1: #37 (25<sub>H</sub>)

#### Clock selector

The clock selector selects the transmit/receive clock from the dedicated baud rate generator, external input clock, and internal clock (clock supplied from 16-bit reload timer).

#### Receive controller

The receive controller is composed of receive bit counter, start bit detector and receive parity counter. The receive bit counter counts the receive data, and outputs a receive interrupt request when reception of one piece of data is completed according to the specified data length.

The start bit detector detects the start bit from the serial input signal and writes the received data to the serial input data register (SIDR1), on a bit-by-bit shift basis in accordance with the transfer rate.

The receive parity counter detects parity bit of the receive data.

DataShe

#### Transmit controller

DataSheet4U.com

The transmit controller is composed of the transmit bit counter, transmit start circuit, and transmit parity counter. The transmit bit counter counts the transmit data, and outputs a transmit interrupt request when transmission of one piece of data is completed according to the set data length. The transmit start circuit starts transmission when serial output data register (SODR1) is written. The transmit parity counter generates the parity bit of the data transferred when parity is provided.

#### Receive shift register

The receive shift register writes the receive data input from the SIN pin while shifting bit-by-bit, and when the data reception is completed, it transfers the receive data to the serial input data register (SIDR1).

#### Transmit shift register

Data written to SODR1 is transferred to the transmit shift register itself, and then the data is output to the SOT pin while shifting bit-by-bit.

et4U.com

Serial mode register 1 (SMR1)

This register:

- Selects operation mode
- Selects clock input source (baud rate)
- Sets dedicated baud rate generator
- Selects clock speed (clock division value) when using dedicated baud rate generator
- · Enables or disables output of serial data and clock pins
- Initialize UART
- Serial control register 1 (SCR1)

This register:

- Sets availability of parity
- Selects type of parity
- Sets stop bit length
- Sets data length
- Selects frame data format in operation mode 1 (asynchronous multiprocessor mode)
- Clears error flag
- Enables or disables transmitting
- Enables or disables receiving

DataSheet4U.com

Serial status register 1 (SSR1)

The status register checks the transmission/reception state and error state and sets enabling/disabling of the transmit/receive interrupt request.

Serial input data register 1 (SIDR1)

The serial input data register retains the receive data. The serial input data is converted and then stored in this register.

Serial output data register 1 (SODR1)

The serial output data register sets the transmit data. Data written to this register is serial-converted and then output.

Communication prescaler control register (CDCR)

The control register sets the baud rate of the baud rate generator, which sets the start/stop of the communication prescaler and the division rate of machine clock.

### 14.3 Configuration of UART1

#### The UART1 pins, interrupt factors, register list and details are shown.

#### UART1 Pin

The pins used in the UART1 serve as general-purpose I/O port.

Table 14.3-1 indicates the pin functions and the setting necessary for use in the UART1.

#### Table 14.3-1 UART1 Pin

| Pin Name | Pin Function                                 | Setting Necessary for Use in UART1                                      |
|----------|----------------------------------------------|-------------------------------------------------------------------------|
| SOT1     | General-purpose I/O port, serial data output | Set to output enable. (SMR1 register bit 0: SOE=1)                      |
| SCK1     | General-purpose I/O port,                    | In clock input, set pin as input port in port direction register (DDR). |
| SCKI     | serial clock input/output                    | In clock output, set to output enable. (SMR1 register bit 1: SCKE=1)    |
| SIN1     | General-purpose I/O port, serial data input  | Set pin as input port in DDR.                                           |

et4U.com

#### ■ Block Diagram of Pins of UART1 DataSheet4U.com

See "CHAPTER 4 I/O PORT" for the block diagram of pins.

#### ■ List of Registers in UART1

| Figure 14.3-1 Lis                                                              | t of | Registe   | ers and   | Reset  | Values | in UAR  | Т1 |   |   |
|--------------------------------------------------------------------------------|------|-----------|-----------|--------|--------|---------|----|---|---|
|                                                                                | bit  | 15        | 14        | 13     | 12     | 11      | 10 | 9 | 8 |
| Serial control register 1 (SCR1)                                               |      | 0         | 0         | 0      | 0      | 0       | 1  | 0 | 0 |
|                                                                                | bit  | 7         | 6         | 5      | 4      | 3       | 2  | 1 | 0 |
| Serial mode register 1 (SMR1)                                                  |      | 0         | 0         | 0      | 0      | 0       | 0  | 0 | 0 |
|                                                                                | bit  | 15        | 14        | 13     | 12     | 11      | 10 | 9 | 8 |
| Serial status register 1 (SSR1)                                                |      | 0         | 0         | 0      | 0      | 1       | 0  | 0 | 0 |
|                                                                                | bit  | 7         | 6         | 5      | 4      | 3       | 2  | 1 | 0 |
| Serial input data register 1 (SIDR1)/<br>Serial output data register 1 (SODR1) |      | Х         | Х         | Х      | Х      | Х       | Х  | Х | x |
| Note: Function as SIDR1 when                                                   | read | ling, fur | nction as | s SODR | 1 when | writing |    |   |   |
|                                                                                | bit  | 15        | 14        | 13     | 12     | 11      | 10 | 9 | 8 |
| Communication prescaler control regis<br>1 (CDCR1)                             | ter  | Х         | Х         | Х      | Х      | Х       | Х  | Х | Х |
| X: Undefined                                                                   | -    |           |           |        |        |         |    |   |   |
|                                                                                |      |           |           |        |        |         |    |   |   |
|                                                                                |      |           |           |        |        |         |    |   |   |

DataSheet4U.com

www.DataSheet4U.com

#### Interrupt Request Generation by UART1

#### • Receive interrupt

- When receive data is loaded to the serial input data register (SIDR1), the receive data load flag bit (bit 12: RDRF) in the serial status register (SSR1) is set to 1. When a receive interrupt is enabled (bit 9: RIE = 1), a receive interrupt request is generated to the interrupt controller.
- When either a framing error, overrun error, or parity error occurs, the framing error flag bit (bit 13: FRE), the overrun error flag bit (bit 14: ORE), or parity error flag bit (bit 15: PE) in the serial status register (SSR1) are set to 1 according to the error occurred. When a receive interrupt is enabled (bit 9: RIE = 1), a receive interrupt is requested to the interrupt controller.

#### • Transmit interrupt

When transmit data is transferred from the serial output data register (SODR1) to the transmit shift register, the transmit data empty flag bit (bit 11: TDRE) in the serial status register (SSR1) is set to 1. If a transmit interrupt is enabled (bit 8: TIE = 1), a transmit interrupt is requested to the interrupt controller.

et4U.com

DataSheet4U.com

DataShe

www.DataSheet4U.com

## 14.3.1 Serial Control Register 1 (SCR1)

The serial control register 1 (SCR1) performs the following: setting parity bit, selecting stop bit length and data length, selecting frame data format in operation mode 1 (asynchronous multiprocessor mode), clearing receive error flag, and enabling/ disabling of transmitting/receiving.

Serial Control Register 1 (SCR1)



Figure 14.3-2 Serial Control Register 1 (SCR1)

DataSheet4U.com

www.DataSheet4U.com

|        | Bit Name                                | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 8  | TXE:<br>Transmit enable bit             | <ul> <li>Enable or disable the UART1 for sending.</li> <li>When set to 0: Transmission disabled</li> <li>When set to 1: Transmission enabled</li> <li>Note: When transmitting is disabled during transmitting, transmitting stops after the data in the serial output data register (SODR1) being transmitted is completed. To set this bit to 0, after writing data to SODR1, wait for a time of 1/16th of the baud rate in the asynchronous mode and for a time equal to or more than the baud rate in the synchronous mode.</li> </ul> |
| bit 9  | RXE:<br>Receive enable bit              | <ul> <li>Enable or disable the UART1 for receiving.</li> <li>When set to 0: Reception disabled</li> <li>When set to 1: Reception enabled</li> <li>Note: When receiving is disabled during receiving, receiving stops after the data being received is stored in the serial input data register.</li> </ul>                                                                                                                                                                                                                                |
| bit 10 | REC:<br>Receive error flag clear<br>bit | Clear the receive error flags (bit 15 to 13: PE, ORE and FRE) of the serial status<br>register (SSR1) to 0.<br>When set to 0: Clears PE, ORE and FRE bits<br>When set to 1: No effect<br>When read: 1 always read<br>Note: When a receive interrupt is enabled (bit 9: RIE = 1), set the bit10: REC bit<br>to 0 only when any one of the PE, ORE and FRE bits is set to 1.                                                                                                                                                                |
| bit 11 | A/D:<br>Address/data select bit         | In operation mode 1 (asynchronous multiprocessor mode), set the data format of<br>the frame to be transmitted/received.<br>When bit set to 0: Data frame set<br>When bit set to 1: Address frame set                                                                                                                                                                                                                                                                                                                                      |
| bit 12 | CL:<br>Data-length select bit           | Specify the length of send and receive data.<br><b>Note:</b> A data length of 7 bits can be selected only in operation mode 0<br>(asynchronous normal mode). In operation modes 1 and 2 (asynchronous<br>multiprocessor mode, Clock synchronous mode), be sure to set a data<br>length of 8 bits.                                                                                                                                                                                                                                         |
| bit 13 | SBL:<br>Stop-bit length select bit      | Set the length of the stop bit (frame end mark of send data) in operation modes 0<br>and 1 (multiprocessor mode, synchronous mode).<br><b>Note:</b> At receiving, only the first bit of the stop bit is always detected.                                                                                                                                                                                                                                                                                                                  |
| bit 14 | P:<br>Parity select bit                 | Select either odd or even parity when with parity ( $PEN = 1$ ) is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| bit 15 | PEN:<br>Parity addition enable bit      | Specify whether to add (at sending) and detect (at receiving) a parity bit.<br><b>Note:</b> A parity bit is not added in operation modes 1 and 2 (Multiprocessor<br>mode, Synchronous mode). Be sure to set this bit to 0.                                                                                                                                                                                                                                                                                                                |

#### Table 14.3-2 Function of Serial Control Register 1 (SCR1)

et4U.com

### 14.3.2 Serial Mode Register 1 (SMR1)

The serial mode register 1 (SMR1) performs selecting operation mode, selecting baud rate clock, and disabling/enabling of output of serial data and clock to pin.

#### Serial Mode Register 1 (SMR1)





|                 | Bit Name                                         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |
|-----------------|--------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| bit 0           | SOE:<br>Serial-data output enable<br>bit         | Enable or disable output of serial data.<br>When set to 0: General-purpose I/O port set<br>When set to 1: Serial data output pin set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      |
| bit 1           | SCKE:<br>Serial clock I/O enable<br>bit          | <ul> <li>Switch between input and output of the serial clock.</li> <li>When set to 0: General-purpose I/O port or serial clock input pin set</li> <li>When set to 1: Serial clock output pin set</li> <li>Notes: 1. When using the SCK1 pin as the serial clock input, set the pin to the input port using the port direction register (DDR). Also select the external clock (bit 5 to 3: CS2 to CS0 = "111<sub>B</sub>") using the clock input source select bit.</li> <li>2. When using the SCK pin as the serial clock output, set the clock input source select bit.</li> <li>2. When using the SCK pin as the serial clock output, set the clock input source select bit to anything other than the external clock (bit 5 to 3: CS2 to CS0 = anything other than "111<sub>B</sub>").</li> </ul> |      |
| bit 2           | RST: UART Reset bit                              | This bit resets all registers in the UART1.<br>When set to 0: No effect on operation<br>When set to 1: Resets all registers in UART1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      |
| bit 3 to bit 5  | CS0 to CS2:<br>Clock input source select<br>bits | <ul> <li>Set the clock input source for the baud rate.</li> <li>Select the external clock (SCK1 pin), internal timer (16-bit reload timer), or dedicated baud rate generator as the clock input source.</li> <li>Set the baud rate when selecting the dedicated baud rate generator.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Data |
| bit 6 and bit 7 | MD0, MD1:<br>Operation mode select<br>bits       | <ul> <li>Select the UART1 operation mode.</li> <li>Notes: 1. In operation mode 1 (asynchronous multiprocessor mode), only the master can be used for master/slave communication. In operation mode 1, the address/data bit on bit 9 cannot be received, so the slave cannot be used.</li> <li>2. In operation mode 1 (asynchronous multiprocessor mode), the parity check function cannot be used, set the parity addition enable bit to no parity (SCR1 register bit 15: PEN = 0).</li> </ul>                                                                                                                                                                                                                                                                                                       |      |

#### Table 14.3-3 Function of Serial Mode Register 1 (SMR1)

| Note: | When 0 is written to the RST bit of Serial Mode Register, the UART interruption should be prohibited. |
|-------|-------------------------------------------------------------------------------------------------------|
| Note. |                                                                                                       |
|       | To prohibit the interruption, take one of the following procedures:                                   |
|       | 1. Before writing 0 to the RST bit, clear I flag to prohibit all interrupt factors.                   |
|       | 2. Before writing 0 to the RST bit, prohibit the UART interruption with the ILM register.             |
|       | 3. When 0 is written to the RST bit, writing should be performed at the UART interruption level or    |
|       | the level with higher priority than the UART interruption.                                            |

DataSheet4U.com

et4U.com

### 14.3.3 Serial Status Register 1 (SSR1)

The serial status register 1 (SSR1) checks the transmission/reception status and error status and enables/disables interrupts.

#### Serial Status Register 1 (SSR1)



Figure 14.3-4 Serial Status Register 1 (SSR1)

DataSheet4U.com

www.DataSheet4U.com

### Table 14.3-4 Function of Serial Status Register 1 (SSR1)

|                                             | Bit Name                              | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |
|---------------------------------------------|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| bit 8 TIE:<br>Transmit interrupt enable bit |                                       | Enable or disable send interrupt.<br>When set to 1:A receive interrupt request is issued when data written to the serial output<br>data register 1 (SODR1) is sent to the transmit shift register (bit 11: TDRE<br>= 1).                                                                                                                                                                                                                                                                                                                                   |     |
| bit 9                                       | RIE:<br>Receive interrupt enable bit  | Enable or disable receive data.<br><b>When set to 1:</b> A receive interrupt request is issued when receive data is loaded to the<br>serial input data register 1 (SIDR1) (bit 12: RDRF = 1) or when a receive<br>error occurs (bit 15: PE = 1, bit 14: ORE = 1, or bit 13: FRE = 1).                                                                                                                                                                                                                                                                      |     |
| bit 10                                      | BDS:<br>Transfer direction select bit | <ul> <li>This bit sets the direction of serial data transfer.</li> <li>When set to 0: Transfers data from least significant bit (LSB first)</li> <li>When set to 1: Transfers data from most significant bit (MSB first)</li> <li>Note: At reading and writing data from and to the serial data register, data is written to the serial output data register (SODR1) and then the transfer direction select bit (BDS) is rewritten to switch between the upper bits and the lower bits of data. In this case, the written data becomes invalid.</li> </ul> |     |
| bit 11                                      | TDRE:<br>Transmit data write flag bit | <ul> <li>Show the status of the serial output data register 1.</li> <li>This bit is cleared to 0 when send data is written to the serial output register 1(SODR1).</li> <li>This bit is set to 1 when data is loaded to the send shift register and transmission starts.</li> <li>When a transmission interrupt is enabled (bit 8: TIE = 1), a transmit interrupt request is issued when data written to the serial output data register 1(SODR1) is transmitted to the transmit shift register (bit 11: TDRE=1).</li> </ul>                               |     |
| bit 12                                      | RDRF:<br>Receive data load flag bit   | <ul> <li>Show the status of the serial input data register 1 (SIDR1).</li> <li>This bit is set to 1 when receive data is loaded to the serial input register 1 (SIDR1).</li> <li>This bit is cleared to 0 when data is read from the SIDR1.</li> <li>When a receive interrupt is enabled (bit 9: RIE = 1), a receive interrupt request is issued when receive data is loaded to the serial input data register 1 (SIDR1).</li> </ul>                                                                                                                       | Dat |
| bit 13                                      | FRE:<br>Framing error flag bit        | <ul> <li>Detect a framing error in receive data.</li> <li>This bit is set to 1 when a framing error occurs.</li> <li>This bit is cleared when 0 is written to the receive error flag clear bit (SCR1 register bit 10: REC).</li> <li>When a receive interrupt is enabled (bit 9: RIE = 1), a receive interrupt request is issued when a framing error occurs.</li> <li>When the framing error flag bit is set (bit 13: FRE = 1), data in the serial input data register 1 (SIDR1) is invalid.</li> </ul>                                                   |     |
| bit 14                                      | ORE:<br>Overrun error flag bit        | <ul> <li>Detect an overrun error in receiving.</li> <li>This bit is set to 1 when an overrun error occurs.</li> <li>This bit is cleared when 0 is written to the receive error flag clear bit (SCR1 register bit 10: REC).</li> <li>When a receive interrupt is enabled (bit 9: RIE = 1), a receive interrupt request is issued when an overrun error occurs.</li> <li>When the overrun error flag bit is set (bit 14: ORE = 1), data in the serial input data register 1 (SIDR1) is invalid.</li> </ul>                                                   |     |
| bit 15                                      | PE:<br>Parity error flag bit          | <ul> <li>Detect a parity error in receiving.</li> <li>This bit is set to 1 when a parity error occurs.</li> <li>This bit is cleared when 0 is written to the receive error flag clear bit (SCR1 register bit 10: REC).</li> <li>When a receive interrupt is enabled (bit 9: RIE = 1), a receive interrupt request is issued when a parity error occurs.</li> <li>When the parity error flag bit is set (bit 15: PE = 1), data in the serial input data register 1 (SIDR1) is invalid.</li> </ul>                                                           |     |

DataSheet4U.com

et4U.com

390

# 14.3.4 Serial Input Data Register 1 (SIDR1) and Serial Output Data Register 1 (SODR1)

The serial input data register (SIDR1) and serial output data register (SODR1) are allocated to the same address. At read, the register functions as SIDR1. At write, the register functions as SODR1.

### Serial Input Data Register 1 (SIDR1)



et4U.com

SIDR1 is a data buffer register for receiving serial data.

• The serial data signal transmitted to the serial data input pin (SIN1) is converted by the shift register and stored in SIDR1. DataSheet4U.com

- When the data length is 7 bits, the upper one bit (SIDR1: D7) becomes invalid.
- When receive data is stored in the serial input data register 1 (SIDR1), the receive data load flag bit (SSR1 register bit 12: RDRF) is set to 1. When a receive interrupt is enabled (SSR1 register bit 9: RIE = 1), a receive interrupt request is issued to the interrupt controller.
- Read SIDR1 when the receive data load flag bit (SSR1 register bit 12: RDRF) is set to 1. The receive data load flag bit (SSR1 register bit 12: RDRF) is cleared to 0 automatically when SIDR1 is read.
- When a receive error occurs (any one of SSR1 register bit 15, 14, 13: PE, ORE and FRE is 1), the receive data in SIDR1 becomes invalid.

#### Serial Output Data Register 1 (SODR1)



The serial output data register 1 (SODR1) is a data buffer register for transmitting serial data.

- When data to be transmitted is written to SODR1 when transmission is enabled (SCR1 register bit 8: TXE = 1), it is transferred to the transmit shift register, converted to serial data, and transmit from the serial data output pin (SOT1).
- When the data length is 7 bits, the upper one bit (SODR1 register bit 7: D7) becomes invalid.
- The transmit data write flag (SSR1 register bit 11: TDRE) is cleared to 0 when send data is written to SODR1.
- The transmit data write flag is set to 1 at completion of data transfer to the transmit shift register.
- When the transmit data write flag (SSR1 register bit 11: TDRE) is 1, the next transmit data can be written. When a transmit interrupt is enabled (SSR1 register bit 8: TIE=1), a transmit interrupt occurs to the interrupt controller. The next transmit bit data should be written with the transmit data write flag (SCR1 register bit 11: TDRE) at 1.

Note: Serial output data register is a write-only register and serial input data register is a read-only register. However, since they are allocated to the same address, the write and read values are different. Therefore, do not use instructions that perform read-modify-write (RMW) operation such as INC and DEC instructions.

et4U.com

### 14.3.5 Communication Prescaler Control Register 1 (CDCR1)

The communication prescaler control register 1 (CDCR1) is used to set the baud rate of the dedicated baud rate generator for the UART1.

- Starts/stop the communication prescaler
- Sets the division ratio for machine clock

#### ■ Communication Prescaler Control Register 1 (CDCR1)



Figure 14.3-7 Communication Prescaler Control Register 1 (CDCR1)

DataShe

et4U.com

393

| Bit Name         |                                                                    | Function                                                                                                                                                                                                                                                                                 |  |  |  |
|------------------|--------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| bit 8 to bit 10  | DIV0 to DIV2:<br>Communication<br>prescaler division ratio<br>bits | <ul> <li>These bits set the machine clock division ratio.</li> <li>Note: When changing the division ratio, the time of at least 2 cycles division of the division clock should be allowed before the next communication is started in order to stabilize the clock frequency.</li> </ul> |  |  |  |
| bit 11           | Reserved: Reserved bit                                             | Be sure to set this bit to 0.                                                                                                                                                                                                                                                            |  |  |  |
| bit 12 to bit 14 | Unused bits                                                        | Read: The value is not fixed.<br>Write: No effect                                                                                                                                                                                                                                        |  |  |  |
| bit 15           | MD:<br>Communication<br>prescaler control bit                      | This bit enables or disables the communication prescaler.<br>When set to 0: Stops communication prescaler<br>When set to 1: Operates communication prescaler                                                                                                                             |  |  |  |

| Table 14.3-5         Functions of Communication Prescaler Control Register 1 (CDCR1) |
|--------------------------------------------------------------------------------------|
|--------------------------------------------------------------------------------------|

et4U.com

DataSheet4U.com

DataShe

DataSheet4U.com

### 14.4 Interrupt of UART1

The UART1 has a receive and a transmit interrupts, and the following factors can issue interrupt requests.

- Receive data is loaded to the serial input data register 1 (SIDR1).
- A receive error (parity error, overrun error, framing error) occurs.
- When send data transferred from the serial output data register 1 (SODR1) to transmit shift register

Also, each of these interrupt factors supports the expansion intelligent I/O service (El<sup>2</sup>OS).

#### Interrupt of UART1

The UART1 interrupt control bits and interrupt factors are shown in Table 14.4-1.

| Table 14.4-1 | UART1 | Interrupt | <b>Control Bit</b> | and | Interrupt | Factor |
|--------------|-------|-----------|--------------------|-----|-----------|--------|
|--------------|-------|-----------|--------------------|-----|-----------|--------|

| Trans-mission/<br>Reception | Interrupt-<br>request |   | berati<br>Mode |   | Interrupt Factor                                                                        | Interrupt<br>Factor | Clear of the Interrupt-<br>request Flag |          |
|-----------------------------|-----------------------|---|----------------|---|-----------------------------------------------------------------------------------------|---------------------|-----------------------------------------|----------|
| Reception                   | Flag Bit              | 0 | 1              | 2 |                                                                                         | Enable Bit          | request riag                            | DataShee |
|                             | SSR1: RDRF            | 0 | 0              | 0 | Receive data loaded into<br>serial input data register 1<br>(SIDR1)                     |                     | Reading receive data                    |          |
| Reception                   | SSR1:ORE              | 0 | 0              | 0 | Overrun error                                                                           | SSR1: RIE           | Writing 0 to receive error              |          |
|                             | SSR1:FRE              | 0 | 0              | Х | Framing error                                                                           |                     | flag clear bit (SCR1                    |          |
|                             | SSR1:PE               | 0 | X              | Х | Parity error                                                                            |                     | register bit 10: REC)                   |          |
| Transmission                | SSR1: TDRE            | 0 | 0              | 0 | Transfer of transmit data<br>completed from serial<br>output data register 1<br>(SODR1) | SSR1: TIE           | Writing transmit data                   |          |

O: Available

X: Not available

et4U.com

#### Receive interrupt

When a receive interrupt is enabled (SSR1 register bit 9: RIE = 1), a receive interrupt request is issued to the interrupt controller at completion of data receiving (SSR1 register bit 12: RDRF = 1) or when any one of the overrun error (SSR1 register bit 14: ORE = 1), framing error (SSR 1 register bit 13: FRE = 1), and parity error (SSR 1 register bit 15: PE = 1) occurs.

The receive data load flag (SSR1 register bit 12: RDRF) is cleared to 0 automatically when the serial input data register 1 (SIDR1) is read. Each receive error flag (SSR1 register bit 15, 14, 13: PE, ORE, FRE) is cleared to 0 when 0 is written to the receive error flag clear bit (SCR1 register bit 10: REC).

Note: If a receive error (parity error, overrun error, framing error) occurs, correct the error as necessary, and then write 0 to the receive error flag clear bit (SCR1 register bit 10: REC) to clear each receive error flag.

#### Transmit interrupt

When send data is transmitted from the serial output data register 1 (SODR1) to the transmit shift register, the transmit data write flag bit (SSR1 register bit 11: TDRE) is set to 1.

When a transmit interrupt is enabled (SSR1 register bit 8: TIE = 1), a send interrupt request is issued to the interrupt controller.

#### Interrupt Related to UART1 and El<sup>2</sup>OS

See Section "3.5 Interrupt" for the interrupt number, interrupt control register, and interrupt vector addresses.

t4U.com

#### ■ EI<sup>2</sup>OS Function of UART1

DataSheet4U.com

The UART1 supports EI<sup>2</sup>OS. Consequently, EI<sup>2</sup>OS can be started separately for receive interrupts and transmit interrupts.

#### At reception:

The EI<sup>2</sup>OS can be used regardless of the state of other resources.

#### • At transmission:

Since the interrupt control registers (ICR13, 14) are shared with transmit interrupts of UART1, EI<sup>2</sup>OS can be started only when UART1 receive interrupts are not used.

### 14.4.1 Generation of Receive Interrupt and Timing of Flag Set

## Interrupts at receiving include the receive completion (SSR1 register bit 12: RDRF), and the receive error (SSR1 register bit 15, 14, 13: PE, ORE, FRE).

#### Generation of Receive Interrupt and Timing of Flag Set

#### • Receive data load flag and each receive error flag sets

When data is received, it is stored in the serial input data register 1 (SIDR1) when the stop bit is detected (in operation modes 0 and 1: Asynchronous normal mode, Asynchronous multiprocessor mode) or when the last bit of receive data (SIDR1 register bit 7: D7) is detected (in operation mode 2: Clock synchronous mode). When a receive error occurs, the error flags (SSR1 register bit 15, 14, 13: PE, ORE, FRE) and receive data load flag (SSR1 register bit 12: RDRF) are set. In each operation mode, the received data in the serial input data register 1 (SIDR1) is invalid if either error flag is set.

#### **Operation mode 0 (Asynchronous normal mode)**

The receive data load flag bit (SSR1 register bit 12: RDRF) is set when the stop bit is detected. The error flags (SSR1 register bit 15, 14, 13: PE, ORE, FRE) are set when a receive error occurs.

#### **Operation mode 1 (Asynchronous multiprocessor mode)**

The receive data load flag bit (SSR1 register bit 12: RDRF) is set when the stop bit is detected. The error DataShet flags (SSR1 register bit 14, 13: ORE, FRE) are set when a receive error occurs. A parity error (SSR1 register bit 15: PE) cannot be detected.

#### **Operation mode 2 (Clock synchronous mode)**

The receive data load flag bit (SSR1 register bit 12: RDRF) is set to 1 when the last bit of receive data (SIDR1 register bit 7: D7) is detected. The error flags (SSR1 register bit 14: ORE) are set when a receive error occurs. A parity error (SSR1 register bit 15: PE) and framing error (SSR1 register bit 13: FRE) cannot be detected.

Reception and timing of flag set are shown in Figure 14.4-1.

et4U.com

www.DataSheet4U.com

397





• Timing of receive interrupt request generation

With a receive interrupt enabled (SSR1 register bit 9: RIE = 1), when any one of the receive data load flag (SSR1 register bit 12: RDRF), parity error flag (SSR1 register bit 15: PE), overrun error flag (SSR1 register bit 14: ORE) and framing error flag (SSR1 register bit 13: FRE) is set, reception interrupt is requested to interrupt controller.

t4U.com

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

DataShe

DataSheet4U.com

### 14.4.2 Generation of Transmit Interrupt and Timing of Flag Set

## At transmission, the interrupt is generated in the state which the succeeding data can be written to the serial output data register 1 (SODR1).

#### ■ Generation of Transmit Interrupt and Timing of Flag Set

• Set and clear of transmit data empty flag bit

The send data write flag bit (SSR1 register bit 11: TDRE) is set when the send data written to the serial output data register 1 (SODR1) is loaded to the send shift register and the next data is ready for writing. The send data write flag bit (SSR1 register bit 11: TDRE) is cleared to 0 when the next send data is written to the serial output data register 1 (SODR1).

Transmission and timing of flag set are shown in Figure 14.4-2.



Figure 14.4-2 Transmission and Timing of Flag Set

#### DataSheet4U.com

### 14.5 Baud Rate of UART1

One of the following can be selected as the UART1 transmit/receive clock.

- Dedicated baud rate generator
- Internal clock (16-bit reload timer output)
- External clock (clock input to SCK1 pin)

Select of UART1 Baud Rate

The UART1 baud rate select circuit comprises as shown in Figure 14.5-1. The clock input source can be selected from among the following three types:

Baud rate by dedicated baud rate generator

- When using the dedicated baud rate generator incorporated into UART1 as a clock input source, set the CS2 to CS0 bits in the serial mode register (SMR1) bit 5 to 3 to " $000_B$ " to " $101_B$ " according to the baud rate. The baud rate can be selected from six types.
- Baud rate by internal timer
  - When using the internal clock supplied from the 16-bit reload timer as a clock input source, set the CS2 to CS0 bits in SMR1 bit 5 to 3 to "110<sub>B</sub>".

DataShee

- The baud rate is the value at which the clock supplied from the 16-bit reload timer as it is in the clock synchronous mode, and the value at which the frequency of the supplied clock is divided by 16 in the clock asynchronous mode.
- Any baud rate can be selected according to the setting values of the 16-bit reload timer.
- Baud rate by external clock
  - When using the external clock supplied from the clock input pin (SCK1) in the UART1 as the clock input source, set the CS2 to CS0 bits in SMR1 bit 5 to 3 to "111<sub>B</sub>".
  - The baud rate is the value at which the external clock is supplied in the clock synchronous mode and the value at which the frequency of the input clock is divided by 16 in the clock asynchronous mode.

et4U.com





DataSheet4U.com

et4U.com

www.DataSheet4U.com

### 14.5.1 Baud Rate by Dedicated Baud Rate Generator

## The baud rate that can be set when the output clock of the dedicated baud rate generator is selected as the transmit/receive clock of the UART1 is shown.

#### Baud Rate by Dedicated Baud Rate Generator

The baud rate based on the dedicated baud rate generator is set by setting the clock input source select bits in the serial mode register (SMR1 register bit 5 to 3: CS2 to CS0) to " $000_B$ " to " $101_B$ ".

When generating a transmit/receive clock using the dedicated baud rate generator, the division ratio for the clock input source selected by the clock selector is selected to determine the baud rate after the machine clock frequency is divided by the communication prescaler.

The division ratio at which the machine clock frequency is divided by the communication prescaler is the same for the clock synchronous and asynchronous modes. The division ratio at which the baud rate is determined is different for the clock synchronous and asynchronous modes.

Figure 14.5-2 shows the baud rate selector based on the dedicated baud rate generator.



Figure 14.5-2 Baud Rate Selector Based on Dedicated Baud Rate Generator

#### Calculation expression for baud rate

Baud rate in asynchronous mode =  $\phi$  x div x (division ratio of transfer clock in asynchronous mode)

Baud rate in clock synchronous mode =  $\phi x \text{ div } x$  (division ratio of transfer clock in clock synchronous mode)

φ: Machine clock frequency

div: Division ratio based on communication prescaler

et4U.com

#### Division ratio based on communication prescaler (common between asynchronous and clock synchronous modes)

The division ratio of the machine clock is set by the division ratio select bits in the communication prescaler control register (CDCR1 register bit 10 to 8: DIV2 to DIV0).

| MD | DIV2 | DIV1 | DIV0 | div  |
|----|------|------|------|------|
| 0  | -    | _    | _    | Stop |
| 1  | 0    | 0    | 0    | 1    |
| 1  | 0    | 0    | 1    | 2    |
| 1  | 0    | 1    | 0    | 3    |
| 1  | 0    | 1    | 1    | 4    |
| 1  | 1    | 0    | 0    | 5    |
| 1  | 1    | 0    | 1    | 6    |
| 1  | 1    | 1    | 0    | 7    |
| 1  | 1    | 1    | 1    | 8    |

#### Table 14.5-1 Division Ratio Based on Communication Prescaler

et4U.com

div: Division ratio based on communication prescaler

DataShe

#### Baud rate (asynchronous mode)

DataSheet4U.com

The baud rate in the asynchronous mode is generated using output clock of the communication prescaler. The division ratio is set by the clock input source select bits (SMR1 register bit 5 to 3: CS2 to CS0).

#### Table 14.5-2 Baud Rate (Asynchronous Mode)

| CS2 | CS1 | CS0 | Asynchronous Mode<br>(Start/Stop Synchronous) | Calculation                  |
|-----|-----|-----|-----------------------------------------------|------------------------------|
| 0   | 0   | 0   | 76,923 bps                                    | (\$\phi/div) / (8 x 13 x 2)  |
| 0   | 0   | 1   | 38,461 bps                                    | (\$\phi/div) / (8 x 13 x 4)  |
| 0   | 1   | 0   | 19,230 bps                                    | (\$\phi/div) / (8 x 13 x 8)  |
| 0   | 1   | 1   | 9,615 bps                                     | (\$\phi/div) / (8 x 13 x 16) |
| 1   | 0   | 0   | 500 kbps                                      | (\$\phi/div) / (8 x 2 x 2)   |
| 1   | 0   | 1   | 250 kbps                                      | (\$\phi/div) / (8 x 2 x 4)   |

φ: Machine clock frequency

div: Division ratio based on communication prescaler

#### Baud rate (synchronous mode)

The baud rate in the synchronous mode is generated by dividing the output clock of the communication prescaler by 1, 2, 4, 8, 16 and 32. Set the division ratio using the clock input source select bits (bits 5 to 3 in SMR1 register: CS2 to CS0).

| CS2 | CS1 | CS0 | CLK Synchronous | Calculation  |
|-----|-----|-----|-----------------|--------------|
| 0   | 0   | 0   | 2 Mbps          | (¢/div) / 1  |
| 0   | 0   | 1   | 1 Mbps          | (¢/div) / 2  |
| 0   | 1   | 0   | 500 kbps        | (\$\div) / 4 |
| 0   | 1   | 1   | 250 kbps        | (¢/div) / 8  |
| 1   | 0   | 0   | 125 kbps        | (¢/div) / 16 |
| 1   | 0   | 1   | 62.5 kbps       | (¢/div) / 32 |

Table 14.5-3 Baud Rate (Clock Synchronous)

φ: Machine clock frequency

div: Division ratio based on communication prescaler

et4U.com

DataShe

DataSheet4U.com

### 14.5.2 Baud Rate by Internal Timer (16-bit Reload Timer)

The setting when selecting the internal clock supplied from the 16-bit reload timer 1 as the clock input source of the UART1 and the baud rate calculation are shown below.

#### Baud Rate by Internal Timer (16-bit Reload Timer Output)

The baud rate based on the internal timer (16-bit reload timer output) is set by setting the clock input source select bits (SMR1 register bit 5 to 3: CS2 to CS0) to " $110_B$ ". Any baud rate can be set by selecting the division ratio of the count clock and the reload value of the 16-bit reload timer freely.

Figure 14.5-3 shows the baud rate selector based on the internal timer.

- If the internal timer (16-bit reload timer) is selected as a clock input source (SMR1 register bit 5 to 3: CS2 to CS0), the 16-bit reload timer output pin (TOT) is connected internally and does not need to be connected externally to the external clock input pin (SCK).
- The 16-bit reload timer output pin (TOT) can be used as a general-purpose I/O port when it is not being used in other way.





• Calculation expression for baud rate



φ: machine clock frequency

N: division ratio based on communication prescaler for 16-bit reload timer  $(2^1, 2^3, 2^5)$ 

n: reload value for 16-bit reload timer (0 to 65,535)

DataSheet4U.com

www.DataSheet4U.com

 Example of setting baud rates and reload register setting values (machine clock frequency: 7.3728 MHz)

|                    | Reload Value                                    |                                                 |                                                 |                                                 |  |  |
|--------------------|-------------------------------------------------|-------------------------------------------------|-------------------------------------------------|-------------------------------------------------|--|--|
| Baud Rate<br>(bps) | Clock Asyı<br>(start-stop syr                   |                                                 | Clock Synchronous                               |                                                 |  |  |
|                    | N = 2 <sup>1</sup> (machine<br>clock 2-divided) | N = 2 <sup>3</sup> (machine<br>clock 8-divided) | N = 2 <sup>1</sup> (machine<br>clock 2-divided) | N = 2 <sup>3</sup> (machine<br>clock 8-divided) |  |  |
| 38,400             | 2                                               | _                                               | 47                                              | 11                                              |  |  |
| 19,200             | 5                                               | -                                               | 95                                              | 23                                              |  |  |
| 9,600              | 11                                              | 2                                               | 191                                             | 47                                              |  |  |
| 4,800              | 23                                              | 5                                               | 383                                             | 95                                              |  |  |
| 2,400              | 47                                              | 11                                              | 767                                             | 191                                             |  |  |
| 1,200              | 95                                              | 23                                              | 1,535                                           | 383                                             |  |  |
| 600                | 191                                             | 47                                              | 3,071                                           | 767                                             |  |  |
| 300                | 383 Dat                                         | aSheet49.5om                                    | 6,143                                           | 1,535                                           |  |  |

| Table 14.5-4         Baud Rate and Reload Value | Table 14.5-4 | Baud R | Rate and | Reload | Value |
|-------------------------------------------------|--------------|--------|----------|--------|-------|
|-------------------------------------------------|--------------|--------|----------|--------|-------|

et4U.com

DataShee

N: Division ratio based on communication prescaler for 16-bit reload timer

-: Setting disabled

### 14.5.3 Baud Rate by External Clock

## This section explains the setting when selecting the external clock as the transmit/ receive clock of the UART1.

#### Baud Rate by External Clock

To select a baud rate by the external clock input, the following settings are essential:

- Set the clock input source select bits in the serial mode register (SMR1 register bit 5 to 3: CS2 to CS0) to "111<sub>B</sub>".
- Set the SCK1 pin as the input port in the port direction register (DDR).
- Set the serial clock I/O enable bit (SMR1 register bit 1: SCKE) to 0.
- Set the baud rate on the basis of the external clock input from the SCK1 pin. Since the internal division ratio is fixed, the external input clock must be changed in changing the baud rate.



#### Figure 14.5-4 Baud Rate Selector by External Clock

Expressions to obtain baud rate

Asynchronous baud rate = f/16 bps

Clock synchronous baud rate = f bps

f: External clock frequency (2 MHz max.)

et4U.com

### 14.6 Explanation of Operation of UART1

The UART1 has master/slave type connection communication function (operation mode 1: asynchronous multiprocessor mode) in addition to bidirectional serial communication function (operation modes 0 and 2: asynchronous normal mode and clock synchronous mode).

#### Operation of UART1

Operation mode

The UART1 has three types of operation modes, they can set the inter-CPU connection mode or data communication mode.

Table 14.6-1 shows operation mode of UART1.

Table 14.6-1 Operation Mode of UART 1

|   | Operation Mode         | Data Length              |                     | Synchronous/ | Length of Stop Bit    |      |  |
|---|------------------------|--------------------------|---------------------|--------------|-----------------------|------|--|
|   | Operation mode         | No Parity With Parity    |                     | Asynchronous | Length of Stop Bit    |      |  |
| 0 | Normal mode            | 7 bits c                 | or 8 bits           | Asynchronous | *2                    | Data |  |
| 1 | Multiprocessor mode    | 8 + 1 <sup>D</sup> ∎taSh | ieet4U. <u>c</u> om | Asynchronous | 1 bit or 2 bits $*^2$ |      |  |
| 2 | Clock synchronous mode | 8                        | _                   | Synchronous  | None                  |      |  |

-: Setting disabled

et4U.com

\*1: +1 is the address/data select bit (SCR1 register bit 11: A/D) used for controlling communications.

\*2: During reception, only one bit can be detected as the stop bit.

Note: The UART1 operation mode 1 (asynchronous multiprocessor mode) is only used as the master in the master/slave type connection.

#### Inter-CPU connection mode

Either 1-to-1 connection or master/slave type connection can be selected for the inter-CPU connection mode. In both cases, the data length, parity, synchronous or asynchronous mode, etc., must be the same for all CPUs. The operation modes are selected as follows.

- For the 1-to-1 connection, the same operation mode (either operation mode 0 or 2: normal mode, clock synchronous mode) must be adopted for the two CPUs. For the asynchronous mode, select operation mode 1: asynchronous multiprocessor mode (SMR1 register bit 7, 6: MD1, MD0 = "00<sub>B</sub>"): for the synchronous mode select operation mode 2: clock synchronous mode (SMR1 register bit 7, 6: MD1, MD0 = "10<sub>B</sub>").
- For the master/slave type connection, operation mode 1: asynchronous multiprocessor mode (SMR1 register bit 7, 6: MD1, MD0 = " $01_B$ " is set; select operation mode 1 (asynchronous multiprocessor mode) and use it as the master. For this connection, select no parity and 8-bit data length.

www.DataSheet4U.com

DataSheet4U.com

#### • Synchronous/asynchronous

For the operation modes, either the asynchronous mode (start-stop synchronization) or the clocksynchronous mode can be selected.

• Signal mode

The UART1 can only handle the NRZ (Non Return to Zero) data format.

- Start of transmission/reception
  - Transmission starts when the transmission enable bit of the serial control register (SCR1 register bit 8: TXE) is set to 1.
  - Reception starts when the reception enable bit of the serial control register (SCR1 register bit 9: RXE) is set to 1.
- Stop of transmission/reception
  - Transmission stops when the transmission enable bit of the serial control register (SCR1 register bit 8: TXE) is set to 0.
  - Reception stops when the reception enable bit of the serial control register (SCR1 register bit 9: RXE) is set to 0.

#### Stop during transmission/reception

- When reception is disabled during receiving (during data input to reception shift register) (SCR1 register bit 9: RXE = 0), it stops after reception of the frame being received is completed and the receive data is stored to the serial input data register 1 (SIDR1).
- When transmission is disabled during transmission (during data output from the transmission shift register) (SCR1 register bit 8: TXE = 0), it stops after transmission of one frame to the transmission shift register from the serial output data register 1 (SODR1) is completed.

DataSheet4U.com

et4U.com

www.DataSheet4U.com

### 14.6.1 Operation in Asynchronous Mode (Operation Mode 0 or 1)

When the UART 1 is used in operation mode 0 (asynchronous normal mode) or operation mode 1 (asynchronous multiprocessor mode), the asynchronous transfer mode is selected.

#### Operation in Asynchronous Mode

• Format of transmit/receive data

Transmission and reception always start with the start bit (Low level); transmission and reception are performed at the specified data bit length on LSB first basis and end with the stop bit (High level).

- In operation mode 0 (Asynchronous normal mode), the data length can be set to 7 or 8 bits. Use of the parity bit can be specified.
- In operation mode 1 (Asynchronous multiprocessor mode), the data length is fixed to 8 bits. There is no parity bit. The address/data bit (SCR1 register bit 11: A/D) is added to bit 9.

Figure 14.6-1 shows the transmit/receive data format in the asynchronous mode.

et4U.com

DataShe

DataSheet4U.com

www.DataSheet4U.com





et4U.com

#### Transmission

- Transmit data is written to the serial output data register 1 (SODR1) with the transmit data write flag bit (SSR1 register bit 11: TDRE) set to 1.
- Transmission starts when transmit data is written and the transmit enable bit of the serial control register (SCR1 register bit 8: TXE) is set to 1.
- The transmit data write flag bit (SSR1 register bit 11: TDRE) is cleared to 0 temporarily when transmit data is written to SODR1.
- The transmit data write flag bit (SSR1 register bit 11: TDRE) is set to 1 again once the transmit data is written to the send shift register from the serial output data register 1 (SODR1).
- When the transmit interrupt enable bit (SSR1 register bit 8: TIE) is set to 1, a send interrupt request is issued once the send data write flag bit (SSR1 register bit 11: TDRE) is set to 1. The succeeding send data can be written to the serial output data register 1 (SODR1) at interrupt processing.

411

#### Reception

- When reception is enabled (SCR1 register bit 9: RXE = 1), receiving is always performed.
- When the start bit of receive data is detected, the serial input data register 1 (SIDR1) receives one frame of data and stores data to the serial input data register 1 (SIDR1) according to the data format specified in the serial control register 1 (SCR1).
- At completion of receiving one frame of data, the receive data load flag bit (SSR1 register bit 12: RDRF) is set to 1.
- When the status of the error flag of the serial status register 1 (SSR1) is checked to find normal reception at the completion of one frame of data, read the receive data from the serial input data register 1 (SIDR1). When a receive error occurs, perform error processing.
- The receive data load flag bit (SSR1 register bit 12: RDRF) is cleared to 0 when receive data is read.

et4U.com

DataSheet4U.com

DataShe

DataSheet4U.com

www.DataSheet4U.com

#### Detecting the start bit

Implement the following settings to detect the start bit:

- Set the communication line level to H (attach the mark level) before the communication period.
- Specify reception permission (RXE = H) while the communication line level is H (mark level).
- Do not specify reception permission (RXE = H) for periods other than the communication period (without mark level). Otherwise, data is not received correctly.
- After the stop bit is detected (the RDRF flag is set to 1), specify reception inhibition (RXE = L) while the communication line level is H (mark level).



#### Figure 14.6-2 Example of normal operation

et4U.com

Note that specifying reception permission at the timing shown below obstructs the correct recognition of the input data (SIN) by the microcontroller.

• Example of operation if reception permission (RXE = H) is specified while the communication line level is L.



#### Figure 14.6-3 Example of abnormal operation

#### Stop bit

During transmission, one bit or two bits can be selected. However, the receive side always detects only the first bit.

DataSheet4U.com

www.DataSheet4U.com

#### • Error detection

- In operation mode 0 (asynchronous normal mode), parity, overrun, and frame errors can be detected.
- In operation mode 1 (asynchronous multiprocessor mode), overrun and frame errors can be detected, but parity errors cannot be detected.

#### Parity bit

A parity bit can be set only in operation mode 0 (asynchronous normal mode). The parity addition enable bit (SCR1 register bit 15: PEN) is used to specify whether there is parity or not, and the parity select bit (SCR1 register bit 14: P) is used to select odd or even parity.

There is no parity bit in operation modes 1 (asynchronous multiprocessor mode).

The transmit/receive data when the parity bit enabled are shown in Figure 14.6-4.



#### Figure 14.6-4 Transmit/Receive Data when Parity Bit Enabled

DataShe

et4U.com

### 14.6.2 Operation in Clock Synchronous Mode (Operation Mode 2)

#### When the UART1 is used in operation mode 2, the transfer mode is clock synchronous.

#### Operation in Clock Synchronous Mode (Operation Mode 2)

#### Format of transmit/receive data

In the clock synchronous mode, 8-bit data is transmitted/received on LSB-first, and the start and stop bits are not added.

Figure 14.6-5 shows the transmit/receive data format for the clock synchronous mode.

## Figure 14.6-5 Format of Transmit/Receive Data (Operation Mode 2)



DataSheet4U.com

www.DataSheet4U.com

#### Clock supply

In the clock synchronous mode, count of clocks equal to the transmit and receive bits count must be supplied.

- When the internal clock (dedicated baud rate generator or internal timer) has already selected (SMR1 register bit 5 to 3: CS2 to  $CS0 = "000_B"$  to " $101_B"$  or " $110_B"$ ) and data is transmitted, the synchronous clock for data reception is generated automatically.
- When the external clock has already selected (SMR1 register bit 5 to 3: CS2 to  $CS0 = "111_B"$ ), the clock for exact one byte must be supplied from outside after ensuring that data is present (SSR1 register bit 11: TDRE = 0) in the serial output data register 1 (SODR1). Also, before and after transmitting, always return to the mark level (High level).

#### Error detection

Only overrun errors can be detected; parity and framing errors cannot be detected.

#### • Setting of register

Table 14.6-2 shows the setting of the control register in transmitting serial data from the transmitting end to the receiving end using the clock synchronous mode (operation mode 2).

| Table 14.6-2 | Setting o | f Control | Register |
|--------------|-----------|-----------|----------|
|--------------|-----------|-----------|----------|

|                                  |                  | Setting                                                                                                                                                                                               |                                                                                   |  |
|----------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--|
| Register Name                    | Bit Name         | Transmit End <sup>J.com</sup><br>(output serial clock)                                                                                                                                                | Receive End<br>(input serial clock)                                               |  |
| Serial mode<br>register 1 (SMR1) | MD1,<br>MD0      | Set clock synchronous mode (MD1, MD0 = $"10_B"$ ).                                                                                                                                                    |                                                                                   |  |
|                                  | CS2, CS1,<br>CS0 | <ul> <li>Set clock input source.</li> <li>Dedicated baud rate generator<br/>(CS2 to CS0 = "000<sub>B</sub>" to "101<sub>B</sub>")</li> <li>Internal timer (CS2 to CS0 = "110<sub>B</sub>")</li> </ul> | Set clock input source.<br>• External clock<br>(CS2 to CS0 = "111 <sub>B</sub> ") |  |
|                                  | SCKE             | Set serial clock output<br>(SCKE = 1).                                                                                                                                                                | Set serial clock input<br>(SCKE = 0).                                             |  |
|                                  | SOE              | Set serial data output pin<br>(SOE = 1).                                                                                                                                                              | Set general-purpose I/O port (SOE = $0$ ).                                        |  |
| Serial control                   | PEN              | Do not add parity bit ( $PEN = 0$ ).                                                                                                                                                                  |                                                                                   |  |
| register 1 (SCR1)                | CL               | 8-bit data length ( $CL = 1$ )                                                                                                                                                                        |                                                                                   |  |
|                                  | REC              | Initialize error flag ( $REC = 0$ ).                                                                                                                                                                  |                                                                                   |  |
|                                  | TXE              | Enable transmitting (TXE = 1).                                                                                                                                                                        | Disable transmitting (TXE = $0$ ).                                                |  |
|                                  | RXE              | Disable receiving ( $RXE = 0$ ).                                                                                                                                                                      | Enable receiving (RXE = 1).                                                       |  |
| Serial status                    | TIE              | Enable transmitting interrupt (TIE = 1)                                                                                                                                                               | Disable transmitting interrupt (TIE = 0)                                          |  |
| register 1 (SSR1)                | RIE              | Disable receiving interrupt (RIE = $0$ ).                                                                                                                                                             | Enable receiving interrupt (RIE = 1).                                             |  |

DataSheet4U.com

416

www.DataSheet4U.com

#### Starting communications

When send data is written to the serial output data register 1 (SODR1), communication is started. When starting communication only in receiving, it is always necessary to write dummy send data to the serial output data register 1 (SODR1).

Terminating communications

After transmitting and receiving of one frame of data, the receive data load flag bit (SSR1 register bit 12: RDRF) is set to 1. When data is received, check the overrun error flag bit (SSR1 register bit 14: ORE) to ensure that the communication has performed normally.

et4U.com

DataSheet4U.com

DataSheet4U.com

#### CHAPTER 14 UART1

# 14.6.3 Bidirectional Communication Function (Operation Modes 0 and 2)

In operation modes 0 and 2 (asynchronous normal mode, clock synchronous mode), normal serial bidirectional communications using 1-to-1 connection can be performed. For operation mode 0 (asynchronous normal mode), the asynchronous mode is used; for operation mode 2 (clock synchronous mode), the clock synchronous mode is used.

#### Bidirectional Communication Function

To operate the UART1 in the operation mode 0, 2 (asynchronous normal mode, clock synchronous mode), shown in Figure 14.6-6 is required.

#### Figure 14.6-6 Setting of Operation Modes 0, 2 (Asynchronous Normal Mode and Clock Synchronous Mode) for UART1



Inter-CPU connect

Connect the two CPUs as shown in Figure 14.6-7.

#### Figure 14.6-7 Example of Bidirectional Communication Connect for UART1



DataShe

www.DataSheet4U.com

DataSheet4U.com

et4U.com

418

#### Communication procedure

Communications start at any timing from the transmitting end when transmit data is provided. At the transmitting end, set transmit data in the serial output data register (SODR1) and set the transmitting enable bit in the serial control register (SCR1 register bit 8: TXE) to 1 to start transmitting.

Figure 14.6-8 gives an example of transferring receive data to the transmitting end to inform the transmitting end of normal reception.





et4U.com

CHAPTER 14 UART1

## 14.6.4 Master/Slave Type Communication Function (Multiprocessor Mode)

## Operation mode 1 (asynchronous multiprocessor mode) enables communications by the master/slave type connection of more than one CPU. Only the master CPU functions.

#### Master/Slave Type Communication Function

To operate the UART1 in operation mode 1 (asynchronous multiprocessor mode), the setting shown in Figure 14.6-9 is required.



#### Figure 14.6-9 Setting of Operation Mode 1 (Asynchronous Multiprocessor Mode) for UART1

#### Inter-CPU connect

One master CPU and more than one slave CPU are connected to two common communication lines to compose the communication system. The UART1 can be used only as the master CPU.

#### Figure 14.6-10 Example of Master/Slave Type Communication Connect for UART1



DataSheet4U.com

et4U.com

420

DataSheet4U.com

www.DataSheet4U.com

#### Function select

At master/slave type communication, select the operation mode and data transfer type.

Since the parity check function cannot be used in operation mode 1 (asynchronous multiprocessor mode), set the parity add enable bit (SCR1 register bit 15: PEN) to 0.

|                                 | Operation Mode |              |                               |          | Supervision           |                 |
|---------------------------------|----------------|--------------|-------------------------------|----------|-----------------------|-----------------|
|                                 | Master<br>CPU  | Slave<br>CPU | Data                          | Parity   | Synchronous<br>System | Stop Bit        |
| Address<br>transmit/<br>receive | Operation      |              | A/D = 1<br>+<br>8-bit address | Not      | Asynchronous          | 1 bit or 2 bits |
| Data<br>transmit/<br>receive    | mode 1         |              | A/D = 0<br>+<br>8-bit data    | provided | Asynchronous          | 1 bit of 2 bits |

 Table 14.6-3
 Select of Master/Slave Type Communication Function

#### Communication procedure

Communications start when the master CPU transmits address data.

t4U.com

The address data is data with the A/D bit set to 1. The address/data select bit (SCR1 register bit 11: A/D) is added to select the slave CPU that the master CPU communicates with. When the program identifies address data and finds a match with the allocated address, each slave CPU starts communications with the master CPU.

Figure 14.6-11 shows the flowchart for master/slave type communications.

DataSheet4U.com

www.DataSheet4U.com

#### CHAPTER 14 UART1



Figure 14.6-11 Flowchart for Master/Slave Type Communications

### 14.7 Precautions when Using UART1

#### Use of the UART1 requires the following cautions.

#### Precautions when Using UART1

Enabling sending and receiving

The send enable bit (SCR1 register bit 8: TXE) and receive enable bit (SCR1 register bit 9: RXE) are provided for sending and receiving.

- In the initial state after reset, both sending and receiving are disabled (SCR1 register bit 8: TXE = 0, bit
  9: RXE = 0). Therefore, it is necessary to enable sending and receiving.
- Sending and receiving are disabled to stop (SCR1 register bit 8: TXE = 0, bit 9: RXE = 0).

#### Setting operation mode

Set the operation mode after disabling sending and receiving (SCR1 register bit 8: TXE = 0, bit 9: RXE = 0). When the operation mode is changed during sending and receiving, the sent and received data is not assured.

#### Clock synchronous mode

DataShe

Operation mode 2 (clock synchronous mode) is set as the clock synchronous mode. Send and receive data do not have the start and stop bits.

#### Timing of enabling send interrupt

The initial value after reset of the send data write enable flag bit (SSR1 register bit 11: TDRE) is set at 1 (no send data, send data write enabled). Therefore, the send interrupt is enabled (SSR1 register bit 8: TIE = 1) and a send interrupt request is issued simultaneously. Always prepare send data and enable a send interrupt (SSR1 register bit 8: TIE = 1).

DataSheet4U.com

DataSheet4U.com

et4U.com

CHAPTER 14 UART1

## 14.8 Program Example for UART1

#### This section gives a program example for the UART1.

#### Program Example for UART1

#### Processing

The bidirectional communication function (normal mode) of the UART1 is used to perform serial transmission/reception.

- Set operation mode 0, asynchronous mode (normal), 8-bit data length, 2-bit stop bit length, and no parity.
- Use the P40/SIN1 and P42/SOT1 pins for communications.
- Use the dedicated baud rate generator to set the baud rate to approximately 9600 bps.
- Transmit the character  $13_{\rm H}$  from the SOT1 pin and receive it at an interrupt.
- Assume the machine clock ( $\phi$ ) 16 MHz.

et4U.com

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

#### • Coding example

| ICR13  |                | 0000BDH           |   | UART Transmit/receive interrupt control register  |          |
|--------|----------------|-------------------|---|---------------------------------------------------|----------|
| DDR1   |                | 000011H           |   | Port 1 data direction register                    |          |
| CDCR1  |                | 00001BH           |   | Communication prescaler register 1                |          |
| SMR1   |                | 000024H           |   | Mode control register 1                           |          |
| SCR1   |                | 000025H           |   | Control register 1                                |          |
| SIDR1  |                | 000026H           |   | Input data register 1                             |          |
| SODR1  |                | 000026H           |   | Output data register 1                            |          |
| SSR1   | EQU            |                   |   | Status register 1                                 |          |
| REC    |                |                   |   | Receive error flag clear bit                      |          |
| ,      | -              | 5                 |   |                                                   |          |
| CODE   | CSEG           | ABS=0FFH          |   |                                                   |          |
| START: |                |                   |   |                                                   |          |
| ;      | :              |                   |   | Assume stack pointer (SP) already reset           |          |
|        |                |                   |   | Disable interrupt                                 |          |
|        |                |                   |   | Interrupt level 0 (highest priority)              |          |
|        |                |                   |   | Set SIN1 as input pin.                            |          |
|        |                |                   |   | Enable communication prescaler                    |          |
|        | MOV            | I:SMR1,#00010001B |   | Operation mode 0 (asynchronous)                   |          |
|        |                |                   |   | Use dedicated baud rate generator (9615 bps)      |          |
|        |                |                   |   | Disable clock pulse output and enable data output |          |
|        | MOV            | I:SCR1,#00010011B |   | Without N parity. 2-bit stop bit                  |          |
|        |                |                   |   | Clear 8-bit data bit and receive error flag       |          |
|        |                |                   | ; | Enable transmitting/receiving                     |          |
|        | MOV            | I:SSR1,#00000010B | ; | Disable transmit interrupt and enable receive     | DataShee |
|        |                |                   | ; | interrupt                                         | Dataone  |
|        | MOV            | I:SODR1,#13H      | ; | Write send data                                   |          |
|        | MOV            | ILM,#07H          | ; | Set ILM of PS to level 7                          |          |
|        | OR             | CCR,#40H          | ; | Enable interrupt                                  |          |
| LOOP:  | MOV            | A,#00H            | ; | Infinite loop                                     |          |
|        | MOV            | A,#01H            |   |                                                   |          |
|        | BRA            | LOOP              |   |                                                   |          |
| ;I     | Interr         | uption program    |   |                                                   |          |
| WARI:  |                |                   |   |                                                   |          |
|        |                | A,SIDR1           |   |                                                   |          |
|        | CLRB           | I:REC             | ; | Clear receive interrupt request flag              |          |
| ;      | :              |                   |   |                                                   |          |
| ;      | Proc           | essing by user    |   |                                                   |          |
| ;      | :              |                   |   |                                                   |          |
|        | RETI           |                   | ; | Return from interrupt                             |          |
| CODE   | ENDS           |                   |   |                                                   |          |
| ;V     | <i>l</i> ector | setting           |   |                                                   |          |
| VECT   | CSEG           | ABS=0FFH          |   |                                                   |          |
|        | ORG            | 0FF68H            | ; | Set interrupt #37 (25H) vector                    |          |
|        | DSL            | WARI              |   |                                                   |          |
|        | ORG            | 0 FFDCH           | ; | Set reset vector                                  |          |
|        | DSL            | START             |   |                                                   |          |
|        | DB             | 00H               | ; | Set single-chip mode                              |          |
| VECT   | ENDS           |                   |   | -                                                 |          |
|        |                |                   |   |                                                   |          |

et4U.com

#### CHAPTER 14 UART1

et4U.com

DataSheet4U.com

DataSheet4U.com

426

DataSheet4U.com

DataShe

www.DataSheet4U.com

This chapter explains the functions and operations of the CAN controller.

- 15.1 Overview of CAN Controller
- 15.2 Block Diagram of CAN Controller
- 15.3 Configuration of CAN Controller
- 15.4 Interrupts of CAN Controller
- 15.5 Explanation of Operation of CAN Controller
- 15.6 Precautions when Using CAN Controller
- 15.7 Program Example of CAN Controller

et4U.com

DataSheet4U.com

www.DataSheet4U.com

## **15.1** Overview of CAN Controller

# The CAN (controller area network) is a serial communication protocol conformed to CAN Ver. 2.0A and Ver. 2.0B. Transmitting and receiving can be performed in the standard frame format and the extended frame format.

#### Overview of CAN Controller

- The CAN controller format conforms to CAN Ver. 2.0A and Ver. 2.0B.
- Transmitting and receiving can be performed in the standard frame format and the extended frame format.
- Data frames can be transmitted automatically by remote frames receiving.
- The baud rate ranges from 10 kpbs to 1 Mbps (at 16-MHz machine clock frequency).

Table 15.1-1 Data Transfer Baud Rate

| Machine Clock | Baud Rate           |
|---------------|---------------------|
| 16 MHz        | 1 Mbps              |
| 12 MHz        | 1 Mbps              |
| 8 MHz         | 1 Mbps              |
| 4 MHz         | ataSheet4U.500 Kbps |
| 2 MHz         | 250 Kbps            |

DataShe

- The CAN controller equips eight transmit/receive message buffers.
- The standard frame format provides transmitting and receiving with 11-bit ID and the extended frame format 29-bit ID.
- Message data can be set from 0 byte to 8 bytes.
- Message buffer configuration can be performed at a multilevel.
- The CAN controller has two acceptance mask registers. These registers can set masks independently for the receive message ID.
- The two acceptance mask registers can receive in the format of standard frame and extended frame.
- Four masks can be set at all bit comparison and masking, and partially at acceptance mask registers 0 and 1.

DataSheet4U.com

et4U.com

#### 15.2 **Block Diagram of CAN Controller**

The CAN controller consists of two types of registers; one controls the CAN controller and the other controls each message buffer.

#### Block Diagram of CAN Controller



#### Figure 15.2-1 Block Diagram of CAN Controller

DataSheet4U.com

The pin names in the block diagram are as follows: TX pin: P43/TX RX pin: P44/RX

#### Bit timing register (BTR)

This register sets the division ratio at which CAN bit timing is generated.

#### Control status register (CSR)

This register controls the operation of the CAN controller. It indicates the state of transmitting/receiving and the CAN bus, controls interrupts, and controls the bus halt and indicates its state.

#### Receive/transmit error counter register (RTEC)

This register indicates the number of times transmit and receive errors have occurred. It counts up when an error occurs in transmitting and receiving messages and counts down when transmitting and receiving are performed normally.

#### Message buffer validating register (BVALR)

This register enables or disables a specified message buffer, and also indicates the enabled/disabled status.

#### IDE register (IDER)

This register sets the frame format of each message buffer. It sets the standard frame format or extended frame format.

#### Transmit request register (TREQR)

This register sets a transmit request to each message buffer.

#### Transmit cancel register (TCANR)

This register cancels transmit requests held in each message buffer.

#### Transmit RTR register (TRTRR)

This register selects a frame format transmitted to each message buffer. It selects the data frame or remote frame.

#### Remote frame receive waiting register (RFWTR)

This register sets the condition for transmitting start when a transmit request of the data frame is set.

#### Transmit complete register (TCR)

The bit is set which is corresponding to the number of the message buffer that completes message transmitting.

DataSheet4U.com

et4U.com

www.DataSheet4U.com

#### Transmit complete interrupt enable register (TIER)

This register controls the generation of an interrupt request when each message buffer completes transmitting. When an interrupt is enabled, an interrupt request is generated when transmitting is completed.

#### Receive complete register (RCR)

This register sets the bit corresponding to the number of the message buffer that completes receiving message.

#### Receive complete interrupt enable register (RIER)

This register controls output of an interrupt request when each message buffer completes receiving. If output of an interrupt request is enabled, an interrupt request is output at completion of receiving.

#### Receive RTR register (RRTRR)

When a remote frame is stored in a message buffer, the bit corresponding to the number of the message buffer is set.

#### Receive overrun register (ROVRR)

This register sets the bit corresponding to the number of the message buffer that overruns when the message is received.

DataShee

## Acceptance mask select register (AMSR)<sup>Sheet4U.com</sup>

This register sets the method for masking the receive message for each message buffer.

Acceptance mask registers (AMR0 and AMR1)

These registers set a mask with the ID for filtering the message to be received.

#### Last event indication register (LEIR)

This register indicates the operating state that last occurred. It indicates that either node status transition, transmitting completion, or receiving completion occurred.

#### Prescaler

The prescaler generates a bit timing clock at a frequency of 1/1 to 1/64 of the system clock. It sets the operation clock (TQ).

#### Bit timing generator

This generator detects a bit timing clock signal to generate a sync segment and time segments 1 and 2.

Node status transition interrupt generator

This generates a node status transition interrupt signal when the node status transits.

et4U.com

#### Bus state identification circuit

This circuit identifies the CAN bus state from the bus halt bit (CSR: HALT) and the signal from the error frame generator.

#### • Acceptance filter

This filter compares the receive message ID with the acceptance code to select the message to be received.

#### • Transmit message buffers/receive message buffers

There are 8 message buffers to store the message to be transmitted and received.

#### • CRC generator/ACK generator

This circuit generates a CRC field or an ACK field when a data frame or remote frame is transmitted.

et4U.com

DataSheet4U.com

DataShe

432

## 15.3 Configuration of CAN Controller

## This section explains the pins and, related registers, interrupt factors of the CAN controller.

#### Pins of CAN Controller

#### Table 15.3-1 Pins of CAN Controller

| Pin Name | Pin Function                                    | Setting of Pin Used in CAN Controller                                            |  |
|----------|-------------------------------------------------|----------------------------------------------------------------------------------|--|
| TX       | Transmit output pin<br>General-purpose I/O port | Specify TX pin as transmit output pin<br>(when TOE bit in CSR register set to 1) |  |
| RX       | Receive input pin<br>General-purpose I/O port   | Specify RX pin as receive input pin<br>(when bit 4 in DDR4 register set to 0)    |  |

#### Block Diagram for Pins of CAN Controller

See "CHAPTER 4 I/O PORT" for details of the block diagram of pins.

et4U.com

DataSheet4U.com

www.DataSheet4U.com

#### ■ CAN Controller Registers

Figure 15.3-1, Figure 15.3-2 and Figure 15.3-3 list the registers of the CAN controller.

#### CAN controller control register bit 15..... ..... bit 8 bit 7 ····· bit 0 Reset value 0000000<sub>B</sub> Reserved area\* BVALR (Message buffer enable register) Reserved area\* TREQR (Transmission request register) 0000000<sub>B</sub> 0000000<sub>B</sub> Reserved area\* TCANR (Transmission cancel register) Reserved area\* TCR (Transmission complete register) 0000000<sub>B</sub> Reserved area\* RCR (Reception complete register) 0000000<sub>B</sub> Reserved area\* RRTRR (Reception RTR register) 0000000<sub>B</sub> Reserved area\* ROVRR (Reception overrun register) 0000000<sub>B</sub> Reserved area\* RIER (Reception complete interrupt enable register) 0000000<sub>B</sub> bit 15 ..... bit 8 bit 7 ..... bit 0 Reset value CSR (Control status register) 00XXX000<sub>B</sub> 0XXXX001<sub>B</sub> 000XX000<sub>B</sub> Reserved area\* LEIR (Last event indicate register) RTEC (Receive/transmit error counter) 0000000<sub>B</sub> 0000000<sub>B</sub> BTR (Bit timing register) X1111111<sub>B</sub> 11111111<sub>B</sub> Reserved area\* IDER (IDE register) XXXXXXXX<sub>B</sub> TRTRR(Transmission RTR register) Reserved area\* 0000000<sub>B</sub> Reserved area\* RFWTR (Remote frame receive waiting register) XXXXXXXX<sub>B</sub> Reserved area\* TIER (Transmission complete interrupt enable register) 0000000<sub>B</sub> AMSR (Acceptance mask select register) XXXXXXXX<sub>B</sub> XXXXXXXXAB Reserved area\* AMR0 (Acceptance mask register 0) XXXXXXXXAB XXXXXXXX<sub>B</sub> XXXXXXXXB XXXXXXXX<sub>B</sub> AMR1 (Acceptance mask register 1) XXXXXXXXAB XXXXXXXX<sub>B</sub> XXXXXXXX<sub>B</sub> XXXXXXXXB \*: Reserved area cannot be used because address is used in the system.

#### Figure 15.3-1 Registers of CAN Controller (Control Registers)

DataShee

DataSheet4U.com

et4U.com

| bit 15 bit | 8 bit 7 bit 0          | Rese                     | t value                                 |
|------------------------------------------------|------------------------|--------------------------|-----------------------------------------|
| RAM (General-pu                                | rpose RAM) (16 bytes)  | XXXXXXXXAB               | ~                                       |
|                                                |                        | ~                        | XXXXXXXX                                |
| IDR0 (I                                        | D register 0)          | XXXXXXXXAB<br>XXXXXXXXAB | XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX |
| IDR1 (I                                        | D register 1)          | XXXXXXXX                 | XXXXXXXX                                |
|                                                |                        | XXXXXXXX <sub>B</sub>    | XXXXXXXX                                |
| IDR2 (I                                        | D register 2)          | XXXXXXXX <sub>B</sub>    | XXXXXXXX                                |
|                                                |                        | XXXXXXXX <sub>B</sub>    | XXXXXXXX                                |
| IDR3 (II                                       | D register 3)          | XXXXXXXXB                | XXXXXXXX                                |
|                                                |                        | XXXXXXXXAB               | XXXXXXXX                                |
| IDR4 (I                                        | D register 4)          | XXXXXXXXXB<br>XXXXXXXXB  | XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX |
| IDR5 (I                                        | D register 5)          |                          | XXXXXXXX                                |
| ``                                             | Ç ,                    | XXXXXXXX                 | XXXXXXXX                                |
| IDR6 (I                                        | D register 6)          | XXXXXXXXB                | XXXXXXXX                                |
|                                                | XXXXXXXXB              | XXXXXXXX                 |                                         |
| IDR7 (I                                        | XXXXXXXXB              | XXXXXXXX                 |                                         |
|                                                | XXXXXXXXX <sub>B</sub> | XXXXXXXX                 |                                         |
| lessage buffer (DLC register)                  |                        |                          |                                         |
| bit 15 bit 8                                   |                        | Reset value              |                                         |
| Reserved area*                                 | DLC0 (DLC register 0)  | XXXXXXXX <sub>B</sub>    |                                         |
| Reserved area*                                 | DLC1 (DLC register 1)  | XXXXXXXXAB               |                                         |
| Reserved area*                                 | DLC2 (DLC register 2)  | XXXXXXXXB                |                                         |
| Reserved area*                                 | DLC3 (DLC register 3)  | XXXXXXXXB                |                                         |
| Reserved area*                                 | DLC4 (DLC register 4)  | XXXXXXXXAB               |                                         |
| Reserved area*                                 | DLC5 (DLC register 5)  | XXXXXXXXAB               |                                         |
| Reserved area*                                 | DLC6 (DLC register 6)  | XXXXXXXXB                |                                         |
| Reserved area*                                 | DLC7 (DLC register 7)  | XXXXXXXXB                |                                         |

#### Figure 15.3-2 Registers of CAN Controller (ID Register and DLC Register)

et4U.com

DataShe

435

| t 15 · · · · · · | bit 8 bit 7                     | ····· bit 0 | Rese | t value        |
|------------------|---------------------------------|-------------|------|----------------|
| D                | TR0 (Data register 0) (8 bytes) | ×××××       |      | ~<br>XXXXXXXXX |
| D                | TR1 (Data register 1) (8 bytes) | XXXX><br>~  |      | ~<br>XXXXXXXXX |
| D                | TR2 (Data register 2) (8 bytes) | XXXXX       |      | xxxxxxxx       |
| D                | TR3 (Data register 3) (8 bytes) | XXXX><br>~  |      | ~<br>XXXXXXXXX |
| D                | TR4 (Data register 4) (8 bytes) |             |      | ~<br>XXXXXXXXX |
| D                | TR5 (Data register 5) (8 bytes) | ×××××       |      | xxxxxxxx       |
| D                | TR6 (Data register 6) (8 bytes) | XXXXX       |      | xxxxxxxx       |
| D                | TR7 (Data register 7) (8 bytes) |             |      | xxxxxxxx       |
|                  | Reserved area* (128 bytes)      |             |      |                |

#### Figure 15.3-3 Registers of CAN Controller (DTR Register)

#### et4U.com

\*: Reserved area cannot be used because address is used in the system.

DataShe

#### ■ Generation of Interrupt Request by CAN Controller

The CAN controller has a transmit complete interrupt, receive complete interrupt, and node status interrupt. Each interrupt request is generated as follows:

- When a transmit complete interrupt is enabled for the message buffer (x) (TIER: TIEx = 1), the TCx bit in the transmit complete register is set to 1 and a transmit complete interrupt request is generated after a completion of message transmitting.
- When a receive complete interrupt is enabled for the message buffer (x) (RIER: RIEx = 1), the RCx bit in the receive complete register is set to 1 and a receive complete interrupt request is generated after a completion of message receiving.
- When a node status transition interrupt is enabled (CSR: NIE = 1), the NT bit in the CAN status register is set to 1 and a node status transition interrupt request is generated after the node status transits.

DataSheet4U.com

## 15.3.1 Control Status Register (High) (CSR: H)

The control status register (CSR) controls operation of the CAN controller. The control status register (High) (CSR: H) transmits and receives the message and indicates the node status.

■ Control Status Register (High) (CSR: H)





Note:

It is prohibited to execute a bit operation (read-modify-write) instruction on the lower 8 bits of control status register (CSR). Only in the case of HALT bits unchanged, use any bit operation instructions without problems (initialization of the macro instructions, etc.).

DataShe

437

|                  | Bit Name                                  | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |
|------------------|-------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| bit 8<br>bit 9   | NS1, NS0:<br>Node status bits             | The combination of the NS1 and NS0 bits indicates the current node status.<br><b>00</b> <sub>B</sub> : Error active<br><b>01</b> <sub>B</sub> : Warning (error active)<br><b>10</b> <sub>B</sub> : Error passive<br><b>11</b> <sub>B</sub> : Bus off<br>Note: Warning is included in error active in the CAN specifications as a node<br>status.                                                                                                                                                                                                                                                                                                     |       |
| bit 10           | NT:<br>Node status transition<br>flag bit | <ul> <li>This bit indicates that the node status transits.</li> <li>When node status transits: Bit set to 1</li> <li>1. Error active (00<sub>B</sub>)&gt; Warning (01<sub>B</sub>)</li> <li>2. Warning (01<sub>B</sub>)&gt; Error Passive (10<sub>B</sub>)</li> <li>3. Error Passive (10<sub>B</sub>)&gt; Bus off (11<sub>B</sub>)</li> <li>4. Bus off (11<sub>B</sub>)&gt; Error active (00<sub>B</sub>)</li> <li>(The parenthesized values are those for the NS1 and NS0 bits.)</li> <li>When set to 0: Clears this bit.</li> <li>When set to 1: Disables bit setting</li> <li>Read using read modify write instructions: 1 always read</li> </ul> |       |
| bit 11 to bit 13 | Unused bits                               | Read: Value not fixed<br>Write: No effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | DataS |
| bit 14           | RS:<br>Receive status bit                 | <ul> <li>This bit indicates whether the message is being received.</li> <li>Message being received: Bit set to 1</li> <li>For example, if the message is on the bus, even during message transmitting, this bit is set to 1 regardless of whether the receive message passes the acceptance filter.</li> <li>Error frame or overload frame on bus: Bit set to 0</li> <li>When the RS bit is 0, the bus halt state (HALT = 1), bus intermission state and bus idle state are also included.</li> </ul>                                                                                                                                                | Data  |
| bit 15           | TS:<br>Transmit status bit                | This bit indicates whether the message is being transmitted.<br><b>Message being transmitted:</b> Bit set to 1<br><b>Error frame or overload frame being transmitted:</b> Bit set to 0                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |

#### Table 15.3-2 Functions of Control Status Register (High) (CSR: H)

et4U.com

DataSheet4U.com

## 15.3.2 Control Status Register (Low) (CSR: L)

The control status register (CSR) controls operation of the CAN controller. The control status register (Low) (CSR: L) enables and disables transmit interrupt and node status transition interrupt, controls bus halt and indicates the node status.

■ Control Status Register (Low) (CSR: L)





Note:

It is prohibited to execute a bit operation (read-modify-write) instruction on the lower 8 bits of control status register (CSR). Only in the case of HALT bits unchanged, use any bit operation instructions without problems (initialization of the macro instructions, etc.).

DataShe

439

|                | Bit Name                                                         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |
|----------------|------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| bit 0          | HALT:<br>Bus halt bit                                            | This bit controls the bus halt. The halt state of the bus can be checked by<br>reading this bit.<br>Writing to this bit<br>0: Cancels bus operation stop<br>1: Sets bus operation not in stop state<br>1: Bus operation not in stop state<br>1: Bus operation not in stop state<br>Note: When write 0 to this bit during the node status is Bus Off, ensure that 1<br>is written to this bit.<br><b>Example program:</b><br>switch (IO_CANCT0.CSR.bit.NS)<br>{<br>case 0 : /* error active */<br>break;<br>case 1 : /* warning */<br>break;<br>default : /* bus off */<br>for (i=0; (i <= 500) && (IO_CANCT0.CSR.bit.<br>HALT == 0); i++);<br>IO_CANCT0.CSR.word = 0x0084; /* HALT = 0 */<br>break;<br>}<br>* The variable "i" is used for fail-safe.<br><b>[Conditions for canceling bus halt]</b><br>• The state in which the bus is halted by a hardware reset or by writing 1 to<br>the HALT bit is cancelled after 0 is written to the HALT bit and an 11-bit<br>High level (receive) is input continuously to the receive input pin (RX).<br>• The state in the bus off is cancelled after 0 is written to the HALT bit and<br>an 11-bit High level (receive) is input continuously 128 times to the<br>receive input pin (RX).<br>• The values of the transmit and receive error counters are both returned to<br>0 and the node status transits to error active.<br>• When write 0 to HALT bit during the node status is Bus Off, ensure that 1<br>is written to this bit.<br><b>[State in which bus halted]</b><br>• Transmitting and receiving are not performed.<br>• A High level (receive) is output to the transmit output pin (TX).<br>• Values of other register and error counter remain unchanged.<br>Note: Set the bit timing register (BTR) after halting the bus. | Da |
| bit 1          | Reserved: Reserved bit                                           | Always set this bit to 0.<br><b>Read:</b> 0 is always read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |    |
| bit 2          | NIE:<br>Node status transition<br>interrupt output enable<br>bit | This bit controls generation of a node status transition interrupt when the node status transits (CSR: NT = 1).<br>When set to 0: Disables interrupt generation<br>When set to 1: Enables interrupt generation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |    |
| bit 3 to bit 6 | Unused bits                                                      | Read: Value not fixed<br>Write: No effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |    |

#### Table 15.3-3 Functions of Control Status Register (Low) (CSR: L) (1/2)

DataSheet4U.com

et4U.com

|       | Bit Name                              | Function                                                                                                                                                                                   |
|-------|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 7 | TOE:<br>Transmit output enable<br>bit | This bit switches between the general-purpose I/O port and the transmit pin (TX).<br>When set to 0: Functions as general-purpose I/O port<br>When set to 1: Functions as transmit pin (TX) |

#### Table 15.3-3 Functions of Control Status Register (Low) (CSR: L) (2/2)

et4U.com

DataShee

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

## 15.3.3 Last Event Indicate Register (LEIR)

This register indicates the state of the last event.

#### Last Event Indicate Register (LEIR)



Figure 15.3-6 Last Event Indicate Register (LEIR)

Note:

When any of the node status transition bit (NTE), transmission complete bit (TCE), and reception complete bit (RCE) corresponding to the last event is set to 1, other bits are set to 0.

DataSheet4U.com

|        |                | Bit Name                                         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|--------|----------------|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|        | bit 0 to bit 2 | MBP2 to MBP0:<br>Message buffer pointer<br>bits  | These bits indicate the number (x) of the message buffer where the last event occurs which is corresponding to each message buffer pointer bit.         Receiving completed:       Indicates number (x) of message buffer that completes receiving message         Transmitting completed:       Indicates number (x) of message buffer that completes receiving message         Node status transition:       The values of the MBP2 to MBP0 bits are invalid.         When set to 0:       Cleared         When set to 1:       No effect         Read by read modify write instruction:       1 always read             |  |
|        | bit 3<br>bit 4 | Unused bits                                      | Read: Value not fixed<br>Write: No effect on operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| .U.com | bit 5          | RCE:<br>Last event reception<br>complete bit     | <ul> <li>This bit indicates that receiving the last event is completed.</li> <li>Receiving of last event completed:</li> <li>Sets bit to 1 when RCx bit in reception complete register set (RCR: RCx = 1)</li> <li>Nothing is related to the setting of the reception complete interrupt enable register (RIER).</li> <li>The number (x) of the message buffer that completes receiving the message is indicated as the last event in the MBP2 to MBP0 bits.</li> <li>When set to 0: Cleared</li> <li>When set to 1: No effect</li> <li>Read using read modify write instructions: 1 always read</li> </ul>                |  |
|        | bit 6          | TCE:<br>Last event transmission<br>complete bit  | <ul> <li>This bit indicates that the transmitting the last event is completed.</li> <li>Transmitting of last event completed:</li> <li>Sets bit to 1 when TCx bit in transmission complete register set (TCR: TCx = 1)</li> <li>Nothing is related to the setting of the transmission complete interrupt enable register (TIER).</li> <li>The number (x) of the message buffer that completes receiving the message is indicated as the last event in the MBP2 to MBP0 bits.</li> <li>When set to 0: Cleared</li> <li>When set to 1: No effect</li> <li>Read using read modify write instruction: 1 always read</li> </ul> |  |
|        | bit 7          | NTE:<br>Last event node status<br>transition bit | <ul> <li>This bit indicates that the last event refers to the node status transition.</li> <li>Last event referring to node status transition:</li> <li>Sets bit to 1 when NTx bit in control status register set (CSR: NTx = 1)</li> <li>The NTE bit is set to 1 at the same time that the TCx in the transmission complete register (TCR) is set.</li> <li>Nothing is related to the setting of the NIE bit in the control status register (CSR).</li> <li>When set to 0: Cleared</li> <li>When set to 1: No effect</li> <li>Read by read modify write instruction: 1 always read</li> </ul>                             |  |

#### Table 15.3-4 Functions of Last Event Indicate Register (LEIR)

Note:

When the last event indicate register (LEIR) is accessed in interrupt processing of the CAN controller, the event causing the interrupt does not always match the event indicated by the last event indicate register (LEIR). Other event may occur before the last event indicate register (LEIR) is accessed in interrupt processing after an interrupt request is generated.

DataSheet4U.com

## 15.3.4 Receive/Transmit Error Counter (RTEC)

The receive/transmit error counter (RTEC) indicates the number of times an error occurs at transmitting and receiving the message. It counts up when transmit or receive errors occurs and counts down when transmitting and receiving are performed normally.

#### Receive/Transmit Error Counter (RTEC)



et4U.com

#### Table 15.3-5 Functions of Receive/Transmit Error Counter (RTEC)

|                 | Bit Name                                        | Function                                                                                                                                                                                                                                                                                                                                                   |
|-----------------|-------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0 to bit 7  | REC7 to REC0:<br>Receive error counter<br>bits  | Receive error counter value = 96 or more:<br>Node status transits to warning (CSR: NS1, NS0 = $01_B$ )Receive error counter value = 128 or more:<br>Node status transits to error passive (CSR: NS1, NS0 = $10_B$ )Receive error counter value = 256 or more:<br>Stops counting up. The node status remains with error passive (CSR: NS1, NS0=" $10_B$ "). |
| bit 8 to bit 15 | TEC7 to TEC0:<br>Transmit error counter<br>bits | Transmit error counter value = 96 or more :<br>Node status transits to warning (CSR: NS1, NS0 = $01_B$ )Transmit error counter value = 128 or more :<br>Node status transits to error passive (CSR: NS1, NS0 = $10_B$ )Transmit error counter value = 256 or more :<br>Stops counting up. The node status transits to bus off (CSR: NS1, NS0 = $11_B$ ).   |

#### Node Status Transition due to Error Occurrence

In the CAN controller, the node status transits according to the error count of the receive/transmit error counter (RTEC). Figure 15.3-8 shows the node status transition.





| Node Status   | State of CAN Bus                                                                                                                                                       |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Error active  | Normal state                                                                                                                                                           |
| Warning       | A bus fault occurs                                                                                                                                                     |
| Error passive | A bus fault occurs                                                                                                                                                     |
| Bus off       | Communications are disabled. The CAN controller is completely isolated<br>from the CAN bus.<br>(To return to the normal state, perform the steps in the above figure.) |

DataSheet4U.com

et4U.com

www.DataSheet4U.com

## 15.3.5 Bit Timing Register (BTR)

## The bit timing register (BTR) sets the prescaler and bit timing after halting the bus (CSR: HALT = 1).

#### ■ Bit Timing Register (BTR)



Table 15.3-7 Functions of Bit Timing Register (BTR)

|                        | Bit Name                                                     | Function                                                                                                                                                                                 |
|------------------------|--------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0 to bit 5         | PSC5 to PSC0:<br>Prescaler setting bits 5 to 0               | • These bits divide the frequency of the system clock to determine the time quantum (TQ) of the CAN controller.                                                                          |
| bit 6 to bit 7         | RSJ1, RSJ0:<br>Resynchronous jump<br>width setting bits 1, 0 | • These bits set the resynchronous jump width (RSJW).                                                                                                                                    |
| bit 8<br>to<br>bit 11  | TS1.3 to TS1.0:<br>Time segment 1 setting<br>bits 3 to 0     | • These bits set the time of time segment 1 (TSEG1). Time segment 1 is equivalent to propagation segment (PROP_SEG) and phase buffer segment 1 (PHASE_SEG1) based on CAN specifications. |
| bit 12<br>to<br>bit 14 | TS2.2 to TS2.0:<br>Time segment 2 setting<br>bits 2 to 0     | • These bits set the time of time segment 2 (TSEG2). Time segment 2 is equivalent to phase buffer segment 2 (PHASE_SEG2) based on CAN specifications.                                    |

Note: Set the bit timing register (BTR) after halting the bus (CSR: HALT = 1). After setting the bit timing register (BTR), write 0 to the HALT bit in the control status register to cancel the bus halt.

DataSheet4U.com

et4U.com

www.DataSheet4U.com

446

#### Definition of Bit Timing Segment

Bit timing is set in the bit timing register (BTR). Figure 15.3-10 and Figure 15.3-11 show the segments of the nominal bit time (one bit of time within message) and bit timing register (BTR).

Bit time segments of general CAN specifications

#### Figure 15.3-10 Bit Time Segments of General CAN Specifications



- SYNC\_SEG (sync segment): Synchronization is performed to shorten or prolong the bit time.
- PROP\_SEG (propagation segment): The physical delay among networks is adjusted.
- PHASE\_SEG (phase segment): The phase shift due to oscillation errors is adjusted.

#### Bit time segments of Fujitsu CAN controller

et4U.com

The propagation segment (PROP\_SEG) and phase segment 1 (PHASE\_SEG1) are used as the time segment 1 (TSEG1). The phase segment 2 (PHASE\_SEG2) is used as the time segment 2 (TSEG2).



- TSEG1 = PROP\_SEG + PHASE\_SEG1
- TSEG2 = PHASE\_SEG2

#### ■ Calculation of Bit Timing

Figure 15.3-12 and Figure 15.3-13 show the calculation example of bit timing, respectively, assuming input clock (CLK), time quantum (TQ), bit time (BT), synchronous segment (SYNC\_SEG), time segments 1 and 2 (TSEG1, TSEG2), resynchronous jump width (RSJW), and frequency division (PSC).

#### Figure 15.3-12 Calculation of Bit Timing

 $\begin{array}{l} \label{eq:spin} \mathsf{TQ} = (\mathsf{PSC}+1) \times \mathsf{CLK} \\ \mathsf{BT} = \mathsf{SYNC}\_\mathsf{SEG} + \mathsf{TSEG1} + \mathsf{TSEG2} \\ = (1 + (\mathsf{TS1}+1) + (\mathsf{TS2}+1)) \times \mathsf{TQ} \\ = (3 + \mathsf{TS1} + \mathsf{TS2}) \times \mathsf{TQ} \\ \mathsf{RSJW} = (\mathsf{RSJ}+1) \times \mathsf{TQ} \\ \end{array}$  For each segment, the following conditions should be met.  $\begin{array}{l} \mathsf{When} \ \mathsf{PSC} \ is \ 1 \ to \ 63 \ (2 \ to \ 64 \text{-divided clock}) \\ \mathsf{TSEG1} \geq 2\mathsf{TQ} \\ \mathsf{TSEG2} \geq 2\mathsf{TQ} \\ \mathsf{TSEG2} \geq 2\mathsf{TQ} \\ \mathsf{TSEG2} \geq \mathsf{RSJW} \\ \end{array}$   $\begin{array}{l} \mathsf{When} \ \mathsf{PSC} \ is \ 0 \ (1 \text{-divided clock}) \\ \mathsf{TSEG2} \geq \mathsf{RSJW} \\ \end{array}$ 

DataShe

DataSheet4U.com

et4U.com

DataSheet4U.com

www.DataSheet4U.com

| (1) Ca                                                                   | alculations of time quan                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | tum (T                                        | Q) [TQ                                                    | = (PS0                                                         | C + 1):                   | × CLKI   | //                |                                                                                          |                                                                                       |                                                                                       |                                                                                       |                                                                                              |                                                                                               |                                                                                              | / ··                                                                                          |                                                                                                                   |
|--------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|-----------------------------------------------------------|----------------------------------------------------------------|---------------------------|----------|-------------------|------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|
| (.) -                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                               | -, [                                                      | (                                                              | · .                       | equer    |                   | vioid                                                                                    | of in                                                                                 |                                                                                       | look                                                                                  |                                                                                              |                                                                                               |                                                                                              | (unit:                                                                                        | με                                                                                                                |
| Mac                                                                      | hine clock (CLK)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1                                             | 2                                                         | 8                                                              | 4                         | squei    | 6 6               |                                                                                          | 8                                                                                     | 9                                                                                     | 1000                                                                                  | 11                                                                                           | 12                                                                                            | 13                                                                                           | 14                                                                                            | 1                                                                                                                 |
|                                                                          | Hine clock (OEIX)<br>Hz (0.25 μs)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0.25                                          |                                                           |                                                                | 1                         | 1.25     | 1.5               | 1.75                                                                                     | 2                                                                                     | 2.25                                                                                  | 2.5                                                                                   | 2.75                                                                                         | 3                                                                                             | 3.25                                                                                         | 3.5                                                                                           | 3.                                                                                                                |
|                                                                          | Hz (0.125 μs)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                               | 0.25                                                      |                                                                | 0.5                       |          |                   | <u> </u>                                                                                 | 1                                                                                     | 1.13                                                                                  | 1.25                                                                                  | -                                                                                            | 1.5                                                                                           | 1.63                                                                                         |                                                                                               |                                                                                                                   |
|                                                                          | 1Hz (0.0625 μs)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0.06                                          |                                                           | 0.19                                                           |                           |          | 0.38              |                                                                                          | 0.5                                                                                   | 0.56                                                                                  | 0.63                                                                                  |                                                                                              | 0.75                                                                                          | 0.81                                                                                         | 0.88                                                                                          | -                                                                                                                 |
|                                                                          | onditions of bit timing (E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                               |                                                           |                                                                |                           |          |                   |                                                                                          |                                                                                       | 1 0.00                                                                                | 1000                                                                                  |                                                                                              | 1                                                                                             |                                                                                              |                                                                                               |                                                                                                                   |
|                                                                          | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ., [= .                                       |                                                           | L.                                                             |                           |          |                   |                                                                                          | 8TQ                                                                                   |                                                                                       |                                                                                       |                                                                                              |                                                                                               |                                                                                              | (unit:                                                                                        | μ                                                                                                                 |
|                                                                          | hine clock (CLK)<br>Hz (0.25 μs)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 2                                             | 4                                                         | 6                                                              | 8                         | 10       | 12                | 14                                                                                       | 16                                                                                    | 18                                                                                    | 20                                                                                    | 22                                                                                           | 24                                                                                            | 26                                                                                           | 28                                                                                            | 3                                                                                                                 |
|                                                                          | Iz (0.25 μs)<br>Iz (0.125 μs)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1                                             | 2                                                         | 3                                                              | 4                         | 5        | 6                 | 7                                                                                        | 8                                                                                     | 9                                                                                     | 10                                                                                    | 11                                                                                           | 12                                                                                            | 13                                                                                           | 14                                                                                            | 1                                                                                                                 |
|                                                                          | 12 (0.125 μs)<br>1Hz (0.0625 μs)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0.5                                           | 1                                                         | 1.5                                                            | 2                         | 2.5      | 3                 | 3.5                                                                                      | 4.                                                                                    | 4.5                                                                                   | 5                                                                                     | 5.5                                                                                          | 6                                                                                             | 6.5                                                                                          | 7                                                                                             | 7                                                                                                                 |
|                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                               |                                                           |                                                                |                           |          |                   |                                                                                          | <u> </u>                                                                              | <del>1</del> .5                                                                       | 5                                                                                     | 0.0                                                                                          | 0                                                                                             | 0.5                                                                                          | 1                                                                                             | 1                                                                                                                 |
| (3) Se                                                                   | etting of resynchronous                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | jump \                                        | width (w                                                  | hen re                                                         | synchi                    | onous j  | ump w             | vidth is                                                                                 | 4TQ) \                                                                                | \                                                                                     |                                                                                       |                                                                                              |                                                                                               |                                                                                              |                                                                                               |                                                                                                                   |
| RSJ+1                                                                    | (frequency division of TQ)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1                                             | 2                                                         | 3                                                              | 4                         | (unit    | : TQ              | )                                                                                        |                                                                                       |                                                                                       |                                                                                       |                                                                                              |                                                                                               |                                                                                              |                                                                                               |                                                                                                                   |
|                                                                          | $T = (RSJ + 1) \times TQ$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0.5                                           | 1                                                         | 1.5                                                            | 2                         | (unit    | : μs)             | )                                                                                        |                                                                                       |                                                                                       |                                                                                       |                                                                                              |                                                                                               |                                                                                              |                                                                                               |                                                                                                                   |
| (5) Co                                                                   | onditions of TSEG2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                               |                                                           |                                                                |                           | -        |                   |                                                                                          |                                                                                       |                                                                                       |                                                                                       |                                                                                              |                                                                                               |                                                                                              |                                                                                               |                                                                                                                   |
| BSI                                                                      | $W = (RSJ + 1) \times TQ$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 1                                             | 2                                                         | 3                                                              | 4                         | (unit:   | то                | )                                                                                        |                                                                                       |                                                                                       |                                                                                       |                                                                                              |                                                                                               |                                                                                              |                                                                                               |                                                                                                                   |
|                                                                          | $G2 \ge RSJW$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1                                             | 2                                                         | 3                                                              | 4                         | · ·      | : TQ              | ·                                                                                        |                                                                                       | /                                                                                     |                                                                                       |                                                                                              |                                                                                               |                                                                                              |                                                                                               |                                                                                                                   |
|                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | · ·                                           | -                                                         | 0                                                              |                           |          |                   |                                                                                          |                                                                                       |                                                                                       |                                                                                       |                                                                                              |                                                                                               |                                                                                              |                                                                                               |                                                                                                                   |
| (6) Co                                                                   | $G2 \ge RSJW$<br>onditions of TSEG1<br>'SEG1 $\ge$ Delay time + F<br>TSEG1<br>5 (uni                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                               |                                                           | 1.5<br>uming 1                                                 | 2                         | · ·      | : μ <b>s)</b>     |                                                                                          | + 4TQ                                                                                 | !≥5TQ                                                                                 |                                                                                       |                                                                                              |                                                                                               |                                                                                              |                                                                                               |                                                                                                                   |
| (6) Ca<br>T                                                              | onditions of TSEG1<br>'SEG1 ≥ Delay time + F<br>TSEG1<br>5 (uni                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | SJW<br>t: TQ)                                 | (Ass                                                      | uming t                                                        | 2                         | (unit:   | : µs)<br>e is 501 | ns) × 2                                                                                  | + 4TQ                                                                                 | !≥5TQ                                                                                 |                                                                                       |                                                                                              |                                                                                               |                                                                                              |                                                                                               |                                                                                                                   |
| (6) Ca<br>T<br>(2) Ca                                                    | onditions of TSEG1<br>'SEG1 ≥ Delay time + F<br>TSEG1<br>5 (uni<br>alculation of bit time (BT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | SJW<br>t: TQ)<br>) base                       | (Ass<br>)<br>ed on th                                     | uming t<br>e abov                                              | 2                         | (unit:   | : µs)<br>e is 501 | ns) × 2                                                                                  | + 4TQ                                                                                 | !≥5TQ                                                                                 |                                                                                       |                                                                                              |                                                                                               | (un                                                                                          | it: kb                                                                                        | ops)                                                                                                              |
| (6) Ca<br>T<br>(2) Ca                                                    | onditions of TSEG1<br>'SEG1 ≥ Delay time + F<br>TSEG1<br>5 (uni<br>alculation of bit time (BT<br>BT = SYNC_SEG + TSI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | SJW<br>t: TQ)<br>) base<br>EG1 +              | (Ass<br>)<br>ed on th<br>TSEG2                            | uming t<br>e abov                                              | 2                         | (unit:   | : µs)<br>e is 501 | ns) × 2                                                                                  |                                                                                       | *                                                                                     |                                                                                       | TSEG                                                                                         |                                                                                               |                                                                                              |                                                                                               | . /                                                                                                               |
| (6) Ca<br>T<br>(2) Ca                                                    | onditions of TSEG1<br>'SEG1 ≥ Delay time + F<br>TSEG1<br>5 (uni<br>alculation of bit time (BT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | (SJW<br>t: TQ)<br>() base<br>EG1 +<br>2+1)) > | (Ass<br>)<br>ed on th<br>TSEG2                            | uming t<br>e abov                                              | 2                         | (unit:   | : µs)<br>e is 501 | ns) × 2                                                                                  | 1                                                                                     | 2                                                                                     | 3                                                                                     | 4                                                                                            | 5                                                                                             | 6                                                                                            | 7                                                                                             | 8                                                                                                                 |
| (6) Ca<br>T<br>(2) Ca                                                    | onditions of TSEG1<br>'SEG1 $\geq$ Delay time + F<br>TSEG1<br>5 (uni<br>alculation of bit time (BT<br>BT = SYNC_SEG + TSI<br>= (1 + (TS1 + 1) + (TS)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | (SJW<br>t: TQ)<br>() base<br>EG1 +<br>2+1)) > | (Ass<br>)<br>ed on th<br>TSEG2                            | uming t<br>e abov                                              | 2                         | (unit:   | : µs)<br>e is 501 | ns) × 2<br>ons                                                                           | 1 667                                                                                 | 2 500                                                                                 | 3 400                                                                                 | 4                                                                                            | 5<br>286                                                                                      | 6<br>250                                                                                     | 7<br>222                                                                                      | 8                                                                                                                 |
| (6) Ca<br>T<br>(2) Ca                                                    | onditions of TSEG1<br>'SEG1 $\geq$ Delay time + F<br>TSEG1<br>5 (uni<br>alculation of bit time (BT<br>BT = SYNC_SEG + TSI<br>= (1 + (TS1 + 1) + (TS)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | (SJW<br>t: TQ)<br>() base<br>EG1 +<br>2+1)) > | (Ass<br>)<br>ed on th<br>TSEG2                            | uming t<br>e abov                                              | 2                         | (unit:   | : µs)<br>e is 501 | ns) × 2<br>ons                                                                           | 1<br>667<br>500                                                                       | 2<br>500<br>400                                                                       | 3<br>400<br>333                                                                       | 4<br>333<br>286                                                                              | 5<br>286<br>250                                                                               | 6<br>250<br>222                                                                              | 7<br>222<br>200                                                                               | 8<br>20<br>18                                                                                                     |
| (6) Cc<br>T<br>(2) Ca<br>I                                               | onditions of TSEG1<br>SEG1 $\geq$ Delay time + F<br>TSEG1<br>5 (uning<br>alculation of bit time (BT<br>BT = SYNC_SEG + TSI<br>= (1 + (TS1 + 1) + (TS))<br>= (3 + TS1 + TS2) × To                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | (SJW<br>t: TQ)<br>() base<br>EG1 +<br>2+1)) > | (Ass<br>)<br>ed on th<br>TSEG2                            | uming t<br>e abov                                              | 2                         | (unit:   | : µs)<br>e is 501 | ns) × 2<br>ons                                                                           | 1<br>667<br>500<br>400                                                                | 2<br>500<br>400<br>333                                                                | 3<br>400<br>333<br>286                                                                | 4<br>333<br>286<br>250                                                                       | 5<br>286<br>250<br>222                                                                        | 6<br>250<br>222<br>200                                                                       | 7<br>222<br>200<br>182                                                                        | 8<br>20<br>18<br>16                                                                                               |
| (6) Cc<br>T<br>(2) Ca<br>I                                               | onditions of TSEG1<br>'SEG1 $\geq$ Delay time + F<br>TSEG1<br>5 (uni<br>alculation of bit time (BT<br>BT = SYNC_SEG + TSI<br>= (1 + (TS1 + 1) + (TS)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | (SJW<br>t: TQ)<br>() base<br>EG1 +<br>2+1)) > | (Ass<br>)<br>ed on th<br>TSEG2                            | uming t<br>e abov                                              | 2                         | (unit:   | : µs)<br>e is 501 | ns) × 2<br>ons                                                                           | 1<br>667<br>500<br>400<br>333                                                         | 2<br>500<br>400<br>333<br>286                                                         | 3<br>400<br>333<br>286<br>250                                                         | 4<br>333<br>286<br>250<br>222                                                                | 5<br>286<br>250<br>222<br>200                                                                 | 6<br>250<br>222<br>200<br>182                                                                | 7<br>222<br>200<br>182<br>167                                                                 | 8<br>20<br>18<br>16<br>15                                                                                         |
| (6) Co<br>T<br>(2) Ca<br>E<br>Calcula                                    | tion of sampling point                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | SJW<br>t: TQ)<br>) base<br>EG1 +<br>2+1)) >   | (Ass<br>)<br>TSEG2<br>×TQ                                 | e abov                                                         | 2<br>that de<br>e settii  | (unit:   | : µs)<br>e is 501 | ns) × 2<br>ons                                                                           | 1<br>667<br>500<br>400<br>333<br>286                                                  | 2<br>500<br>400<br>333<br>286<br>250                                                  | 3<br>400<br>333<br>286<br>250<br>222                                                  | 4<br>333<br>286<br>250<br>222<br>200                                                         | 5<br>286<br>250<br>222<br>200<br>182                                                          | 6<br>250<br>222<br>200<br>182<br>167                                                         | 7<br>222<br>200<br>182<br>167<br>154                                                          | 8<br>20<br>18<br>16<br>15<br>14                                                                                   |
| (6) Co<br>T<br>(2) Ca<br>E<br>Calcula                                    | onditions of TSEG1<br>SEG1 $\geq$ Delay time + F<br>TSEG1<br>5 (uning<br>alculation of bit time (BT<br>BT = SYNC_SEG + TSI<br>= (1 + (TS1 + 1) + (TS))<br>= (3 + TS1 + TS2) × To                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | SJW<br>t: TQ)<br>) base<br>EG1 +<br>2+1)) >   | (Ass<br>)<br>TSEG2<br>×TQ                                 | e abov                                                         | 2<br>that de              | (unit:   | : µs)<br>e is 501 | ns) × 2<br>ons<br>1<br>2<br>3<br>4<br>5<br>6                                             | 1<br>667<br>500<br>400<br>333<br>286<br>250                                           | 2<br>500<br>400<br>333<br>286<br>250<br>222                                           | 3<br>400<br>333<br>286<br>250<br>222<br>200                                           | 4<br>333<br>286<br>250<br>222<br>200<br>182                                                  | 5<br>286<br>250<br>222<br>200<br>182<br>167                                                   | 6<br>250<br>222<br>200<br>182<br>167<br>154                                                  | 7<br>222<br>200<br>182<br>167<br>154<br>143                                                   | 8<br>20<br>18<br>16<br>15<br>14<br>13                                                                             |
| (6) Co<br>T<br>(2) Ca<br>E<br>Calcula                                    | tion of sampling point                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | SJW<br>t: TQ)<br>) base<br>EG1 +<br>2+1)) >   | (Ass<br>)<br>TSEG2<br>×TQ                                 | e abov                                                         | 2<br>that de<br>re settin | lay time | : μs)<br>e is \$0 | ns) × 2<br>ons<br>1<br>2<br>3<br>4<br>5<br>6<br>7                                        | 1<br>667<br>500<br>400<br>333<br>286<br>250<br>222                                    | 2<br>500<br>400<br>333<br>286<br>250<br>222<br>200                                    | 3<br>400<br>333<br>286<br>250<br>222<br>200<br>182                                    | 4<br>333<br>286<br>250<br>222<br>200<br>182<br>167                                           | 5<br>286<br>250<br>222<br>200<br>182<br>167<br>154                                            | 6<br>250<br>222<br>200<br>182<br>167<br>154<br>143                                           | 7<br>222<br>200<br>182<br>167<br>154<br>143<br>133                                            | 8<br>200<br>188<br>160<br>155<br>144<br>133                                                                       |
| (6) Cc<br>T<br>(2) Ca<br>E<br>Calcula                                    | tion of sampling point<br>SYNC_SEG + (TSEG1<br>SYNC_SEG + (TSEG1<br>(Uni<br>SYNC_SEG + TSI<br>= (1 + (TS1 + 1) + (TS<br>= (3 + TS1 + TS2) × TC<br>tion of sampling point<br>SYNC_SEG + (TSEG1 +                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | SJW<br>t: TQ)<br>) base<br>EG1 +<br>2+1)) >   | (Ass<br>)<br>TSEG2<br>≺TQ<br>;EG2 +                       | e abov                                                         | 2<br>that de<br>re settin | (unit:   | : μs)<br>e is \$0 | ns) × 2<br>ons<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8                                   | 1<br>667<br>500<br>400<br>333<br>286<br>250<br>222<br>200                             | 2<br>500<br>400<br>333<br>286<br>250<br>222<br>200<br>182                             | 3<br>400<br>333<br>286<br>250<br>222<br>200<br>182<br>167                             | 4<br>333<br>286<br>250<br>222<br>200<br>182<br>167<br>154                                    | 5<br>286<br>2250<br>222<br>200<br>182<br>167<br>154<br>143                                    | 6<br>250<br>222<br>200<br>182<br>167<br>154<br>143<br>133                                    | 7<br>222<br>200<br>182<br>167<br>154<br>143<br>133<br>125                                     | 8<br>200<br>18<br>16<br>15<br>14<br>13<br>12<br>11                                                                |
| (6) Cc<br>T<br>(2) Ca<br>E<br>Calcula                                    | tion of sampling point<br>SYNC_SEG + (TSEG1<br>(Uni)<br>(TSEG1)<br>(TSEG1)<br>(Uni)<br>(TSEG1)<br>(Uni)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG1)<br>(TSEG | SJW<br>t: TQ)<br>) base<br>EG1 +<br>2+1)) >   | (Ass<br>)<br>TSEG2<br>×TQ<br>;EG2 +<br>4                  | e abov                                                         | 2<br>that de<br>e settin  | lay time | : μs)<br>e is \$0 | ns) × 2<br>ons<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9                              | 1<br>667<br>500<br>400<br>333<br>286<br>220<br>200<br>182                             | 2<br>500<br>400<br>333<br>286<br>220<br>200<br>182<br>167                             | 3<br>400<br>333<br>286<br>250<br>222<br>200<br>182<br>167<br>154                      | 4<br>333<br>286<br>220<br>222<br>200<br>182<br>167<br>154<br>143                             | 5<br>286<br>220<br>200<br>182<br>167<br>154<br>143<br>133                                     | 6<br>250<br>222<br>200<br>182<br>167<br>154<br>143<br>133<br>125                             | 7<br>222<br>200<br>182<br>167<br>154<br>143<br>133<br>125<br>118                              | 8<br>20<br>18<br>16<br>15<br>14<br>13<br>12<br>11                                                                 |
| (6) Ca<br>T<br>(2) Ca<br>E<br>Calcula                                    | tion of sampling point<br>SYNC_SEG + (TSEG1<br>SYNC_SEG + TS2<br>$= (1 + (TS1 + 1) + (TS2) \times T62)$<br>$= (1 + (TS1 + TS2) \times T62)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | SJW<br>t: TQ)<br>) base<br>EG1 +<br>2+1)) >   | (Ass<br>)<br>TSEG2<br>$\times$ TQ<br>$3EG2 + \frac{4}{5}$ | uming 1<br>e abov<br>1 Sam<br>po<br>80<br>75<br>70<br>65       | 2<br>that de<br>e settin  | lay time | : μs)<br>e is \$0 | ns) × 2<br>ons<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8                                   | 1<br>667<br>500<br>400<br>333<br>286<br>250<br>222<br>200                             | 2<br>500<br>400<br>333<br>286<br>250<br>222<br>200<br>182                             | 3<br>400<br>333<br>286<br>250<br>222<br>200<br>182<br>167                             | 4<br>333<br>286<br>250<br>222<br>200<br>182<br>167<br>154                                    | 5<br>286<br>2250<br>222<br>200<br>182<br>167<br>154<br>143                                    | 6<br>250<br>222<br>200<br>182<br>167<br>154<br>143<br>133<br>125<br>118                      | 7<br>222<br>200<br>182<br>167<br>154<br>143<br>133<br>125                                     | 8<br>200<br>188<br>166<br>155<br>144<br>133<br>122<br>111<br>111                                                  |
| (6) Cc<br>T<br>(2) Ca<br>E<br>Calcula<br>(1)<br>(2)<br>(3)               | onditions of TSEG1<br>SEG1 $\geq$ Delay time + F<br>TSEG1<br>= (uni<br>alculation of bit time (BT<br>BT = SYNC_SEG + TSI<br>= (1 + (TS1 + 1) + (TSi<br>= (3 + TS1 + TS2) × To<br>tion of sampling point<br>SYNC_SEG + (TSEG1 + 16<br>15<br>14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | SJW<br>t: TQ)<br>) base<br>EG1 +<br>2+1)) >   | (Ass<br>)<br>TSEG2<br>× TQ<br>3EG2 +<br>4<br>5<br>6       | e abov                                                         | 2<br>that de<br>e settin  | lay time | : μs)<br>e is \$0 | ns) × 2<br>ons<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>7<br>8<br>9<br>10                   | 1<br>667<br>500<br>400<br>333<br>286<br>220<br>200<br>182<br>167                      | 2<br>500<br>400<br>333<br>286<br>220<br>222<br>200<br>182<br>167<br>154               | 3<br>400<br>333<br>286<br>250<br>222<br>200<br>182<br>167<br>154<br>143               | 4<br>333<br>286<br>250<br>222<br>200<br>182<br>167<br>154<br>143<br>133                      | 5<br>286<br>220<br>200<br>182<br>167<br>154<br>143<br>133<br>125                              | 6<br>250<br>222<br>200<br>182<br>167<br>154<br>143<br>133<br>125                             | 7<br>222<br>200<br>182<br>167<br>154<br>143<br>133<br>125<br>118<br>111                       | 8<br>20<br>18<br>16<br>15<br>14<br>13<br>12<br>11<br>11<br>11<br>10                                               |
| (6) Cd<br>T<br>(2) Ca<br>E<br>Calcula<br>(1)<br>(2)<br>(3)<br>(4)<br>(5) | conditions of TSEG1<br>TSEG1 $\geq$ Delay time + F<br>TSEG1<br>5 (uning<br>alculation of bit time (BT<br>BT = SYNC_SEG + TSI<br>= (1 + (TS1 + 1) + (TS)<br>= (3 + TS1 + TS2) × To<br>tion of sampling point<br>SYNC_SEG + (TSEG1 + 16)<br>15<br>14<br>13<br>12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | SJW<br>t: TQ)<br>base<br>EG1 +<br>2+1))<br>2  | (Ass<br>)<br>TSEG2<br>× TQ<br>× TQ                        | uming f<br>e abov<br>e abov<br>9<br>80<br>75<br>70<br>65<br>60 | 2<br>that de<br>e settin  | lay time | : μs)<br>e is \$0 | ns) × 2<br>ons<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>7<br>8<br>9<br>10<br>11             | 1<br>667<br>500<br>400<br>333<br>286<br>250<br>222<br>200<br>182<br>167<br>154        | 2<br>500<br>400<br>333<br>286<br>250<br>222<br>200<br>182<br>167<br>154<br>143        | 3<br>400<br>333<br>286<br>220<br>222<br>200<br>182<br>167<br>154<br>143<br>133        | 4<br>333<br>286<br>250<br>222<br>200<br>182<br>167<br>154<br>143<br>133<br>125               | 5<br>286<br>250<br>222<br>200<br>182<br>167<br>154<br>143<br>133<br>125<br>118                | 6<br>250<br>222<br>200<br>182<br>167<br>154<br>143<br>133<br>125<br>118<br>111               | 7<br>222<br>200<br>182<br>167<br>154<br>143<br>133<br>125<br>118<br>111<br>105                | 8<br>20<br>18<br>16<br>15<br>14<br>13<br>12<br>11<br>11<br>10<br>95                                               |
| (6) Cd<br>T<br>(2) Ca<br>E<br>Calcula<br>(1)<br>(2)<br>(3)<br>(4)<br>(5) | onditions of TSEG1<br>SEG1 $\geq$ Delay time + F<br>TSEG1<br>5 (uni<br>alculation of bit time (BT<br>BT = SYNC_SEG + TSI<br>= (1 + (TS1 + 1) + (TS)<br>= (3 + TS1 + TS2) × TO<br>tion of sampling point<br>SYNC_SEG + (TSEG1 + 16<br>15<br>14<br>13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | SJW<br>t: TQ)<br>base<br>EG1 +<br>2+1))<br>2  | (Ass<br>)<br>TSEG2<br>× TQ<br>× TQ                        | uming f<br>e abov<br>e abov<br>9<br>80<br>75<br>70<br>65<br>60 | 2<br>that de<br>e settin  | lay time | : μs)<br>e is \$0 | ns) × 2<br>ons<br>1<br>2<br>3<br>4<br>5<br>6<br>6<br>7<br>8<br>9<br>10<br>11<br>12       | 1<br>667<br>500<br>400<br>333<br>286<br>220<br>200<br>182<br>167<br>154<br>143        | 2<br>500<br>400<br>333<br>286<br>220<br>200<br>182<br>167<br>154<br>143<br>133        | 3<br>400<br>333<br>286<br>250<br>200<br>182<br>167<br>154<br>143<br>133<br>125        | 4<br>333<br>286<br>250<br>222<br>200<br>182<br>167<br>154<br>143<br>133<br>125<br>118        | 5<br>286<br>2250<br>222<br>200<br>182<br>167<br>154<br>143<br>133<br>125<br>118<br>111        | 6<br>250<br>222<br>200<br>182<br>167<br>154<br>143<br>133<br>125<br>118<br>111<br>105        | 7<br>222<br>200<br>182<br>167<br>154<br>143<br>133<br>125<br>118<br>111<br>105<br>100         | 8<br>20<br>18<br>16<br>15<br>14<br>13<br>12<br>11<br>11<br>10<br>10<br>95.<br>90                                  |
| (6) Cc<br>T<br>(2) Ca<br>E<br>Calcula<br>(1)<br>(2)<br>(3)<br>(4)<br>(5) | conditions of TSEG1<br>TSEG1 $\geq$ Delay time + F<br>TSEG1<br>5 (uning<br>alculation of bit time (BT<br>BT = SYNC_SEG + TSI<br>= (1 + (TS1 + 1) + (TS)<br>= (3 + TS1 + TS2) × To<br>tion of sampling point<br>SYNC_SEG + (TSEG1 + 16)<br>15<br>14<br>13<br>12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | SJW<br>t: TQ)<br>base<br>EG1 +<br>2+1))<br>2  | (Ass<br>)<br>TSEG2<br>× TQ<br>× TQ                        | uming f<br>e abov<br>e abov<br>9<br>80<br>75<br>70<br>65<br>60 | 2<br>that de<br>e settin  | lay time | : μs)<br>e is \$0 | ns) × 2<br>ons<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>7<br>8<br>9<br>10<br>11<br>12<br>13 | 1<br>667<br>500<br>400<br>333<br>286<br>220<br>200<br>182<br>167<br>154<br>143<br>133 | 2<br>500<br>400<br>333<br>286<br>220<br>200<br>182<br>167<br>154<br>143<br>133<br>125 | 3<br>400<br>333<br>286<br>250<br>200<br>182<br>167<br>154<br>143<br>133<br>125<br>118 | 4<br>333<br>286<br>250<br>222<br>200<br>182<br>167<br>154<br>143<br>133<br>125<br>118<br>111 | 5<br>286<br>2250<br>222<br>200<br>182<br>167<br>154<br>143<br>133<br>125<br>118<br>111<br>105 | 6<br>250<br>222<br>200<br>182<br>167<br>154<br>143<br>133<br>125<br>118<br>111<br>105<br>100 | 7<br>222<br>200<br>182<br>167<br>154<br>143<br>133<br>125<br>118<br>111<br>105<br>100<br>95.2 | 8<br>200<br>182<br>163<br>154<br>143<br>123<br>114<br>115<br>115<br>115<br>115<br>115<br>115<br>115<br>115<br>115 |

#### Figure 15.3-13 Calculation Example of Bit Timing

DataSheet4U.com

et4U.com

www.DataSheet4U.com

## 15.3.6 Message Buffer Valid Register (BVALR)

The message buffer valid register (BVALR) enables or disables the message buffers and indicates their status.

#### Message Buffer Valid Register (BVALR)





DataSheet4U.com

www.DataSheet4U.com

DataShe

450

| Bit Name       |                                                         | Function                                                                                                                             |                                                                                                                                                                                               |  |  |  |  |  |
|----------------|---------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| bit 0 to bit 7 | BVAL7 to BVAL0:<br>Message buffer enable<br>bits 7 to 0 | from the message buf<br>When set to 0: No me<br>messa                                                                                | essage can be transmitted and received to and from the ge buffer $(x)$ .                                                                                                                      |  |  |  |  |  |
|                |                                                         | When set to 1: A message can be transmitted and received to and from the message buffer (x).                                         |                                                                                                                                                                                               |  |  |  |  |  |
|                |                                                         | [Message buffer disa                                                                                                                 | bled (BVALx = 0)]                                                                                                                                                                             |  |  |  |  |  |
|                |                                                         | During transmitting                                                                                                                  | : Transmitting and receiving are disabled after message transmitting is completed or a transmit error is terminated.                                                                          |  |  |  |  |  |
|                |                                                         | During receiving:                                                                                                                    | Transmitting and receiving are disabled immediately.<br>When the received message is stored in the message<br>buffer, transmitting and receiving are disabled after<br>the message is stored. |  |  |  |  |  |
|                |                                                         | <b>Note:</b> The read modify write instructions are disabled until the BVALx bit is actually set to 0 after 0 is written to the bit. |                                                                                                                                                                                               |  |  |  |  |  |
|                |                                                         |                                                                                                                                      |                                                                                                                                                                                               |  |  |  |  |  |
| Note:          | participating in CAN com                                | nunication (the read val                                                                                                             | VALR: BVAL bit to 0) while CAN Controller is<br>lue of the CSR: HALT bit is 0 and CAN Controller is<br>cautions in Section "15.6 Precautions when Using<br>om                                 |  |  |  |  |  |

#### Table 15.3-8 Functions of Message Buffer Enable Register

et4U.com

## 15.3.7 IDE Register (IDER)

The IDE register (IDER) sets the frame format of the message buffer used during transmitting and receiving. Transmitting and receiving are enabled in the standard frame format (ID11 bits) and the extended frame format (ID29 bits).

#### ■ IDE Register (IDER)



Figure 15.3-15 IDE Register (IDER)

et4U.com

DataSheet4U.com

www.DataSheet4U.com

### Table 15.3-9 Functions of IDE Register (IDER)

|                | Bit Name                                      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0 to bit 7 | IDE7 to IDE0:<br>ID Format select bits 7 to 0 | <ul> <li>These bits set the ID format of the message buffer (x).</li> <li>When set to 0: Uses message buffer (x) in standard format (ID11 bits)</li> <li>When set to 1: Uses message buffer (x) in extended format (ID29 bits)</li> <li>Note: The IDE register (IDER) should be set after having the message buffer (x) disabled (BVALR: BVALx = 0). Setting the IDE register (IDER) with the message buffer (x) being enabled may store message unnecessary received.</li> </ul> |
| Note:          | •                                             | ffer (by setting the BVALR: BVAL bit to 0) while CAN Controller is inication (the read value of the CSR: HALT bit is 0 and CAN Controller is                                                                                                                                                                                                                                                                                                                                      |

ready to receive or transmit messages), follow the cautions in Section "15.6 Precautions when Using CAN Controller".

et4U.com

DataSheet4U.com

DataSheet4U.com

# 15.3.8 Transmission Request Register (TREQR)

# The transmission request register (TREQR) sets a transmit request for each message buffer and indicates its status.

### Transmission Request Register (TREQR)





et4U.com

DataSheet4U.com

www.DataSheet4U.com

| Bit Name      |                                                                                                                                                                                                                                                                                                                                                                                                         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0 to bit7 | TREQ7 to TREQ0:<br>Transmission request<br>bits 7 to 0                                                                                                                                                                                                                                                                                                                                                  | <ul> <li>These bits starts transmitting for the message buffer (x).</li> <li>When set to 0: No effect</li> <li>When set to 1: Starts transmitting for message buffer (x)</li> <li>If more than one transmit complete bit is set (TREQx = 1), transmitting is started with the lower number of the message buffer (x) that accepts the transmit request.</li> <li>These bits remain 1s during the transmit being requested and are cleared to 0 when transmitting is completed or the transfer request is cancelled.</li> <li>Clearing a transmit request when transmitting is completed (TREQx = 0) overrides setting of the transmit request bit when 0 is written (TREQx = 1) if both occur at the same time.</li> <li>Read by read modify write instruction: 1 always read</li> <li>[Setting of remote frame receive wait bit (RFWTR: RFWTx)]</li> <li>RFWTx bit = 0: Starts transmitting immediately even if RRTRx bit in receive RTR register = 1</li> <li>RFWTx bit = 1: Starts transmitting after remote frame received.</li> </ul> |
| References:   | <ul> <li>See "15.3.10 Remote Frame Receiving Wait Register (RFWTR)" for details of the remote frame receive wait register (RFWTR).</li> <li>See "15.3.15 Reception RTR Register (RRTRR)" for details of the receive RTR register (RRTRR). DataSheet4U.com</li> <li>See "15.3.11 Transmission Cancel Register (TCANR)" and "15.5.1 Transmission" for details about the transmit cancellation.</li> </ul> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

#### Table 15.3-10 Functions of Transmission Request Register (TREQR)

DataSheet4U.com

et4U.com

www.DataSheet4U.com

#### 15.3.9 Transmission RTR Register (TRTRR)

This register sets the frame format of transmit message for the message buffers.

## Transmission RTR Register (TRTRR)





DataShe



• When 0 is written to each bit in the transmit RTR register (TRTRR), the data frame format is set. When 1 is written to each bit, the remote frame format is set.

Table 15.3-11 Functions of Transmission RTR Register (TRTRR)

| Bit Name       |                                                        | Function                                                                                                                                                                        |
|----------------|--------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0 to bit 7 | TRTR7 to TRTR0:<br>Remote frame setting<br>bits 7 to 0 | These bits set the transfer format of the message buffer (x) for transmitting or receiving.<br>When set to 0: Sets data frame format<br>When set to 1: Sets remote frame format |

et4U.com

DataShe

#### 15.3.10 **Remote Frame Receiving Wait Register (RFWTR)**

Remote frame receiving wait register (RFWTR) sets whether this register waits remote frame receiving when transmission request of data frame is set.

### Remote Frame Receiving Wait Register (RFWTR)





DataShe

458

| Bit Name       |                                                               | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
|----------------|---------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| bit 0 to bit 7 | RFWT7 to RFWT0:<br>Remote frame receiving<br>wait bits 7 to 0 | <ul> <li>These bits set whether to wait for reception of a remote frame for the message buffer (x) for which a request to transmit a data frame is set.</li> <li>When set to 0: Starts transmitting immediately for message buffer (x) for which a request to transmit data frame is set</li> <li>Transmitting is started immediately even if the receive RTR register is already set in the message buffer (x) (RRTRR: RRTRx = 1).</li> <li>When set to 1: Starts transmitting after remote frame is received in message buffer (x) in which a request to transmit a data frame is set.</li> </ul> |  |

| References: | • See "15.3.8 Transmission Request Register (TREQR)" for details of the transmission request register (TREQR). |
|-------------|----------------------------------------------------------------------------------------------------------------|
|             | • See "15.3.9 Transmission RTR Register (TRTRR)" for details of the transmission RTR register (TRTRR).         |
|             | • See "15.3.15 Reception RTR Register (RRTRR)" for details of the receive RTR register (RRTRR).                |

et4U.com

DataSheet4U.com

# 15.3.11 Transmission Cancel Register (TCANR)

The transmission cancel register (TCANR) sets cancellation of a transmission request for the message buffer in the transmit wait state.

### Transmission Cancel Register (TCANR)





DataSheet4U.com

et4U.com

460

www.DataSheet4U.com

| Bit Name       |                                                       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|-------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0 to bit 7 | TCAN7 to TCAN0:<br>Transmission cancel bits<br>7 to 0 | <ul> <li>These bits cancel a transmission request for the message buffer (x) in the transmit wait state.</li> <li>When set to 0: No effect</li> <li>When set to 1: Cancels transmission request for message buffer (x)</li> <li>When a transmission request is cancelled by setting 1 to the TCANx bit, the TREQx bit corresponding to the message buffer (x) is cleared (TREQx = 0) for which transmission request is cancelled.</li> <li>Read: 0 always read</li> <li>Note: The transmission cancel register (TCANR) is a write-only register.</li> </ul> |

### Table 15.3-13 Functions of Transmission Cancel Register (TCANR)

et4U.com

DataShee

# 15.3.12 Transmission Complete Register (TCR)

The transmission complete register (TCR) indicates whether transmitting a data from the message buffer completes. When an output of interrupt request is enabled at completing transmitting, an interrupt request is output when transmitting is completed.

### Transmission Complete Register (TCR)





DataSheet4U.com

462

| Bit Name       |                                                     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0 to bit 7 | TC7 to TC0:<br>Transmission complete<br>bits 7 to 0 | <ul> <li>These bits indicate whether the message buffer (x) completes transmitting message.</li> <li>When message transmitting completed: <ol> <li>is set to the TCx bit corresponding to the message buffer (x) that completes transmitting.</li> </ol> </li> <li>When set to 0: Clears bits if transmitting already completed</li> <li>When set to 1: No effect</li> <li>Read by read modify write instruction: 1 always read</li> <li>Setting the TCx bit when transmitting is completed (TCx = 1) overrides clearing of the TCx bit when 0 is written (TCx = 0) if both occur at the same time.</li> <li>When the TREQx bit in the transmit request register (TREQR) is set (TREQR: TREQx = 1), the TCx bit is cleared (TCx = 0).</li> <li>[Generation of transmission complete interrupt]</li> <li>If the transmit complete interrupt enable register (TIER) is set (TIER: TIEx = 1), a transmit complete interrupt is generated when transmitting is completed (TCR: TCx = 1).</li> </ul> |

### Table 15.3-14 Functions of Transmission Complete Register (TCR)

et4U.com

DataSheet4U.com

#### 15.3.13 Transmission Complete Interrupt Enable Register (TIER)

The transmission complete interrupt enable register (TIER) enables or disables a transmit complete interrupt for each message buffer.

### Transmission Complete Interrupt Enable Register (TIER)



Figure 15.3-21 Transmission complete Interrupt Enable Register (TIER)

DataShe

464

| Table 15.3-15 Functions of Transmission Complete Interrupt Enable Register (TIER) | ) |
|-----------------------------------------------------------------------------------|---|
| ······································                                            | / |

| Bit Name       |                                                                        | Function                                                                                                                                                                                                                                              |
|----------------|------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0 to bit 7 | TIE7 to TIE0:<br>Transmission complete<br>interrupt enable bits 7 to 0 | These bits enable or disable a transmission complete interrupt for the message buffer (x).<br>When set to 0: Disables transmit complete interrupt for message buffer (x)<br>When set to 1: Enables transmit complete interrupt for message buffer (x) |

DataShe

# 15.3.14 Reception Complete Register (RCR)

The reception complete register (RCR) indicates whether the reception a data to the message buffer (x) completes receiving. When an interrupt is enabled at completion of receiving, an interrupt request is generated.

#### Reception Complete Register (RCR)



Figure 15.3-22 Reception Complete Register (RCR)

DataSheet4U.com

466

| Bit Name       |                                                  | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|----------------|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| bit 0 to bit 7 | RC7 to RC0:<br>Reception complete bits<br>7 to 0 | <ul> <li>These bits indicate whether the message buffer (x) completes message receiving.</li> <li>When message receiving completed: <ol> <li>is set to the RCx bit corresponding to the message buffer (x) that completes receiving.</li> </ol> </li> <li>When set to 0: Clears bits when receiving already completed</li> <li>When set to 1: No effect</li> <li>Read by read modify write instruction: 1 always read</li> <li>Setting the RCx bit when receiving is completed (RCx = 1) overrides clearing of the RCx bit when 0 is written (RCx = 0) if both occur at th same time.</li> <li>[Generation of reception complete interrupt]</li> <li>If the reception complete enable register is set (RIER: RIEx = 1), a reception complete interrupt is generated when receiving is completed Note: To clear the reception complete register (RCR), read the received message after the completion of receiving and write 0.</li> </ul> |  |

### Table 15.3-16 Functions of Reception Complete Register (RCR)

et4U.com

DataShe

# 15.3.15 Reception RTR Register (RRTRR)

# The reception RTR register (RRTRR) indicates that the remote frame is stored in the message buffer.

### Reception RTR Register (RRTRR)



#### Figure 15.3-23 Reception RTR Register (RRTRR)

DataSheet4U.com

468

DataShee

www.DataSheet4U.com

| Bit Name       |                                                        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|--------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0 to bit 7 | RRTR7 to RRTR0:<br>Remote frame receive<br>bits 7 to 0 | <ul> <li>These bits indicate that the message buffer (x) receives a remote frame.</li> <li>When remote frame is received: <ol> <li>is set to the RRTRx bit corresponding to the message buffer (x) that receives a remote frame.</li> </ol> </li> <li>When set to 0: Cleared when receiving completed</li> <li>When set to 1: No effect <ol> <li>Setting the RRTRx bit when a remote frame is received (RRTRx = 1) overrides clearing of the RRTRx bit when 0 is written (RRTRx = 0) if both occur at the same time.</li> <li>The RRTRx bit corresponding to the message buffer (x) that receives a data frame is cleared (RRTRx = 0).</li> <li>If message transmitting is completed (TCR: TCx = 1), the RRTRx bit corresponding to the message buffer (x) that transmits the message is cleared (RRTRx = 0).</li> </ol> </li> <li>Read by read modify write instruction: 1 always read</li> </ul> |

### Table 15.3-17 Functions of Reception RTR Register (RRTRR)

et4U.com

DataShe

# 15.3.16 Reception Overrun Register (ROVRR)

The reception overrun register (ROVRR) indicates that an overrun occurs (the corresponding message buffer is in the receive complete state.) at storing the received message in the message buffer.

### Reception Overrun Register (ROVRR)



Figure 15.3-24 Reception Overrun Register (ROVRR)

et4U.com

DataSheet4U.com

www.DataSheet4U.com

|                | Bit Name                                            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|-----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0 to bit 7 | ROVR7 to ROVR0:<br>Reception overrun bits 7<br>to 0 | <ul> <li>These bits indicate that an overrun occurs at storing the received message in the message buffer that had completed receiving.</li> <li>At overrun: 1 is set to the ROVRx bit corresponding to the message buffer (x) where an overrun occurs.</li> <li>When set to 0: Cleared when 0 is set to after reception overrun occurred</li> <li>When set to 1: No effect</li> <li>Read by read modify write instruction: 1 always read</li> <li>Setting the ROVRx bit when an overrun occurs (ROVRx = 1) overrides clearing of the ROVRx bit when 0 is written (ROVRx = 0) if both occur at the same time.</li> </ul> |

### Table 15.3-18 Functions of Reception Overrun Register (ROVRR)

et4U.com

DataSheet4U.com

# 15.3.17 Reception Complete Interrupt Enable Register (RIER)

The reception complete interrupt enable register (RIER) enables or disables a reception complete interrupt for each message buffer.

#### Reception Complete Interrupt Enable Register (RIER)



Figure 15.3-25 Reception Complete Interrupt Enable Register (RIER)

DataShe

DataSheet4U.com

et4U.com

| Table 15.3-19 | <b>Functions of</b> | Reception | <b>Complete Interrupt</b> | Enable Register (RIER) |
|---------------|---------------------|-----------|---------------------------|------------------------|
|---------------|---------------------|-----------|---------------------------|------------------------|

|                | Bit Name                                                            | Function                                                                                                                                                                                                                                                                         |
|----------------|---------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0 to bit 7 | RIE7 to RIE0:<br>Reception complete<br>interrupt enable bits 7 to 0 | <ul><li>These bits enable or disable a reception complete interrupt for the message buffer (x).</li><li>When set to 0: Disables reception complete interrupt for message buffer (x)</li><li>When set to 1: Enables reception complete interrupt for message buffer (x)</li></ul> |

DataShe

# 15.3.18 Acceptance Mask Select Register (AMSR)

The acceptance mask select register (AMSR) selects the mask (acceptance mask) format for comparison between the identifier (ID) of the received message and the message buffer.

### Acceptance Mask Select Register (AMSR)

|        |                                | <u> </u> |        |         |           |         |            |         | •        | ,                     |
|--------|--------------------------------|----------|--------|---------|-----------|---------|------------|---------|----------|-----------------------|
|        |                                | bit 15   | 14     | 13      | 12        | 11      | 10         | 9       | 8        | Reset value           |
|        |                                | AMS7.1   | AMS7.0 | AMS6.1  | AMS6.0    | AMS5.1  | AMS5.0     | AMS4.1  | AMS4.0   | XXXXXXXX <sub>B</sub> |
|        |                                | R/W      | R/W    | R/W     | R/W       | R/W     | R/W        | R/W     | R/W      |                       |
|        |                                | 7        | 6      | 5       | 4         | 3       | 2          | 1       | 0        | Reset value           |
|        |                                | AMS3.1   | AMS3.0 | AMS2.1  | AMS2.0    | AMS1.1  | AMS1.0     | AMS0.1  | AMS0.0   | XXXXXXXX <sub>B</sub> |
|        |                                | R/W      | R/W    | R/W     | R/W       | R/W     | R/W        | R/W     | R/W      | _                     |
|        |                                |          |        |         |           |         |            |         |          |                       |
| 4U.com |                                |          |        | AMS     | x.1 AN    | /ISx.0  | Accept     | ance m  | ask sele | ct bits (x = 7 to 0)  |
|        |                                |          |        | 0       |           | 0       | Full-bit o | compari | son      |                       |
|        |                                |          |        | 0       | JataShe   | 9140.0  | Full-bit ı | mask    |          |                       |
|        |                                |          |        | 1       |           | 0       | Uses ac    | ceptan  | ce mask  | register 0 (AMR0)     |
|        |                                |          |        | 1       |           | 1       | Uses ac    | ceptan  | ce mask  | register 1 (AMR1)     |
|        |                                |          |        | x (7 to | o 0) is m | iessage | e buffer's | s numbe | er (x).  |                       |
|        | X: Undefined<br>R/W: Read/Writ | 0        |        |         |           |         |            |         |          |                       |
|        | R/W. Reau/Will                 | e        |        |         |           |         |            |         |          |                       |
|        |                                |          |        |         |           |         |            |         |          |                       |
|        |                                |          |        |         |           |         |            |         |          |                       |
|        |                                |          |        |         |           |         |            |         |          |                       |

Figure 15.3-26 Acceptance Mask Select Register (AMSR)

| Bit Name        |                                                                                                 | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------|-------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0 to bit 15 | AMS7.0 to AMS0.0,<br>AMS7.1 to AMS0.1:<br>Acceptance mask select<br>bits 7.0 to 0.0, 7.1 to 0.0 | <ul> <li>These bits select the mask (acceptance mask) format for comparison between the received message ID and message buffer ID (IDR) for the message buffer (x).</li> <li>No comparison with masked bits is made.</li> <li>Full-bit comparison: All bits are compared in collating the setting values of the ID register (IDR) with the received message ID.</li> <li>Full-bit masking: All bits for the setting values of the ID register (IDR) and the received message ID are masked.</li> <li>Using acceptance mask register 0 (or 1):</li> <li>The acceptance mask register 0 or 1 (AMR0 or AMR1) is used as an acceptance mask filter. At collating the setting values of the ID register (IDR) with the received message ID, only the bits set to 0 and corresponding to the AMx bit in the acceptance mask register are compared and the bits set to 1 and corresponding to the AMx bit are masked.</li> <li>If the AMSx.1 and AMSx.0 bits are set to 10<sub>B</sub> or 11<sub>B</sub>, always set the acceptance mask select register (AMSR) should be set after disabling the message buffer (x) to be set (BVALR: BVALx = 0). Setting the acceptance mask select register (AMSR) with the message buffer (x) enabled may store a message unnecessary received.</li> </ul> |

### Table 15.3-20 Functions of Acceptance Mask Select Register (AMSR)

ready to receive or transmit messages), follow the cautions in Section "15.6 Precautions when Using CAN Controller".

DataSheet4U.com

et4U.com

www.DataSheet4U.com

# 15.3.19 Acceptance Mask Register (AMR)

The CAN controller has two acceptance mask registers (AMR0 and AMR1). Both of them can be used in the standard frame format (ID11 bits, AM28 to AM18) and the extended frame format (ID29 bits, AM28 to AM0).

#### Acceptance Mask Register (AMR)



www.DataSheet4U.com

|                  | Bit Name                                                   | Function                                                                                                                                                                                                                                                                            |
|------------------|------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0 to bit 7   | AM21 to AM 28:<br>Acceptance mask bits 28<br>to 21 (BYTE0) | These bits set whether to compare or mask each bit at collating the acceptance code set in the ID register (IDR: IDx) with the received message ID.                                                                                                                                 |
| bit 8 to bit 15  | AM20 to AM 13:<br>Acceptance mask bits 20<br>to 13 (BYTE1) | <ul> <li>If the AMSx.1 or AMSx.0 bits of acceptance mask select registers are set to 10<sub>B</sub> or 11<sub>B</sub>, always set the acceptance mask register (AMR0 or AMR1) to be used, too.</li> <li>Standard frame format (IDER: IDEx = 0):11 bits from AM28 to AM18</li> </ul> |
| bit 0 to bit 7   | AM12 to AM 5:<br>Acceptance mask bits 12<br>to 5 (BYTE2)   | are used.<br><b>Extended frame format (IDER: IDEx = 1):</b> 29 bits from AM28 to AM0 are used.                                                                                                                                                                                      |
| bit 11 to bit 15 | AM4 to AM 0:<br>Acceptance mask bits 4<br>to 0 (BYTE3)     | When AMx bit set to 0 (compare):<br>The bits corresponding to the AMx bit set to 0 are compared at collating<br>the acceptance code set in the ID register (IDR: IDx) with the received<br>message ID.                                                                              |
|                  |                                                            | When AMx bit set to 1 (mask):<br>The bits corresponding to the AMx bit set to 1 are masked at collating the<br>acceptance code set in the ID register (IDR: IDx) with the received<br>message ID.                                                                                   |
|                  |                                                            | Note: The acceptance mask select register (AMR0, AMR1) should be set<br>after disabling the message buffer (x) to be set (BVALR: BVALx = 0).<br>Setting the acceptance mask select register (AMR) with the message<br>Dbuffer (x) thabled may store a message unnecessary received. |
| Note:            | participating in CAN com                                   | buffer (by setting the BVALR: BVAL bit to 0) while CAN Controller is<br>nunication (the read value of the CSR: HALT bit is 0 and CAN Controller is<br>t messages), follow the cautions in Section "15.6 Precautions when Using                                                      |

### Table 15.3-21 Functions of Acceptance Mask Register (AMSR)

DataSheet4U.com

et4U.com

www.DataSheet4U.com

## 15.3.20 Message Buffers

# The message buffers consist of ID register, DLC register, and data register are used for transmission/reception of the message.

#### Message Buffers

- There are 8 message buffers.
- One message buffer (x) (x = 0 to 7) consists of an ID register (IDRx), DLC register (DLCRx), and data register (DTRx).
- The message buffer (x) is used to transmit and receive messages.
- Higher priority is given to smaller number message buffer.
  - At transmitting, if a transmit request is generated to more than one message buffer, transmitting is started from the message buffer with the smallest number.
  - At receiving, if the received message ID passes the acceptance filter (which compares received message ID with message buffer ID after acceptance masking) set in more than one message buffer, a received message is stored in the message buffer with the smallest number.
- If the same acceptance filter is set in more than one message buffer, it can be used as multiple message buffers. This provides sufficient time to perform receiving.

| Notes:      | <ul> <li>Write by words to the message buffer area and general-purpose RAM area. At writing by bytes, undefined data is written to the upper bytes and writing to the upper bytes is ignored when writing to the lower bytes is performed.</li> <li>The message buffer (x) area disabled by the message buffer enable register (BVALR: BVALx = 0) can be used as a general-purpose RAM area. However, during transmitting or receiving, it may take up to 64 machine cycles to access the message buffer area and general-purpose RAM area.</li> </ul> |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| References: | • See "15.5.1 Transmission".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|             | • See "15.5.2 Reception".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|             | • See "15.5.4 Setting Multiple Message Receiving" for details of the configuration of the multiple message buffer.                                                                                                                                                                                                                                                                                                                                                                                                                                     |

et4U.com

# 15.3.21 ID Register (IDRx, x = 7 to 0)

The ID register (IDR) sets the ID of the message buffer used for transmitting and receiving. In the standard frame format, 11 bits from ID28 to ID18 are used, and in the extended frame format, 29 bits from ID28 to ID0 are used.

## ■ ID Register (IDR)

|        |                                                                  |                       |                   | Figure            | 15.3-28           | ID Reg            | ister (ID         | DR)              |                  |                                     |
|--------|------------------------------------------------------------------|-----------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|-------------------------------------|
|        | BYTE0                                                            | bit 7<br>ID28<br>R/W  | 6<br>ID27<br>R/W  | 5<br>ID26<br>R/W  | 4<br>ID25<br>R/W  | 3<br>ID24<br>R/W  | 2<br>ID23<br>R/W  | 1<br>ID22<br>R/W | 0<br>ID21<br>R/W | Reset value<br>XXXXXXX <sub>B</sub> |
|        | BYTE1                                                            | bit 15<br>ID20<br>R/W | 14<br>ID19<br>R/W | 13<br>ID18<br>R/W | 12<br>ID17<br>R/W | 11<br>ID16<br>R/W | 10<br>ID15<br>R/W | 9<br>ID14<br>R/W | 8<br>ID13<br>R/W | Reset value<br>XXXXXXX <sub>B</sub> |
| 4U.com | BYTE2                                                            | 7<br>ID12<br>R/W      | 6<br>ID11<br>R/W  | 5<br>ID10<br>R/W  | 4<br>ID9<br>DRAWh | 3<br>ID8<br>R/W.c | 2<br>ID7<br>R/W   | 1<br>ID6<br>R/W  | 0<br>ID5<br>R/W  | Reset value<br>XXXXXXX <sub>B</sub> |
|        | BYTE3                                                            | bit 15<br>ID4<br>R/W  | 14<br>ID3<br>R/W  | 13<br>ID2<br>R/W  | 12<br>ID1<br>R/W  | 11<br>ID0<br>R/W  | 10                | 9                | 8                | Reset value<br>XXXXXXX <sub>B</sub> |
|        | R/W: Read/Write<br>X : Undefined<br>- : Unused<br>: Used bits in |                       | ndard fra         | ame forr          | nat               |                   |                   |                  |                  |                                     |

DataSheet4U.com

www.DataSheet4U.com

### Table 15.3-22 Functions of ID Register (IDR)

| Bit              | Name                                         | Function                                                                                                                                                                                                                                                                                                  |
|------------------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0 to bit 7   | ID28 to ID21:<br>ID bits 28 to 21<br>(BYTE0) | These bits set the acceptance code or transmit message ID to be collated with the received message ID.<br><b>Standard frame format (IDER: IDEx = 0):</b> 11 bits from ID28 to ID18 are used.                                                                                                              |
| bit 8 to bit 15  | ID20 to ID13:<br>ID bits 20 to 13<br>(BYTE1) | <ul> <li>The old messages left in the receive shift register are stored in ID17 to ID0. This will not affect the operation.</li> <li>All received message IDs are stored even if specific bits are masked.</li> <li>Extended frame format (IDER: IDEx = 1): 29 bits from ID28 to ID0 are used.</li> </ul> |
| bit 0 to bit 7   | ID12 to ID5:<br>ID bits 28 to 21<br>(BYTE2)  | <ul> <li>Notes: • When using the standard frame format (IDER: IDEx = 0), the bits from ID28 to ID22 cannot be all set to 1.</li> <li>• When setting the ID register (IDR), perform writing by words. Writing by bytes is disabled.</li> </ul>                                                             |
| bit 11 to bit 15 | ID4 to ID 0:<br>ID bits 4 to 0<br>(BYTE3)    | <ul> <li>The ID register (IDR) should be set after disabling the message buffer (x) to be set (BVALR: BVALx = 0). Setting the ID register (IDR) with the message buffer (x) enabled may store a message unnecessary received.</li> </ul>                                                                  |

et4U.com

DataSheet4U.com

• Setting example of ID register (IDR)

Table 15.3-23 gives a setting example of the ID register (IDR) in the standard and extended frame formats.

### Table 15.3-23 Example of ID Setting in Standard and Extended Frame Formats

| Sta      | andard Fram | ne Format |       |           | Exter    | ded Fram | e Format |       |       |
|----------|-------------|-----------|-------|-----------|----------|----------|----------|-------|-------|
| ID (Dec) | ID (Hex)    | BYTE0     | BYTE1 | ID (Dec)  | ID (Hex) | BYTE0    | BYTE1    | BYTE2 | BYTE3 |
| 1        | 1           | 00        | 20    | 1         | 1        | 00       | 00       | 00    | 08    |
| 2        | 2           | 00        | 40    | 2         | 2        | 00       | 00       | 00    | 10    |
| 3        | 3           | 00        | 60    | 3         | 3        | 00       | 00       | 00    | 18    |
| 4        | 4           | 00        | 80    | 4         | 4        | 00       | 00       | 00    | 20    |
| 5        | 5           | 00        | A0    | 5         | 5        | 00       | 00       | 00    | 28    |
| 6        | 6           | 00        | C0    | 6         | 6        | 00       | 00       | 00    | 30    |
| 7        | 7           | 00        | E0    | 7         | 7        | 00       | 00       | 00    | 38    |
| 8        | 8           | 01        | 00    | 8         | 8        | 00       | 00       | 00    | 40    |
| 9        | 9           | 01        | 20    | 9         | 9        | 00       | 00       | 00    | 48    |
| 10       | А           | 01        | 40    | 10        | А        | 00       | 00       | 00    | 50    |
|          | 1<br>1<br>1 |           | •     |           | •        |          |          | •     |       |
| 30       | 1E          | 03        | C0    | 30        | 1E       | 00       | 00       | 00    | F0    |
| 31       | 1F          | 03        | E0    | 31        | 1F       | 00       | 00       | 00    | F8    |
| 32       | 20          | 04        | 00    | 32        | 20       | 00       | 00       | 01    | 00    |
|          | 1<br>1      |           | •     |           | •        |          |          | •     | 1     |
| 100      | 64          | 0C        | 80    | 100       | 64       | 00       | 00       | 03    | 20    |
| 101      | 65          | 0C        | A0    | 101       | 65       | 00       | 00       | 03    | 28    |
| •        | 1           |           | •     |           | •        |          | I        | •     | 1     |
| 200      | C8          | 19        | 00    | 200       | C8       | 00       | 00       | 06    | 40    |
|          | ,<br>,      |           | •     |           |          |          |          | •     |       |
| 2043     | 7FB         | FF        | 60    | 2043      | 7FB      | 00       | 00       | 3F    | D8    |
| 2044     | 7FC         | FF        | 80    | 2044      | 7FC      | 00       | 00       | 3F    | EO    |
| 2045     | 7FD         | FF        | A0    | 2045      | 7FD      | 00       | 00       | 3F    | E8    |
| 2046     | 7FE         | FF        | C0    | 2046      | 7FE      | 00       | 00       | 3F    | F0    |
| 2047     | 7FF         | FF        | E0    | 2047      | 7FF      | 00       | 00       | 3F    | F8    |
|          |             |           |       |           | •        |          |          | •     |       |
|          |             |           |       | 8190      | 1FFE     | 00       | 00       | FF    | F0    |
|          |             |           |       | 8191      | 1FFF     | 00       | 00       | FF    | F8    |
|          |             |           |       | 8192      | 2000     | 00       | 01       | 00    | 00    |
|          |             |           |       |           | •        |          | -        | •     |       |
|          |             |           |       | 536870905 | 1FFFFFF9 | FF       | FF       | FC    | 80    |
|          |             |           |       | 536870906 | 1FFFFFFA | FF       | FF       | FD    | 00    |
|          |             |           |       | 536870907 | 1FFFFFB  | FF       | FF       | FD    | 80    |
|          |             |           |       | 536870908 | 1FFFFFFC | FF       | FF       | FE    | 00    |
|          |             |           |       | 536870909 | 1FFFFFFD | FF       | FF       | FE    | 80    |
|          |             |           |       | 536870910 | 1FFFFFFE | FF       | FF       | FF    | 00    |
|          |             |           |       | 536870911 | 1FFFFFFF | FF       | FF       | FF    | 80    |

DataShe

DataSheet4U.com

et4U.com

www.DataSheet4U.com

# 15.3.22 DLC Register (DLCR)

# The DLC register (DLCR) sets the data length of the message to be transmitted or received.

## ■ DLC Register (DLCR)



et4U.com

#### Table 15.3-24 Functions of DLC Register (DLCR)

DataShe

|                | Bit Name                                  | DataSheet4U.com F                                                                                                                                                             | unction                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0 to bit 3 | DLC3 to DLC0:<br>Data length setting bits | received.<br>When data frame transmitted:<br>When remote frame transmitted:<br>When data frame received:<br>When remote frame received:<br>Notes: • The data length should be | count) of the message to be transmitted or<br>The data length (byte count) of the<br>transmit message is set.<br>The data length (byte count) of the<br>request message is set.<br>The data length (byte count) of the<br>received message is stored.<br>The data length (byte count) of the<br>request message is stored.<br>Set within the range of 0 to 8 bytes.<br>ister (DLCR), write by words. Writing by |

# 15.3.23 Data Register (DTR)

The data register (DTR) sets the messages at transmitting or receiving a data frame. The data length can be set from 0 to 8 bytes.

### ■ Data Register (DTR)



et4U.com

#### Table 15.3-25 Functions of Data Register (DTR)

|                 | Bit Name                                          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------|---------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0 to bit 15 | D7 to D0 (BYTE7 to<br>BYTE0):<br>Data bits 7 to 0 | <ul> <li>The data register (DTRx) is used only for transmitting or receiving a data frame, and is not used for a remote frame.</li> <li>The transmit message is set up to 8 bytes. The message is transmitted on an MSB-first basis starting with the small message buffer number (BYTE0 to BYTE7).</li> <li>The received message is stored on an MSB-first basis starting with the small message buffer number (BYTE0 to BYTE7).</li> <li>If the received message is less than 8 bytes, undefined data is stored in the rest of the bytes of the data register (DTRx). However this does not affect the operation.</li> <li>Note: When setting the data register (DTR), write by words. Writing by bytes is disabled.</li> </ul> |

www.DataSheet4U.com

## **15.4** Interrupts of CAN Controller

The CAN controller has a transmit complete interrupt, receive complete interrupt and node state transition interrupt, and can generate interrupts when;

- The transmission complete bit (TCR: TCx) is set.
- The reception complete bit (RCR: RCx) is set.
- The node status transition flag (CSR: NT) is set.

#### Interrupts of CAN Controller

Table 15.4-1 shows the interrupt control bits and interrupt factors of the CAN controller.

 Table 15.4-1
 Interrupt Control Bits and Interrupt Factors of CAN Controller

| Transmit/<br>Receive | Interrupt Flag Bit                          | Interrupt Factor                        | Interrupt Enable Bit                                               | Clearing of Interrupt Request<br>Flag                                                                          | Data |
|----------------------|---------------------------------------------|-----------------------------------------|--------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|------|
| Transmit             | Transmission<br>complete bit<br>TCR: TCx=1  | Message transmitting complete           | Transmission<br>complete interrupt<br>enable bit<br>TIER: TIEx = 1 | Setting transmission request bit<br>(TREQR: TREQx = 1)<br>Writing 0 to transmission<br>complete bit (TCR: TCx) |      |
| Receive              | Reception complete<br>bit<br>RCR: RCx=1     | Message receiving<br>complete DataSheet | Reception complete<br>interrupt enable bit<br>RIER: RIEx=1         | Writing 0 to reception complete<br>bit (RCR: RCx)                                                              |      |
| Transmit             | Node status transition<br>flag<br>CSR: NT=1 | Node status transition                  | Node status transition<br>interrupt enable bit<br>CSR: NIE=1       | Writing 0 to node status transition<br>flag (CSR: NT)                                                          |      |

• Transmission complete interrupt

When message transmitting is completed, 1 is set to the TCx bit in the transmission complete register (TCR). When a transmission complete interrupt is enabled (TIER: TIEx = 1) and when TCx = 1, a transmission complete interrupt is generated. When a transmission request to the message buffer is set (TREQR: TREQx = 1), the TCx bit in the transmission complete register (TCR) is automatically cleared to 0. When 0 is written to the TCx bit in the transmission complete register (TCR) after the completion of message transmitting (TCR: TCx = 1), the TCx bit is cleared.

Reception complete interrupt

When message receiving is completed, 1 is set to the RCx bit in the receive complete register (RCR). When a reception complete interrupt is enabled (RIER: RIEx = 1) and when RCx = 1, a reception complete interrupt is generated. When 0 is written to the RCx bit in the reception complete register (RCR) after the completion of message receiving (RCR: RCx = 1), the RCx bit is cleared.

et4U.com

#### Node status transition interrupt

When the node status of the CAN controller changes, 1 is set to the NT bit in the control status register (CSR). If a node status transition interrupt is enabled (CSR: NIE = 1) when NT = 1, a node status transition interrupt is generated. When 0 is written to the NT bit in the control status register the NT bit is cleared.

### Registers and Vector Tables Related to Interrupt of CAN Controller

See "3.5 Interrupt" for details of the interrupts.

et4U.com

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

# 15.5 Explanation of Operation of CAN Controller

# This section explains the procedures for transmitting and receiving messages and the setting of bit timing, frame format, ID and acceptance filter.

### Explanation of Operation of CAN Controller

The following sections provide more details of the operation of CAN controller.

- Transmission of message (See Section "15.5.1 Transmission")
- Reception of message (See Section "15.5.2 Reception")
- Procedures for transmission/reception of message (See Section "15.5.3 Procedures for Transmitting and Receiving")
- Reception of multiple message (See Section "15.5.4 Setting Multiple Message Receiving")

et4U.com

DataSheet4U.com

DataShe

www.DataSheet4U.com

# 15.5.1 Transmission

### Figure 15.5-1 shows a transmission flowchart.

### Transmission



Figure 15.5-1 Transmission Flowchart

#### Starting transmitting

#### Setting of transmission request

To start transmitting, set the TREQx bit in the transmission request register to 1 which is corresponding to the message buffer (x) that transmits the message. When the TREQx bit is set, the transmission complete register is cleared (TCR: TCx = 0).

#### Presence or absence of remote frame receive wait

If the RFWTx bit in the remote frame receive wait register is set, transmitting is started after a remote frame is received (RRTRR: RRTRx = 1).

If the remote frame receive wait register does not wait for receiving of a remote frame (RFWTR: RFWTx = 0), transmitting is started immediately after the transmission request bit is set (TREQR: TREQx = 1).

#### Performing transmitting

#### Transmission request set in more than one message buffer

When a transmission request is set in more than one message buffer (TREQR: TREQx = 1), transmitting is performed starting with the small-numbered message buffer (x = 7 to 0).

#### Transmitting to CAN bus

Transmitting message to the CAN bus from the transmit output pin (TX) is started when the CAN bus is idle.

#### DataShe

#### Arbitration

Arbitration is performed when a message buffer conflicts with transmitting from other CAN controllers on the CAN bus. If arbitration fails or an error occurs during transmitting, retransmitting is performed automatically until it succeeds after waiting until the bus goes idle again.

#### Selection of frame format

When 0 is set to the TRTRx bit in the transmit RTR register, a data frame is transmitted. When 1 is set to the bit, a remote frame is transmitted.

#### Canceling transmit request

#### Cancellation by transmission cancel register (TCANR)

During transmitting message, the transmission request set in the message buffer that is not transmitted (held) can be cancelled by setting 1 in the transmission cancel register (TCANR).

When the transmission request is completely cancelled (TCANR: TCANx = 1), the transmission request register is cleared (TREQx = 1).

#### Cancellation by receiving message

The message buffer can receive the message even during requesting a transmitting. However, the transmission request is cancelled under the following conditions:

#### **Request to transmit data frame:**

When a data frame is received, the transmission request is cancelled. When a remote frame is received, the transmission request is not cancelled.

#### **Request to transmit remote frame:**

The transmission request is cancelled even if either a data frame or remote frame is received.

DataSheet4U.com

et4U.com

#### • Completing transmitting

#### Success of transmitting

When transmitting is terminated normally, the TCx bit in the transmission complete register is set. The transmission request register and receive RTR register (TREQR: TREQx = 0, RRTRR: RRTRx = 0) are cleared.

#### Generation of transmission interrupt

When the TIEx bit in the transmission complete interrupt enable register is set, an interrupt request is generated when transmitting is completed (TCR: TCx = 1).

et4U.com

DataSheet4U.com

DataShe

## 15.5.2 Reception



#### Reception



490

#### Starting receiving

Receiving is started when the start-of-frame (SOF) of a data frame or remote frame is detected on the CAN bus.

#### Acceptance filter

The received message in the standard frame format is compared with the message buffer (x) set in the standard frame format (IDER: IDEx = 0). The received message in the extended frame format is compared with the message buffer (x) set in the extended frame format (IDER: IDEx = 1).

#### Passing through acceptance filter

If all bits set to "compare" in the acceptance mask are matched after comparison between the received message ID and acceptance code (IDR: IDx), the received message passes the acceptance filter in the message buffer (x).

#### Storing received message

If receiving message is successful, the received message is stored in the message buffer (x) that has the ID that had passed the acceptance filter.

#### Data frame received

The received message is stored in the ID register (IDR) and DLC register (DLCR), data register (DTR). If the received message is less than 8 bytes, undefined data is stored in the rest of the bytes in the data register (DTR).

#### **Remote frame received**

DataSheet4U.com

The received message is stored in the ID register (IDR) and DLC register (DLCR). The data register (DTR) remains unchanged.

#### More than one message buffer

If there is more than one message buffer with the ID that had passed the acceptance filter, the message buffer (x) where the received message is stored is determined under the following conditions:

- Higher priority is given to the message buffer with a smaller number (x = 0 to 7). The priority of message buffer 0 is the highest and 7 is the lowest.
- The received message is stored in preference to the message buffer that has not been completed receiving (RCR: RCx = 0).
- If the bit in the acceptance mask select register is set to "full-bit comparison" (AMSx.1 = 0, 0 =  $00_B$ ), the received message is stored in the corresponding message buffer (x), regardless of the setting value of the reception complete register (RCR: RCx).
- If there is more than one message buffer that has not been completed receiving, or if there is more than one message buffer with the AMSx.1 and AMSx.0 bits in the acceptance mask select register set to 00<sub>B</sub> (full-bit comparison), the received message is stored in the message buffer with the smallest number (x).
- If there is no message buffer that satisfies the above conditions, the received message is stored in the message buffer with the lowest number (x).
- The message buffers should be arranged in order of ascending number (x) as follows;
  - Smallest number (x): Acceptance mask set to "full-bit comparison"
  - Middle number (x): Acceptance mask registers 0 and 1 used
- Largest number (x): Acceptance mask set to "full-bit masking" www.DataSheet4U.com

et4U.com

DataSheet4U.com

Setting of acceptance mask select register

| ſ | AMSx. 1 | AMSx. 0 | Acceptance Mask (x = 7 to 0)               |
|---|---------|---------|--------------------------------------------|
| ſ | 0       | 0       | Full-bit comparison is performed.          |
| Ī | 0       | 1       | Full-bit masking is performed.             |
| Ī | 1       | 0       | Acceptance mask register 0 (AMR0) is used. |
|   | 1       | 1       | Acceptance mask register 1 (AMR1) is used. |

 Table 15.5-1
 Setting of Acceptance Mask Select Register

Figure 15.5-3 Flowchart of Determining Message Buffer that Stores Received Message



DataShe

DataSheet4U.com

et4U.com

492

#### Receive overrun

When another received message is stored in the message buffer that has completed receiving (RCR: RCx = 1), a receive overrun occurs. When a receive overrun occurs, 1 is set to the ROVRx bit in the receive overrun register corresponding to the number of the message buffer (x) where the receive overrun occurs.

Processing for reception of data frame and remote frame

#### Processing for reception of data frame

- The reception RTR register is cleared (RRTRR: RRTRx = 0).
- The transmission request register is cleared (TREQR: TREQx = 0) immediately before the received message is stored. A transmission request to the message buffer (x) that does not perform transmitting is cancelled.

| Note: | Either the request to transmit a data frame or a remote frame is cancelled.                                                                                                                                                                          |    |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
|       | Processing for reception of remote frame                                                                                                                                                                                                             |    |
|       | • The reception RTR register is set (RRTRR: $RRTRx = 1$ ).                                                                                                                                                                                           |    |
|       | • If the transmission RTR register is set (TRTRR: TRTRx = 1), the transmission request register is cleared (TREQx = 0). The request to transmit a remote frame to the message buffer (x) that does not perform transmitting is cancelled.            |    |
| Note: | The request to transmit a data frame is not cancelled.<br>For details about how to cancel a transmit request, see "Canceling transmit request" in Section "15.5.1<br>Transmission".                                                                  | Da |
| •     | Completing receiving                                                                                                                                                                                                                                 |    |
|       | When the received message is stored, the reception complete register is set (RCR: $RCx = 1$ ). If the reception complete interrupt enable register is set (RIER: RIEx = 1), an interrupt is generated when receiving is completed (RCR: $RCx = 1$ ). |    |
| Note: | The CAN controller cannot receive any message transmitted by itself.                                                                                                                                                                                 |    |

et4U

## 15.5.3 **Procedures for Transmitting and Receiving**

#### The section explains the procedure for transmission/reception of message.

#### Presetting

- Setting of bit timing
  - Set the bit timing register (BTR) after halting the bus operation (CSR: HALT = 1).
- Setting of frame format
  - Set the frame format used in the message buffer (x). When using the standard frame format, set the IDEx bit in the IDE register (IDER) to 0. When using the extended frame format, set the IDEx bit to 1.

#### Setting of ID

- Set the ID of the message buffer (x) to the ID28 to ID0 bits in the ID register (IDR). In the standard frame format, it does not have to set the ID17 to ID0 bits. The ID of the message buffer (x) is used as the transmit message ID at transmitting and as the acceptance code at receiving.
- Set the ID after disabling the message buffer (x) (BVALR: BVALx = 0). Setting the ID with the message buffer (x) enabled may store a message unnecessary received.

DataShe

Setting of acceptance filter

DataSheet4U.com

- The acceptance filter used in the message buffer (x) is set by a combination of the acceptance code and acceptance mask. Set the acceptance filter after disabling the message buffer (x) (BVALR: BVALx = 0). Setting the acceptance filter with the message buffer (x) enabled may store a message unnecessary received.
- The acceptance mask used for each message buffer (x) is selected by the acceptance mask select register (AMSR). When using the acceptance mask registers (AMR0 and AMR1), set the acceptance mask register (AMR0.1), too.
- Set the acceptance mask so that a transmission request will not be cancelled by storing a message unnecessary received.

et4U.com

#### Procedure for Transmitting message Buffer (x)

Figure 15.5-4 shows a procedure for the transmit setting.



Procedure for transmission message buffer (x)

After completion of presetting, set the message buffer (x) enabled (BVALR: BVALx = 1) by message buffer enable register.

#### • Setting transmit data length code

- Set the transmit data length code (byte count) to the DLC3 to DLC0 bits in the DLC register (DLCR).
- When transmitting a data frame (TRTRR: TRTRx = 0), set the data length of the transmit message.
- When transmitting a remote frame (TRTRR: TRTRx = 1), set the data length (byte count) of the message to be requested.

| Note: | Setting other than " $0000_{B}$ " to " $1000_{B}$ " (0 to 8 bytes) is prohibited.                                                                                                                                                                                |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <ul> <li>Setting transmit data (only for transmission of data frame)</li> </ul>                                                                                                                                                                                  |
|       | When transmitting a data frame (TRTRR: TRTR $x = 0$ ), set the data of byte count to be transmitted in the data register (DTR).                                                                                                                                  |
| Note: | Rewrite transmit data after setting the TREQx bit in the transmit request register to 0. There is no need to set the bit disabled in the message buffer enable register (BVALR: $BVALx = 0$ ). When the bit is set to disabled, no remote frame can be received. |
|       | Setting transmission RTR register (TRTRR)                                                                                                                                                                                                                        |
|       | • When transmitting a data frame, set the TRTRx bit in the transmission RTR register to 0.                                                                                                                                                                       |
|       | • When transmitting a remote frame, set the TRTRx bit in the transmission RTR register to 1.                                                                                                                                                                     |
|       | <ul> <li>Setting conditions for starting transmitting (only in transmitting data frame)</li> </ul>                                                                                                                                                               |
|       | • When setting the request to transmit a data frame (TREQR: TREQx = 1 and TRTRR: TRTRx = 0) and starting transmitting immediately, set the RFWTx bit in the remote frame wait register to 0.                                                                     |
|       | • When setting the request to transmit a data frame (TREQR: TREQx = 1 and TRTRR: TRTRx = 0) and starting transmitting after waiting until a remote frame is received (RRTRR: RRTRx = 1), set the RFWTx bit in the remote frame wait register to 1.               |
| Note: | When the RFWT bit in the remote frame wait register is set to 1, no remote frame can be transmitted.                                                                                                                                                             |
|       | Setting transmission complete interrupt                                                                                                                                                                                                                          |
|       | • When enabling an interrupt when transmitting is completed (TCR: $TCx = 1$ ), set the TIEx bit in the transmit complete enable register to 1.                                                                                                                   |
|       | • When disabling an interrupt when transmitting is completed (TCR: $TCx = 1$ ), set the TIEx bit in the transmission complete enable register to 0.                                                                                                              |
|       |                                                                                                                                                                                                                                                                  |

#### Canceling bus halt

After the completion of setting bit timing and transmitting, write 0 to the HALT bit in the control status register (CSR: HALT) to cancel the bus halt.

Setting transmission request

To set a transmission request, set the TREQx bit in the transmission request register to 1.

- Canceling transmission request
  - To cancel the transmission request held in the message buffer (x), write 1 to the TCANx bit in the transmission cancel register.
  - Check the TREQx bit in the transmission request register (TREQR). When the TREQx bit is 0, transmission cancel is terminated or transmitting is completed. After that, check the TCx bit in the transmission complete register (TCR). If the TCx bit is 0, transmission cancel is terminated and if the TCx bit is 1, transmitting is completed.

#### • Processing when transmitting completed

- When transmitting is successful, 1 is set to the TCx bit in the transmit complete register (TCR).
- When a transmission complete interrupt is enabled (TIER: TIEx = 1), an interrupt is generated.
- After checking the completion of transmitting, write 0 to the TCx bit in the transmission complete register (TCR) to clear the transmission complete register (TCR). When the transmission complete interrupt is cancelled.
- When the message is received or stored, the held transmission requests are cancelled as follows:
  - When a data frame is received, the request to transmit a data frame is cancelled.
  - When a data frame is received, the request to transmit a remote frame is cancelled.
  - When a remote frame is received, the request to transmit a remote frame is cancelled.

When a remote frame is received or stored, the request to transmit a data frame is not cancelled but the data in the ID register and DLC register are rewritten to the data of the received remote frame. Therefore, the data in the ID register and DLC register for the data frame to be transmitted are replaced by data in the received remote frame.

DataShe

et4U.com

#### ■ Procedure for Receiving Message Buffer (x)

Figure 15.5-5 shows the procedure for the receiving setting.



#### Figure 15.5-5 Flowchart of Procedure for Receive Setting

#### Procedure for receiving message buffer (x)

After presetting, perform the following setting:

- Setting reception complete interrupt
  - To generate a reception complete interrupt, set the RIEx bit in the reception complete interrupt enable register (RIER) to 1.
  - To disable a reception complete interrupt (RCR: RCx = 1), set the RIEx bit to 0.

DataSheet4U.com

et4U.com

498

#### Starting receiving

To start receiving after the completion of setting, set the BVALx bit in the message buffer enable register (BVALR) to 1 and enable the message buffer (x).

Canceling bus halt

After the completion of setting bit timing and transmitting, write 0 to the HALT bit in the control status register (CSR: HALT) to cancel the bus halt.

#### Processing when receiving completed

- If reception is successful after passing through the acceptance filter, the received message is stored in the message buffer (x), 1 is set to the RCx of the reception complete register (RCR). For data frame reception, RRTRx bit of the remote request receive register (RRTRR) is cleared to 0. For remote frame reception, 1 is set to the RRTRx bit.
- If a reception interrupt is enabled (RIEx of the reception interrupt enable register (RIER) is 1), an interrupt is generated.
- Process the received message after checking the completion of receiving (RCR: RCx = 1).
- Check the ROVRx bit in the receive overrun register (ROVRR) after the completion of processing the received message.
  - If the ROVRx bit is set to 0, the received message is enabled. When 0 is written to the RCx bit (a reception complete interrupt is also cancelled), receiving is terminated.
  - If the ROVRx bit is set to 1, a receive overrun occurs and the new message may overwrite the received message. When a receive overrun occurs, write 0 to the ROVRx bit and then process the received message again.

499





Figure 15.5-6 shows an example of reception interrupt processing.



DataShe

DataSheet4U.com

et4U.com

DataSheet4U.com

## 15.5.4 Setting Multiple Message Receiving

When there is insufficient time to receive messages such as frequently received messages or messages with different IDs, more than one message buffer can be combined to a multiple message buffer to give the CPU sufficient time to process received messages.

To configure multiple message buffers, perform the same setting of acceptance filter of the message buffers to be combined.

#### Setting Configuration of Multiple Message Buffer

When four messages in the standard frame format are received with doing the acceptance filter of message buffers 5, 6 and 7 on the same settings, the multiple message buffer operates as shown in the figure.

Note: When the acceptance mask select register is set to "full-bit comparison" (AMSR: AMSx.1, AMSx.0 =  $00_B$ ), do not set the same acceptance code. When the register is set to "full-bit comparison", the messages are always stored in the message buffer with the smaller number, so the message buffers cannot be formed into a multiple message buffer.

et4U.com

DataSheet4U.com

www.DataSheet4U.com



Figure 15.5-7 Example of Operation of Multiple Message Buffer

DataSheet4U.com

et4U.com

502

www.DataSheet4U.com

## 15.6 Precautions when Using CAN Controller

#### Use of the CAN Controller requires the following cautions.

#### Caution for Disabling Message Buffers by BVAL bits

The use of BVAL bits may affect malfunction of CAN Controller when messages buffers are set disabled while CAN Controller is participating in CAN communication (read value of HALT bit is 0 and CAN Controller is ready to receive or transmit messages). This section shows the work around of this malfunction.

#### Condition

When following two conditions occur at the same time, CAN Controller will not perform to receive or transmit messages normally.

- CAN Controller is participating in the CAN communication. (i.e. The read value of HALT bit is 0 and CAN Controller is ready to receive or transmit messages)
- Message buffers are read or written when the message buffers are disabled by BVAL bits.

#### Work around

#### **Operation for re-configuring receiving message buffers**

While CAN Controller is participating in CAN communication (the read value of HALT bit is 0 and CAN Controller is ready to receive or transmit messages), it is necessary to following one from the two operations described below to re-configure message buffers by ID, AMS and AMR0/1 register-settings.

- Use of HALT bit
  - Write 1 to HALT bit and read it back for checking the result is 1. Then change the settings for ID/ AMS/AMR0/1 registers.
- No Use of Message Buffer 0
  - Don't use the message buffer 0. In other words, disable message buffer (BVAL0=0), prohibit receive interrupt (RIE0=0) and do not request transmission (TREQ0=0).

#### Operation for processing received message

Don't use the receiving prohibition by BVAL bit to avoid over-written of next message. Use the ROVR bit for checking if over-write has been performed. For details, refer to section "15.3.16 Reception Overrun Register (ROVRR)" and "15.5.3 Procedures for Transmitting and Receiving".

#### **Operation for suppressing transmission request**

Don't use BVAL bit for suppressing transmission request, use TCAN bit instead of it.

#### Operation for composing transmission message

For composing a transmission message, it is necessary to disable the message buffer by BVAL bit to change contents of ID and IDE registers. In this case, BVAL bit should reset (BVAL=0) after checking if TREQ bit is 0 or after completion of the previous message transmission (TC=1).

et4U.com

## 15.7 Program Example of CAN Controller

This section shows the program example of CAN controller.

#### Program Example of CAN Transmission and Reception

- Processing specifications
  - Set message buffer 5 of CAN to data frame transmit mode and message buffer 0 to data frame receive mode.
  - Setting of frame format: Standard frame format
  - Setting of ID: message buffer 0 ID = 1, message buffer 5 ID = 5
  - Baud rate: 100 Kbps (machine clock = 16 MHz)
  - Acceptance mask selection: full-bit comparison
  - After entering the bus mode (HALT = 0), data  $A0A0_{H}$  is transmitted.
  - A transmission request is made within the transmission complete interrupt routine (TREQx=1) to transmit the same data (When TREQx is set to start sending, the transmission complete interrupt bit is cleared).

et4U.com

• The reception complete interrupt bit is cleared within the reception interrupt routine.

DataShe

DataSheet4U.com

#### • Coding example

|          | :                                                                               |          |
|----------|---------------------------------------------------------------------------------|----------|
|          | :                                                                               |          |
|          | :                                                                               |          |
|          | ;//Setting of data format (CAN initialization)                                  |          |
|          | MOVW BTR,#05CC7H ; Setting baud rate 100 Kbps                                   |          |
|          | MOVW IDER, #0000H ; (Machine clock = 16 MHz)                                    |          |
|          | ; Setting of frame format                                                       |          |
|          | ; (0: Standard, 1:Expanded)                                                     |          |
|          | MOVW IDR51,#0A000H ; Setting of data frame 5 ID (ID = 5)                        |          |
|          | MOVW IDR01,#2000H ; Setting of data frame 0 ID (ID = 1)                         |          |
|          | MOVW AMSR,#0000H ; Acceptance mask select register                              |          |
|          | ; (full-bit comparison)                                                         |          |
|          | MOVW BVALR,#021H ; Message buffers 5 and 0 enabled                              |          |
|          | ;//Transmit setting                                                             |          |
|          | MOVW DLCR5,#02H ; Setting of transmission data length                           |          |
|          | ; (00H: 0-byte length, 08H: 8-byte length)                                      |          |
|          | MOVW RFWTR,#0000H ; Remote frame receive wait register                          |          |
|          | MOVW TRTRR,#0000H ; Transmission RTR register (0: Data frame                    |          |
|          | ; transmission, 1: Remote frame transmission)                                   |          |
|          | MOVW TIER,#0020H ; Transmission complete interrupt enable register              |          |
|          | ;//Reception setting                                                            |          |
|          | MOVW RIER, #0001H ; Reception complete interrupt enable register                |          |
|          | ;//Bus operation start                                                          |          |
| et4U.com | MOV CSR0,#80H ; Control status register (HALT=0)                                | DataShee |
|          | sthlt BBS CSR0:0,sthlt ; Wait until HALT=0                                      | Dataone  |
|          | ;//Transmission data set                                                        |          |
|          | MOVW DTR5, #0A0A0H ; Write $A0A0_{\rm H}$ to data register of message buffer 5. |          |
|          | MOVW TREQR, #0020H ; Transmission request register                              |          |
|          | ; (1: Transmission start, 0: Transmission stop)                                 |          |
|          |                                                                                 |          |
|          |                                                                                 |          |
|          |                                                                                 |          |
|          | ;//Reception complete interrupt<br>CANRX                                        |          |
|          | MOVW RCR,#0000H ; Reception complete register<br>RETI                           |          |
|          | ;//Transmission complete interrupt                                              |          |
|          | CANTX                                                                           |          |
|          | MOVW TREQR,#0020H ; Transmission request register                               |          |
|          | ; (1: Transmission start, 0: Transmission stop)                                 |          |
|          | RETI                                                                            |          |
|          |                                                                                 |          |

et4U.com

DataSheet4U.com

DataSheet4U.com

506

DataSheet4U.com

DataShe

# CHAPTER 16 8/16 ADDRESS MATCH DETECTION FUNCTION

This chapter explains the address match detection function and its operation.

et4U.com

- 16.1 Overview of Address Match Detection Function
- 16.2 Block Diagram of Address Match Detection Function
- 16.3 Configuration of Address Match Detection Function
- 16.4 Explanation of Operation of Address Match Detection Function
- 16.5 Program Example of Address Match Detection Function

CHAPTER 16 8/16 ADDRESS MATCH DETECTION FUNCTION

### 16.1 Overview of Address Match Detection Function

If the address of the instruction to be processed next to the instruction currently processed by the program matches the address set in the detect address setting registers, the address match detection function forcibly replaces the next instruction to be processed by the program with the INT9 instruction to branch to the interrupt processing program. Since the address match detection function function can use the INT9 interrupt for instruction processing, the program can be corrected by patch processing.

#### Overview of Address Match Detection Function

- The address of the instruction to be processed next to the instruction currently processed by the program is always held in the address latch through the internal bus. The address match detection function always compares the value of the address held in the address latch with that of the address set in the detect address setting registers. When these compared values match, the next instruction to be processed by the CPU is forcibly replaced by the INT9 instruction, and the interrupt processing program is executed.
- There are two detect address setting registers (PADR0 and PADR1), each of which has an interrupt enable bit. The generation of an interrupt due to a match between the address held in the address latch and the address set in the detect address setting registers can be enabled and disabled for each register.

et4U.com

ataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

## 16.2 Block Diagram of Address Match Detection Function

The address match detection module consists of the following blocks:

- Address latch
- Address detection control register (PACSR)
- Detect address setting registers

#### Block Diagram of Address Match Detection Function

Figure 16.2-1 shows the block diagram of the address match detection function.





et4U.com

#### Address latch

The address latch stores the value of the address output to the internal data bus.

Address detection control register (PACSR)

The address detection control register enables or disables output of an interrupt at an address match.

Detect address setting registers (PADR0, PADR1)

The detect address setting registers set the address that is compared with the value of the address latch.

## **16.3** Configuration of Address Match Detection Function

This section details the registers used by the address match detection function.

#### ■ List of Registers and Reset Values of Address Match Detection Function

|                                                    | bit | 7           | 6            | 5        | 4  | 3  | 2  | 1 | 0 |
|----------------------------------------------------|-----|-------------|--------------|----------|----|----|----|---|---|
| Address detection control register (PACSR)         |     | 0           | 0            | 0        | 0  | 0  | 0  | 0 | 0 |
|                                                    | bit | 7           | 6            | 5        | 4  | 3  | 2  | 1 | 0 |
| Detect address setting register 0 (PAD<br>: High   | R0) | Х           | Х            | Х        | Х  | Х  | Х  | Х | Х |
|                                                    | bit | 15          | 14           | 13       | 12 | 11 | 10 | 9 | 8 |
| Detect address setting register 0 (PAD<br>: Middle | R0) | Х           | Х            | Х        | Х  | Х  | Х  | Х | х |
|                                                    | bit | 7           | 6            | 5        | 4  | 3  | 2  | 1 | 0 |
| Detect address setting register 0 (PAD<br>: Low    | R0) | Х           | Х            | Х        | Х  | Х  | Х  | Х | х |
|                                                    | bit | 7           | 6            | 5        | 4  | 3  | 2  | 1 | 0 |
| Detect address setting register 1 (PAD<br>: High   | R1) | X<br>DataSl | X<br>heet4U. | X<br>com | Х  | Х  | Х  | Х | Х |
|                                                    | bit | 15          | 14           | 13       | 12 | 11 | 10 | 9 | 8 |
| Detect address setting register 1 (PAD<br>: Middle | R1) | Х           | Х            | Х        | Х  | Х  | Х  | Х | х |
|                                                    | bit | 7           | 6            | 5        | 4  | 3  | 2  | 1 | 0 |
| Detect address setting register 1 (PAD<br>: Low    | R1) | Х           | Х            | Х        | Х  | Х  | Х  | Х | Х |

#### Figure 16.3-1 List of Registers and Reset Values of Address Match Detection Function

DataShe

et4U.com

## 16.3.1 Address Detection Control Register (PACSR)

The address detection control register (PACSR) enables or disables output of an interrupt at an address match. When an address match is detected when output of an interrupt at an address match is enabled, the INT9 interrupt is generated.

#### Address Detection Control Register (PACSR)





DataShe

DataSheet4U.com

et4U.com

#### CHAPTER 16 8/16 ADDRESS MATCH DETECTION FUNCTION

|                   | Bit Name                                         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------------|--------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0             | Reserved: reserved bit                           | Always set to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| bit 1             | AD0E:<br>Address match<br>detection enable bit 0 | <ul> <li>The address match detection operation with the detect address setting register 0 (PADR0) is enabled or disabled.</li> <li>When set to 0: Disables the address match detection operation.</li> <li>When set to 1: Enables the address match detection operation.</li> <li>When the value of detect address setting register 0 (PADR0) matches with the value of address latch at enabling the address match detect operation (AD0E = 1), the INT9 instruction is immediately executed.</li> </ul>     |
| bit 2             | Reserved: reserved bit                           | Always set to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| bit 3             | AD1E:<br>Address match<br>detection enable bit 1 | <ul> <li>The address match detection operation with the detect address setting register 1 (PADR1) is enabled or disabled.</li> <li>When set to 0: Disables the address match detection operation.</li> <li>When set to 1: Enables the address match detection operation.</li> <li>When the value of detect address setting registers 1 (PADR1) matches with the value of address latch at enabling the address match detection operation (AD1E = 1), the INT9 instruction is immediately executed.</li> </ul> |
| bit 4 to<br>bit 7 | Reserved: reserved bit                           | Always set to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

#### Table 16.3-1 Functions of Address Detection Control Register (PACSR)

et4U.com

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

DataShe

DataSheet4U.com

## 16.3.2 Detect Address Setting Registers (PADR0 and PADR1)

The value of an address to be detected is set in the detect address setting registers. When the address of the instruction processed by the program matches the address set in the detect address setting registers, the next instruction is forcibly replaced by the INT9 instruction, and the interrupt processing program is executed.

Figure 16.3-3 Detect Address Setting Registers (PADR0 and PADR1)

#### ■ Detect Address Setting Registers (PADR0 and PADR1)

|                         | bit 7  | bit 6  | bit 5  | bit 4  | bit 3    | bit 2  | bit 1 | bit 0 | Reset value           |      |
|-------------------------|--------|--------|--------|--------|----------|--------|-------|-------|-----------------------|------|
| PADR0, PADR1:<br>High   | D23    | D22    | D21    | D20    | D19      | D18    | D17   | D16   | 00000000 <sub>B</sub> |      |
| ·                       | R/W    | R/W    | R/W    | R/W    | R/W      | R/W    | R/W   | R/W   |                       |      |
|                         | bit 15 | bit 14 | bit 13 | bit 12 | bit 11   | bit 10 | bit 9 | bit 8 | Reset value           |      |
| PADR0, PADR1:<br>Middle | D15    | D14    | D13    | D12    | D11      | D10    | D9    | D8    | 00000000 <sub>B</sub> |      |
|                         | R      | R      | R/W    | R/W    | R/W      | R/W    | R/W   | R/W   |                       | Data |
|                         | bit 7  | bit 6  | bit 5  | DataSh | eet4 J.c | Dit 2  | bit 1 | bit 0 | Reset value           |      |
| PADR0, PADR1:<br>Low    | D7     | D6     | D5     | D4     | D3       | D2     | D1    | D0    | 00000000 <sub>B</sub> |      |
|                         | R/W    | R/W    | R/W    | R/W    | R/W      | R/W    | R/W   | R/W   |                       |      |

et4U.com

DataSheet4U.com

#### CHAPTER 16 8/16 ADDRESS MATCH DETECTION FUNCTION

#### Functions of Detect Address Setting Registers

• There are two detect address setting registers (PADR0 and PADR1) that consist of a high byte (bank), middle byte, and low byte, totaling 24 bits.

Table 16.3-2 Address Setting of Detect Address Setting Registers

| Register Name                                | Interrupt Output Enable | Address Setting |                                                  |  |  |  |
|----------------------------------------------|-------------------------|-----------------|--------------------------------------------------|--|--|--|
|                                              |                         | High            | Set the upper 8 bits of detect address 0 (bank). |  |  |  |
| Detect address setting<br>register 0 (PADR0) | PACSR: AD0E             | Middle          | Set the middle 8 bits of detect address 0.       |  |  |  |
|                                              |                         | Low             | Set the lower 8 bits of detect address 0.        |  |  |  |
|                                              |                         | High            | Set the upper 8 bits of detect address 1 (bank). |  |  |  |
| Detect address setting<br>register 1 (PADR1) | PACSR: AD1E             | Middle          | Set the middle 8 bits of detect address 1.       |  |  |  |
|                                              |                         | Low             | Set the lower 8 bits of detect address 1.        |  |  |  |

• In the detect address setting registers (PADR0 and PADR1), starting address (first byte) of instruction to be replaced by INT9 instruction should be set.

#### Figure 16.3-4 Setting of Starting Address of Instruction Code to be Replaced by INT9

|          |                  | Set to det | ect address (High : FFн, Middle : 00н, Low : 1Fн) |
|----------|------------------|------------|---------------------------------------------------|
| Address  | Instruction code | Mnemonic   |                                                   |
| FF001C:  | A8 00 00         | MOVW       | RW0, #0000                                        |
| FF001F : | (4A)00 00        | MOVW       | A, #0000                                          |
| FF0022 : | 4A 80 08         | MOVW       | A,#0880                                           |

|        | 0 | to. | <u> </u> | n  | $\square$ |
|--------|---|-----|----------|----|-----------|
| 1)     | ~ | 10  | $\odot$  | 11 | $\sim$    |
| $\sim$ | ~ |     |          |    |           |
|        |   |     |          |    |           |

| Notes: | • | When an address of other than the first byte is set to the detect address setting register (PADR0 and |
|--------|---|-------------------------------------------------------------------------------------------------------|
|        |   | PADR1), the instruction code is not replaced by INT9 instruction and a program of an interrupt        |
|        |   | processing is not be performed. When the address is set to the second byte or subsequent, the address |
|        |   | set by the instruction code is replaced by "01" (INT9 instruction code) and, which may cause          |
|        |   | malfunction.                                                                                          |
|        |   |                                                                                                       |

- The detect address setting registers (PADR0 and PADR1) should be set after disabling the address match detection (PACSR: AD0E = 0 or AD1E = 0) of corresponding address match control registers. If the detect address setting registers are changed without disabling the address match detection, the address match detection function will work immediately after an address match occurs during writing address, which may cause malfunction.
- The address match detection function can be used only for addresses of the internal ROM area. If addresses of the external memory area are set, the address match detection function will not work and the INT9 instruction will not be executed.

## 16.4 Explanation of Operation of Address Match Detection Function

If the addresses of the instructions executed in the program match those set in the detection address setting registers (PADR0 and PADR1), the address match detection function will replace the first instruction code with the INT9 instruction ( $01_H$ ) to branch to the interrupt processing program.

#### Operation of Address Match Detection Function

Figure 16.4-1 shows the operation of the address match detection function when the detect addresses are set and an address match is detected.

#### Figure 16.4-1 Operation of Address Match Detection Function



DataShe

#### Setting Detect Address

- 1. Disable the detection address setting register 0 (PADR0) where the detect address is set for address match detection (PACSR: AD0E = 0).
- 2. Set the detect address in the detection address setting register 0 (PADR0). Set "FF<sub>H</sub>" at the higher bits of the detection address setting register 0 (PADR0), " $00_{\text{H}}$ " at the middle bits, and " $1F_{\text{H}}$ " at the lower bits.
- 3. Enable the detect address setting register 0 (PADR0) where the detect address is set for address match detection (PACSR: AD0E = 1).

#### Program Execution

- 1. If the address of the instruction to be executed in the program matches the set detect address, the first instruction code at the matched address is replaced by the INT9 instruction code  $(01_{\rm H})$ .
- 2. INT9 instruction is executed. INT9 interrupt is generated and then interrupt processing program is executed.

515

CHAPTER 16 8/16 ADDRESS MATCH DETECTION FUNCTION

## 16.4.1 Example of using Address Match Detection Function

## This section gives an example of patch processing for program correction using the address match detection function.

## ■ System Configuration and E<sup>2</sup>PROM Memory Map

• System configuration

Figure 16.4-2 gives an example of the system configuration using the address match detection function.





et4U.com

DataSheet4U.com

www.DataSheet4U.com

### ■ E<sup>2</sup>PROM Memory Map

Figure 16.4-3 shows the allocation of the patch program and data at storing the patch program in  $E^2$ PROM.





et4U.com

#### Patch program byte count

The total byte count of the patch program (main body) is stored. If the byte count is " $00_{\text{H}}$ ", it indicates that no patch program is provided.

#### Detect address (24 bits)

The address where the instruction code is replaced by the INT9 instruction code due to program error is stored. This address is set in the detection address setting registers (PADR0 and PADR1).

#### • Patch program (main body)

The program executed by the INT9 interrupt processing when the program address matches the detect address is stored. Patch program 0 is allocated from any predetermined address. Patch program 1 is allocated from the address indicating <starting address of patch program 0 + total byte count of patch program 0>.

#### CHAPTER 16 8/16 ADDRESS MATCH DETECTION FUNCTION

#### Setting and Operating State

- Initialization
  - $E^2$ PROM data are all cleared to "00<sub>H</sub>".
- Occurrence of program error
  - By using the connector (UART), information about the patch program is transmitted to the MCU (F<sup>2</sup>MC-16LX) from the outside according to the allocation of the E<sup>2</sup>PROM patch program and data.
  - The MCU ( $F^2MC-16LX$ ) stores the information received from outside in the  $E^2PROM$ .

#### Reset sequence

- After reset, the MCU (F<sup>2</sup>MC-16LX) reads the byte count of the E<sup>2</sup>PROM patch program to check the presence or absence of the correction program.
- If the byte count of the patch program is not " $00_{\text{H}}$ ", the higher, middle and lower bits at detect addresses 0 and 1 are read and set in the detection address setting registers 0 and 1 (PADR0 and PADR1). The patch program (main body) is read according to the byte count of the patch program and written to RAM in the MCU (F<sup>2</sup>MC-16LX).
- The patch program (main body) is allocated to the address where the patch program is executed in the INT9 interrupt processing by the address match detection function.

• Address match detection is enabled (PACSR: AD0E = 1, AD1E = 1)

#### INT9 Interrupt processing

- Interrupt processing is performed by the INT9 instruction. The MB90385 series has no interrupt request flag by address match detection. Therefore, if the stack information in the program counter is discarded, the detect address cannot be checked. When checking the detect address, check the value of program counter stacked in the interrupt processing routine.
- The patch program is executed, branching to the normal program.

DataSheet4U.com

et4U.com

## Operation of Address Match Detection Function at Storing Patch Program in E<sup>2</sup>PROM

Figure 16.4-4 shows the operation of the address match detection function at storing the patch program in  $E^2$ PROM.

## Figure 16.4-4 Operation of Address Match Detection Function at Storing Patch Program in E<sup>2</sup>PROM



#### CHAPTER 16 8/16 ADDRESS MATCH DETECTION FUNCTION

#### ■ Flow of Patch Processing

Figure 16.4-5 shows the flow of patch processing using the address match detection function.



Figure 16.4-5 Flow of Patch Processing

DataSheet4U.com

et4U.com

www.DataSheet4U.com

### 16.5 Program Example of Address Match Detection Function

This section gives a program example for the address match detection function.

#### Program Example for Address Match Detection Function

#### Processing specifications

If the address of the instruction to be executed by the program matches the address set in the detection address setting register (PADR0), the INT9 instruction is executed.

#### Coding example

```
et4U.com
```

```
PACSR EQU 00009EH
PADRL EQU 001FF0H
PADRM EQU 001FF1H
                           ; Address detection control register
                           ; Detection address setting register 0 (Low)
                           ; Detection address setting register 0 (Middle)
PADRH EQU 001FF2H
                            ; Detection address setting register 0 (High)
;-----Main program------
CODE CSEG
START:
                                                                                DataShe
                            ; Stack pointer (SP), etc.,
                            ; already reset
       MOVPADRL,#00H; Set address detection register 0 (Low)MOVPADRM,#00H; Set address detection register 0 (Middle)MOVPADRH,#00H; Set address detection register 0 (High)
;
       MOV I:PACSR, #00000010B ; Enable address match
       :
       processing by user
       :
LOOP:
        :
       processing by user
        :
       BAR LOOP
;----Interrupt program------
WARI:
        :
       processing by user
       :
       BETI
                            ; Return from interrupt processing
CODE
      ENDS
;-----Vector setting------
VECT
       CSEG ABS=0FFH
       ORG 00FFDCH
       DSL WARI
       ORG 00FFDCH ; Set reset vector
       DSL START
       DB 00H
                            ; Set to single-chip mode
VECT
      ENDS
       END START
```

#### CHAPTER 16 8/16 ADDRESS MATCH DETECTION FUNCTION

et4U.com

DataSheet4U.com

DataSheet4U.com

522

DataSheet4U.com

DataShe

# CHAPTER 17 ROM MIRRORING FUNCTION SELECT MODULE

This chapter describes the functions and operations of the ROM mirroring function select module.

et4U.com

17.1 Overview of ROM Mirroring Function Select Module

17.2 ROM Mirroring Function Select Register (ROMM) DataSheet4U.com DataShe

CHAPTER 17 ROM MIRRORING FUNCTION SELECT MODULE

### 17.1 Overview of ROM Mirroring Function Select Module

## The ROM mirroring function select module provides a setting so that ROM data in the FF bank can be read by access to the 00 bank.

#### Block Diagram of ROM Mirroring Function Select Module



et4U.com

#### ■ Access to FF Bank by ROM Mirroring Function

Figure 17.1-2 shows the location in memory when ROM mirroring function allows access to the 00 bank to read ROM data in the FF bank.



#### Figure 17.1-2 Access to FF Bank by ROM Mirroring Function

DataSheet4U.com

524

DataSheet4U.com

www.DataSheet4U.com

### Memory Space when ROM Mirroring Function Enabled/Disabled

Figure 17.1-3 shows the availability of access to memory space when the ROM mirroring function is enabled or disabled.

|       | 000000H<br>1/O area<br>0000C0H<br>000100H<br>RAM area<br>Address 1<br>003900H<br>Extend I/O area<br>RAM area<br>RAM area<br>RAM area<br>Extend I/O area<br>Extend I/O area<br>ROM area<br>ROM area<br>FF0000H<br>ROM area<br>ROM area |       |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| U.com | function enabled       function disabled         Product type       MB90V495G       MB90F387/S       MB90387/S         Address 1       001900H       000900H       000900H          :       Internal access memory           :       Access disabled         * : When the area from "FE0000 <sub>H</sub> " to "FEFFFF <sub>H</sub> " of MB90387/S or MB90F387/S is read out, the area "FF0000 <sub>H</sub> " to "FFFFFF <sub>H</sub> " can be read.                                                                                                           | DataS |

### Figure 17.1-3 Memory Space when ROM Mirroring Function Enabled/Disabled (in Single Chip Mode)

### ■ List of Registers and Reset Values of ROM Mirroring Function Select Module

### Figure 17.1-4 List of Registers and Reset Values of ROM Mirroring Function Select Module

| bit                                           | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
|-----------------------------------------------|----|----|----|----|----|----|---|---|
| ROM mirroring function select register (ROMM) | Х  | Х  | Х  | Х  | Х  | Х  | Х | 1 |
| X: Undefined                                  |    |    |    |    |    |    |   |   |

525

CHAPTER 17 ROM MIRRORING FUNCTION SELECT MODULE

### **17.2 ROM Mirroring Function Select Register (ROMM)**

The ROM mirroring function select register (ROMM) enables or disables the ROM mirroring function. When the ROM mirroring function is enabled, ROM data in the FF bank can be read by access to the 00 bank.

### ■ ROM Mirror Function Select Register (ROMM)



### Figure 17.2-1 ROM Mirroring Function Select Register (ROMM)

t4U.com

DataShe

### Table 17.2-1 Functions of ROM Mirroring Function Select Register (ROMM)

function select register (ROMM) is prohibited.

|                 | Bit Name                                    | Function                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 8           | MI:<br>ROM mirroring function<br>select bit | <ul> <li>This bit enables or disables the ROM mirroring function.</li> <li>When set to 0: Disables ROM mirroring function</li> <li>When set to 1: Enables ROM mirroring function</li> <li>When the ROM mirroring function is enabled (MI = 1), data at ROM addresses "FF4000<sub>H</sub>" to "FFFFFF<sub>H</sub>" can be read by accessing addresses "004000<sub>H</sub>" to "00FFFF<sub>H</sub>"</li> </ul> |
| bit 9 to bit 15 | Unused bits                                 | <b>Read:</b> Value undefined<br>Be sure to set these bits to 0.                                                                                                                                                                                                                                                                                                                                              |
| Note:           | While the ROM area at add                   | dresses " $004000_{\text{H}}$ " to " $00$ FFFF <sub>H</sub> " is being used, access to the ROM mirroring                                                                                                                                                                                                                                                                                                     |

This chapter describes the function and operation of 512 Kbit flash memory.

- 18.1 Overview of 512 Kbit Flash Memory
- 18.2 Registers and Sector Configuration of Flash Memory
- 18.3 Flash Memory Control Status Register (FMCS)
- 18.4 How to Start Automatic Algorithm of Flash Memory
- 18.5 Check the Execution State of Automatic Algorithm DataSheet4U.com
- 18.6 Details of Programming/Erasing Flash Memory
- 18.7 Program Example of 512 Kbit Flash Memory

et4U.com

www.DataSheet4U.com

## 18.1 Overview of 512 Kbit Flash Memory

There are three ways of programming and erasing flash memory as follows:

- 1. Programming and erasing using parallel writer
- 2. Programming and erasing using serial writer

3. Programming and erasing by executing program

This chapter describes the above "3. Programming and Erasing by Executing Program".

### Overview of 512 Kbit Flash Memory

512 Kbit flash memory is placed in the  $FF_H$  banks on the CPU memory map. The function of the flash memory I/F circuit provides read access and program access from the CPU to flash memory.

Programming and erasing flash memory are enabled by an instruction from the CPU via the flash memory I/F circuit. This allows reprogramming in the mounted state under CPU control and improvement of programming data efficiency.

### Features of 512 Kbit Flash Memory

- 128 Kwords x 8 bits/64 Kwords x 16 bits (16 K + 8 K + 8 K + 32 K) sector configuration
- Uses automatic program algorithm (Embedded Algorithm<sup>TM</sup>: the same manner as MBM29LV200
- Erase pause/restart function

DataShe

- 4U.com
- Detects completion of writing/erasing using data polling or toggle bit functions
- Detects completion of writing/erasing by CPU interrupts
- Sector erase function (any combination of sectors)
- Programming/erase count 10,000 (min.)
- Flash read cycle time (min.): 2 machine cycles
- Sector protection function
- Temporary sector protection cancel function
- Extend sector protection function

Embedded Algorithm<sup>TM</sup> is a registered trademark of Advanced Micro Devices, Inc.

Note:The function for reading the manufacture code and device code is unprovided.These codes cannot be accessed by any command.

### Programming and Erasing Flash Memory

- Programming and erasing flash memory cannot be performed at one time.
- Programming or erasing flash memory can be performed by copying the program in flash memory to RAM and executing the program copied in RAM.

### 18.2 Registers and Sector Configuration of Flash Memory

This section explains the registers and the sector configuration of flash memory.

### ■ List of Registers and Reset Values of Flash Memory

|                                                | bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------------------------------------|-----|---|---|---|---|---|---|---|---|
| Flash memory control status<br>register (FMCS) |     | 0 | 0 | 0 | Х | 0 | 0 | 0 | 0 |
| X: Undefined                                   | _   |   |   |   |   |   |   |   |   |

### Figure 18.2-1 List of Registers and Reset Values of Flash Memory

### Sector Configuration of 512 Kbit Flash Memory

Figure 18.2-2 shows the sector configuration of 512 Kbit flash memory. The upper and lower addresses of each sector are given in the figure.

### • Sector configuration

For access from the CPU, the FF bank register has SA0 to SA3.

### Figure 18.2-2 Sector Configuration of 512 Kbit Flash Memory

DataShe

| Flash memory    | CPU address     | Writer address* |
|-----------------|-----------------|-----------------|
|                 | <b>FF0000</b> н | 70000н          |
| SA0 (32 Kbytes) |                 |                 |
|                 | FF7FFFH         | 77FFFH          |
|                 | FF8000н         | 78000н          |
| SA1 (8 Kbytes)  |                 |                 |
|                 | FF9FFFH         | 79FFFн          |
|                 | FFA000н         | 7А000н          |
| SA2 (8 Kbytes)  |                 |                 |
|                 | FFBFFFH         | 7BFFFH          |
|                 | FFC000н         | 7С000н          |
| SA3 (16 Kbytes) |                 |                 |
|                 | FFFFFH          | 7FFFFH          |

DataSheet4U.com

### 18.3 Flash Memory Control Status Register (FMCS)

The flash memory control status register (FMCS) functions are shown in Figure 18.3-1.

### Flash Memory Control Status Register (FMCS)



Figure 18.3-1 Flash Memory Control Status Register (FMCS)

DataSheet4U.com

530

|                | Bit Name                                                             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 0 to bit 3 | Reserved: Reserved bits                                              | Always set these bits to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| bit 4          | RDY:<br>Flash memory<br>programming/erasing<br>status bit            | <ul> <li>This bit shows the programming/erasing status of flash memory.</li> <li>If the RDY bit is 0, programming/erasing flash memory is disabled.</li> <li>The suspend commands, such as the read/reset command and sector erasing pause, can be accepted even if the RDY bit is 0. The RDY bit is set to 1 when programming/erasing is completed.</li> </ul>                                                                                                                                                                                                                                                                          |
| bit 5          | WE:<br>Flash memory<br>programming/erasing<br>enable bit             | <ul> <li>This bit enables or disables the programming/erasing of flash memory area. The WE bit should be set before starting the command to program/erase flash memory.</li> <li>When set to 0: No program/erase signal is generated even if the command to program/erase the FF bank is input.</li> <li>When set to 1: Programming/erasing flash memory is enabled after inputting program/erase command to the FF bank.</li> <li>When not performing programming/erasing, the WE bit should be set to 0 so as not to accidentally program or erase flash memory.</li> </ul>                                                            |
| bit 6          | RDYINT:<br>Flash memory operation<br>flag bit                        | <ul> <li>This bit shows the operating state of flash memory.</li> <li>If programming/erasing flash memory is terminated, the RDYINT bit is set to 1 in timing of termination of the automatic flash memory algorithm.</li> <li>If the RDYINT bit is set to 1 when an interrupt as programming/erasing flash memory is terminated is enabled (FMCS: INTE = 1), an interrupt is requested.</li> <li>If the RDYINT bit is 0, programming/erasing flash memory is disabled.</li> <li>When set to 0: Cleared.</li> <li>When set to 1: Unaffected.</li> <li>If the read-modify-write (RMW) instructions are used, 1 is always read.</li> </ul> |
| bit 7          | INTE:<br>Flash memory<br>programming/erasing<br>interrupt enable bit | This bit enables or disables an interrupt as programming/erasing flash<br>memory is terminated.<br>When set to 1: If the flash memory operation flag bit is set to 1 (FMCS:<br>RDYINT = 1), an interrupt is requested.                                                                                                                                                                                                                                                                                                                                                                                                                   |

### Table 18.3-1 Functions of Flash Memory Control Status Register (FMCS)

et4U.com

Note: The flash memory operation flag bit (RDYINT) and flash memory programming/erasing status bit (RDY) do not change simultaneously. A program should be created so that either RDYINT bit or RDY bit can identify the termination of programming/erasing.



et4U.com

DataSheet4U.com

DataShe

DataSheet4U.com

532

### 18.4 How to Start Automatic Algorithm of Flash Memory

### There are four commands for starting the automatic algorithm of flash memory: read/ reset, write, chip erase. The sector erase command controls suspension and resumption of sector erase.

### Command Sequence Table

Table 18.4-1 list the commands used in programming/erasing flash memory.

All data is written to command registers by byte access but should be written by word access in the normal mode. Upper data bytes are ignored.

#### Table 18.4-1 Command Sequence Table

| r                   |               |                                                                                        |                                                                                |                                |      |                             |      |                              |              |                             |      |                             |      |
|---------------------|---------------|----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|--------------------------------|------|-----------------------------|------|------------------------------|--------------|-----------------------------|------|-----------------------------|------|
| Command<br>Sequence | Command Write |                                                                                        | rcle of<br>Bus                                                                 | f Write Cycle of<br>Second Bus |      | Write Cycle of<br>Third Bus |      | Write Cycle of<br>Fourth Bus |              | Write Cycle of<br>Fifth Bus |      | Write Cycle of<br>Sixth Bus |      |
| Coquerioe           | Access        | Address                                                                                | Data                                                                           | Address                        | Data | Address                     | Data | Address                      | Data         | Address                     | Data | Address                     | Data |
| Read/<br>Reset*     | 1             | FFXXXX                                                                                 | XXF0                                                                           | -                              | _    | -                           | _    | -                            | -            | -                           | _    | -                           | _    |
| Read/<br>Reset*     | 4             | FFAAAA                                                                                 | XXAA                                                                           | FF5554                         | XX55 | FFAAAA                      | XXF0 | RA                           | RD           | _                           | _    | _                           | _    |
| Write<br>program    | 4             | FFAAAA                                                                                 | XXAA                                                                           | FF5554                         | XX55 | FFAAAA                      | XXA0 | PA<br>(even)                 | PD<br>(word) | _                           | _    | _                           | _    |
| Chip<br>erase       | 6             | FFAAAA                                                                                 | XXAA                                                                           | FF5554                         | XX55 | FFAAAA                      | XX80 | FFAAAA                       | XXAA         | FF5554                      | XX55 | FFAAAA                      | XX10 |
| Sector<br>erase     | 6             | FFAAAA                                                                                 | XXAA                                                                           | FF5554                         | XX55 | FFAAAA                      | XX80 | FFAAAA                       | XXAA         | FF5554                      | XX55 | SA<br>(even)                | XX30 |
| Sector e            | rase su       | ase suspend Input of address"FFXXXX"Data (xxB0 <sub>H</sub> ) suspends sector erasing. |                                                                                |                                |      |                             |      |                              |              |                             |      |                             |      |
| Sector e            | rase re       | sume                                                                                   | Input address "FFXXXX" Data ( $xx30_{H}$ ) suspends and resume sector erasing. |                                |      |                             |      |                              |              |                             |      |                             |      |
| Auto<br>Select      | 3             | FFAAAA                                                                                 | XXAA                                                                           | FF5554                         | XX55 | FFAAAA                      | XX90 | _                            | _            | _                           | _    | _                           | _    |

### DataShe

Notes:

et4U.com

• Addresses in the table are the values in the CPU memory map. All addresses and data are hexadecimal values, where "x" is any value.

- RA: Read address
- PA: Program address. Only even addresses can be specified.
- SA: Sector address (See "18.2 Registers and Sector Configuration of Flash Memory")
- RD: Read data
- PD: Program data. Only word data can be specified.
- \*: Two kinds of read/reset commands can reset flash memory to the read mode.

Auto Select in Table 18.4-2 is the command to check the state of sector protection. The addresses must be set as indicated below together with the command in Table 18.4-2.

Table 18.4-2 Address Setting for Auto Select

|                   | AQ13 to AQ15   | AQ7 | AQ2 | AQ1 | AQ0 | DQ7 to DQ0 |
|-------------------|----------------|-----|-----|-----|-----|------------|
| Sector protection | Sector address | L   | Н   | L   | L   | CODE *     |

\*: The output at the protected sector address is " $01_{\text{H}}$ ".

The output at the unprotected sector address is " $00_{\mathrm{H}}$ ".

et4U.com

DataShe

DataSheet4U.com

### 18.5 Check the Execution State of Automatic Algorithm

# Since the programming/erasing flow is controlled by the automatic algorithm, hardware sequence can check the internal operating state of flash memory.

### Hardware Sequence Flags

Overview of hardware sequence flag

The hardware sequence flag consists of the following 5-bit outputs:

- Data polling flag (DQ7)
- Toggle bit flag (DQ6)
- Timing limit over flag (DQ5)
- Sector erasing timer flag (DQ3)
- Toggle bit 2 flag (DQ2)

These flags can be used to check whether programming, chip and sector erasing, and erase code writing are enabled.

The hardware sequence flags can be referred by setting command sequences and performing read access to the address of a target sector in flash memory. Table 18.5-1 gives the bit allocation of the hardware sequence flags.

DataShe

#### DataSheet4U.com

#### Table 18.5-1 Bit Allocation of Hardware Sequence Flags

| Bit No.                | 7   | 6   | 5   | 4 | 3   | 2   | 1 | 0 |
|------------------------|-----|-----|-----|---|-----|-----|---|---|
| Hardware sequence flag | DQ7 | DQ6 | DQ5 | _ | DQ3 | DQ2 |   | _ |

- To identify whether automatic programming/chip and sector erasing is in execution or terminated, check the hardware sequence flag or the flash memory programming/erasing status bit in the flash memory control status register (FMCS: RDY). Programming/erasing is terminated, returning to the read/reset state.
- To create a programming/erasing program, use the DQ7, DQ6, DQ5, DQ3 and DQ2 flags to check that automatic programming/erasing is terminated and read data.
- The hardware sequence flags can also be used to check whether the second and later sector erase code writing is enabled.

et4U.com

• Explanation of hardware sequence flag

Table 18.5-2 lists the functions of the hardware sequence flag.

### Table 18.5-2 List of Hardware Sequence Flag Functions

|                                        | State                                                          | DQ7            | DQ6               | DQ5          | DQ3          | DQ2             |
|----------------------------------------|----------------------------------------------------------------|----------------|-------------------|--------------|--------------|-----------------|
| State change in<br>normal<br>operation | Programming> Completed<br>(when program address<br>specified)  | DQ7><br>DATA:7 | Toggle><br>DATA:6 | 0><br>DATA:5 | 0><br>DATA:3 | 1><br>DATA:2    |
|                                        | Chip and sector erasing<br>> Completed                         | 0> 1           | Toggle><br>Stop   | 0> 1         | 1            | Toggle><br>Stop |
|                                        | Sector erasing wait<br>> Started                               | 0              | Toggle            | 0            | 0> 1         | Toggle          |
|                                        | Erasing> Sector erasing<br>suspended<br>(Sector being erased)  | 0> 1           | Toggle> 1         | 0            | 1> 0         | Toggle          |
|                                        | Sector erasing suspended><br>Resumed<br>(Sector being erased)  | 1> 0           | 1> Toggle         | 0            | 0> 1         | Toggle          |
|                                        | Sector erasing being<br>suspended<br>(Sector not being erased) | DATA:7         | DATA:6            | DATA:5       | DATA:3       | DATA:2          |
| Abnormal                               | Programming                                                    | DQ7            | Toggle            | 1            | 0            | 1               |
| operation                              | Chip and sector erasing                                        | 0              | Toggle            | 1            | 1            | *               |

\*: If the DQ5 flag is 1 (timing limit over), the DQ2 flag performs the toggle operation for continuous reading from the programming/erasing sector but does not perform the toggle operation for reading from other sectors.

DataShee

et4U.com

# 18.5.1 Data Polling Flag (DQ7)

# The data polling flag (DQ7) is mainly used to notify that the automatic algorithm is executing or has been completed using the data polling function.

### Data Polling Flag (DQ7)

Table 18.5-3 and Table 18.5-4 give the state transition of the data polling flag.

 Table 18.5-3
 State Transition of Data Polling Flag (State Change at Normal Operation)

| Operating State | Programming><br>Completed | Chip and<br>Sector Erasing<br>> Completed | Wait for Sector<br>Erasing><br>Started | Sector Erasing<br>> Erasing<br>Suspended<br>(Sector being<br>Erased) | Sector Erasing<br>Suspended><br>Resume<br>(Sector being<br>Erased) | Sector Erasing<br>being<br>Suspended<br>(Sector not<br>being Erased) |
|-----------------|---------------------------|-------------------------------------------|----------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------------|----------------------------------------------------------------------|
| DQ7             | DQ7> DATA:7               | 0> 1                                      | 0                                      | 0> 1                                                                 | 1> 0                                                               | DATA:7                                                               |

### Table 18.5-4 State Transition of Data Polling Flag (State Change at Abnormal Operation)

| et4U.com | Operating<br>State | Programming | Chip and<br>Sector Erasing |                 |
|----------|--------------------|-------------|----------------------------|-----------------|
|          | DQ7                | DQ7         | 0                          | )ataSheet4U.com |

DataShe

### • At programming

- Read access during execution of the auto-programming algorithm causes flash memory to output the reversed data of bit 7 last written.
- Read access at the end of the auto-programming algorithm causes flash memory to output the value of bit 7 at the address to which read access was performed.

### • At chip/sector erasing

• During executing chip and sector erasing algorithms, when read access is made to the currently being erasing sector, bit 7 of flash memory outputs 0. When chip erasing/sector erasing is terminated, bit 7 of flash memory outputs 1.

537

• At sector erasing suspension

- Read access during sector erasing suspension causes flash memory to output 1 if the address specified by the address signal belongs to the sector being erased. Flash memory outputs bit 7 (DATA: 7) of the read value at the address specified by the signal address if the address specified by the address signal does not belong to the sector being erased.
- Referring this flag together with the toggle bit flag (DQ6) permits a decision on whether flash memory is in the erase suspended state and which sector is being erased.

Note: Read access to the specified address while the automatic algorithm starts is ignored. Data reading is enabled after 1 is set to the data polling flag (DQ7). Data reading after the end of the automatic algorithm should be performed following read access after completion of data polling has been checked.

et4U.com

DataSheet4U.com

DataShe

DataSheet4U.com

DataSheet4U.com

# 18.5.2 Toggle Bit Flag (DQ6)

# The toggle bit flag (DQ6) is a hardware sequence flag used to notify that the automatic algorithm is being executed or in the end state using the toggle bit function.

### ■ Toggle Bit Flag (DQ6)

Table 18.5-5 and Table 18.5-6 give the state transition of the toggle bit flag.

 Table 18.5-5
 State Transition of Toggle Bit Flag (State Change at Normal Operation)

| Operating State | Programming><br>Completed | Chip and<br>Sector Erasing<br>> Erasing<br>Completed | Wait for Sector<br>Erasing><br>Erasing<br>Started | Sector Erasing<br>> Erasing<br>Suspended<br>(Sector being<br>Erased) | Sector Erasing<br>Suspended><br>Resume<br>(Sector being<br>Erased) | Sector Erasing<br>Suspended<br>(Sector not<br>being Erased) |
|-----------------|---------------------------|------------------------------------------------------|---------------------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------------|-------------------------------------------------------------|
| DQ6             | Toggle> DATA:6            | Toggle> Stop                                         | Toggle                                            | Toggle> 1                                                            | 1> Toggle                                                          | DATA:6                                                      |

### Table 18.5-6 State Transition of Toggle Bit Flag (State Change at Abnormal Operation)

| et4U.com | Operating<br>State | Programming | Chip and<br>Sector Erasing |                |
|----------|--------------------|-------------|----------------------------|----------------|
|          | DQ6                | Toggle      | Toggle                     | ataSheet4U.com |

• At programming and chip/sector erasing

- If a continuous read access is made during the execution of the automatic algorithm for programming and chip erasing/sector erasing, flash memory toggle-outputs 1 and 0 alternately every reading.
- If a continuous read access is made after the completion of the automatic algorithm for programming and chip erasing/sector erasing, flash memory outputs bit 6 (DATA: 6) for the read value of the read address every reading.

### • At sector erasing suspension

If a read access is made in the sector erasing suspension state, flash memory outputs 1 when the read address is the sector being erased and bit 6 (DATA: 6) for the read value of the read address when the read address is not the sector being erased.

Reference:If the sector for programming is reprogram-protected, the toggle bit flag (DQ6) produces a toggle output<br/>for approximately 2 μs, and then terminates it without reprogramming data.If all sectors for erasing are reprogram-protected, the toggle bit flag (DQ6) produces a toggle output for<br/>approximately 100 μs, and then returns to the read/reset state without reprogramming data.

## 18.5.3 Timing Limit Over Flag (DQ5)

# The timing limit over flag (DQ5) is a hardware sequence flag that notifies flash memory that the execution of the automatic algorithm has exceeded a prescribed time (the time required for programming/erasing).

### Timing Limit Over Flag (DQ5)

Table 18.5-7 and Table 18.5-8 give the state transition of the timing limit over flag.

Table 18.5-7 State Transition of Timing Limit Over Flag (State Change at Normal Operation)

| Operating State | Programming><br>Completed | Chip and<br>Sector Erasing<br>> Completed | Wait for Sector<br>Erasing><br>Started | Sector Erasing<br>> Erasing<br>Suspended<br>(Sector being<br>Erased) | Sector Erasing<br>Suspended><br>Resume<br>(Sector being<br>Erased) | Sector Erasing<br>being<br>Suspended<br>(Sector not<br>being Erased) |
|-----------------|---------------------------|-------------------------------------------|----------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------------|----------------------------------------------------------------------|
| DQ5             | 0> DATA:5                 | 0> 1                                      | 0                                      | 0                                                                    | 0                                                                  | DATA:5                                                               |

| Operating<br>State | Programming | Chip and<br>Sector Erasing | DataSheet4U.com |
|--------------------|-------------|----------------------------|-----------------|
| DQ5                | 1           | 1                          |                 |

• At programming and chip erasing/sector erasing

- If a read access made after starting the automatic algorithm for programming or chip erasing/sector erasing is within a prescribed time (the time required for programming/erasing), the timing limit over flag (DQ5) outputs 0. If it exceeds the prescribed time, the timing limit over flag (DQ5) outputs 1.
- The timing limit over flag (DQ5) can be used to identify the success or failure of programming/erasing, regardless of whether the automatic algorithm is in progress or terminated. If the automatic algorithm by the data polling or the toggle bit function is in execution when the timing limit over flag (DQ5) outputs 1, programming can be identified as a failure.
- For example, when 1 is set to the flash memory address with 1 set the flash memory, programming fails. In this case, the flash memory will be locked and the automatic algorithm will not complete. Therefore, no valid data is output from the data polling flag (DQ7). Also, the toggle bit flag (DQ6) does not stop the toggle operation and exceeds the time limit, causing the timing limit over flag (DQ5) to output 1. This state means that the flash memory is not being used correctly; it does not mean that the flash memory is faulty. When this state occurs, execute the reset command.

www.DataSheet4U.com

## 18.5.4 Sector Erase Timer Flag (DQ3)

# The sector erase timer flag (DQ3) is a hardware sequence flag used to notify during the period of waiting for sector erasing after the sector erase command has started.

### Sector Erase Timer Flag (DQ3)

Table 18.5-9 and Table 18.5-10 give the state transition of the sector erase timer flag.

Table 18.5-9 State Transition of Sector Erase Timer Flag (State Change at Normal Operation)

| 0 | perating State | Programming><br>Completed | Chip and<br>Sector Erasing<br>> Completed | Wait for Sector<br>Erasing><br>Started | Sector Erasing<br>> Erasing<br>Suspended<br>(Sector being<br>Erased) | Sector Erasing<br>Suspended><br>Resume<br>(Sector being<br>Erased) | Sector Erasing<br>being<br>Suspended<br>(Sector not<br>being Erased) |
|---|----------------|---------------------------|-------------------------------------------|----------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------------|----------------------------------------------------------------------|
|   | DQ3            | 0> DATA:3                 | 1                                         | 0> 1                                   | 1> 0                                                                 | 0> 1                                                               | DATA:3                                                               |

### Table 18.5-10 State Transition of Sector Erase Timer Flag (State Change at Abnormal Operation)

| Operating<br>State | Programming | Chip and<br>Sector Erasing |                |
|--------------------|-------------|----------------------------|----------------|
| DQ3                | 0           | 1                          | ataSheet4U.com |

DataShe

### At sector erasing

- If a read access made after starting the sector erase command is within a sector erasing wait period, the sector erasing timer flag (DQ3) outputs 0. If it exceeds the period, the sector erasing timer flag (DQ3) outputs 1.
- If the sector erasing timer flag (DQ3) is 1, indicating that the automatic algorithm for sector erasing by the data polling or toggle bit function is in progress (DQ = 0; DQ6 produces a toggle output), sector erasing is performed. If any command other than the sector erasing suspension is set, it is ignored until sector erasing is terminated.
- If the sector erasing timer flag (DQ3) is 0, flash memory can accept the sector erase command. To program the sector erase command, check that the sector erasing timer flag (DQ3) is 0. If the flag is 1, flash memory may not accept the sector erase command of suspending.
- At sector erasing suspension
  - Read access during sector erasing suspension causes flash memory to output 1, if the read address is the sector being erased. Flash memory outputs bit 3 (DATA: 3) for the read value of the read address when the read address is not the sector being erased.

# 18.5.5 Toggle Bit 2 Flag (DQ2)

# The toggle bit 2 flag (DQ2) is a hardware sequence flag that notifies flash memory that sector erasing is being suspended using the toggle bit function.

### ■ Toggle Bit Flag (DQ2)

Table 18.5-11 and Table 18.5-12 give the state transition of the toggle bit flag.

Table 18.5-11 State Transition of Toggle Bit Flag (State Change at Normal Operation)

| Operating State | Programming><br>Completed | Chip and<br>Sector Erasing<br>> Completed | Wait for Sector<br>Erasing<br>> Started | Sector Erasing<br>> Erasing<br>Suspended<br>(Sector being<br>Erased) | Sector Erasing<br>Suspended><br>Resume Sector<br>being Erased) | Sector Erasing<br>being<br>Suspended<br>(Sector not<br>being Erased) |
|-----------------|---------------------------|-------------------------------------------|-----------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------------|----------------------------------------------------------------------|
| DQ2             | 1> DATA:2                 | Toggle> Stop                              | Toggle                                  | Toggle                                                               | Toggle                                                         | DATA:2                                                               |

### Table 18.5-12 State Transition of Toggle Bit Flag (State Change at Abnormal Operation)

| Operating<br>State | Programming | Chip and<br>Sector<br>Erasing | ataSheet4U.com |
|--------------------|-------------|-------------------------------|----------------|
| DQ2                | 1           | *                             |                |

\*: If the DQ5 flag is 1 (timing limit over), the DQ2 flag performs the toggle operation for continuous reading from the programming/erasing sector but does not perform the toggle operation for reading from other sectors.

#### • At sector erasing

- If a continuous read access is made during the execution of the automatic algorithm for chip erasing/ sector erasing, flash memory toggle-outputs 1 and 0 alternately every reading.
- If a continuous read access is made after the completion of the algorithm for chip erasing/sector erasing, flash memory outputs bit 2 (DATA: 2) for the read value of the read address every reading.

| • At       | sector erasing suspension                                                                                                                                                                                                                                                     |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | • If a read access is made in the sector erasing suspension state, flash memory outputs 1 and 0 alternately when the read address is the sector being erased and bit 2 (DATA: 2) for the read value of the read address when the read address is not the sector being erased. |
|            | • If programming is performed in the sector erasing suspension state, flash memory outputs 1 when a continuous read access is started with the sector that is not in the erasing suspension state.                                                                            |
|            | • The toggle bit 2 flag (DQ2) is used together with the toggle bit flag (DQ6) to detect that sector erasing is suspended (the DQ2 flag performs the toggle operation but the DQ6 flag does not).                                                                              |
|            | • If a read access from the sector being erased is made, the toggle bit 2 flag (DQ2) performs the toggle operation, so it can also be used to detect the sector being erased.                                                                                                 |
| Reference: | If all sectors for erasing are reprogram-protected, the toggle bit flag (DQ2) produces a toggle output for approximately 100 $\mu$ s, and then returns to the read/reset state without reprogramming data.                                                                    |

DataSheet4U.com

### 18.6 Details of Programming/Erasing Flash Memory

This section explains the procedure for inputting commands starting the automatic algorithm, and for read/reset of flash memory, programming, chip erasing, sector erasing suspension and sector erasing resumption.

### Detailed Explanation of Programming and Erasing Flash Memory

Automatic algorithm can be started by programming the command sequence of read/reset, programming, chip erasing, sector erasing suspension and erasing resumption from CPU to flash memory. Programming flash memory from the CPU should always be performed continuously. The termination of the automatic algorithm can be checked by the data polling function. After normal termination, it returns to the read/reset state.

Each operation is explained in the following order.

- Read/reset state
- Data programming
- All data erasing (chip all erase)
- Any data erasing (sector erase)
- Sector erasing suspension
- Sector erasing resumption

DataSheet4U.com

et4U.com

DataSheet4U.com

### 18.6.1 Read/Reset State in Flash Memory

# This section explains the procedure for inputting the read/reset command to place flash memory in the read/reset state.

### Read/Reset State in Flash Memory

- Flash memory can be placed in the read/reset state by continuously transmitting the read/reset command in the command sequence table from CPU to flash memory.
- There are two kinds of read/reset commands: one is executed at one time bus operation, and the other is executed at three times bus operations; the command sequence of both is essentially the same.
- Since the read/reset state is the initial state for flash memory, flash memory always enters this state after power-on and at the normal termination of command. The read/reset state is also described as the wait state for command input.
- In the read/reset state, a read access to flash memory enables data to be read. As is the case with mask ROM, a program access from the CPU can be made. A read access to flash memory does not require the read/reset command. If the command is not terminated normally, use the read/reset command to initialize the automatic algorithm.

et4U.com

DataShe

DataSheet4U.com

### 18.6.2 Data Programming to Flash Memory

# This section explains the procedure for inputting the program command to program data to flash memory.

### Data Programming to Flash Memory

- In order to start the data programming automatic algorithm, continuously transmit the program command in the command sequence table from CPU to flash memory.
- At completion of data programming to a target address in the fourth cycle, the automatic algorithm starts automatic programming.

#### • How to specify address

- The only even addresses can be specified for the programming address specified by programming data cycle. Specifying odd addresses prevents correct writing. Writing to even addresses must be performed in word data units.
- Programming is possible in any address order or even beyond sector boundaries. However, execution of one programming command, permits programming of only one word for data.

#### Notes on data programming

www.DataSheet4U.com

- Data 0 cannot be returned to data 1 by programming. When data 0 is programmed to data 1, the data polling algorithm (DQ7) or toggling (DQ6) is not terminated and the flash memory is considered faulty; the timing limit over flag (DQ5) is determined as an error.
- When data is read in the read/reset state, the bit data remains 0. To return the bit data to 1 from 0, erase flash memory data.
- All commands are ignored during automatic programming. If a hardware reset occurs during programming, data being programmed to addresses are not assured.

### Data Programming Procedure

- Figure 18.6-1 gives an example of the procedure for programming data into flash memory. The hardware sequence flags can be used to check the operating state of the automatic algorithm in flash memory. The data polling flag (DQ7) is used for checking the completion of programming to flash memory in this example.
- Flag check data should be read from the address where data was last written.
- Because the data polling flag (DQ7) and the timing limit over flag (DQ5) change at the same time, the data polling flag (DQ7) must be checked even when the timing limit over flag (DQ5) is 1.
- Similarly, since the toggle bit flag (DQ6) stops toggling at the same time the timing limit over flag (DQ5) changes to 1, toggle bit flag (DQ6) must be checked.



Figure 18.6-1 Example of Data Programming Procedure

# 18.6.3 Data Erase from Flash Memory (Chip Erase)

# This section explains the procedure for inputting the chip erase command to erase all data from flash memory.

### ■ All Data Erase from Flash Memory (Chip Erase)

- All data can be erased from flash memory by continuously transmitting the chip erase command in the command sequence table from CPU to flash memory.
- The chip erase command is executed in six bus operations. Chip erasing is started at completion of the sixth programming cycle.
- Before chip erasing, the user need not perform programming to flash memory. During execution of the automatic erasing algorithm, flash memory automatically programs 0 before erasing all cells.

et4U.com

DataSheet4U.com

DataShe

### 18.6.4 Erasing Any Data in Flash Memory (Sector Erasing)

This section explains the procedure for inputting the sector erase command to erase any data in flash memory. Sector-by-sector erasing is enabled and multiple sectors can be specified at a time.

### Erasing Any Data in Flash Memory (Sector Erasing)

Any sector in flash memory can be erased by continuously transmitting the sector erase command in the command sequence table from CPU to flash memory.

- How to specify sector
  - The sector erase command is executed in six bus operations. By setting the address on the sixth cycle in the even address in the target sector and programming the sector erase code  $(30_{\rm H})$  to data, a 50 µs sector erasing wait is started
  - When erasing more than one sector, the sector erase code  $(30_{\rm H})$  is programmed to the sector address to be erased, following the above.

#### Notes on specifying multiple sectors

- Sector erasing is started after a 50 µs period waiting for sector erasing is completed after the last sector erase code has been programmedataSheet4U.com
  - That is, when erasing more than one sector simultaneously, the address of erase sector and the sector erase code must be input within 50  $\mu$ s. If the sector erase code is input 50  $\mu$ s or later, it cannot be accepted.
- Whether continuous programming of the sector erase code is enabled can be checked by the sector erase timer flag (DQ3).
- In this case, the address from which the sector erase timer is flag (DQ3) read should correspond to the sector to be erased.

### Erasing Procedure for Flash Memory Sectors

- The state of the automatic algorithm in the flash memory can be determined using the hardware sequence flag. Figure 18.6-2 gives an example of the flash memory sector erase procedure. In this example, the toggle bit flag (DQ6) is used to check that erase ends.
- DQ6 terminates toggling concurrently with the change of the timing limit over flag (DQ5) to 1, so the DQ6 must be checked even when DQ5 is 1.
- Similarly, the data polling flag (DQ7) changes concurrently with the transition of the DQ5, so DQ7 must be checked.

et4U.com



Figure 18.6-2 Example of Sector Erasing Procedure

550

### 18.6.5 Sector Erase Suspension in Flash Memory

# This section explains the procedure for inputting the sector erase suspend command to suspend sector erasing. Data can be read from the sector not being erased.

### Sector Erase Suspension in Flash Memory

- To cause flash memory sector erasing to suspend, continuously transmit the sector erasing suspend command in the command sequence table from CPU to flash memory.
- The sector erasing suspend command suspends the sector erase currently being performed, enabling data read from a sector that is currently not being erased. Only read can be performed when this command is suspended; programming cannot be performed.
- This command is only enabled during the sector erasing period including the erasing wait time; it is ignored during the chip erasing period or during programming.
- The sector erasing suspend command is executed when the sector erasing suspend code  $(B0_H)$  is programmed. Arbitrary address in flash memory should be set for address. If the sector erasing suspend command is executed during sector erasing pause, the command input again is ignored.
- When the sector erasing suspend command is input during the sector erasing wait period, the sector erase wait state ends immediately, the erasing is interrupted, and the erase stop state occurs.
- When the erase suspend command is input during the sector erasing after the sector erase wait period, DataShee the erase suspend state occurs after 15 us max.

et4U.com

### 18.6.6 Sector Erase Resumption in Flash Memory

# This section explains the procedure for inputting the sector erase resume command to resume erasing of the suspended flash memory sector.

### **Erase Resumption in Flash Memory**

- Suspended sector erasing can be resumed by continuously transmitting the sector erase resume command in the command sequence table from CPU to flash memory.
- The sector erase resume command resumes sector erasing suspended by the sector erase suspend command. This command is executed by writing the erase resume code (30<sub>H</sub>). In this case, any address in the flash memory area is specified.
- Inputting the sector erase resume command during sector erasing is ignored.

et4U.com

DataSheet4U.com

DataShe

# 18.7 Program Example of 512 Kbit Flash Memory

### A program example of the 512 Kbit flash memory is given below.

### ■ Program Example of 512 Kbit Flash Memory

|          |                                                             |                                                                                                      | FLASHWE<br>FLASHWE                                                                                                                                                    |         |
|----------|-------------------------------------------------------------|------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
|          | ; 512 K<br>; 1: Tr<br>; se<br>; 2: Ex<br>; 3: Pr<br>; 4: Re | bit FLASH Sample<br>cansfer program in<br>ctor SA2) to RAM<br>cecute program on<br>rogram PDR1 value | Program<br>FLASH (address FFBC00 H,<br>(address 000700H).<br>RAM.<br>to FLASH (address FF0000H, sector SA0).<br>.ue (address FF0000H, sector SA0) and output to PDR2. |         |
|          |                                                             | tput check that d                                                                                    | lata is erased.                                                                                                                                                       |         |
|          | ; Condi<br>: -                                              |                                                                                                      | cansferred to RAM: 100H (256 bytes)                                                                                                                                   |         |
|          |                                                             |                                                                                                      | pgramming and erasing checked by:                                                                                                                                     |         |
|          | i                                                           |                                                                                                      | t over flag (DQ5)                                                                                                                                                     |         |
|          | i                                                           | Toggle bit                                                                                           | -                                                                                                                                                                     |         |
| et4U.com | ;                                                           | RDY (FMCS)                                                                                           | -                                                                                                                                                                     | DataShe |
|          | ; -                                                         | Action taken at                                                                                      | error                                                                                                                                                                 | Dataone |
|          | i                                                           | Output H to                                                                                          | P00 to P07.                                                                                                                                                           |         |
|          | i                                                           | Issue reset                                                                                          | command.                                                                                                                                                              |         |
|          | ;                                                           |                                                                                                      |                                                                                                                                                                       |         |
|          | ;                                                           |                                                                                                      |                                                                                                                                                                       |         |
|          | RESOUS                                                      | IOSEG ABS=00                                                                                         | ; Definition of "RESOUS" I/O segment                                                                                                                                  |         |
|          |                                                             | ORG 0000H                                                                                            |                                                                                                                                                                       |         |
|          | PDR0                                                        | RB 1                                                                                                 |                                                                                                                                                                       |         |
|          | PDR1                                                        | RB 1                                                                                                 |                                                                                                                                                                       |         |
|          | PDR2                                                        | RB 1                                                                                                 |                                                                                                                                                                       |         |
|          | PDR3                                                        | RB 1                                                                                                 |                                                                                                                                                                       |         |
|          |                                                             | ORG 0010H                                                                                            |                                                                                                                                                                       |         |
|          | DDR0                                                        | RB 1                                                                                                 |                                                                                                                                                                       |         |
|          | DDR1                                                        | RB 1                                                                                                 |                                                                                                                                                                       |         |
|          | DDR2                                                        | RB 1                                                                                                 |                                                                                                                                                                       |         |
|          | DDR3                                                        | RB 1                                                                                                 |                                                                                                                                                                       |         |
|          | OKCOD                                                       | ORG 00A1H                                                                                            |                                                                                                                                                                       |         |
|          | CKSCR                                                       | RB 1                                                                                                 |                                                                                                                                                                       |         |
|          | TMCC                                                        | ORG 00AEH                                                                                            |                                                                                                                                                                       |         |
|          | FMCS                                                        | RB 1<br>ORG 006FH                                                                                    |                                                                                                                                                                       |         |
|          | ROMM                                                        | RB 1                                                                                                 |                                                                                                                                                                       |         |
|          | RESOUS                                                      | ENDS                                                                                                 |                                                                                                                                                                       |         |
|          | ;                                                           | טעוונו                                                                                               |                                                                                                                                                                       |         |
|          | 1                                                           |                                                                                                      |                                                                                                                                                                       |         |

SSTA SSEG RW 0127H STA T RW 1 ENDS SSTA ; DATA DSEG ABS=0FFH ; FLASH command address ORG 5554H COMADR2 ORG 1 ORG 0AAAAH 1 COMADR1 ORG DATA ENDS ;------; Main program (SA1) ;------CODE CSEG START: ;-----; Initialize ;------MOV CKSCR, #0BAH ; Set to 3-multiplying count MOV RP,#0 MOV A, #!STA\_T MOV SSB, A MOVW A, #STA T MOVW SP, A MOV ROMM, #00H ; Mirror OFF MOV PDRO #00H : For error ( DataShe PDRO,#00H ; For error check MOV MOV DDR0,#0FFH MOV PDR1,#00H ; Data input port MOV DDR1,#00H MOV PDR2,#00H ; Data output port MOV DDR2,#0FFH ;-----; Transfer FLASH programming/erasing program (FFBC00H) to RAM ; (address 700H) MOVW A,#0700H ; Transfer destination RAM area MOVW A,#0BC00H ; Transfer source ;------; (position where program exist) MOVWRW0,#100H; Count of bytes to be transferredMOVSADB,PCB; Transfer 100H from FFBC00H to 000700H CALLP 000700H ; Jump to address where transferred program exists ;-----; Data output ;-----OUT MOV A, #0FFH ADB,A MOV MOVW RW2,#0000H MOVW A,@RW2+00 MOV PDR2, A END JMP \* CODE ENDS

et4U.com

DataSheet4U.com

```
Flash programming/erasing program (SA2)
                    ;-----
                   RAMPRG CSEG ABS=0FFH
                        ORG 0BC00H
                         ;-----
                         ; Initialize
                         ;-----
                         MOVW RW0,#0500H
                                        ; RWO: RAM space for storage of input data
                                        ; 00:0500 to
                         MOVW RW2,#0000H
                                       ; RW2: Flash memory programming address
                                       ; FD:0000 to
                        MOV A,#00H
                                       ; DTB change
                        MOVDTB,A; Specify bank for @RW0MOVA,#0FFH; ADB change 1MOVADB,A; Specify bank for program mode specifying addressMOVPDR3,#00H; Initialize switch
                         MOV DTB,A
                         MOV DDR3,#00H
                   WAIT1 BBC PDR3:0,WAIT1
                                       ; PDR3: 0 with High level, start programming
                   ;
                    ;-----
                   ; Program (SA0)
                    ;-----
                         MOV A, PDR1
                        MOVW @RW0+00,A ; Save PDR1 data in RAM.
MOV FMCS,#20H ; Set program mode.
et4U.com
                                                                              DataShe
                         MOVW ADB:COMADR1, #00AAH
                                      ; Flash program command 1
                         MOVW ADB:COMADR2, #0055H
                                      ; Flash program command 2
                         MOVW ADB:COMADR1, #00A0H
                                      ; Flash program command 3
                    ;
                         MOVW A, @RW0+00 ; Program input data (RW0) to flash memory (RW2).
                    ;
                        MOVW @RW2+00, A
                   WRITE
                        ; Waiting time check
                         ;ERROR occurs when the time limit over check flag is set and toggling.
                         ;------
                         MOVW A,@RW2+00
                        AND A, #20H
                                      ; DQ5 time limit check
                         BZ NTOW
                                       ; Time limit over
                         MOVW A,@RW2+00
                                        ; AH
                         MOVW A,@RW2+00
                                        ; AL
                         XORW A
                                        ; XOR of AH and AL (1 if value is invalid)
                                   ; Is DQ6 toggle bit?
                         AND A,#40H
                         BNZ ERROR
                                       ; If no, go to ERROR.
                         ;-----
                         ; Programming end check (FMCS-RDY)
                         ;-----
                   NTOW
                         MOVW A, FMCS
                                       ; Extract RDY bit (bit 4) of FMCS.
                         AND A,#10H
                         BZ WRITE
                                       ; Is programming ended?
                         MOV FMCS, #00H
                                       ; Cancel program mode.
```

DataSheet4U.com

```
;-----
     ; Program data output
     ;------
     MOVW RW2,#0000H
                     ; Output program data
     MOVW A, @RW2+00
     MOV PDR2, A
WAIT2 BBC PDR3:1,WAIT2
                     ; PDR3:1 With "H", start sector erasing.
;
;-----
; Sector erasing (SA0)
;-----
     MOV @RW2+00,#0000H ; Initialize address
     MOV FMCS, #20H ; Set erase mode
     MOVW ADB:COMADR1, #00AAH ; Flash command 1
     MOVW ADB:COMADR2, #0055H ; Flash command 2
     MOVW ADB:COMADR1, #0080H ; Flash command 3
     MOVW ADB:COMADR1, #00AAH ; Flash command 4
     MOVW ADB:COMADR2, #0055H ; Flash command 5
     MOV @RW2+00,#0030H ; Issue erase command to sector to be erased 6.
ELS
     ; Waiting time check
     •-----
     ;ERROR occurs when time limit over check flag is set and toggling is underway.
;------
     MOVW A,@RW2+00
     AND A, #20H
                    ; DQ5 time limit check
                                                               DataShe
                     ; Time limit over
     B7 NOTE
     BZNOTE; Time limit overMOVWA,@RW2+00; During AH programming, "H/L" is outputMOVWA,@RW2+00; alternately every time AL is read fromXORWA; XOR of AH and AL (1 if DQ6 value inval
                    ; alternately every time AL is read from DQ6
                     ; XOR of AH and AL (1 if DQ6 value invalid,
     XORW A
                     ; indicating programming underway)
     AND A, #40H ; Is DQ6 toggle bit "H"?
                     ; If "H", go to ERROR
     BNZ ERROR
     ;Erasing end check (FMCS-RDY)
     ;------
     ,
MOVW A,FMCS ;
AND A,#10H ; Extract RDY bit (bit 4) of FMCS
BZ ELS ; Is erasing ended?
MOV FMCS,#00H ; Cancel FLASH erase mode
RETP ; Return to main program
NTOE
     RETP
                     ; Return to main program
;-----
;Error
;-----
ERROR MOV ADB:COMADR1, #0F0H ; Reset command (read enabled)
     MOV FMCS, #00H ; Cancel FLASH mode
     MOV PDR0,#0FFH
                     ; Check error processing
     RETP
                     ; Return to main program
RAMPRG ENDS
VECT CSEG ABS=0FFH
     ORG 0FFDCH
     DSL START
     DB
         00H
VECT
   ENDS
;
     ENDS START
                                                      www.DataSheet4U.com
```

DataSheet4U.com

# CHAPTER 19 FLASH SERIAL PROGRAMMING CONNECTION

This chapter describes an example of serial programming connection using the flash microcontroller programmer made by Yokogawa Digital Computer Corporation.

DataShe

DataSheet4U.com

- 19.1 Basic Configuration of Serial Programming Connection for F<sup>2</sup>MC-16LX MB90F387/S
- 19.2 Connection Example in Single-chip Mode (User Power Supply)
- 19.3 Connection Example in Single-chip Mode (Writer Power Supply)
- 19.4 Example of Minimum Connection to Flash Microcontroller Programmer (User Power Supply)
- 19.5 Example of Minimum Connection to Flash Microcontroller Programmer (Writer Power Supply)

et4U.com

DataSheet4U.com

# 19.1 Basic Configuration of Serial Programming Connection for F<sup>2</sup>MC-16LX MB90F387/S

# The MB90F387/S supports the serial on-board programming of flash ROM (Fujitsu standard). The specification for serial on-board programming are explained below.

### ■ Basic Configuration of Serial Programming Connection for MB90F387/S

The flash microcontroller programmer made by Yokogawa Digital Computer Corporation is used for Fujitsu standard serial on-board programming.



### Figure 19.1-1 Basic Configuration of Serial Programming Connection

Note: Inquire of Yokogawa Digital Computer Corporation for details about the functions and operations of the AF220/AF210/AF120/AF110 flash microcontroller programmer, general-purpose common cable for connection (AZ210), and connectors

### Table 19.1-1 Pins Used for Fujitsu Standard Serial On-board Programming (1/2)

| Pin              | Function                          | Supplementary Information                                                                                                                                                                                                                                                                                                                                                                         |
|------------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MD2, MD1,<br>MD0 | Mode pins                         | Writing 1 to MD2, 1 to MD1 and 0 to MD0 sets the flash serial program mode.                                                                                                                                                                                                                                                                                                                       |
| X0, X1           | Oscillation pins                  | In the flash serial program mode, the internal operating clock of the CPU has<br>a frequency one time that of the PLL clock, so the internal operating clock<br>frequency is the same as the oscillation clock frequency. Since the<br>oscillation clock frequency serves as an internal operation clock, the<br>oscillator used for serial programming have frequencies from 1 MHz to 16<br>MHz. |
| P30, P31         | Programming program<br>start pins | Input a Low level to P30 and a High level to P31.                                                                                                                                                                                                                                                                                                                                                 |

DataSheet4U.com

et4U.com

558

www.DataSheet4U.com

### Table 19.1-1 Pins Used for Fujitsu Standard Serial On-board Programming (2/2)

| Pin             | Function                 | Supplementary Information                                                                                                          |  |
|-----------------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------|--|
| RST             | Reset pin                | _                                                                                                                                  |  |
| SIN1            | Serial data input pin    | UART is used in clock synchronous mode.                                                                                            |  |
| SOT1            | Serial data output pin   |                                                                                                                                    |  |
| SCK1            | Serial clock input pin   |                                                                                                                                    |  |
| С               | C pin                    | This pin is a capacitance pin for stabilizing voltage. Connect the ceramic capacitor approx. 0.1 $\mu$ F externally.               |  |
| V <sub>CC</sub> | Power supply voltage pin | If the program voltage (5 V $10\%$ ) is supplied from the user system, the flash microcontroller programmer need not be connected. |  |
| V <sub>SS</sub> | GND pin                  | GND pin is common to the ground of the flash microcontroller programmer.                                                           |  |

Note:

Even if the P30, SIN1, SOT1, and SCK1 pins are used for the user system, the controller shown in the figure below is required. The TICS signal of the flash microcontroller programmer can be used to disconnect the user circuit during serial programming.

See the following serial programming connection examples given in Sections "19.2 Connection Example in Single-chip Mode (User Power Supply)" to "19.5 Example of Minimum Connection to Flash Microcontroller Programmer (Writer Power Supply)".

et4U.com

- Connection example in single-chip mode (user power supply)
- Connection example in single-chip mode (writer power supply)
- Example of minimum connection with flash microcontroller programmer (user power supply)
- Example of minimum connection with flash microcontroller programmer (writer power supply)

### Figure 19.1-2 Control circuit



559

### CHAPTER 19 FLASH SERIAL PROGRAMMING CONNECTION

### ■ Oscillation Clock Frequency and Serial Clock Input Frequency

The inputable serial clock frequency for the MB90F387/S can be determined by the following expression. Therefore, change the serial clock input frequency according to the setting of the programmer of the flash microcontroller on the basis of the oscillation clock frequency.

#### Inputable serial clock frequency = 0.125 x oscillation clock frequency

#### Table 19.1-2 Maximum Serial Clock Frequency

| Oscillation<br>Clock<br>Frequency | Maximum serial clock<br>frequency that can be<br>input for the<br>microcomputer | Maximum serial clock<br>frequency that can be<br>set with AF220/AF210/<br>AF120/AF110 | Maximum serial clock<br>frequency that can be<br>set with AF200 |
|-----------------------------------|---------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|-----------------------------------------------------------------|
| 4 MHz                             | 500 kHz                                                                         | 500 kHz                                                                               | 500 kHz                                                         |
| 8 MHz                             | 1 MHz                                                                           | 850 kHz                                                                               | 500 kHz                                                         |
| 16 MHz                            | 2 MHz                                                                           | 1.25 MHz                                                                              | 500 kHz                                                         |

### Flash Microcontroller Programmer System Configuration (Made by Yokogawa Digital Computer Corporation)

et4U.com

# Table 19.1-3 Flash Microcontroller Programmer System Configuration (Made by Yokogawa Digital Computer Corporation)

DataShe

| Model |            | DataSheet4U.com Function                                                      |  |  |
|-------|------------|-------------------------------------------------------------------------------|--|--|
| Unit  | AF220/AC4P | Model with internal Ethernet interface<br>/100 V to 220 V power adapter       |  |  |
|       | AF210/AC4P | Standard model<br>/100 V to 220 V power adapter                               |  |  |
|       | AF120/AC4P | Single key internal Ethernet interface model<br>/100 V to 220 V power adapter |  |  |
|       | AF110/AC4P | Single key model<br>/100 V to 220 V power adapter                             |  |  |
| AZ221 |            | PC/AT RS232C cable for writer                                                 |  |  |
| AZ220 |            | Standard target probe (a) length: 1 m                                         |  |  |
| FF201 |            | Control module for Fujitsu F <sup>2</sup> MC-16LX flash microcontroller       |  |  |
| /P2   |            | 2MB PC Card (Option) FLASH memory corresponding Max. 128 KB                   |  |  |
| /P4   |            | 4MB PC Card (Option) FLASH memory corresponding Max. 512 KB                   |  |  |

Note:

The AF200 flash microcontroller programmer is an end product but is made available using the control module FF201. Examples of serial programming connections can correspond to those in the next section.

DataSheet4U.com

560

## 19.2 Connection Example in Single-chip Mode (User Power Supply)

When 1 is input to the mode pin MD2 of the user system placed in single-chip mode and 0 to the mode pin MD0 from the TAUX and TMODE pins of the AF220/AF210/AF120/ AF110, the system enters the flash memory serial programming mode. A connection example using the user power supply is given below.



DataSheet4U.com

#### CHAPTER 19 FLASH SERIAL PROGRAMMING CONNECTION

- Even if the SIN1, SOT1, and SCK1 pins are used for the user system, the controller shown in the figure below is required in the same as P30. The /TICS signal of the flash microcontroller programmer can be used to disconnect the user circuit during serial programming.
  - Connect the AF220/AF210/AF120/AF110 while the user power is off.





et4U.com

DataShe

DataSheet4U.com

DataSheet4U.com

562

DataSheet4U.com

## 19.3 Connection Example in Single-chip Mode (Writer Power Supply)

When 1 is input to the mode pin MD2 of the user system placed in single-chip mode and 0 to the mode pin MD0 from the TAUX and TMODE pins of the AF220/AF210/AF210/AF120/AF110, the system enters the flash memory serial programming mode. A connection example using the writer power supply is given below.

### Connection Example in Single-chip Mode (Power Supplied from Flash Microcontroller Programmer)



Figure 19.3-1 Example of Serial Programming Connection for MB90F387/S (Power Supplied from Flash Microcontroller Programmer)

DataSheet4U.com

#### CHAPTER 19 FLASH SERIAL PROGRAMMING CONNECTION

| Notes: | • Even if the SIN1, SOT1, and SCK1 pins are used for the user system, the controller shown in the figure below is required in the same as P30 (Figure 19.3-2). The /TICS signal of the flash |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | microcontroller programmer can be used to disconnect the user circuit during serial programming                                                                                              |
|        | • Connect the AF220/AF210/AF120/AF110 while the user power is off.                                                                                                                           |
|        | • When supplying programming power from AF220/AF210/AF120/AF110, do not short-circuit the                                                                                                    |
|        | programming power and user power.                                                                                                                                                            |



et4U.com

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

DataShe

DataSheet4U.com

## 19.4 Example of Minimum Connection to Flash Microcontroller Programmer (User Power Supply)

When each pin is set as shown below at programming to flash memory, there is no need for connections between MD2, MD0, P30 and the flash microcontroller programmer.

#### Example of Minimum Connection to Flash Microcontroller Programmer (User Power Supply Used)





DataSheet4U.com

www.DataSheet4U.com

#### CHAPTER 19 FLASH SERIAL PROGRAMMING CONNECTION

- Even if the SIN1, SOT1, and SCK1 pins are used for the user system, the controller shown in the figure below is required. The /TICS signal of the flash microcontroller programmer can be used to disconnect the user circuit during serial programming.
  - Connect the AF220/AF210/AF120/AF110 while the user power is off.





et4U.com

DataShe

DataSheet4U.com

DataSheet4U.com

566

DataSheet4U.com

## 19.5 Example of Minimum Connection to Flash Microcontroller Programmer (Writer Power Supply)

When each pin is set as shown below at programming to flash memory, there is no need for connections between MD2, MD0, P30 and the flash microcontroller programmer.

#### Example of Minimum Connection to Flash Microcontroller Programmer (Power Supplied from Flash Microcontroller Programmer)





DataSheet4U.com

#### CHAPTER 19 FLASH SERIAL PROGRAMMING CONNECTION

| Notes: | Even if the SIN1, SOT1, and SCK1 pins are used for the user system, the controller shown in the figure below is required. The /TICS signal of the flash microcontroller programmer can be used to |                                                                  |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|
|        |                                                                                                                                                                                                   | disconnect the user circuit during serial programming.           |
|        | •                                                                                                                                                                                                 | Connect the AF220/AF210/AF120/AF110 while the user power is off. |
|        |                                                                                                                                                                                                   |                                                                  |

• When supplying programming power from AF220/AF210/AF120/AF110, do not short-circuit the programming power and user power.



et4U.com

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

DataShe

DataSheet4U.com

The appendices provide the I/O map and outline of instructions.

APPENDIX A InstructionsAPPENDIX B Register IndexAPPENDIX C Pin Function IndexAPPENDIX D Interrupt Vector Index

DataSheet4U.com

et4U.com

DataSheet4U.com

www.DataSheet4U.com

## **APPENDIX A** Instructions

## Appendix A describes the instructions used by the $F^2MC-16LX$ .

- A.1 Instruction Types
- A.2 Addressing
- A.3 Direct Addressing
- A.4 Indirect Addressing
- A.5 Execution Cycle Count
- A.6 Effective Address Field
- A.7 How to Read the Instruction List
- A.8 F<sup>2</sup>MC-16LX Instruction List
- A.9 Instruction Map

et4U.com

DataSheet4U.com

www.DataSheet4U.com

## A.1 Instruction Types

## The F<sup>2</sup>MC-16LX supports 351 types of instructions. Addressing is enabled by using an effective address field of each instruction or using the instruction code itself.

#### ■ Instruction Types

The F<sup>2</sup>MC-16LX supports the following 351 types of instructions:

- 41 transfer instructions (byte)
- 38 transfer instructions (word or long word)
- 42 addition/subtraction instructions (byte, word, or long word)
- 12 increment/decrement instructions (byte, word, or long word)
- 11 comparison instructions (byte, word, or long word)
- 11 unsigned multiplication/division instructions (word or long word)
- 11 signed multiplication/division instructions (word or long word)
- 39 logic instructions (byte or word)
- 6 logic instructions (long word)
- 6 sign inversion instructions (byte or word)
- 1 normalization instruction (long word)
- 18 shift instructions (byte, word, or long word)
- 50 branch instructions
- 6 accumulator operation instructions (byte or word)
- 28 other control instructions (byte, word, or long word)
- 21 bit operation instructions
- 10 string instructions

t4U.com

571

## A.2 Addressing

With the  $F^2MC-16LX$ , the address format is determined by the instruction effective address field or the instruction code itself (implied). When the address format is determined by the instruction code itself, specify an address in accordance with the instruction code used. Some instructions permit the user to select several types of addressing.

#### Addressing

et4U.com

The F<sup>2</sup>MC-16LX supports the following 23 types of addressing:

- Immediate (#imm)
- Register direct
- Direct branch address (addr16)
- Physical direct branch address (addr24)
- I/O direct (io)
- Abbreviated direct address (dir)
- Direct address (addr16)
- I/O direct bit address (io:bp)
- Abbreviated direct bit address (dir:bp)heet4U.com
- Direct bit address (addr16:bp)
- Vector address (#vct)
- Register indirect (@RWj j = 0 to 3)
- Register indirect with post increment (@RWj+ j = 0 to 3)
- Register indirect with displacement (@RWi + disp8 i = 0 to 7, @RWj+ disp16 j = 0 to 3)
- Long register indirect with displacement (@RLi + disp8 i = 0 to 3)
- Program counter indirect with displacement (@PC + disp16)
- Register indirect with base index (@RW0 + RW7, @RW1 + RW7)
- Program counter relative branch address (rel)
- Register list (rlst)
- Accumulator indirect (@A)
- Accumulator indirect branch address (@A)
- Indirectly-specified branch address (@ear)
- Indirectly-specified branch address (@eam)

DataSheet4U.com

#### Effective Address Field

Table A.2-1 lists the address formats specified by the effective address field.

| Code | Representation                                                                                                                |            | tion         | Address format                                               | Default bank |  |
|------|-------------------------------------------------------------------------------------------------------------------------------|------------|--------------|--------------------------------------------------------------|--------------|--|
| 00   | R0 RW0 RL0                                                                                                                    |            |              |                                                              |              |  |
| 01   | R1                                                                                                                            | RW1        | (RL0)        |                                                              |              |  |
| 02   | R2                                                                                                                            | RW1<br>RW2 | (RL0)<br>RL1 |                                                              |              |  |
| 02   |                                                                                                                               |            |              | Register direct: Individual parts correspond to              |              |  |
|      | R3     RW3     (RL1)       R4     RW4     RL2       R5     RW5     (RL2)       R6     RW6     RL3       P7     RW7     (RL 2) |            |              | the byte, word, and long word                                | None         |  |
| 04   |                                                                                                                               |            |              | types in order from the left.                                |              |  |
| 05   |                                                                                                                               |            |              |                                                              |              |  |
| 06   |                                                                                                                               |            |              |                                                              |              |  |
| 07   | R7                                                                                                                            | RW7        | (RL3)        |                                                              | DTD          |  |
| 08   | @RW0                                                                                                                          |            |              |                                                              | DTB          |  |
| 09   | @RW1                                                                                                                          |            |              | Register indirect                                            | DTB          |  |
| 0A   | @RW2                                                                                                                          |            |              |                                                              | ADB          |  |
| 0B   | @RW3                                                                                                                          |            |              |                                                              | SPB          |  |
| 0C   | @RW0+<br>@RW1+<br>DataShe                                                                                                     |            |              |                                                              | DTB          |  |
| 0D   |                                                                                                                               |            |              | Register indirect with post increment                        | DTB          |  |
| 0E   | @RW2+                                                                                                                         |            |              |                                                              | ADB          |  |
| 0F   | @RW3+                                                                                                                         |            |              |                                                              | SPB          |  |
| 10   | @RW0+disp8                                                                                                                    |            |              |                                                              | DTB          |  |
| 11   | @RW1+disp8                                                                                                                    |            |              | Register indirect with 8-bit displacement                    | DTB          |  |
| 12   | @RW2+disp8                                                                                                                    |            |              |                                                              | ADB          |  |
| 13   | @RW3+disp8                                                                                                                    |            |              |                                                              | SPB          |  |
| 14   | @RW4+disp8                                                                                                                    |            |              |                                                              | DTB          |  |
| 15   | @RW5+disp8                                                                                                                    |            |              | Register indirect with 8-bit displacement                    | DTB          |  |
| 16   | @RW6+di                                                                                                                       | •          |              |                                                              | ADB          |  |
| 17   | @RW7+di                                                                                                                       |            |              |                                                              | SPB          |  |
| 18   | @RW0+di                                                                                                                       | isp16      |              |                                                              | DTB          |  |
| 19   | @RW1+disp16                                                                                                                   |            |              | Register indirect with 16-bit displacement                   | DTB          |  |
| 1A   | @RW2+disp16                                                                                                                   |            |              |                                                              | ADB          |  |
| 1B   | @RW3+disp16                                                                                                                   |            |              |                                                              | SPB          |  |
| 1C   | @RW0+R                                                                                                                        | W7         |              | Projector indiract with index                                | DTB          |  |
| 1D   | @RW1+R                                                                                                                        | W7         |              | Register indirect with index<br>Register indirect with index | DTB          |  |
| 1E   | @PC+disp                                                                                                                      | 016        |              | PC indirect with 16-bit displacement<br>Direct address       | РСВ          |  |
| 1F   | addr16                                                                                                                        |            |              |                                                              | DTB          |  |

| Table A.2-1 Effe | ective Address | Field |
|------------------|----------------|-------|
|------------------|----------------|-------|

et4U.com

DataSheet4U.com

www.DataSheet4U.com

## A.3 Direct Addressing

An operand value, register, or address is specified explicitly in direct addressing mode.

#### Direct Addressing

#### Immediate addressing (#imm)

Specify an operand value explicitly (#imm4/ #imm8/ #imm16/ #imm32).

| Figure A.3-1 Example of immediate addressing (#imm) | Figure A.3-1 | Example of | immediate | addressing | (#imm) |
|-----------------------------------------------------|--------------|------------|-----------|------------|--------|
|-----------------------------------------------------|--------------|------------|-----------|------------|--------|

| MOVW A, #01212H (This | instr | ruction stores the operand value in A.)         |
|-----------------------|-------|-------------------------------------------------|
| Before execution      | А     | 2233 4455                                       |
| After execution       | А     | 44551212 (Some instructions transfer AL to AH.) |

#### Register direct addressing

Specify a register explicitly as an operand. Table A.3-1 lists the registers that can be specified. Figure A.3-2 shows an example of register direct addressing.

DataShe

#### Table A.3-1 Direct Addressing Registers .....

| General-purpose register | Byte        | R0, R1, R2, R3, R4, R5, R6, R7         |
|--------------------------|-------------|----------------------------------------|
|                          | Word        | RW0, RW1, RW2, RW3, RW4, R5W, RW6, RW7 |
|                          | Long word   | RL0, RL1, RL2, RL3                     |
| Special-purpose register | Accumulator | A, AL                                  |
|                          | Pointer     | SP *                                   |
|                          | Bank        | PCB, DTB, USB, SSB, ADB                |
|                          | Page        | DPR                                    |
|                          | Control     | PS, CCR, RP, ILM                       |

\*: One of the user stack pointer (USP) and system stack pointer (SSP) is selected and used depending on the value of the S flag bit in the condition code register (CCR). For branch instructions, the program counter (PC) is not specified in an instruction operand but is specified implicitly.

DataSheet4U.com

٦

| MOV R0, A (This instruction transfers the eight low-order bits of A to the general-purpose register R0.) |   |          |              |  |  |  |
|----------------------------------------------------------------------------------------------------------|---|----------|--------------|--|--|--|
| Before execution                                                                                         | А | 07162534 | Memory space |  |  |  |
| After execution                                                                                          | A | 07162564 | R0 ??        |  |  |  |
|                                                                                                          |   |          | Memory space |  |  |  |
|                                                                                                          |   |          | R0 34        |  |  |  |

#### Figure A.3-2 Example of Register Direct Addressing

#### Direct branch addressing (addr16)

Г

et4U.com

Specify an offset explicitly for the branch destination address. The size of the offset is 16 bits, which indicates the branch destination in the logical address space. Direct branch addressing is used for an unconditional branch, subroutine call, or software interrupt instruction. Bits 23 to 16 of the address are specified by the program bank register (PCB).

#### Figure A.3-3 Example of Direct Branch Addressing (addr16)

| JMP | 3B20H (This instruct<br>in a bank.) | ion causes an un | conditional b | ranch by di | rect branch a    | addre | ssing |
|-----|-------------------------------------|------------------|---------------|-------------|------------------|-------|-------|
|     | Before execution                    | PC 3C20          | PCB 4 F       |             | Memory space     |       |       |
|     |                                     |                  |               | 4F3C22H     | 3 B              |       |       |
|     |                                     |                  |               | 4F3C21H     | 2 0              |       |       |
|     |                                     |                  |               | 4F3C20H     | 62               | JMP   | 3B20H |
|     | After execution                     | PC 3 B 2 0       | PCB 4 F       | 4F3B20H     | Next instruction |       |       |

#### Physical direct branch addressing (addr24)

Specify an offset explicitly for the branch destination address. The size of the offset is 24 bits. Physical direct branch addressing is used for unconditional branch, subroutine call, or software interrupt instruction.

| Figure A.3-4 | Example of Direct | ct Branch Addressing | (addr24) |
|--------------|-------------------|----------------------|----------|
|--------------|-------------------|----------------------|----------|

| JMPP 333B20H (This in address | struction causes a sing.) | an unconditior | nal branch                               | by direct bra        | nch 24· | -bit    |
|-------------------------------|---------------------------|----------------|------------------------------------------|----------------------|---------|---------|
| Before execution              | PC 3C20                   | PCB 4 F        |                                          | Memory space         |         |         |
|                               |                           |                | 4F3C23H<br>4F3C22H<br>4F3C21H<br>4F3C20H | 33<br>3B<br>20<br>63 | JMPP    | 333B20H |
| After execution               | PC 3 B 2 0                | PCB 33         | 333B20H                                  | Next instruction     |         |         |

#### I/O direct addressing (io)

DataSheet4U.com

#### Figure A.3-5 Example of I/O Direct Addressing (io)

| MOVW A, i:0C0H (This instruction reads data by I/O direct addressing and stores it in A.) |   |           |                          |  |  |  |  |
|-------------------------------------------------------------------------------------------|---|-----------|--------------------------|--|--|--|--|
| Before execution                                                                          | A | 07162534  | Memory space             |  |  |  |  |
|                                                                                           |   |           | 0000C1H FF<br>0000C0H EE |  |  |  |  |
| After execution                                                                           | A | 2534 FFEE | 1 1                      |  |  |  |  |

DataSheet4U.com

#### • Abbreviated direct addressing (dir)

Specify the eight low-order bits of a memory address explicitly in an operand. Address bits 8 to 15 are specified by the direct page register (DPR). Address bits 16 to 23 are specified by the data bank register (DTB).



| MOVW S;20H, A (This instruction writes the contents of the eight low-order bits of A in abbreviated direct addressing mode.) |   |           |              |  |  |
|------------------------------------------------------------------------------------------------------------------------------|---|-----------|--------------|--|--|
| Before execution                                                                                                             | А | 4455 1212 | Memory space |  |  |
|                                                                                                                              |   | 66 DTB 77 | 776620H ??   |  |  |
| After execution                                                                                                              | А | 4455 1212 | Memory space |  |  |
|                                                                                                                              |   | 66 DTB 77 | 776620H 1 2  |  |  |

#### Direct addressing (addr16)

Specify the 16 low-order bits of a memory address explicitly in an operand. Address bits 16 to 23 are specified by the data bank register (DTB). A prefix instruction for access space addressing is invalid for this mode of addressing.

DataShe

#### Figure A.3-7 Example of Direct Addressing (addr16)

| BRA 3B20H (This instruction causes an unconditional relative branch.) |           |                               |                   |     |       |
|-----------------------------------------------------------------------|-----------|-------------------------------|-------------------|-----|-------|
| Before execution PC 3C20 PCB 4F Memory space                          |           |                               |                   |     |       |
|                                                                       |           | 4F3C22H<br>4F3C21H<br>4F3C20H | F F<br>F E<br>6 0 | BRA | 3B20H |
| After execution PC 3                                                  | B20 PCB4F | 4F3B20H                       |                   | 4   |       |

et4U.com

I/O direct bit addressing (io:bp)

Specify bits in physical addresses  $000000_{\text{H}}$  to  $0000\text{FF}_{\text{H}}$  explicitly. Bit positions are indicated by ":bp", where the larger number indicates the most significant bit (MSB) and the lower number indicates the least significant bit (LSB).



| SETB I:0C1H: (This instruc | tion sets bits by I/O direct bit addressing.)<br>Memory space |
|----------------------------|---------------------------------------------------------------|
| Before execution           | 0000C1H 0 0                                                   |
| After execution            | 0000C1H 0 1                                                   |

#### • Abbreviated direct bit addressing (dir:bp)

Specify the eight low-order bits of a memory address explicitly in an operand. Address bits 8 to 15 are specified by the direct page register (DPR). Address bits 16 to 23 are specified by the data bank register (DTB). Bit positions are indicated by ":bp", where the larger number indicates the most significant bit (MSB) and the lower number indicates the least significant bit (LSB).

DataShe

www.DataSheet4U.com

#### Figure A.3-9 Example of Abbreviated Direct Bit Addressing (dir:bp)

| SETB S:10H:0 (This instr | ruction sets t | oits by abbreviat | ed direct bit addressing.) |
|--------------------------|----------------|-------------------|----------------------------|
| Before execution         | DTB 55         | DPR 66            | Memory space<br>556610H    |
| After execution          | DTB 55         | DPR 66            | Memory space               |

#### Direct bit addressing (addr16:bp)

Specify arbitrary bits in 64 kilobytes explicitly. Address bits 16 to 23 are specified by the data bank register (DTB). Bit positions are indicated by ":bp", where the larger number indicates the most significant bit (MSB) and the lower number indicates the least significant bit (LSB).

#### Figure A.3-10 Example of Direct Bit addressing (addr16:bp)

| SETB 2222H:0 (This instruction sets bits by direct bit addressing.) |              |  |  |
|---------------------------------------------------------------------|--------------|--|--|
| Before execution DTB 55                                             | Memory space |  |  |
| After execution DTB 55                                              | Memory space |  |  |

DataSheet4U.com

et4U.com

#### Vector Addressing (#vct)

Specify vector data in an operand to indicate the branch destination address. There are two sizes for vector numbers: 4 bits and 8 bits. Vector addressing is used for a subroutine call or software interrupt instruction.

Figure A.3-11 Example of Vector Addressing (#vct)



Table A.3-2 CALLV Vector List

| Instruction | Vector address L    | Vector address H    |
|-------------|---------------------|---------------------|
| CALLV #0    | XXFFFE <sub>H</sub> | XXFFFF <sub>H</sub> |
| CALLV #1    | XXFFFC <sub>H</sub> | XXFFFD <sub>H</sub> |
| CALLV #2    | XXFFFA <sub>H</sub> | XXFFFB <sub>H</sub> |
| CALLV #3    | Datas XXFEF8 Hom    | XXFFF9 <sub>H</sub> |
| CALLV #4    | XXFFF6 <sub>H</sub> | XXFFF7 <sub>H</sub> |
| CALLV #5    | XXFFF4 <sub>H</sub> | XXFFF5 <sub>H</sub> |
| CALLV #6    | XXFFF2 <sub>H</sub> | XXFFF3 <sub>H</sub> |
| CALLV #7    | XXFFF0 <sub>H</sub> | XXFFF1 <sub>H</sub> |
| CALLV #8    | XXFFEE <sub>H</sub> | XXFFEF <sub>H</sub> |
| CALLV #9    | XXFFEC <sub>H</sub> | XXFFED <sub>H</sub> |
| CALLV #10   | XXFFEA <sub>H</sub> | XXFFEB <sub>H</sub> |
| CALLV #11   | XXFFE8 <sub>H</sub> | XXFFE9 <sub>H</sub> |
| CALLV #12   | XXFFE6 <sub>H</sub> | XXFFE7 <sub>H</sub> |
| CALLV #13   | XXFFE4 <sub>H</sub> | XXFFE5 <sub>H</sub> |
| CALLV #14   | XXFFE2 <sub>H</sub> | XXFFE3 <sub>H</sub> |
| CALLV #15   | XXFFE0 <sub>H</sub> | XXFFE1 <sub>H</sub> |

Note: A PCB register value is set in XX.

When the program bank register (PCB) is  $FF_H$ , the vector area overlaps the vector area of INT #vct8 (#0 to #7). Use vector addressing carefully (see Table A.3-2).

DataSheet4U.com

Note:

et4U.com

## A.4 Indirect Addressing

In indirect addressing mode, an address is specified indirectly by the address data of an operand.

#### Indirect Addressing

Register indirect addressing (@RWj j = 0 to 3)

Memory is accessed using the contents of general-purpose register RWj as an address. Address bits 16 to 23 are indicated by the data bank register (DTB) when RW0 or RW1 is used, system stack bank register (SSB) or user stack bank register (USB) when RW3 is used, or additional data bank register (ADB) when RW2 is used.





DataShe

Register indirect addressing with post increment (@RWj+ j = 0 to 3)

Memory is accessed using the contents of general-purpose register RWj as an address. After operand operation, RWj is incremented by the operand size (1 for a byte, 2 for a word, or 4 for a long word). Address bits 16 to 23 are indicated by the data bank register (DTB) when RW0 or RW1 is used, system stack bank register (SSB) or user stack bank register (USB) when RW3 is used, or additional data bank register (ADB) when RW2 is used.

If the post increment results in the address of the register that specifies the increment, the incremented value is referenced after that. In this case, if the next instruction is a write instruction, priority is given to writing by an instruction and, therefore, the register that would be incremented becomes write data.

ataSheet4U.com

et4U.com



#### Figure A.4-2 Example of Register Indirect Addressing with Post Increment (@RWj + j = 0 to 3)

● Register indirect addressing with offset (@RWi + disp8 i = 0 to 7, @RWj + disp16 j = 0 to 3)

Memory is accessed using the address obtained by adding an offset to the contents of general-purpose register RWj. Two types of offset, byte and word offsets, are used. They are added as signed numeric values. Address bits 16 to 23 are indicated by the data bank register (DTB) when RW0, RW1, RW4, or RW5 is used, system stack bank register (SSB) or user stack bank register (USB) when RW3 or RW7 is used, or additional data bank register (ADB) when RW2 or RW6 is used.

#### Figure A.4-3 Example of Register Indirect Addressing with Offset (@RWi + disp8 i = 0 to 7, @RWj + disp16 j = 0 to 3)



#### Long register indirect addressing with offset (@RLi + disp8 i = 0 to 3)

Memory is accessed using the address that is the 24 low-order bits obtained by adding an offset to the contents of general-purpose register RLi. The offset is 8-bits long and is added as a signed numeric value.

#### Figure A.4-4 Example of Long Register Indirect Addressing with Offset (@RLi + disp8 i = 0 to 3)



DataSheet4U.com

et4U.com

www.DataSheet4U.com

Program counter indirect addressing with offset (@PC + disp16)

Memory is accessed using the address indicated by (instruction address + 4 + disp16). The offset is one word long. Address bits 16 to 23 are specified by the program bank register (PCB). Note that the operand address of each of the following instructions is not deemed to be (next instruction address + disp16):

- DBNZ eam, rel
- DWBNZ eam, rel
- CBNE eam, #imm8, rel
- CWBNE eam, #imm16, rel
- MOV eam, #imm8
- MOVW eam, #imm16

#### Figure A.4-5 Example of Program Counter Indirect Addressing with Offset (@PC + disp16)



DataShe

#### Register indirect addressing with base index (@RW0 + RW7, @RW1 + RW7)

Memory is accessed using the address determined by adding RW0 or RW1 to the contents of generalpurpose register RW7. Address bits 16 to 23 are indicated by the data bank register (DTB).

#### Figure A.4-6 Example of Register Indirect Addressing with Base Index (@RW0 + RW7, @RW1 + RW7)

| MOVW A, @RW1+RW7 (This instruction reads data by register indirect addressing with a base index and stores it in A.) |                                |                            |  |  |
|----------------------------------------------------------------------------------------------------------------------|--------------------------------|----------------------------|--|--|
| Before execution                                                                                                     | A 07162534                     | Memory space               |  |  |
| After execution                                                                                                      | RW1 D 30F DTB 78<br>RW7 0101 + | 78D411H F F<br>78D410H E E |  |  |

www.DataSheet4U.com

DataSheet4U.com

et4U.com

#### Program counter relative branch addressing (rel)

The address of the branch destination is a value determined by adding an 8-bit offset to the program counter (PC) value. If the result of addition exceeds 16 bits, bank register incrementing or decrementing is not performed and the excess part is ignored, and therefore the address is contained within a 64-kilobyte bank. This addressing is used for both conditional and unconditional branch instructions. Address bits 16 to 23 are indicated by the program bank register (PCB).

Figure A.4-7 Example of Program Counter Relative Branch Addressing (rel)

| BRA 3B20H (This instru                       | ction causes an unconditional re | lative branch.)               |                   |           |  |
|----------------------------------------------|----------------------------------|-------------------------------|-------------------|-----------|--|
| Before execution PC 3C20 PCB 4F Memory space |                                  |                               |                   |           |  |
|                                              |                                  | 4F3C22H<br>4F3C21H<br>4F3C20H | F F<br>F E<br>6 0 | BRA 3B20H |  |
| After execution                              | PC 3B20 PCB4F                    | 4F3B20H                       | Next instruction  |           |  |

Register list (rlst)

Specify a register to be pushed onto or popped from a stack.

DataShe

#### Figure A.4-8 Configuration of the Register List

et4U.com

583



Figure A.4-9 Example of Register List (rlist)

DataShe

www.DataSheet4U.com

#### Accumulator indirect addressing (@A)

Memory is accessed using the address indicated by the contents of the low-order bytes (16 bits) of the accumulator (AL). Address bits 16 to 23 are specified by a mnemonic in the data bank register (DTB).





#### Accumulator indirect branch addressing (@A)

The address of the branch destination is the content (16 bits) of the low-order bytes (AL) of the accumulator. It indicates the branch destination in the bank address space. Address bits 16 to 23 are specified by the program bank register (PCB). For the Jump Context (JCTX) instruction, however, address bits 16 to 23 are specified by the data bank register (DTB). This addressing is used for unconditional branch instructions.

Figure A.4-11 Example of Accumulator Indirect Branch Addressing (@A)

| JMP @A (This instruction cau<br>addressing.) | ses an unconditional branch b | y accumulator indirect branch |
|----------------------------------------------|-------------------------------|-------------------------------|
| Before execution                             | PC 3C20 PCB 4F                | Memory space                  |
|                                              | A 66773B20                    | 4F3C20H 6 1 JMP @A            |
|                                              |                               | 4F3B20H Next instruction      |
| After execution                              | PC 3B20 PCB 4F                | F I                           |
|                                              | A 6677 3B20                   |                               |

Indirect specification branch addressing (@ear)

The address of the branch destination is the word data at the address indicated by ear.

DataShe

#### Figure A.4-12 Example of Indirect Specification Branch Addressing (@ear)

| JMP @ @RW0 (This instruction causes an unconditional branch by register indirect addressing.) |                                |                      |                  |     |       |  |
|-----------------------------------------------------------------------------------------------|--------------------------------|----------------------|------------------|-----|-------|--|
| Before execution                                                                              | PC 3C20 PCB4F                  | Me                   | mory space       |     |       |  |
|                                                                                               | PW0 7 F 4 8 DTB 2 1            | 4F3C21H<br>4F3C20H   | 0 8<br>7 3       | JMP | @@RW0 |  |
|                                                                                               |                                | 4F3B20H              | Next instruction |     |       |  |
| After execution                                                                               | PC 3B20 PCB4F<br>PW07F48 DTB21 | 217F49H<br>→ 217F48H | 3 B<br>2 0       |     |       |  |

www.DataSheet4U.com

DataSheet4U.com

DataSheet4U.com

et4U.com

Indirect specification branch addressing (@eam)

The address of the branch destination is the word data at the address indicated by eam.

#### Figure A.4-13 Example of Indirect Specification Branch Addressing (@eam)



et4U.com

DataSheet4U.com

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

## A.5 Execution Cycle Count

The number of cycles required for instruction execution (execution cycle count) is obtained by adding the number of cycles required for each instruction, "correction value" determined by the condition, and the number of cycles for instruction fetch.

#### Execution Cycle Count

The number of cycles required for instruction execution (execution cycle count) is obtained by adding the number of cycles required for each instruction, "correction value" determined by the condition, and the number of cycles for instruction fetch. In the mode of fetching an instruction from memory such as internal ROM connected to a 16-bit bus, the program fetches the instruction being executed in word increments. Therefore, intervening in data access increases the execution cycle count.

Similarly, in the mode of fetching an instruction from memory connected to an 8-bit external bus, the program fetches every byte of an instruction being executed. Therefore, intervening in data access increases the execution cycle count. In CPU intermittent operation mode, access to a general-purpose register, internal ROM, internal RAM, internal I/O, or external data bus causes the clock to the CPU to halt for the cycle count specified by the CG0 and CG1 bits of the low power consumption mode control register. Therefore, for the cycle count required for instruction execution in CPU intermittent operation mode, add the "access count x cycle count for the halt" as a correction value to the normal execution count.

DataShe

et4U.com

DataSheet4U.com

#### ■ Calculating the Execution Cycle Count

Table A.5-1 lists execution cycle counts and Table A.5-2 and Table A.5-3 summarize correction value data.

(a) \* Register access count in Code Operand each addressing mode Execution cycle count in each addressing mode Ri 00 to 07 See the instruction list. See the instruction list. Rwi RLi 2 08 to 0B @RWj 1 0C to 0F @RWj+ 2 4 10 to 17 @RWi+disp8 2 1 18 to 1B @RWi+disp16 2 1 2 1C@RW0+RW7 4 1D @RW1+RW7 4 2 1E @PC+disp16 2 0 0 1Faddr16 1

Table A.5-1 Execution Cycle Counts in Each Addressing Mode

DataShe

\*: (a) is used for ~ (cycle count) and B (correction value) in "A.8 F<sup>2</sup>MC-16LX Instruction List".

et4U.com

DataSheet4U.com

| Operand                                  | (b) byte <sup>(*)</sup> |                 | (c) word <sup>(*)</sup> |                 | (d) long <sup>(*)</sup> |                 |
|------------------------------------------|-------------------------|-----------------|-------------------------|-----------------|-------------------------|-----------------|
|                                          | Cycle<br>count          | Access<br>count | Cycle<br>count          | Access<br>count | Cycle<br>count          | Access<br>count |
| Internal register                        | +0                      | 1               | +0                      | 1               | +0                      | 2               |
| Internal memory<br>Even address          | +0                      | 1               | +0                      | 1               | +0                      | 2               |
| Internal memory<br>Odd address           | +0                      | 1               | +2                      | 2               | +4                      | 4               |
| External data bus<br>16-bit even address | +1                      | 1               | +1                      | 1               | +2                      | 2               |
| External data bus<br>16-bit odd address  | +1                      | 1               | +4                      | 2               | +8                      | 4               |
| External data bus<br>8-bits              | +1                      | 1               | +4                      | 2               | +8                      | 4               |

#### Table A.5-2 Cycle Count Correction Values for Counting Execution Cycles

t4U.com

\*: (b), (c), and (d) are used for ~ (cycle count) and B (correction value) in "A.8 F<sup>2</sup>MC-16LX Instruction List".

DataShe

#### DataSheet4U.com

Note: When an external data bus is used, the cycle counts during which an instruction is made to wait by ready input or automatic ready must also be added.

#### Table A.5-3 Cycle Count Correction Values for Counting Instruction Fetch Cycles

| Instruction               | Byte boundary | Word boundary |
|---------------------------|---------------|---------------|
| Internal memory           | -             | +2            |
| External data bus 16-bits | -             | +3            |
| External data bus 8-bits  | +3            | -             |

Notes:

• When an external data bus is used, the cycle counts during which an instruction is made to wait by ready input or automatic ready must also be added.

• Actually, instruction execution is not delayed by every instruction fetch. Therefore, use the correction values to calculate the worst case.

## A.6 Effective Address Field

#### Table A.6-1 shows the effective address field.

#### Effective Address Field

#### Table A.6-1 Effective Address Field

| Code | Representation |                      |        | Address format                                                                | Byte count of<br>extended address<br>part * |     |
|------|----------------|----------------------|--------|-------------------------------------------------------------------------------|---------------------------------------------|-----|
| 00   | R0             | RW0                  | RL0    |                                                                               |                                             |     |
| 01   | R1             | RW1                  | (RL0)  |                                                                               |                                             |     |
| 02   | R2             | RW2                  | RL1    |                                                                               |                                             |     |
| 03   | R3             | RW3                  | (RL1)  | Register direct: Individual parts correspond to the byte, word, and long word |                                             |     |
| 04   | R4             | RW4                  | RL2    | types in order from the left.                                                 |                                             |     |
| 05   | R5             | RW5                  | (RL2)  | 51                                                                            |                                             |     |
| 06   | R6             | RW6                  | RL3    |                                                                               |                                             |     |
| 07   | R7             | RW7                  | (RL3)  |                                                                               |                                             |     |
| 08   | @RW0           |                      |        |                                                                               |                                             | Dat |
| 09   | @RW1           |                      |        | Register indirect                                                             | 0                                           |     |
| 0A   | @RW2           |                      | DataSI | eee 0.com                                                                     | v                                           |     |
| 0B   | @RW3           |                      |        |                                                                               |                                             |     |
| 0C   | @RW0+          |                      |        |                                                                               |                                             |     |
| 0D   | @RW1+          |                      |        | Register indirect with post increment                                         | 0                                           |     |
| 0E   | @RW2+          |                      |        | Register multeet with post merement                                           | 0                                           |     |
| 0F   | @RW3+          |                      |        |                                                                               |                                             |     |
| 10   | @RW0+          | disp8                |        |                                                                               |                                             |     |
| 11   | @RW1+          | W0+disp8<br>W1+disp8 |        |                                                                               |                                             |     |
| 12   | @RW2+          | disp8                |        |                                                                               |                                             |     |
| 13   | @RW3+          | disp8                |        | Register indirect with 8-bit displacement                                     | 1                                           |     |
| 14   | @RW4+          | disp8                |        | register maneet with 6-on displacement                                        | · ·                                         |     |
| 15   | @RW5+          | -                    |        |                                                                               |                                             |     |
| 16   | @RW6+          | -                    |        |                                                                               |                                             |     |
| 17   | @RW7+          | -                    |        |                                                                               |                                             |     |
| 18   | @RW0+          | -                    |        |                                                                               |                                             |     |
| 19   | @RW1+          | -                    |        | Register indirect with 16-bit displacement                                    | 2                                           |     |
| 1A   | @RW2+disp16    |                      |        | register marcet with 10 bit displacement                                      | 2                                           |     |
| 1B   | @RW3+          | disp16               |        |                                                                               |                                             |     |
| 1C   | @RW0+          | RW7                  |        | Register indirect with index                                                  | 0                                           |     |
| 1D   | @RW1+          | RW7                  |        | Register indirect with index                                                  | 0                                           |     |
| 1E   | @PC+di         | sp16                 |        | PC indirect with 16-bit displacement                                          | 2                                           |     |
| 1F   | addr16         |                      |        | Direct address                                                                | 2                                           |     |

\*: Each byte count of the extended address part applies to + in the # (byte count) column in "A.8  $F^2MC-16LX$ Instruction List".

et4U.com

DataSheet4U.com

## A.7 How to Read the Instruction List

## Table A.7-1 describes the items used in the $F^2MC-16LX$ Instruction List, and Table A.7-2 describes the symbols used in the same list.

Description of instruction presentation items and symbols

| Item      | Description                                                                                                                                                                                                                                                     |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Mnemonic  | Uppercase, symbol: Represented as is in the assembler.<br>Lowercase: Rewritten in the assembler.<br>Number of following lowercase: Indicates bit length in the instruction.                                                                                     |
| #         | Indicates the number of bytes.                                                                                                                                                                                                                                  |
| ~         | Indicates the number of cycles.<br>See Table A.2-1 for the alphabetical letters in items.                                                                                                                                                                       |
| RG        | Indicates the number of times a register access is performed during instruction execution.<br>The number is used to calculate the correction value for CPU intermittent operation. DataSheet4U.com                                                              |
| В         | Indicates the correction value used to calculate the actual number of cycles during instruction execution.<br>The actual number of cycles during instruction execution can be determined by adding the value in the ~ column to this value.                     |
| Operation | Indicates the instruction operation.                                                                                                                                                                                                                            |
| LH        | <ul><li>Indicates the special operation for bits 15 to 08 of the accumulator.</li><li>Z: Transfers 0.</li><li>X: Transfers after sign extension.</li><li>-: No transfer</li></ul>                                                                               |
| АН        | <ul> <li>Indicates the special operation for the 16 high-order bits of the accumulator.</li> <li>*: Transfers from AL to AH.</li> <li>-: No transfer</li> <li>Z: Transfers 00 to AH.</li> <li>X: Transfers 00H or FFH to AH after AL sign extension.</li> </ul> |

| Table A.7-1 | Description | of Items in th | he Instruction List (1/2) |
|-------------|-------------|----------------|---------------------------|
|-------------|-------------|----------------|---------------------------|

et4U.com

www.DataSheet4U.com

| Item | Description                                                                                                                                                                                                                                                                                                                                                                             |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Ι    | Each indicates the state of each flag:I (interrupt enable), S (stack), T (sticky bit),                                                                                                                                                                                                                                                                                                  |
| S    | N (negative), Z (zero), V (overflow), C (carry).                                                                                                                                                                                                                                                                                                                                        |
| Т    | *: Changes upon instruction execution.<br>-: No change                                                                                                                                                                                                                                                                                                                                  |
| N    | Z: Set upon instruction execution.                                                                                                                                                                                                                                                                                                                                                      |
| Z    | X: Reset upon instruction execution.                                                                                                                                                                                                                                                                                                                                                    |
| V    |                                                                                                                                                                                                                                                                                                                                                                                         |
| С    |                                                                                                                                                                                                                                                                                                                                                                                         |
| RMW  | <ul> <li>Indicates whether the instruction is a Read Modify Write instruction (reading data from memory by the I instruction and writing the result to memory).</li> <li>*: Read Modify Write instruction <ul> <li>Not Read Modify Write instruction</li> </ul> </li> <li>Note: Cannot be used for an address that has different meanings between read and write operations.</li> </ul> |

#### Table A.7-1 Description of Items in the Instruction List (2/2)

#### Table A.7-2 Explanation on Symbols in the Instruction List (1/2)

DataShe

| Symbol | DataSheet4U.com Explanation                                                                                                                                                     |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| А      | The bit length used varies depending on the 32-bit accumulator instruction.<br>Byte: Low-order 8 bits of byte AL<br>Word: 16 bits of word AL<br>Long word: 32 bits of AL and AH |
| AH     | 16 high-order bits of A                                                                                                                                                         |
| AL     | 16 low-order bits of A                                                                                                                                                          |
| SP     | Stack pointer (USP or SSP)                                                                                                                                                      |
| PC     | Program counter                                                                                                                                                                 |
| РСВ    | Program bank register                                                                                                                                                           |
| DTB    | Data bank register                                                                                                                                                              |
| ADB    | Additional data bank register                                                                                                                                                   |
| SSB    | System stack bank register                                                                                                                                                      |
| USB    | User stack bank register                                                                                                                                                        |
| SPB    | Current stack bank register (SSB or USB)                                                                                                                                        |
| DPR    | Direct page register                                                                                                                                                            |
| brg1   | DTB, ADB, SSB, USB, DPR, PCB, SPB                                                                                                                                               |
| brg2   | DTB, ADB, SSB, USB, DPR, SPB                                                                                                                                                    |

DataSheet4U.com

et4U.com

592

| Symbol     | Explanation                                                                       |
|------------|-----------------------------------------------------------------------------------|
| Ri         | R0, R1, R2, R3, R4, R5, R6, R7                                                    |
| RWi        | RW0, RW1, RW2, RW3, RW4, RW5, RW6, RW7                                            |
| RWj        | RW0, RW1, RW2, RW3                                                                |
| RLi        | RL0, RL1, RL2, RL3                                                                |
| dir        | Abbreviated direct addressing                                                     |
| addr16     | Direct addressing                                                                 |
| addr24     | Physical direct addressing                                                        |
| ad24 0-15  | Bits 0 to 15 of addr24                                                            |
| ad24 16-23 | Bits 16 to 23 of addr24                                                           |
| io         | I/O area $(000000_{\rm H} \text{ to } 0000 \text{FF}_{\rm H})$                    |
| #imm4      | 4-bit immediate data                                                              |
| #imm8      | 8-bit immediate data                                                              |
| #imm16     | 16-bit immediate data                                                             |
| #imm32     | 32-bit immediate data                                                             |
| ext (imm8) | DataSheet4U.com<br>16-bit data obtained by sign extension of 8-bit immediate data |
| disp8      | 8-bit displacement                                                                |
| disp16     | 16-bit displacement                                                               |
| bp         | Bit offset                                                                        |
| vct4       | Vector number (0 to 15)                                                           |
| vct8       | Vector number (0 to 255)                                                          |
| ( ) b      | Bit address                                                                       |
| rel        | PC relative branch                                                                |
| ear        | Effective addressing (code 00 to 07)                                              |
| eam        | Effective addressing (code 08 to 1F)                                              |
| rlst       | Register list                                                                     |

#### Table A.7-2 Explanation on Symbols in the Instruction List (2/2)

et4U.com

## A.8 F<sup>2</sup>MC-16LX Instruction List

### Table A.8-1 to Table A.9-19 list the instructions used by the $F^2MC-16LX$ .

## ■ F<sup>2</sup>MC-16LX Instruction List

Table A.8-1 41 Transfer Instructions (byte)

| Mnemonic                       | #  | ~       | RG | В          | Operation                          | L<br>H | A<br>H | I | s | т | N | z | v | с | R<br>M<br>W |
|--------------------------------|----|---------|----|------------|------------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| MOV A,dir                      | 2  | 3       | 0  | (b)        | byte (A) < (dir)                   | Ζ      | *      | - | - | * | * | - | - | - | -           |
| MOV A,addr16                   | 3  | 4       | 0  | (b)        | byte (A) < (addr16)                | Ζ      | *      | - | - | * | * | - | - | - | -           |
| MOV A,Ri                       | 1  | 2       | 1  | 0          | byte (A) < (Ri)                    | Ζ      | *      | - | - | * | * | - | - | - | -           |
| MOV A,ear                      | 2  | 2       | 1  | 0          | byte (A) < (ear)                   | Ζ      | *      | - | - | * | * | - | - | - | -           |
| MOV A,eam                      | 2+ | 3 + (a) | 0  | (b)        | byte (A) < (eam)                   | Ζ      | *      | - | - | * | * | - | - | - | -           |
| MOV A,io                       | 2  | 3       | 0  | (b)        | byte (A) < (io)                    | Ζ      | *      | - | - | * | * | - | - | - | -           |
| MOV A,#imm8                    | 2  | 2       | 0  | 0          | byte (A) < imm8                    | Ζ      | *      | - | - | * | * | - | - | - | -           |
| MOV A,@A                       | 2  | 3       | 0  | (b)        | byte (A) < ((A))                   | Z      | -      | - | - | * | * | - | - | - | -           |
| MOV A,@RLi+disp8               | 3  | 10      | 2  | (b)        | byte (A) < ((RLi)+disp8)           | Z      | *      | - | - | * | * | - | - | - | -           |
| MOVN A,#imm4                   | 1  | 1       | 0  | 0          | byte (A) < imm4                    | Z      | *      | - | - | R | * | - | - | - | -           |
| MOVX A,dir                     | 2  | 3       | 0  | (b)        | byte (A) < (dir)                   | Х      | *      | - | - | - | * | * | - | - | -           |
| MOVX A,addr16                  | 3  | 4       | 0  | (b)        | byte (A) $<$ (addr16)              | х      | *      | - | - | - | * | * | - | - | -           |
| MOVX A,Ri                      | 2  | 2       | 1  | 0          | byte (A) $<$ (Ri)                  | X      | *      | - | - | - | * | * | - | - | -           |
| MOVX A,ear                     | 2  | 2       | 1  | 0          | byte (A) $<$ (ear)                 | x      | *      | - | - | - | * | * | - | - | -           |
| MOVX A,eam                     | 2+ | 3 + (a) | 0  | (b)        | byte (A) $<$ (eam)                 | x      | *      | - | - | - | * | * | - | - | -           |
| MOVX A,io                      | 2  | 3       | 0  |            | byte (A) < (io)                    | x      | *      | - | - | - | * | * | - | - | _           |
| MOVX A,#imm8                   | 2  | 2       | 0  | 0          | byte (A) $<$ imm8                  | X      | *      |   | _ | _ | * | * |   | _ |             |
| MOVX A,#MINIO<br>MOVX A,@A     | 2  | 3       | 0  | (b)        | byte (A) $<$ ((A))                 | X      | _      | - | - | - | * | * |   | - | -           |
| MOVX A,@RWi+disp8              | 2  | 5       | 1  | (b)<br>(b) | byte (A) $<$ ((RWi)+disp8)         | X      | *      | - | - | - | * | * | - | - | _           |
| •                              | 3  | 10      | 2  |            |                                    | X      | *      | - | - | - | * | * | - | - | -           |
| MOVX A,@RLi+disp8<br>MOV dir.A | 2  | 3       | 0  | (b)<br>(b) | byte (A) $\leftarrow$ ((RLi)+disp8 | -      |        | - | - | - | * | * | - | - | -           |
| ,                              |    | 3       |    |            | byte (dir) $\leftarrow$ (A)        |        | -      | - | - | - | * | * | - |   |             |
| MOV addr16,A                   | 3  |         | 0  | (b)        | byte $(addr16) < (A)$              | -      | -      | - | - | - | * | * | - | - | -           |
| MOV Ri,A                       | 1  | 2       | 1  | 0          | byte (Ri) < (A)                    | -      | -      | - | - | - | * | * | - | - | -           |
| MOV ear,A                      | 2  | 2       | 1  | 0          | byte (ear) < (A)                   | -      | -      | - | - | - |   |   | - | - | -           |
| MOV eam,A                      | 2+ | 3 + (a) | 0  | (b)        | byte (eam) < (A)                   | -      | -      | - | - | - | * | * | - | - | -           |
| MOV io,A                       | 2  | 3       | 0  | (b)        | byte (io) < (A)                    | -      | -      | - | - | - | * | * | - | - | -           |
| MOV @RLi+disp8,A               | 3  | 10      | 2  | (b)        | byte ((RLi)+disp8) < (A)           | -      | -      | - | - | - | * | * | - | - | -           |
| MOV Ri,ear                     | 2  | 3       | 2  | 0          | byte (Ri) < (ear)                  | -      | -      | - | - | - | * | * | - | - | -           |
| MOV Ri,eam                     | 2+ | 4 + (a) | 1  | (b)        | byte (Ri) < (eam)                  | -      | -      | - | - | - | * | * | - | - | -           |
| MOV ear,Ri                     | 2  | 4       | 2  | 0          | byte (ear) < (Ri)                  | -      | -      | - | - | - | * | * | - | - | -           |
| MOV eam,Ri                     | 2+ | 5 + (a) | 1  | (b)        | byte (eam) < (Ri)                  | -      | -      | - | - | - | * | * | - | - | -           |
| MOV Ri,#imm8                   | 2  | 2       | 1  | 0          | byte (Ri) < imm8                   | -      | -      | - | - | - | * | * | - | - | -           |
| MOV io,#imm8                   | 3  | 5       | 0  | (b)        | byte (io) < imm8                   | -      | -      | - | - | - | - | - | - | - | -           |
| MOV dir,#imm8                  | 3  | 5       | 0  | (b)        | byte (dir) < imm8                  | -      | -      | - | - | - | - | - | - | - | -           |
| MOV ear,#imm8                  | 3  | 2       | 1  | 0          | byte (ear) < imm8                  | -      | -      | - | - | - | * | * | - | - | -           |
| MOV eam,#imm8                  | 3+ | 4 + (a) | 0  | (b)        | byte (eam) < imm8                  | -      | -      | - | - | - | - | - | - | - | -           |
| MOV @AL,AH / MOV @A,T          | 2  | 3       | 0  | (b)        | byte ((A)) < (AH)                  | -      | -      | - | - | - | * | * | - | - | -           |
| XCH A,ear                      | 2  | 4       | 2  | 0          | byte (A) <> (ear)                  | Ζ      | -      | - | - | - | - | - | - | - | -           |
| XCH A,eam                      | 2+ | 5 + (a) | 0  | 2 x (b)    | byte (A) <> (eam)                  | Ζ      | -      | - | - | - | - | - | - | - | -           |
| XCH Ri,ear                     | 2  | 7       | 4  | 0          | byte (Ri) <> (ear)                 | -      | -      | - | - | - | - | - | - | - | -           |
| XCH Ri,eam                     | 2+ | 9 + (a) | 2  | 2 x (b)    | byte (Ri) <> (eam)                 | -      | -      | - | - | - | - | - | - | - | -           |

DataShee

Note:

See Table A.5-1 and Table A.5-2 for information on (a) to (d) in the table.

DataSheet4U.com

et4U.com

594

| Mnemonic                   | #       | ~                 | RG | В          | Operation                           | L<br>H | A<br>H | I | S | Т | Ν | Z | V | С | R<br>M<br>W |
|----------------------------|---------|-------------------|----|------------|-------------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| MOVW A.dir                 | 2       | 3                 | 0  | (a)        | word (A) < (dir)                    | -      | *      |   | - |   | * | * |   | - |             |
| MOVW A,addr16              | 2 3     | 3                 | 0  | (c)<br>(c) | word (A) $<$ (addr16)               | -      | *      | - | - | - | * | * | - | - | -           |
| MOVW A,addrio<br>MOVW A,SP | 3       | 4                 | 0  | 0          | word (A) $<$ (SP)                   | -      | *      | - | - | - | * | * | - | - | -           |
| MOVW A,SF<br>MOVW A,RWi    | 1       | 2                 | 1  | 0          | word (A) < (RWi)                    | -      | *      | - | - | - | * | * | _ | - | -           |
| MOVW A,RWI<br>MOVW A,ear   | 2       | 2                 | 1  | 0          |                                     | -      | *      | - | - | - | * | * | - | - | -           |
| MOVW A,eam                 | 2<br>2+ | $\frac{2}{3+(a)}$ | 0  | -          | word (A) $<$ (ear)                  | -      | *      | - | - | - | * | * | - | - | -           |
| ,                          | 2+2     |                   | 0  | (c)        | word (A) $<$ (eam)                  | -      | *      | - | - | - | * | * | - |   | -           |
| MOVW A,io                  |         | 3                 | 0  | (c)        | word (A) $<$ (io)                   | -      |        | - | - | - | * | * | - | - | -           |
| MOVW A,@A                  | 2<br>3  | 3<br>2            |    | (c)<br>0   | word $(A) < ((A))$                  | -      | - *    | - | - | - | * | * | - | - | -           |
| MOVW A,#imm16              |         |                   | 2  | -          | word (A) $<$ imm16                  | -      | *      | - | - | - | * | * |   | - | -           |
| MOVW A,@RWi+disp8          | 2       | 5                 | 1  | (c)        | word (A) $\leftarrow$ ((RWi)+disp8) | -      | *      | - | - | - | * | * | - | - | -           |
| MOVW A,@RLi+disp8          | 3       | 10                | 2  | (c)        | word (A) < ((RLi)+disp8)            | -      |        | - | - | - | * | * | - | - | -           |
| MOVW dir,A                 | 2       | 3                 | 0  | (c)        | word (dir) $\leftarrow$ (A)         | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW addr16,A              | 3       | 4                 | 0  | (c)        | word (addr16) $<$ (A)               | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW SP,A                  | 1       | 1                 | 0  | 0          | word (SP) < (A)                     | -      | -      | - | - | - |   |   | - | - | -           |
| MOVW RWi,A                 | 1       | 2                 | 1  | 0          | word (RWi) < (A)                    | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW ear,A                 | 2       | 2                 | 1  | 0          | word (ear) < (A)                    | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW eam,A                 | 2+      | 3 + (a)           | 0  | (c)        | word (eam) < (A)                    | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW io,A                  | 2       | 3                 | 0  | (c)        | word (io) < (A)                     | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW @RWi+disp8,A          | 2       | 5                 | 1  | (c)        | word ((RWi)+disp8) < (A)            | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW @RLi+disp8,A          | 3       | 10                | 2  | (c)        | word ((RLi)+disp8) < (A)            | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW RWi,ear               | 2       | 3                 | 2  | 0          | word (RWi) < (ear)                  | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW                       | 2+      | 4 + (a)           | 1  | (c)        | word (RWi) < (eam)                  | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW ear,Rwi               | 2       | 4                 | 2  | 0          | word (ear) < (RWi)                  | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW eam,Rwi               | 2+      | 5 + (a)           | 1  | (c)        | word (eam) < (RWi)                  | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW RWi,#imm16            | 3       | 2                 | 1  | 0          | word (RWi) < imm16                  | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW io,#imm16             | 4       | 5                 | 0  | (c)        | word (io) < imm16                   | -      | -      | - | - | - | - | - | - | - | -           |
| MOVW ear,#imm16            | 4       | 2                 | 1  | ataShe     | word (ear) < imm16                  | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW eam,#imm16            | 4+      | 4 + (a)           | 0  | (c)        | word (eam) < imm16                  | -      | -      | - | - | - | - | - | - | - | -           |
| MOVW @AL,AH / MOVW @A,T    | 2       | 3                 | 0  | (c)        | word ((A)) < (AH)                   | -      | -      | - | - | - | * | * | - | - | -           |
| XCHW A,ear                 | 2       | 4                 | 2  | 0          | word (A) <> (ear)                   | -      | -      | - | - | - | - | - | - | - | -           |
| XCHW A,eam                 | 2+      | 5 + (a)           | 0  | 2 x (c)    | word (A) <>(eam)                    | -      | -      | - | - | - | - | - | - | - | -           |
| XCHW RWi, ear              | 2       | 7                 | 4  | 0          | word (RWi) <> (ear)                 | -      | -      | - | - | - | - | - | - | - | -           |
| XCHW RWi, eam              | 2+      | 9 + (a)           | 2  | 2 x (c)    | word (RWi) <> (eam)                 | -      | -      | - | - | - | - | - | - | - | -           |
| MOVL A,ear                 | 2       | 4                 | 2  | 0          | long (A) < (ear)                    | -      | -      | - | - | - | * | * | - | - | -           |
| MOVL A,eam                 | 2+      | 5 + (a)           | 0  | (d)        | long (A) < (eam)                    | -      | -      | - | - | - | * | * | - | - | -           |
| MOVL A,#imm32              | 5       | 3                 | 0  | 0          | long (A) < imm32                    | -      | -      | - | - | - | * | * | - | - | -           |
| MOVL ear,A                 | 2       | 4                 | 2  | 0          | long (ear1) < (A)                   | -      | -      | - | - | - | * | * | - | - | -           |
| MOVL eam,A                 | 2+      | 5 + (a)           | 0  | (d)        | long(eam1) < (A)                    | -      | -      | - | - | - | * | * | - | - | -           |

Table A.8-2 38 Transfer Instructions (byte)

Note:

et4U.com

See Table A.5-1 and Table A.5-2 for information on (a) to (d) in the table.

| I     | Mnemonic | #  | ~       | RG | В       | Operation                                 | L<br>H | A<br>H | I | s              | т   | N | z | v | с | R<br>M<br>W |
|-------|----------|----|---------|----|---------|-------------------------------------------|--------|--------|---|----------------|-----|---|---|---|---|-------------|
| ADD   | A,#imm8  | 2  | 2       | 0  | 0       | byte (A) < (A) + imm8                     | Ζ      | -      | - | -              | -   | * | * | * | * | -           |
| ADD   | A,dir    | 2  | 5       | 0  | (b)     | byte (A) $<$ (A) + (dir)                  | Ζ      | -      | - | -              | -   | * | * | * | * | -           |
| ADD   | A,ear    | 2  | 3       | 1  | 0       | byte (A) < (A) + (ear)                    | Ζ      | -      | - | -              | -   | * | * | * | * | -           |
| ADD   | A,eam    | 2+ | 4 + (a) | 0  | (b)     | byte (A) < (A) + (eam)                    | Ζ      | -      | - | -              | -   | * | * | * | * | -           |
| ADD   | ear,A    | 2  | 3       | 2  | 0       | byte (ear) < (ear) + (A)                  | -      | -      | - | -              | -   | * | * | * | * | -           |
| ADD   | eam,A    | 2+ | 5 + (a) | 0  | 2 x (b) | byte (eam) < (eam) + (A)                  | Ζ      | -      | - | -              | -   | * | * | * | * | *           |
| ADDC  | А        | 1  | 2       | 0  | 0       | byte (A) < (AH) + (AL) + (C)              | Ζ      | -      | - | -              | -   | * | * | * | * | -           |
| ADDC  | A,ear    | 2  | 3       | 1  | 0       | byte (A) $<$ (A) + (ear)+ (C)             | Ζ      | -      | - | -              | -   | * | * | * | * | -           |
| ADDC  | A,eam    | 2+ | 4 + (a) | 0  | (b)     | byte (A) < (A) + (eam)+ (C)               | Ζ      | -      | - | -              | -   | * | * | * | * | -           |
| ADDDC | А        | 1  | 3       | 0  | 0       | byte (A) < (AH) + (AL) + (C)<br>(decimal) | Z      | -      | - | -              | -   | * | * | * | * | -           |
| SUB   | A,#imm8  | 2  | 2       | 0  | 0       | byte (A) < (A) - imm8                     | Ζ      | -      | - | -              | -   | * | * | * | * | -           |
| SUB   | A,dir    | 2  | 5       | 0  | (b)     | byte (A) < (A) - (dir)                    | Ζ      | -      | - | -              | -   | * | * | * | * | -           |
| SUB   | A,ear    | 2  | 3       | 1  | 0       | byte (A) < (A) - (ear)                    | Z      | -      | - | -              | -   | * | * | * | * | -           |
| SUB   | A,eam    | 2+ | 4 + (a) | 0  | (b)     | byte (A) < (A) - (eam)                    | Ζ      | -      | - | -              | -   | * | * | * | * | -           |
| SUB   | ear,A    | 2  | 3       | 2  | 0       | byte (ear) < (ear) - (A)                  | -      | -      | - | -              | -   | * | * | * | * | -           |
| SUB   | eam,A    | 2+ | 5 + (a) | 0  | 2 x (b) | byte (eam) < (eam) - (A)                  | -      | -      | - | -              | -   | * | * | * | * | *           |
| SUBC  | А        | 1  | 2       | 0  | 0       | byte (A) < (AH) - (AL) - (C)              | Z      | -      | - | -              | -   | * | * | * | * | -           |
| SUBC  | A,ear    | 2  | 3       | 1  | 0       | byte (A) < (A) - (ear) - (C)              | Z      | -      | - | -              | -   | * | * | * | * | -           |
| SUBC  | A,eam    | 2+ | 4 + (a) | 0  | (b)     | byte (A) < (A) - (eam) - (C)              | Z      | -      | - | -              | -   | * | * | * | * | -           |
| SUBDC | A        | 1  | 3       | 0  | 0       | byte (A) < (AH) - (AL) - (C)              | Z      | -      | - | -              | -   | * | * | * | * | -           |
|       |          |    |         |    |         | (decimal)                                 |        |        |   |                |     |   |   |   |   |             |
| ADDW  | А        | 1  | 2       | 0  | 0       | word (A) < (AH) + (AL)                    | -      | -      | - | -              | -   | * | * | * | * | -           |
| ADDW  | A,ear    | 2  | 3       | 1  | 0       | word (A) < (A) + (ear)                    | -      | -      | - | -              | -   | * | * | * | * | -           |
| ADDW  | A,eam    | 2+ | 4+(a)   | 0  | (c)     | word (A) < (A) + (eam)                    | -      | -      | - | -              | -   | * | * | * | * | -           |
| ADDW  | A,#imm16 | 3  | 2       | 0  | 0       | word (A) < (A) + imm16                    | -      | -      | - | -              | -   | * | * | * | * | -           |
| ADDW  | ear,A    | 2  | 3       | 2  | 0       | word (ear) < (ear) + (A)                  | -      | -      | - | -              | -   | * | * | * | * | -           |
| ADDW  | eam,A    | 2+ | 5+(a)   | 0  | DetaShe | word (eam) $\triangleleft$ (eam) + (A)    | -      | -      | - | -              | -   | * | * | * | * | *           |
| ADDCW | A,ear    | 2  | 3       | 1  | 0       | word (A) < (A) + (ear) + (C)              | -      | -      | - | -              | -   | * | * | * | * | -           |
| ADDCW | A,eam    | 2+ | 4+(a)   | 0  | (c)     | word (A) < (A) + (eam) + (C)              | -      | -      | - | -              | -   | * | * | * | * | -           |
| SUBW  | А        | 1  | 2       | 0  | 0       | word (A) < (AH) - (AL)                    | -      | -      | - | -              | -   | * | * | * | * | -           |
| SUBW  | A,ear    | 2  | 3       | 1  | 0       | word (A) < (A) - (ear)                    | -      | -      | - | -              | -   | * | * | * | * | -           |
| SUBW  | A,eam    | 2+ | 4+(a)   | 0  | (c)     | word (A) < (A) - (eam)                    | -      | -      | - | -              | -   | * | * | * | * | -           |
| SUBW  | A,#imm16 | 3  | 2       | 0  | 0       | word (A) < (A) - imm16                    | -      | -      | - | -              | -   | * | * | * | * | -           |
| SUBW  | ear,A    | 2  | 3       | 2  | 0       | word (ear) < (ear) - (A)                  | -      | -      | - | -              | -   | * | * | * | * | -           |
| SUBW  | eam,A    | 2+ | 5+(a)   | 0  | 2 x (c) | word (eam) < (eam) - (A)                  | -      | -      | - | -              | -   | * | * | * | * | *           |
| SUBCW | A,ear    | 2  | 3       | 1  | 0       | word (A) < (A) - (ear) - (C)              | -      | -      | - | -              | -   | * | * | * | * | -           |
| SUBCW | A,eam    | 2+ | 4+(a)   | 0  | (c)     | word (A) < (A) - (eam) - (C)              | -      | -      | - | -              | -   | * | * | * | * | -           |
| ADDL  | A,ear    | 2  | 6       | 2  | 0       | long (A) < (A) + (ear)                    | -      | -      | - | -              | -   | * | * | * | * | -           |
| ADDL  | A.eam    | 2+ | 7+(a)   | 0  | (d)     | $\log (A) < (A) + (eam)$                  | -      | -      | - | -              | -   | * | * | * | * | -           |
| ADDL  | A,#imm32 | 5  | 4       | 0  | 0       | long (A) < (A) + imm32                    | -      | -      | - | -              | -   | * | * | * | * | -           |
| SUBL  | A.ear    | 2  | 6       | 2  | 0       | $\log (A) < (A) - (ear)$                  | -      | -      | - | -              | -   | * | * | * | * | -           |
| SUBL  | A,eam    | 2+ | 7+(a)   | 0  | (d)     | long (A) < (A) - (eam)                    | -      | -      | - | -              | -   | * | * | * | * | -           |
|       | A,#imm32 | 5  | 4       | 0  | 0       | 1011B (11) < (11) - (0mm)                 | 1 -    | 1      | 1 | 1 <sup>-</sup> | 1 - | * | * | * | * | 1           |

#### Table A.8-3 42 Addition/subtraction Instructions (byte, word, long word)

Note:

See Table A.5-1 and Table A.5-2 for information on (a) to (d) in the table.

et4U.com

DataSheet4U.com

596

|       | Mnemonic | #       | ~          | RG      | В           | Operation                     | L<br>H | A<br>H | I | s | т | Ν | z | v | с | R<br>M<br>W |
|-------|----------|---------|------------|---------|-------------|-------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| INC   | ear      | 2       | 3          | 2       | 0           | byte (ear) < (ear) + 1        | -      | -      | - | - | - | * | * | * | - | -           |
| INC   | eam      | 2+      | 5+(a)      | 0       | 2 x (b)     | byte (eam) < (eam) + 1        | -      | -      | - | - | - | * | * | * | - | *           |
| DEC   | ear      | 2       | 3          | 2       | 0           | byte (ear) < (ear) - 1        | -      | -      | - | - | - | * | * | * | - | -           |
| DEC   | eam      | 2+      | 5+(a)      | 0       | 2 x (b)     | byte (eam) < (eam) - 1        | -      | -      | - | - | - | * | * | * | - | *           |
| INCW  | ear      | 2       | 3          | 2       | 0           | word (ear) < (ear) + 1        | -      | -      | - | - | - | * | * | * | - | -           |
| INCW  | eam      | 2+      | 5+(a)      | 0       | 2 x (c)     | word (eam) < (eam) + 1        | -      | -      | - | - | - | * | * | * | - | *           |
| DECW  | ear      | 2       | 3          | 2       | 0           | word (ear) < (ear) - 1        | -      | -      | - | - | - | * | * | * | - | -           |
| DECW  | eam      | 2+      | 5+(a)      | 0       | 2 x (c)     | word (eam) < (eam) - 1        | -      | -      | - | - | - | * | * | * | - | *           |
| INCL  | ear      | 2       | 7          | 4       | 0           | long (ear) < (ear) + 1        | -      | -      | - | - | - | * | * | * | - | -           |
| INCL  | eam      | 2+      | 9+(a)      | 0       | 2 x (d)     | long (eam) < (eam) + 1        | -      | -      | - | - | - | * | * | * | - | *           |
| DECL  | ear      | 2       | 7          | 4       | 0           | long (ear) < (ear) - 1        | -      | -      | - | - | - | * | * | * | - | -           |
| DECL  | eam      | 2+      | 9+(a)      | 0       | 2 x (d)     | long (eam) < (eam) - 1        | -      | -      | - | - | - | * | * | * | - | *           |
| Note: | See Ta   | ble A.5 | -1 and Tab | le A.5- | 2 for infor | mation on (a) to (d) in the t | abl    | e.     |   |   |   |   |   |   |   |             |

Table A.8-4 12 Increment/decrement Instructions (byte, word, long word)

Table A.8-5 11 Compare Instructions (byte, word, long word)

|      | Mnemonic | #  | ~     | RG | DateShe | et4U.coroperation | LH | A<br>H | I | s | т | Ν | z | v | с | R<br>M<br>W |
|------|----------|----|-------|----|---------|-------------------|----|--------|---|---|---|---|---|---|---|-------------|
| CMP  | А        | 1  | 1     | 0  | 0       | byte (AH) - (AL)  | -  | -      | - | - | - | * | * | * | * | -           |
| CMP  | A,ear    | 2  | 2     | 1  | 0       | byte (A) - (ear)  | -  | -      | - | - | - | * | * | * | * | -           |
| CMP  | A,eam    | 2+ | 3+(a) | 0  | (b)     | byte (A) - (eam)  | -  | -      | - | - | - | * | * | * | * | -           |
| CMP  | A,#imm8  | 2  | 2     | 0  | 0       | byte (A) - imm8   | -  | -      | - | - | - | * | * | * | * | -           |
| CMPW | А        | 1  | 1     | 0  | 0       | word (AH) - (AL)  | -  | -      | - | - | - | * | * | * | * | -           |
| CMPW | A,ear    | 2  | 2     | 1  | 0       | word (A) - (ear)  | -  | -      | - | - | - | * | * | * | * | -           |
| CMPW | A,eam    | 2+ | 3+(a) | 0  | (c)     | word (A) - (eam)  | -  | -      | - | - | - | * | * | * | * | -           |
| CMPW | A,#imm16 | 3  | 2     | 0  | 0       | word (A) - imm16  | -  | -      | - | - | - | * | * | * | * | -           |
| CMPL | A,ear    | 2  | 6     | 2  | 0       | long (A) - (ear)  | -  | -      | 1 | - | - | * | * | * | * | -           |
| CMPL | A,eam    | 2+ | 7+(a) | 0  | (d)     | long (A) - (eam)  | -  | -      | - | - | - | * | * | * | * | -           |
| CMPL | A,#imm32 | 5  | 3     | 0  | 0       | long (A) - imm32  | -  | -      | - | - | - | * | * | * | * | -           |

Note:

See Table A.5-1 and Table A.5-2 for information on (a) to (d) in the table.

| Mn                                                                                                                                                                                     | emonic                                                                                                                                                                                                                                                                           | #                                                                                                                                                           | ~                                                                                                          | RG           | в   | Operation                                                         | L<br>H | A<br>H | I | s | т | Ν | z | v | с | R<br>M<br>W |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|--------------|-----|-------------------------------------------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| DIVU                                                                                                                                                                                   | А                                                                                                                                                                                                                                                                                | 1                                                                                                                                                           | *1                                                                                                         | 0            | 0   | word (AH) / byte (AL)<br>quotient> byte (AL) remainder> byte (AH) | -      | -      | - | - | - | - | - | * | * | -           |
| DIVU                                                                                                                                                                                   | A,ear                                                                                                                                                                                                                                                                            | 2                                                                                                                                                           | *2                                                                                                         | 1            | 0   | word (A) / byte (ear)<br>quotient> byte (A) remainder> byte (ear) | -      | -      | - | - | - | - | - | * | * | -           |
| DIVU                                                                                                                                                                                   | A,eam                                                                                                                                                                                                                                                                            | 2+                                                                                                                                                          | *3                                                                                                         | 0            | *6  | word (A) / byte (eam)<br>quotient> byte (A) remainder> byte (eam) |        | -      | - | - | - | - | - | * | * | -           |
| DIVUW                                                                                                                                                                                  | A,ear                                                                                                                                                                                                                                                                            | 2                                                                                                                                                           | *4                                                                                                         | 1            | 0   | long (A) / word (ear)<br>quotient> word(A) remainder> word(ear)   |        | -      | - | - | - | - | - | * | * | -           |
| DIVUW                                                                                                                                                                                  | A,eam                                                                                                                                                                                                                                                                            | 2+                                                                                                                                                          | *5                                                                                                         | 0            | *7  | long (A) / word (eam)<br>quotient> word(A) remainder> word(eam)   | -      | -      | - | - | - | - | - | * | * | -           |
| MULU                                                                                                                                                                                   | А                                                                                                                                                                                                                                                                                | 1                                                                                                                                                           | *8                                                                                                         | 0            | 0   | byte (AH) * byte (AL)> word (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |
| MULU                                                                                                                                                                                   | A,ear                                                                                                                                                                                                                                                                            | 2                                                                                                                                                           | *9                                                                                                         | 1            | 0   | byte (A) * byte (ear)> word (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |
| MULU                                                                                                                                                                                   | A,eam                                                                                                                                                                                                                                                                            | 2+                                                                                                                                                          | *10                                                                                                        | 0            | (b) | byte (A) * byte (eam)> word (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |
| MULUW                                                                                                                                                                                  | А                                                                                                                                                                                                                                                                                | 1                                                                                                                                                           | *11                                                                                                        | 0            | 0   | word (AH) * word (AL)> Long (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |
| MULUW                                                                                                                                                                                  | A,ear                                                                                                                                                                                                                                                                            | 2                                                                                                                                                           | *12                                                                                                        | 1            | 0   | word (A) * word (ear)> Long (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |
| MULUW                                                                                                                                                                                  | A,eam                                                                                                                                                                                                                                                                            | 2+                                                                                                                                                          | *13                                                                                                        | 0            | (c) | word (A) * word (eam)> Long (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |
| *2: 4: Divis<br>*3: 6+(a): D<br>*4: 4: Divis<br>*5: 6+(a): D<br>*6: (b): Div<br>*7: (c): Div<br>*8: 3: Byte<br>*9: 4: Byte<br>*9: 4: Byte<br>*10: 5+(a):<br>*11: 3: Wor<br>*12: 4: Wor | ion by 0 7: Overfl<br>ion by 0 8: Overfl<br>ivision by 0 9+(a)<br>ion by 0 7: Overfl<br>ivision by 0 7: Overfl<br>ivision by 0 or overff<br>(AH) is 0. 7: Byte<br>(ear) is 0. 8: Byte<br>Byte (eam) is 0. 9-<br>4(AH) is 0. 11: Wo<br>(d(ear) is 0. 12: Wo<br>Word (eam) is 0. 1 | ow 16: No<br>coverflow<br>ow 22: No<br>coverflow<br>low 2 x (to<br>ow 2 x (coverflow<br>(AH) is no<br>(ear) is no<br>(a): Byte<br>ord (AH) i<br>rd (ear) is | ormal<br>w 19+(a):<br>ormal<br>w 26+(a):<br>): Normal<br>ot 0.<br>t 0.<br>(eam) is n<br>s not 0.<br>not 0. | Normal ot 0. |     | DataSheet4U.com                                                   |        |        |   |   |   |   |   |   |   |             |

#### Table A.8-6 11 Unsigned multiplication/division instructions (word, long word)

Note:

et4U.com

See Table A.5-1 and Table A.5-2 for information on (a) to (d) in the table.

DataSheet4U.com

| Γ    | Mnemonic | #  | ~   | RG | В   | Operation                                                         | L<br>H | A<br>H | I | s | т | N | z | v | С | R<br>M<br>W |
|------|----------|----|-----|----|-----|-------------------------------------------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| DIV  | А        | 2  | *1  | 0  | 0   | word (AH) / byte (AL)<br>quotient> byte (AL) remainder> byte (AH) | Z      | -      | - | - | - | - | - | * | * | -           |
| DIV  | A,ear    | 2  | *2  | 1  | 0   | word (A) / byte (ear)<br>quotient> byte (A) remainder> byte (ear) | Z      | -      | - | - | - | - | - | * | * | -           |
| DIV  | A,eam    | 2+ | *3  | 0  | *6  | word (A) / byte (eam)<br>quotient> byte (A) remainder> byte (eam) | Z      | -      | - | - | - | - | - | * | * | -           |
| DIVW | A,ear    | 2  | *4  | 1  | 0   | long (A) / word (ear)<br>quotient> word(A) remainder> word(ear)   | -      | -      | - | - | - | - | - | * | * | -           |
| DIVW | A,eam    | 2+ | *5  | 0  | *7  | long (A) / word (eam)<br>quotient> word(A) remainder> word(eam)   | -      | -      | - | - | - | - | - | * | * | -           |
| MUL  | А        | 2  | *8  | 0  | 0   | byte (AH) * byte (AL)> word (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |
| MUL  | A,ear    | 2  | *9  | 1  | 0   | byte (A) * byte (ear)> word (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |
| MUL  | A,eam    | 2+ | *10 | 0  | (b) | byte (A) * byte (eam)> word (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |
| MULW | А        | 2  | *11 | 0  | 0   | word (AH) * word (AL)> Long (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |
| MULW | A,ear    | 2  | *12 | 1  | 0   | word (A) * word (ear)> Long (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |
| MULW | A,eam    | 2+ | *13 | 0  | (c) | word (A) * word (eam)> Long (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |

#### Table A.8-7 11 Signed Multiplication/Division Instructions (word, long word)

\*1: 3: Division by 0, 8 or 18: Overflow, 18: Normal

\*2: 4: Division by 0, 11 or 22: Overflow, 23: Normal \*3: 5+(a): Division by 0, 12+(a) or 23+(a): Overflow, 24+(a): Normal

\*4: When dividend is positive; 4: Division by 0, 12 or 30: Overflow, 31: Normal

When dividend is negative; 4: Division by 0, 12 or 31: Overflow, 32: Normal

\*5: When dividend is positive; 5+(a): Division by 0, 12+(a) or 31+(a): Overflow, 32+(a): Normal

When dividend is negative; 5+(a): Division by 0, 12+(a) or 32+(a): Overflow, 33+(a): Normal

\*6: (b): Division by 0 or overflow, 2 x (b): Normal

\*7: (c): Division by 0 or overflow, 2 x (c): Normal

\*8: 3: Byte (AH) is 0, 12: result is positive, 13: result is negative

\*9: 4: Byte (ear) is 0, 13: result is positive, 14: result is negative DataSheet4U.com

\*10: 5+(a): Byte (eam) is 0, 14+(a): result is positive, 15+(a): result is negative

\*11: 3: Word(AH) is 0, 16: result is positive, 19: result is negative

\*12: 4: Word(ear) is 0, 17: result is positive, 20: result is negative

\*13: 5+(a): Word(eam) is 0, 18+(a): result is positive, 21+(a): result is negative

Notes:

• The execution cycle count found when an overflow occurs in a DIV or DIVW instruction may be a preoperation count or a post-operation count depending on the detection timing.

• When an overflow occurs with DIV or DIVW instruction, the contents of the AL are destroyed.

• See Table A.5-1 and Table A.5-2 for information on (a) to (d) in the table.

et4U.com

DataSheet4U.com

| М    | Inemonic | #  | ~     | RG | В       | Operation                  | L<br>H | A<br>H | I | s | т | N | Z | v | с | R<br>M<br>W |
|------|----------|----|-------|----|---------|----------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| AND  | A,#imm8  | 2  | 2     | 0  | 0       | byte (A) < (A) and imm8    | -      | -      | - | - | - | * | * | R | - | -           |
| AND  | A,ear    | 2  | 3     | 1  | 0       | byte (A) < (A) and (ear)   | -      | -      | - | - | - | * | * | R | - | -           |
| AND  | A,eam    | 2+ | 4+(a) | 0  | (b)     | byte (A) < (A) and (eam)   | -      | -      | - | - | - | * | * | R | - | -           |
| AND  | ear,A    | 2  | 3     | 2  | 0       | byte (ear) < (ear) and (A) | -      | -      | - | - | - | * | * | R | - | -           |
| AND  | eam,A    | 2+ | 5+(a) | 0  | 2 x (b) | byte (eam) < (eam) and (A) | -      | -      | - | - | - | * | * | R | - | *           |
| OR   | A,#imm8  | 2  | 2     | 0  | 0       | byte (A) < (A) or imm8     | -      | -      | - | - | - | * | * | R | - | -           |
| OR   | A,ear    | 2  | 3     | 1  | 0       | byte (A) < (A) or (ear)    | -      | -      | - | - | - | * | * | R | - | -           |
| OR   | A,eam    | 2+ | 4+(a) | 0  | (b)     | byte (A) < (A) or (eam)    | -      | -      | - | - | - | * | * | R | - | -           |
| OR   | ear,A    | 2  | 3     | 2  | 0       | byte (ear) < (ear) or (A)  | -      | -      | - | - | - | * | * | R | - | -           |
| OR   | eam,A    | 2+ | 5+(a) | 0  | 2 x (b) | byte (eam) < (eam) or (A)  | -      | -      | - | - | - | * | * | R | - | *           |
| XOR  | A,#imm8  | 2  | 2     | 0  | 0       | byte (A) < (A) xor imm8    | -      | -      | - | - | - | * | * | R | - | -           |
| XOR  | A,ear    | 2  | 3     | 1  | 0       | byte (A) < (A) xor (ear)   | -      | -      | - | - | - | * | * | R | - | -           |
| XOR  | A,eam    | 2+ | 4+(a) | 0  | (b)     | byte (A) < (A) xor (eam)   | -      | -      | - | - | - | * | * | R | - | -           |
| XOR  | ear,A    | 2  | 3     | 2  | 0       | byte (ear) < (ear) xor (A) | -      | -      | - | - | - | * | * | R | - | -           |
| XOR  | eam,A    | 2+ | 5+(a) | 0  | 2 x (b) | byte (eam) < (eam) xor (A) | -      | -      | - | - | - | * | * | R | - | *           |
| NOT  | А        | 1  | 2     | 0  | 0       | byte (A) < not (A)         | -      | -      | - | - | - | * | * | R | - | -           |
| NOT  | ear      | 2  | 3     | 2  | 0       | byte (ear) < not (ear)     | -      | -      | - | - | - | * | * | R | - | -           |
| NOT  | eam      | 2+ | 5+(a) | 0  | 2 x (b) | byte (eam) < not (eam)     | -      | -      | - | - | - | * | * | R | - | *           |
| ANDW | А        | 1  | 2     | 0  | 0       | word (A) < (AH) and (A)    | -      | -      | - | - | - | * | * | R | - | -           |
| ANDW | A,#imm16 | 3  | 2     | 0  | 0       | word (A) < (A) and imm16   | -      | -      | - | - | - | * | * | R | - | -           |
| ANDW | A,ear    | 2  | 3     | 1  | 0       | word (A) < (A) and (ear)   | -      | -      | - | - | - | * | * | R | - | -           |
| ANDW | A,eam    | 2+ | 4+(a) | 0  | (c)     | word (A) < (A) and (eam)   | -      | -      | - | - | - | * | * | R | - | -           |
| ANDW | ear,A    | 2  | 3     | 2  | 0       | word (ear) < (ear) and (A) | -      | -      | - | - | - | * | * | R | - | -           |
| ANDW | eam,A    | 2+ | 5+(a) | 0  | 2 x (c) | word (eam) < (eam) and (A) | -      | -      | - | - | - | * | * | R | - | *           |
| ORW  | А        | 1  | 2     | 0  | 0       | word (A) < (AH) or (A)     | -      | -      | - | - | - | * | * | R | - | -           |
| ORW  | A,#imm16 | 3  | 2     | 0  | 0       | word (A) < (A) or imm16    | -      | -      | - | - | - | * | * | R | - | -           |
| ORW  | A,ear    | 2  | 3     | 1  | 0       | word (A) < (A) or (ear)    | -      | -      | - | - | - | * | * | R | - | -           |
| ORW  | A,eam    | 2+ | 4+(a) | 0  | (c)     | word (A) < (A) or (eam)    | -      | -      | - | - | - | * | * | R | - | -           |
| ORW  | ear,A    | 2  | 3     | 2  | 0       | word (ear) < (ear) or (A)  | -      | -      | - | - | - | * | * | R | - | -           |
| ORW  | eam,A    | 2+ | 5+(a) | 0  | 2 x (c) | word (eam) < (eam) or (A)  | -      | -      | - | - | - | * | * | R | - | *           |
| XORW | А        | 1  | 2     | 0  | 0       | word (A) < (AH) xor (A)    | -      | -      | - | - | - | * | * | R | - | -           |
| XORW | A,#imm16 | 3  | 2     | 0  | 0       | word (A) < (A) xor imm16   | -      | -      | - | - | - | * | * | R | - | -           |
| XORW | A,ear    | 2  | 3     | 1  | 0       | word (A) < (A) xor (ear)   | -      | -      | - | - | - | * | * | R | - | -           |
| XORW | A,eam    | 2+ | 4+(a) | 0  | (c)     | word (A) < (A) xor (eam)   | -      | -      | - | - | - | * | * | R | - | -           |
| XORW | ear,A    | 2  | 3     | 2  | 0       | word (ear) < (ear) xor (A) | -      | -      | - | - | - | * | * | R | - | -           |
| XORW | eam,A    | 2+ | 5+(a) | 0  | 2 x (c) | word (eam) < (eam) xor (A) | -      | -      | - | - | - | * | * | R | - | *           |
| NOTW | А        | 1  | 2     | 0  | 0       | word (A) < not (A)         | -      | -      | - | - | - | * | * | R | - | -           |
| NOTW | ear      | 2  | 3     | 2  | 0       | word (ear) < not (ear)     | -      | -      | - | - | - | * | * | R | - | -           |
| NOTW | eam      | 2+ | 5+(a) | 0  | 2 x (c) | word (eam) < not (eam)     | -      | -      | - | - | - | * | * | R | - | *           |

Table A.8-8 39 Logic 1 Instructions (byte, word)

Note:

See Table A.5-1 and Table A.5-2 for information on (a) to (d) in the table.

et4U.com AND

DataSheet4U.com

600

DataSheet4U.com

|      | Mnemonic | #  | ~     | RG | В   | Operation                | L<br>H | A<br>H | Ι | s | т | Ν | z | v | С | R<br>M<br>W |
|------|----------|----|-------|----|-----|--------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| ANDL | A,ear    | 2  | 6     | 2  | 0   | long (A) < (A) and (ear) | -      | -      | - | - | - | * | * | R | - | -           |
| ANDL | A,eam    | 2+ | 7+(a) | 0  | (d) | long (A) < (A) and (eam) | -      | -      | - | - | - | * | * | R | - | -           |
| ORL  | A,ear    | 2  | 6     | 2  | 0   | long (A) < (A) or (ear)  | -      | -      | - | - | - | * | * | R | - | -           |
| ORL  | A,eam    | 2+ | 7+(a) | 0  | (d) | long (A) < (A) or (eam)  | -      | -      | - | - | - | * | * | R | - | -           |
| XORL | A,ear    | 2  | 6     | 2  | 0   | long (A) < (A) xor (ear) | -      | -      | - | - | - | * | * | R | - | -           |
| XORL | A,eam    | 2+ | 7+(a) | 0  | (d) | long (A) < (A) xor (eam) | -      | -      | - | - | - | * | * | R | - | -           |

#### Table A.8-9 Six Logic 2 Instructions (long word)

Note: See Table A.5-1 and Table A.5-2 for information on (a) to (d) in the table.

et4U.com

DataSheet4U.com

DataSheet4U.com

|      | Mnemonic | #  | ~     | RG | В       | Operation              | L<br>H | A<br>H | I | s | т | N | z | v | С | R<br>M<br>W |
|------|----------|----|-------|----|---------|------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| NEG  | А        | 1  | 2     | 0  | 0       | byte (A) < 0 - (A)     | Х      | -      | - | - | - | * | * | * | * | -           |
| NEG  | ear      | 2  | 3     | 2  | 0       | byte (ear) < 0 - (ear) | -      | -      | - | - | - | * | * | * | * | -           |
| NEG  | eam      | 2+ | 5+(a) | 0  | 2 x (b) | byte (eam) < 0 - (eam) | -      | -      | - | - | - | * | * | * | * | *           |
| NEGW | А        | 1  | 2     | 0  | 0       | word (A) < 0 - (A)     | -      | -      | - | - | - | * | * | * | * | -           |
| NEGW | ear      | 2  | 3     | 2  | 0       | word (ear) < 0 - (ear) | -      | -      | - | - | - | * | * | * | * | -           |
| NEGW | eam      | 2+ | 5+(a) | 0  | 2 x (c) | word (eam) < 0 - (eam) | -      | -      | - | - | - | * | * | * | * | *           |

#### Table A.8-10 Six Sign Inversion Instructions (byte, word)

Note: See Table A.5-1 and Table A.5-2 for information on (a) to (d) in the table.

#### Table A.8-11 One Normalization Instruction (long word)

| Mnemonic  | # | ~  | RG | В | Operation                                                                                                         | L<br>H | A<br>H | I | S | т | Ν | Z | V | С | R<br>M<br>W |
|-----------|---|----|----|---|-------------------------------------------------------------------------------------------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| NRML A,R0 | 2 | *1 | 1  | 0 | long (A) < Shifts to the position where '1' is set for<br>the first time.<br>byte (RD) < Shift count at that time | -      | -      | - | - | - | - | * | - | - | -           |

et4U.com

\*1: 4 when all accumulators have a value of 0; otherwise, 6+(R0)

DataSheet4U.com

DataSheet4U.com

602

www.DataSheet4U.com

|      | Mnemonic | #  | ~     | RG | В       | Operation                                        | L<br>H | A<br>H | I | s | т | N | z | V | С | R<br>M<br>W |
|------|----------|----|-------|----|---------|--------------------------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| RORC | Α        | 2  | 2     | 0  | 0       | byte (A) < With right rotation carry             | -      | -      | - | - | - | * | * | - | * | -           |
| ROLC | А        | 2  | 2     | 0  | 0       | byte (A) < With left rotation carry              | -      | -      | - | - | - | * | * | - | * | -           |
| RORC | ear      | 2  | 3     | 2  | 0       | byte (ear) < With right rotation carry           | -      | -      | - | - | - | * | * | - | * | -           |
| RORC | eam      | 2+ | 5+(a) | 0  | 2 x (b) | byte (eam) < With right rotation carry           | -      | -      | - | - | - | * | * | - | * | *           |
| ROLC | ear      | 2  | 3     | 2  | 0       | byte (ear) < With left rotation carry            | -      | -      | - | - | - | * | * | - | * | -           |
| ROLC | eam      | 2+ | 5+(a) | 0  | 2 x (b) | byte (eam) < With left rotation carry            | -      | -      | - | - | - | * | * | - | * | *           |
| ASR  | A,R0     | 2  | *1    | 1  | 0       | byte (A) < Arithmetic right shift (A, 1 bit)     | -      | -      | - | - | - | * | * | - | * | -           |
| LSR  | A,R0     | 2  | *1    | 1  | 0       | byte (A) < Logical right barrel shift (A, R0)    | -      | -      | - | - | - | * | * | - | * | -           |
| LSL  | A,R0     | 2  | *1    | 1  | 0       | byte (A) < Logical left barrel shift (A, R0)     | -      | -      | - | - | - | * | * | - | * | -           |
| ASRW | А        | 1  | 2     | 0  | 0       | word (A) < Arithmetic right shift (A, 1 bit)     | -      | -      | 1 | - | * | * | * | - | * | -           |
| LSRW | A/SHRW A | 1  | 2     | 0  | 0       | word (A) < Logical right shift (A, 1 bit)        | -      | -      | - | - | * | R | * | - | * | -           |
| LSLW | A/SHLW A | 1  | 2     | 0  | 0       | word (A) < Logical left shift (A, 1 bit)         | -      | -      | - | - | - | * | * | - | * | -           |
| ASRW | A,R0     | 2  | *1    | 1  | 0       | word (A) < Arithmetic right barrel shift (A, R0) | -      | -      | - | - | * | * | * | - | * | -           |
| LSRW | A,R0     | 2  | *1    | 1  | 0       | word (A) < Logical right barrel shift (A, R0)    | -      | -      | - | - | * | * | * | - | * | -           |
| LSLW | A,R0     | 2  | *1    | 1  | 0       | word (A) < Logical left barrel shift (A, R0)     | -      | -      | - | - | - | * | * | - | * | -           |
| ASRL | A,R0     | 2  | *2    | 1  | 0       | long (A) < Arithmetic right barrel shift (A, R0) | -      | -      | - | - | * | * | * | - | * | -           |
| LSRL | A,R0     | 2  | *2    | 1  | 0       | long (A) < Logical right barrel shift (A, R0)    | -      | -      | - | - | * | * | * | - | * | -           |
| LSLL | A,R0     | 2  | *2    | 1  | 0       | long (A) < Logical left barrel shift (A, R0)     | -      | -      | - | - | - | * | * | - | * | -           |

## Table A.8-12 18 Shift Instructions (byte, word, long word)

et4U.com

\*1: 6 when R0 is 0; otherwise, 5 + (R0) \*2: 6 when R0 is 0; otherwise, 6 + (R0)

DataShee

DataSheet4U.com

Note:

See Table A.5-1 and Table A.5-2 for information on (a) to (d) in the table.

Table A.8-13 31 Branch 1 Instructions

| Mn      | emonic    | #  | ~      | RG | В       | Operation                                       | L<br>H | A<br>H | I | s | т | N | z | V | С | R<br>M<br>W |
|---------|-----------|----|--------|----|---------|-------------------------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| BZ/BEQ  | rel       | 2  | *1     | 0  | 0       | Branch on $(Z) = 1$                             | -      | -      | - | - | - | - | - | - | - | -           |
| BNZ/BNE | rel       | 2  | *1     | 0  | 0       | Branch on $(Z) = 0$                             | -      | -      | - | - | - | - | - | - | - | -           |
| BC/BLO  | rel       | 2  | *1     | 0  | 0       | Branch on $(C) = 1$                             | -      | -      | - | - | - | - | - | - | - | -           |
| BNC/BHS | rel       | 2  | *1     | 0  | 0       | Branch on $(\mathbf{C}) = 0$                    | -      | -      | - | - | - | - | - | - | - | -           |
| BN      | rel       | 2  | *1     | 0  | 0       | Branch on $(N) = 1$                             | -      | -      | - | - | - | - | - | - | - | -           |
| BP      | rel       | 2  | *1     | 0  | 0       | Branch on $(N) = 0$                             | -      | -      | - | - | - | - | - | - | - | -           |
| BV      | rel       | 2  | *1     | 0  | 0       | Branch on $(V) = 1$                             | -      | -      | - | - | - | - | - | - | - | -           |
| BNV     | rel       | 2  | *1     | 0  | 0       | Branch on $(V) = 0$                             | -      | -      | - | - | - | - | - | - | - | -           |
| BT      | rel       | 2  | *1     | 0  | 0       | Branch on $(T) = 1$                             | -      | -      | - | - | - | - | - | - | - | -           |
| BNT     | rel       | 2  | *1     | 0  | 0       | Branch on $(T) = 0$                             | -      | -      | - | - | - | - | - | - | - | -           |
| BLT     | rel       | 2  | *1     | 0  | 0       | Branch on (V) nor (N) = $1$                     | -      | -      | - | - | - | - | - | - | - | -           |
| BGE     | rel       | 2  | *1     | 0  | 0       | Branch on (V) nor (N) $= 0$                     | -      | -      | - | - | - | - | - | - | - | -           |
| BLE     | rel       | 2  | *1     | 0  | 0       | Branch on $((V) \text{ xor } (N))$ or $(Z) = 1$ | -      | -      | - | - | - | - | - | - | - | -           |
| BGT     | rel       | 2  | *1     | 0  | 0       | Branch on $((V) \text{ xor } (N))$ or $(Z) = 0$ | -      | -      | - | - | - | - | - | - | - | -           |
| BLS     | rel       | 2  | *1     | 0  | 0       | Branch on (C) or $(Z) = 1$                      | -      | -      | - | - | - | - | - | - | - | -           |
| BHI     | rel       | 2  | *1     | 0  | 0       | Branch on (C) or $(Z) = 0$                      | -      | -      | - | - | - | - | - | - | - | -           |
| BRA     | rel       | 2  | *1     | 0  | 0       | Unconditional branch                            | -      | -      | - | - | - | - | - | - | - | -           |
| JMP     | @A        | 1  | 2      | 0  | 0       | word (PC) < (A)                                 | -      | -      | - | - | - | - | - | - | - | -           |
| JMP     | addr16    | 3  | 3      | 0  | 0       | word (PC) < addr16                              | -      | -      | - | - | - | - | - | - | - | -           |
| JMP     | @ear      | 2  | 3      | 1  | 0       | word (PC) < (ear)                               | -      | -      | - | - | - | - | - | - | - | -           |
| JMP     | @eam      | 2+ | 4+(a)  | 0  | (c)     | word (PC) < (eam)                               | -      | -      | - | - | - | - | - | - | - | -           |
| JMPP    | @ear *3   | 2  | 5      | 2  | 0       | word (PC) < (ear), (PCB) < (ear+2)              | -      | -      | - | - | - | - | - | - | - | -           |
| JMPP    | @eam *3   | 2+ | 6+(a)  | 0  | (d)     | word (PC) < (eam), (PCB) < (eam+2)              | -      | -      | - | - | - | - | - | - | - | -           |
| JMPP    | addr24    | 4  | 4      | 0  | 0       | word(PC) < ad24 0-15,(PCB) < ad24 16-23         | -      | -      | - | - | - | - | - | - | - | -           |
| CALL    | @ear *4   | 2  | 6      | 1  | (c)     | word (PC) < (ear)                               | -      | -      | - | - | - | - | - | - | - | -           |
| CALL    | addr16 *5 | 2+ | 7+(a)  | 0  | 2 x (c) | word (PC) < (eam)                               | -      | -      | - | - | - | - | - | - | - | -           |
| CALL    | @eam *4   | 3  | 6      | 0  | (c)     | word (PC) < addr16                              | -      | -      | - | - | - | - | - | - | - | -           |
| CALLV   | #vct4 *5  | 1  | 7      | 0  | 2 x (c) | Vector call instruction                         | -      | -      | - | - | - | - | - | - | - | -           |
| CALLP   | @ear *6   | 2  | 10     | 2  | 2 x (c) | word(PC) < (ear)0-15,(PCB) < (ear)16-23         | -      | -      | - | - | - | - | - | - | - | -           |
| CALLP   | @eam *6   | 2+ | 11+(a) | 0  | *2      | word(PC) < (eam)0-15,(PCB) < (eam)16-23         | -      | -      | - | - | - | - | - | - | - | -           |
| CALLP   | addr24 *7 | 4  | 10     | 0  | 2 x (c) | word(PC) < addr0-15, (PCB) < addr16-23          | -      | -      | - | - | - | - | - | - | - | -           |

DataShe

\*1: 4 when a branch is made; otherwise, 3 \*2: 3 x (c) + (b)

et4U.com

\*3: Read (word) of branch destination address \*4: W: Save to stack (word) R: Read (word) of branch destination address

\*5: Save to stack (word)

\*6: W: Save to stack (long word), R: Read (long word) of branch destination address \*7: Save to stack (long word)

Note:

See Table A.5-1 and Table A.5-2 for information on (a) to (d) in the table.

|        | Mnemonic         | #  | ~  | RG | В       | Operation                                                                                                                                    | L<br>H | A<br>H | I | s | т | N | z | v | с | R<br>M<br>W |
|--------|------------------|----|----|----|---------|----------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| CBNE   | A,#imm8,rel      | 3  | *1 | 0  | 0       | Branch on byte (A) not equal to imm8                                                                                                         | -      | -      | - | - | - | * | * | * | * | -           |
| CWBNE  | A,#imm16,rel     | 4  | *1 | 0  | 0       | Branch on word (A) not equal to imm16                                                                                                        | -      | 1      | - | - | - | * | * | * | * | -           |
| CBNE   | ear,#imm8,rel    | 4  | *2 | 1  | 0       | Branch on byte (ear) not equal to imm8                                                                                                       | -      | I.     | - | 1 | - | * | * | * | * | -           |
| CBNE   | eam,#imm8,rel *9 | 4+ | *3 | 0  | (b)     | Branch on byte (eam) not equal to imm8                                                                                                       | -      | -      | - | - | - | * | * | * | * | -           |
| CWBNE  | ear,#imm16,rel   | 5  | *4 | 1  | 0       | Branch on word (ear) not equal to imm16                                                                                                      | -      | -      | - | - | - | * | * | * | * | -           |
| CWBNE  | eam,#imm16,rel*9 | 5+ | *3 | 0  | (c)     | Branch on word (eam) not equal to imm16                                                                                                      | -      | -      | - | - | - | * | * | * | * | -           |
| DBNZ   | ear,rel          | 3  | *5 | 2  | 0       | Branch on byte (ear) = (ear) - 1, (ear)not equal to $0$                                                                                      | -      | -      | - | - | - | * | * | * | - | -           |
| DBNZ   | eam,rel          | 3+ | *6 | 2  | 2 x (b) | Branch on byte $(eam) = (eam) - 1$ , $(eam)$ not equal to 0                                                                                  | -      | -      | - | - | - | * | * | * | - | *           |
| DWBNZ  | ear,rel          | 3  | *5 | 2  | 0       | Branch on word (ear) = (ear) - 1, (ear) not equal to $0$                                                                                     | -      | -      | - | - | - | * | * | * | - | -           |
| DWBNZ  | eam,rel          | 3+ | *6 | 2  | 2 x (c) | Branch on word (eam) = (eam) - 1, (eam) not equal to $0$                                                                                     | -      | -      | - | - | - | * | * | * | - | *           |
| INT    | #vct8            | 2  | 20 | 0  | 8 x (c) | Software interrupt                                                                                                                           | -      | -      | R | S | - | - | - | - | - | -           |
| INT    | addr16           | 3  | 16 | 0  | 6 x (c) | Software interrupt                                                                                                                           | -      | -      | R | s | - | - | - | - | - | -           |
| INTP   | addr24           | 4  | 17 | 0  | 6 x (c) | Software interrupt                                                                                                                           | -      | -      | R | s | - | - | - | - | - | -           |
| INT9   |                  | 1  | 20 | 0  | 8 x (c) | Software interrupt                                                                                                                           | -      | -      | R | s | - | - | - | - | - | -           |
| RETI   |                  | 1  | *8 | 0  | *7      | Return from interrupt                                                                                                                        | -      | -      | * | * | * | * | * | * | * | -           |
| LINK   | #imm8            | 2  | 6  | 0  | (c)     | Saves the old frame pointer in the stack upon entering the function,<br>then sets the new frame pointer and reserves the local pointer area. | -      | -      | - | - | - | - | - | - | - | -           |
| UNLINK |                  | 1  | 5  | 0  | (c)     | Recovers the old frame pointer from the stack upon exiting the<br>function.                                                                  | -      | -      | - | - | - | - | - | - | - | -           |
| RET    | *10              | 1  | 4  | 0  | (c)     | Return from subroutine                                                                                                                       | -      | -      | - | - | - | - | - | - | - | -           |
| RETP   | *11              | 1  | 6  | 0  | (d)     | Return from subroutine                                                                                                                       | -      | -      | - | - | - | - | - | - | - | -           |

DataSheet4U.com

#### Table A.8-14 19 Branch 2 Instructions

et4U.com

\*1: 5 when a branch is made; otherwise, 4

\*2: 13 when a branch is made; otherwise, 12 \*3: 7+(a) when a branch is made; otherwise, 6+(a)

\*4: 8 when a branch is made; otherwise, 7 \*5: 7 when a branch is made; otherwise, 6

\*6: 8+(a) when a branch is made; otherwise, 7+(a)

\*7: 3 x (b) + 2 x (c) when jumping to the next interruption request; 6 x (c) when returning from the current interruption \*8: 15 when jumping to the next interruption request; 17 when returning from the current interruption

\*9: Do not use RWj+ addressing mode with a CBNE or CWBNE instruction.

\*10: Return from stack (word)

\*11: Return from stack (long word)

Note:

See Table A.5-1 and Table A.5-2 for information on (a) to (d) in the table.

| Mr    | nemonic   | #  | ~     | RG | В       | Operation                            | L<br>H | A<br>H | I | s | т | N | z | v | с | R<br>M<br>W |
|-------|-----------|----|-------|----|---------|--------------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| PUSHW | А         | 1  | 4     | 0  | (c)     | word (SP) < (SP) - 2 , ((SP)) < (A)  | -      | -      | - | - | - | - | - | - | - | -           |
| PUSHW | AH        | 1  | 4     | 0  | (c)     | word (SP) < (SP) - 2 , ((SP)) < (AH) | -      | -      | - | - | - | - | - | - | - | -           |
| PUSHW | PS        | 1  | 4     | 0  | (c)     | word (SP) < (SP) - 2 , ((SP)) < (PS) | -      | -      | - | - | - | - | - | - | - | -           |
| PUSHW | rlst      | 2  | *3    | *5 | *4      | (SP) < (SP) - 2n , ((SP)) < (rlst)   | -      | -      | - | - | - | - | - | - | - | -           |
| POPW  | А         | 1  | 3     | 0  | (c)     | word (A) < ((SP)) , (SP) < (SP) + 2  | -      | *      | - | - | - | - | - | - | - | -           |
| POPW  | AH        | 1  | 3     | 0  | (c)     | word (AH) < ((SP)) , (SP) < (SP) + 2 | -      | -      | - | - | - | - | - | - | - | -           |
| POPW  | PS        | 1  | 4     | 0  | (c)     | word (PS) < ((SP)) , (SP) < (SP) + 2 | -      | -      | * | * | * | * | * | * | * | -           |
| POPW  | rlst      | 2  | *2    | *5 | *4      | (rlst) < ((SP)) , (SP) < (SP)        | -      | -      | - | - | - | - | - | - | - | -           |
| JCTX  | @A        | 1  | 14    | 0  | 6 x (c) | Context switch instruction           | -      | -      | * | * | * | * | * | * | * | -           |
| AND   | CCR,#imm8 | 2  | 3     | 0  | 0       | byte (CCR) < (CCR) and imm8          | -      | -      | * | * | * | * | * | * | * | -           |
| OR    | CCR,#imm8 | 2  | 3     | 0  | 0       | byte(CCR) < (CCR) or imm8            | -      | -      | * | * | * | * | * | * | * | -           |
| MOV   | RP,#imm8  | 2  | 2     | 0  | 0       | byte (RP) < imm8                     | -      | -      | - | - | - | - | - | - | - | -           |
| MOV   | ILM,#imm8 | 2  | 2     | 0  | 0       | byte (ILM) < imm8                    | -      | -      | - | - | - | - | - | - | - | -           |
| MOVEA | RWi,ear   | 2  | 3     | 1  | 0       | word (RWi) < ear                     | -      | -      | - | - | - | - | - | - | - | -           |
| MOVEA | RWi,eam   | 2+ | 2+(a) | 1  | 0       | word (RWi) < eam                     | -      | -      | - | - | - | - | - | - | - | -           |
| MOVEA | A,ear     | 2  | 1     | 0  | 0       | word (A) < ear                       | -      | *      | - | - | - | - | - | - | - | -           |
| MOVEA | A,eam     | 2+ | 1+(a) | 0  | 0       | word (A) < eam                       | -      | *      | - | - | - | - | - | - | - | -           |
| ADDSP | #imm8     | 2  | 3     | 0  | 0       | word (SP) < ext(imm8)                | -      | -      | 1 | - | - | - | - | - | - | -           |
| ADDSP | #imm16    | 3  | 3     | 0  | 0       | word (SP) < imm16                    | -      | -      | - | - | - | - | - | - | - | -           |
| MOV   | A,brg1    | 2  | *1    | 0  | 0       | byte (A) < (brg1)                    | Ζ      | *      | - | - | - | * | * | - | - | -           |
| MOV   | brg2,A    | 2  | 1     | 0  | 0       | byte (brg2) < (A)                    | -      | -      | - | - | - | * | * | - | - | -           |
| NOP   |           | 1  | 1     | 0  | 0       | No operation                         | -      | -      | - | - | - | - | - | - | - | -           |
| ADB   |           | 1  | 1     | 0  | 0       | Prefix code for AD space access      | -      | -      | - | - | - | - | - | - | - | -           |
| DTB   |           | 1  | 1     | 0  | 0       | Prefix code for DT space access      | -      | -      | - | - | - | - | - | - | - | -           |
| PCB   |           | 1  | 1     | 0  | 0       | Prefix code for PC space access      | -      | -      | - | - | - | - | - | - | - | -           |
| SPB   |           | 1  | 1     | 0  | 0       | Prefix code for SP space access      | -      | -      | - | - | - | - | - | - | - | -           |
| NCC   |           | 1  | 1     | 0  | 0       | Prefix code for flag no-change       | -      | -      | - | - | - | - | - | - | - | -           |
| CMR   |           | 1  | 1     | 0  | 0       | Prefix code for common register bank | -      | -      | - | - | - | - | - | - | - | -           |

#### Table A.8-15 28 Other Control Instructions (byte, word, long word)

\*1: PCB, ADB, SSB, USB, SPB: 1, DTB, DPR: 2
\*2: 7 + 3 x (POP count) + 2 x (POP last register number), 7 when RLST = 0 (no transfer register)
\*3: 29 + 3 x (PUSH count) - 3 x (PUSH last register number), 8 when RLST = 0 (no transfer register)
\*4: (POP count) x (c) or (PUSH count) x (c)
\*5: (POP count) or (PUSH count)

Note:

et4U.com

See Table A.5-1 and Table A.5-2 for information on (a) to (d) in the table.

DataShe

| Μ    | Inemonic      | # | ~  | RG | В       | Operation                               | L<br>H | A<br>H | I | s | т | N | z | v | с | R<br>M<br>W |
|------|---------------|---|----|----|---------|-----------------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| MOVB | A,dir:bp      | 3 | 5  | 0  | (b)     | byte (A) < ( dir:bp )b                  | Ζ      | *      | - | - | - | * | * | - | - | -           |
| MOVB | A,addr16:bp   | 4 | 5  | 0  | (b)     | byte (A) < ( addr16:bp )b               | Ζ      | *      | - | - | - | * | * | - | - | -           |
| MOVB | A,io:bp       | 3 | 4  | 0  | (b)     | byte (A) < ( io:bp )b                   | Ζ      | *      | - | - | - | * | * | - | - | -           |
| MOVB | dir:bp,A      | 3 | 7  | 0  | 2 x (b) | bit ( dir:bp )b < (A)                   | -      | -      | - | - | - | * | * | - | - | *           |
| MOVB | addr16:bp,A   | 4 | 7  | 0  | 2 x (b) | bit ( addr16:bp )b < (A)                | -      | -      | - | - | - | * | * | - | - | *           |
| MOVB | io:bp,A       | 3 | 6  | 0  | 2 x (b) | bit ( io:bp )b < (A)                    | -      | -      | - | - | - | * | * | - | - | *           |
| SETB | dir:bp        | 3 | 7  | 0  | 2 x (b) | bit ( dir:bp )b < 1                     | -      | -      | - | - | - | - | - | - | - | *           |
| SETB | addr16:bp     | 4 | 7  | 0  | 2 x (b) | bit ( addr16:bp )b < 1                  | -      | -      | - | - | - | - | - | - | - | *           |
| SETB | io:bp         | 3 | 7  | 0  | 2 x (b) | bit ( io:bp )b < 1                      | -      | -      | - | - | - | - | - | - | - | *           |
| CLRB | dir:bp        | 3 | 7  | 0  | 2 x (b) | bit ( dir:bp )b < 0                     | -      | -      | - | - | - | - | - | - | - | *           |
| CLRB | addr16:bp     | 4 | 7  | 0  | 2 x (b) | bit ( addr16:bp )b < 0                  | -      | -      | - | - | - | - | - | - | - | *           |
| CLRB | io:bp         | 3 | 7  | 0  | 2 x (b) | bit ( io:bp )b < 0                      | -      | -      | - | - | - | - | - | - | - | *           |
| BBC  | dir:bp,rel    | 4 | *1 | 0  | (b)     | Branch on (dir:bp) $b = 0$              | -      | -      | - | - | - | - | * | - | - | -           |
| BBC  | addr16:bp,rel | 5 | *1 | 0  | (b)     | Branch on $(addr16:bp) b = 0$           | -      | -      | - | - | - | - | * | - | - | -           |
| BBC  | io:bp,rel     | 4 | *2 | 0  | (b)     | Branch on (io:bp) $b = 0$               | -      | -      | - | - | - | - | * | - | - | -           |
| BBS  | dir:bp,rel    | 4 | *1 | 0  | (b)     | Branch on (dir:bp) $b = 1$              | -      | -      | - | - | - | - | * | - | - | -           |
| BBS  | addr16:bp,rel | 5 | *1 | 0  | (b)     | Branch on $(addr16:bp) b = 1$           | -      | -      | - | - | - | - | * | - | - | -           |
| BBS  | io:bp,rel     | 4 | *1 | 0  | (b)     | Branch on (io:bp) $b = 1$               | -      | -      | - | - | - | - | * | - | - | -           |
| SBBS | addr16:bp,rel | 5 | *3 | 0  | 2 x (b) | Branch on (addr16:bp) $b = 1$ , bit = 1 | -      | -      | - | - | - | - | * | - | - | *           |
| WBTS | io:bp         | 3 | *4 | 0  | *5      | Waits until (io:bp) b = 1               | -      | -      | - | - | - | - | - | - | - | -           |
| WBTC | io:bp         | 3 | *4 | 0  | *5      | Waits until (io:bp) $b = 0$             | -      | -      | - | - | - | - | - | - | - | -           |

#### Table A.8-16 21 Bit Operand Instructions

et4U.com

\*1: 8 when a branch is made; otherwise, 7

\*2: 7 when a branch is made; otherwise, 6

\*3: 10 when the condition is met; otherwise 9

\*4: Undefined count\*5: Until the condition is met( dir:bp )b

Note:

DataSheet4U.com

See Table A.5-1 and Table A.5-2 for information on (a) to (d) in the table.

#### Table A.8-17 Six Accumulator Operation Instructions (byte, word)

| Mnemonic | # | ~ | RG | В | Operation               | L<br>H | A<br>H | I | S | т | N | z | V | с | R<br>M<br>♥ |
|----------|---|---|----|---|-------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| SWAP     | 1 | 3 | 0  | 0 | byte (A)0-7 <> (A)8-15  | -      | -      | - | - | - | - | - | - | - | -           |
| SWAPW    | 1 | 2 | 0  | 0 | word (AH) <> (AL)       | -      | *      | - | - | - | - | - | - | - | -           |
| EXT      | 1 | 1 | 0  | 0 | Byte sign extension     | Х      | -      | - | - | - | * | * | - | - | -           |
| EXTW     | 1 | 2 | 0  | 0 | Word sign extension     | -      | Х      | - | - | - | * | * | - | - | -           |
| ZEXT     | 1 | 1 | 0  | 0 | Byte zero extension     | z      | -      | - | - | - | R | * | - | - | -           |
| ZEXTW    | 1 | 1 | 0  | 0 | Word zero extensionbyte | -      | z      | - | - | - | R | * | - | - | -           |

DataSheet4U.com

www.DataSheet4U.com

R A H L H s Ν V С Μ # RG В Operation Т т z Mnemonic  $\sim$ W MOVS / MOVSI \*2 2 \*5 \*3 byte transfer @AH+ <-- @AL+, counter = RW0 -\_ -\_ MOVSD 2 \*2 \*5 \*3 byte transfer @AH- <-- @AL-, counter = RW0 SCEQ / SCEQI 2 \*1 \*5 \*4 byte search @AH+ <-- AL, counter RW0 \_ SCEQD 2 \*1 \*5 \*4 byte search @AH- <-- AL, counter RW0 \_ FILS / FILSI 2 \*5 \*3 byte fill @AH+ <-- AL, counter RW0 6m+6 \*2 \*5 MOVSW / MOVSWI 2 \*6 word transfer @AH+ <-- @AL+, counter = RW0 \_ \_ -MOVSWD \*2 \*5 2 \*6 word transfer @AH- <-- @AL-, counter = RW0 SCWEQ / SCWEQI 2 \*1 \*5 \*7 word search @AH+ - AL, counter = RW0 \* \* \* \_ \_ SCWEQD 2 \*1 \*5 \*7 word search @AH- - AL, counter = RW0 \* \* \* FILSW / FILSWI 2 \*5 \*6 word fill @AH+ <-- AL, counter = RW0 6m+6

#### Table A.8-18 Ten String Instructions

\*1: 5 when RW0 is 0, 4 + 7 x (RW0) when the counter expires, or 7n + 5 when a match occurs

\*2: 5 when RW0 is 0; otherwise,  $4 + 8 \times (RW0)$ 

\*3: (b) x (RW0) + (b) x (RW0) When the source and destination access different areas, calculate the (b) item individually.

\*4: (b) x n \*5: 2 x (RW0)

et4U.com

\*6: (c) x (RW0) + (c) x (RW0) When the source and destination access different areas, calculate the (c) item individually. \*7: (c) x n

DataShe

DataSheet4U.com

Note:m: RW0 value (counter value), n: Loop countSee Table A.5-1 and Table A.5-2 for information on (a) to (d) in the table.

# A.9 Instruction Map

Each  $F^2MC-16LX$  instruction code consists of 1 or 2 bytes. Therefore, the instruction map consists of multiple pages. Table A.9-2 to Table A.9-21 summarize the  $F^2MC-16LX$  instruction map.

## ■ Structure of Instruction Map





et4U.com

An instruction such as the NOP instruction that ends in one byte is completed within the basic page. An instruction such as the MOVS instruction that requires two bytes recognizes the existence of byte 2 when it references byte 1, and can check the following one byte by referencing the map for byte 2. Figure A.9-2 shows the correspondence between an actual instruction code and instruction map.

www.DataSheet4U.com



#### Figure A.9-2 Correspondence between Actual Instruction Code and Instruction Map

An example of an instruction code is shown in Table A.9-1.

 Table A.9-1 Example of an Instruction Code

| Instruction    | Byte 1<br>(from basic page map) | Byte 2<br>(from extended page map) |
|----------------|---------------------------------|------------------------------------|
| NOP            | 00 + 0 = 00                     | -                                  |
| AND A, #8      | 30 + 4 = 34                     | -                                  |
| MOV A, ADB     | 60 + F = 6F                     | 00 + 0 = 00                        |
| @RW2+d8, #8rel | 70 + 0 = 70                     | F0 + 2 = F2                        |

DataShe

DataSheet4U.com

et4U.com

#### APPENDIX A Instructions

## Table A.9-2 Basic Page Map

| FO | BZ /BEQ     | re       | BNZ/BNE     | re     | BC /BLO     | re       | BNC /BHS    | re       | BN          | re     | ВР          | re     | BV          | re     | BNV         | re       | BT          | re       | BNT    | re     | BLT      | re       | BGE  | re       | BLE           | re          | BGT   | re     | BLS       | e.               | BHI    | re          |
|----|-------------|----------|-------------|--------|-------------|----------|-------------|----------|-------------|--------|-------------|--------|-------------|--------|-------------|----------|-------------|----------|--------|--------|----------|----------|------|----------|---------------|-------------|-------|--------|-----------|------------------|--------|-------------|
| EO | CALLV       | #4       |             |        |             |          |             |          |             |        |             |        |             |        |             |          |             |          |        |        |          |          |      |          |               |             |       |        |           |                  |        | •           |
| DO | MOVN        | A,#4     |             |        |             |          |             |          |             |        |             |        |             |        |             |          |             |          |        |        |          |          |      |          |               |             |       |        |           |                  |        | •           |
| CO | MOVX A,     | @ RWi+d8 |             |        |             |          |             |          |             |        |             |        |             |        |             | •        | MOVW @R     | Wi+d8,A  |        |        |          |          |      |          |               |             |       |        |           |                  |        | •           |
| BO | XVOM        | A,Ri     |             |        |             |          |             |          |             |        |             |        |             |        |             | •        | MOVW A,     | @ RWi+d8 |        |        |          |          |      |          |               |             |       |        |           |                  |        | •           |
| AO | NOV         | Ri,#8    |             |        |             |          |             |          |             |        |             |        |             |        |             | •        | MOVW        | RWi,#16  |        |        |          |          |      |          |               |             |       |        |           |                  |        | •           |
| 06 | MOV         | Ri,A     |             |        |             |          |             |          |             |        |             |        |             |        |             | •        | MOVW        | RWi,A    |        |        |          |          |      |          |               |             |       |        |           |                  |        | •           |
| 80 | MOV         | A,Ri     |             |        |             |          |             |          |             |        |             |        |             |        | _,          | •        | MOVW        | A,RWi    |        |        |          |          |      |          |               |             |       |        |           |                  |        | -           |
| 70 | ea instruc- | tion 1   | ea instruc- | tion 2 | ea instruc- | tion 3   | ea instruc- | tion 4   | ea instruc- |        | ea instruc- | tion 6 | ea instruc- | 1011 / | ea instruc- | tion 8   | ea instruc- | tion 9   | MOVEA  | RWi,ea | MOV      | Ri,ea    | MOVW | RWi,ea   | MOV           | ea,Ri       | MOVW  | ea,RWi | ХСН       |                  | XCHW   | RWi.ea      |
| 60 | BRA         | re       | JMP         | @Α     | JMP         | addr16   | JMPP        | addr24   | CALL        | addr16 | CALLP       | addr24 | RETP        |        | RET         |          | INT         | #vct8    | INT    | addr16 | INTP     | addr24   | RETI |          | Bit operation | instruction |       |        | Character | tion instruction | 2-byte | instruction |
| 50 | MOV         | A,io     | MOV         | io,A   | MOV         | A,addr16 | MOV         | addr16,A | MOV         | io,#8  | MOVX        | A,io   | MOVW        | io,#16 | MOVX        | A,addr16 | MOVW        | A,io     | MOVW   | io,A   | MOVW     | A,addr16 | MOVW | addr16,A | POPW          | A           | POPW  | AH     | POPW      | PS               | POPW   | rist        |
| 40 | MOV         | A,dir    | MOV         | dir,A  | MOV         | A,#8     | MOVX        | A,#8     | MOV         | dir,#8 | MOVX        | A,dir  | MOVW        | A,SP   | MOVW        | SP,A     | MOVW        | A,dir    | MOVW   | dir,A  | MOVW     | A,#16    | MOVL | A,#32    | PUSHW         | A           | PUSHW | AH     | PUSHW     | PS               | PUSHW  | rist        |
| 30 | ADD         | A,#8     | SUB         | A,#8   | SUBC        | A        | CMP         | A,#8     | AND         | A,#8   | OR          | A,#8   | XOR         | A,#8   | NOT         | A        | ADDW        | A,#16    | SUBW   | A,#16  | CWBNE A, | #16,rel  | CMPW | A,#16    | ANDW          | A,#16       | ORW   | A,#16  | XORW      | A,#16            | NOTW   | A           |
| 20 | ADD         | A,dir    | SUB         | A,dir  | ADDC        | A        | CMP         | A        | AND         | CCR,#8 | OR          | CCR,#8 | DIVU        | A      | MULU        | A        | ADDW        |          | SUBW   | A      | CBNE A,  | -        | CMPW | A        | ANDW          | A           | ORW   | A      | XORW      | ∢                | MULUW  | A           |
| 10 | CMR         |          | NCC         |        | SUBDC       | A        | JCTX        | @Α       | EXT         |        | ZEXT        |        | SWAP        |        | ADDSP       | #8       | ADDL        | A,#32    | SUBL   | A,#32  | MOV      | ILM,#8   | CMPL | A,#32    | EXTW          |             | ZEXTW |        | SWAPW     |                  | ADDSP  | #16         |
| 00 | NOP         |          | INT9        |        | ADDDC       | A        | NEG         | A        | PCB         |        | DTB         |        | ADB         |        | SPB         |          | LINK        | #imm8    | UNLINK |        | MOV      | RP,#8    | NEGW |          | LSLW          | A           |       |        | ASRW      | A                | LSRW   | A           |
|    | -<br>-      | ><br>+   |             | +      | -           | 7 +      | -           | Ω<br>+   |             | + 4    |             | ი<br>+ | بو<br>+     | -      | 1           | + /      |             | ∞<br>+   |        | 6<br>+ |          | + +      | í    | т<br>+   |               | ပ<br>+      |       | 0<br>+ |           | ш<br>+           | u<br>H | -           |

DataShe

DataSheet4U.com

et4U.com

| FO |                   |    |            |   |     |    |          | SBBS<br>a ddr16:bp   |        |     |               |                                                                                             |       |        | <b>→</b>      |
|----|-------------------|----|------------|---|-----|----|----------|----------------------|--------|-----|---------------|---------------------------------------------------------------------------------------------|-------|--------|---------------|
| EO | WBTC<br>io:bp     |    |            |   |     |    | <b>→</b> |                      |        |     |               |                                                                                             |       |        |               |
| DO |                   |    |            |   |     |    |          |                      |        |     |               |                                                                                             |       |        |               |
| ŝ  | WBTS<br>io:bp     |    |            |   |     |    | <b>→</b> |                      |        |     |               |                                                                                             |       |        |               |
| BO |                   |    |            |   |     |    |          | BBS ad16<br>:bp,rel  |        |     |               |                                                                                             |       |        | $\rightarrow$ |
| AO | BBS io<br>:bp,rel |    |            |   |     |    | <b>→</b> | BBS<br>dir:bp,rel    |        |     |               | -<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-                                                   |       |        | $\rightarrow$ |
| 06 |                   |    |            |   |     |    |          | BBC ad16<br>:bp,rel  |        |     |               |                                                                                             |       |        | <b>→</b>      |
| 80 | BBC io<br>:bp,rel |    |            |   |     |    | <b>→</b> | BBC<br>dir:bp,rel    |        |     |               |                                                                                             |       |        | <b>→</b>      |
| 70 |                   |    |            |   |     |    |          | SETB<br>a ddr16:bp   |        |     |               | -<br>-<br>-<br>-<br>-<br>-<br>-<br>-                                                        |       |        | <b>→</b>      |
| 60 | SETB<br>io:bp     |    |            |   |     |    | <b>→</b> | SETB<br>dir:bp       |        |     |               | -<br>-<br>-<br>-<br>-<br>-<br>-<br>-                                                        |       |        | <b>→</b>      |
| 50 |                   |    |            |   |     |    |          | CLRB a<br>ddr16:bp   |        |     |               |                                                                                             |       |        | <b>→</b>      |
| 40 | CLRB<br>io:bp     |    |            |   |     |    | <b>→</b> | CLRB<br>dir:bp       |        |     |               |                                                                                             |       |        | <b>→</b>      |
| 30 |                   |    |            |   |     |    |          | MOVB<br>addr16:bp,A  |        |     |               | -<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>- |       |        | <b>→</b>      |
| 20 | MOVB<br>io:bp,A   |    | <br>       |   |     |    | <b>→</b> | MOVB<br>dir:bp,A     |        |     |               | -                                                                                           |       |        | <b>→</b>      |
| 10 |                   |    |            |   |     |    |          | MOVB A,a<br>ddr16:bp |        |     |               | -<br>-<br>-<br>-<br>-<br>-<br>-<br>-                                                        |       |        | <b>→</b>      |
| 00 | MOVB<br>A,io:bp   |    | <br>       |   |     |    | <b>→</b> | MOVB<br>A,dir:bp     |        |     |               |                                                                                             |       |        | <b>→</b>      |
|    | 0<br>+            | -+ | <br>ε<br>+ | + | + 5 | 9+ | × +      | 8+                   | 6<br>+ | × + | <u>ه</u><br>+ | 0<br>+                                                                                      | <br>+ | ш<br>+ | ш<br>+        |

## Table A.9-3 Bit Operation Instruction Map (first byte = $6C_H$ )

et4U.com

www.DataSheet4U.com

DataShe

DataSheet4U.com

| 10 |             | 20   | 30  | 40 | 50 | 60 | 70 | 80           | 06           | AO            | BO            |              | DO | EO            | FO |
|----|-------------|------|-----|----|----|----|----|--------------|--------------|---------------|---------------|--------------|----|---------------|----|
|    |             | /SWI |     |    |    |    |    | SCEQI<br>PCB | SCEQD<br>PCB | SCWEQI<br>PCB | SCWEQD<br>PCB | FILSI<br>PCB |    | FILSWI<br>PCB |    |
|    |             |      |     |    |    |    |    | DTB          |              |               |               |              |    | DTB           |    |
|    |             |      |     |    |    |    |    | ADB          |              |               |               |              |    | ADB           |    |
|    |             |      |     |    |    |    |    | ♦ SPB        |              |               |               |              |    | V SPB         |    |
|    |             |      |     |    |    |    |    |              |              |               |               |              |    |               |    |
|    |             |      |     |    |    |    |    |              |              |               |               |              |    |               |    |
|    | · · · · · · |      |     |    |    |    |    |              |              |               |               |              |    |               |    |
|    |             |      |     |    |    |    |    |              |              |               |               |              |    |               |    |
|    |             |      |     |    |    |    |    |              |              |               |               |              |    |               |    |
|    | :   :       |      | 1   |    |    |    |    |              |              |               |               |              |    |               |    |
|    |             |      |     |    |    |    |    |              |              |               |               |              |    |               |    |
|    |             |      |     |    |    |    |    |              |              |               |               |              |    |               |    |
|    |             |      |     |    |    |    |    |              |              |               |               |              |    |               |    |
|    |             |      |     |    |    |    |    |              |              |               |               |              |    |               |    |
|    | : []        |      | : : |    |    |    |    |              |              |               |               |              |    |               |    |
|    |             |      |     |    |    |    |    |              |              |               |               |              |    |               |    |

## Table A.9-4 Character String Operation Instruction Map (first byte = $6E_H$ )

et4U.com

DataSheet4U.com

www.DataSheet4U.com

|        | 00           | 10            | 20                 | 30                 | 40                                 | 50 | 60        | 20 | 80 | 06 | AO | BO | ő | DO | EO | FO |
|--------|--------------|---------------|--------------------|--------------------|------------------------------------|----|-----------|----|----|----|----|----|---|----|----|----|
| 0<br>+ | MOV<br>A,DTB | MOV<br>bTB,A  | MOVX A,<br>@RL0+d8 | MOV @<br>+d8,A     | RL0 MOV A,<br>@RL0+d8              |    |           |    |    |    |    |    |   |    |    |    |
| +      | MOV<br>A,ADB | MOV<br>ADB,A  |                    |                    |                                    |    |           |    |    |    |    |    |   |    |    |    |
| +2     | MOV<br>A,SSB | MOV<br>SSB,A  | MOVX A,<br>@RL1+d  | MOV @RL1<br>+d8,A  | MOV @RL1 MOV A,<br>8 +d8,A @RL1+d8 |    |           |    |    |    |    |    |   |    |    |    |
| +      | MOV A,USB    | AOV<br>USB,A  |                    |                    |                                    |    |           |    |    |    |    |    |   |    |    |    |
| +      | MOV<br>A,DPR | AOV<br>DPR,A  | MOVX A,<br>@RL2+d8 | MOV<br>+d8,A       | @RL2 MOV A,<br>@RL2+d8             |    |           |    |    |    |    |    |   |    |    |    |
| +5     | MOV<br>A,@A  | IOV<br>@AL,AH |                    |                    |                                    |    |           |    |    |    |    |    |   |    |    |    |
| 9+     | MOV A,PCB    | AOVX<br>A,@A  |                    | MOV<br>+d8,A       | @RL3 MOV A,<br>@RL3+d8             |    |           |    |    |    |    |    |   |    |    |    |
| + 2    | ROLC A       | 12            |                    | -                  |                                    |    |           |    |    |    |    |    |   |    |    |    |
| 8+     |              |               |                    | MOVW @RL<br>0+d8,A | @RL MOVW A,<br>@RL0+d8             |    | MULA      |    |    |    |    |    |   |    |    |    |
| 6<br>+ |              |               |                    |                    |                                    |    | MULW A    |    |    |    |    |    |   |    |    |    |
| 4 H    |              |               |                    | MOVW @RL<br>1+d8,A | V @RL MOVW A,<br>A @RL1+d8         |    | DIVU<br>A |    |    |    |    |    |   |    |    |    |
| B<br>+ |              |               |                    |                    |                                    |    |           |    |    |    |    |    |   |    |    |    |
| 0<br>+ | LSLW<br>A,R0 |               | LSL<br>A,R0        | MOVW<br>2+d8,A     | @RL MOVW A,<br>@RL2+d8             |    |           |    |    |    |    |    |   |    |    |    |
| С<br>+ | MOVW<br>A,@A | NOM<br>@/     | NRM                |                    |                                    |    |           |    |    |    |    |    |   |    |    |    |
| ш<br>+ | ASRW<br>A,R0 | ASRL<br>A,R0  | ASR                | MOVW<br>3+d8,A     | @RL MOVW A,<br>@RL3+d8             |    |           |    |    |    |    |    |   |    |    |    |
| ц<br>+ | LSRW<br>A,R0 | LSRL<br>A,R0  | LSR<br>A,R0        |                    |                                    |    |           |    |    |    |    |    |   |    |    |    |

## Table A.9-5 2-byte Instruction Map (first byte = $6F_H$ )

et4U.com

DataSheet4U.com

614

DataSheet4U.com

DataShe

| www.DataSheet4U.com |
|---------------------|
|---------------------|

#### APPENDIX A Instructions

## Table A.9-6 ea Instruction 1 (first byte = $70_{H}$ )

|          | 00      | 10       | 20      | 30       | 40           | 50        | 60      | 70       | 80      | 06       | AO      | BO       | CO      | DO        | EO         | FO        |
|----------|---------|----------|---------|----------|--------------|-----------|---------|----------|---------|----------|---------|----------|---------|-----------|------------|-----------|
|          |         |          |         |          | CWBNE        | CWBNE     |         |          |         |          |         |          |         |           | CBNE (     | CBNE (    |
|          | ADDL    | ADDL A,  | SUBL    | SUBL A,  | RW0,         | @RW0+d8,  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | R0,        | @RW0+d8,  |
|          | A,RL0   | @RW0+d8  | A,RL0   | @RW0+d8  | #16,rel      | #16,rel   | A, RL0  | @RW0+d8  | A,RL0   | @RW0+d8  | A,RL0   | @RW0+d8  | A,RL0   | @RW0+d8   | #8,rel     | #8,rel    |
|          | ADDL    | ADDL A,  | SUBL    | SUBL     | RW1,         | @RW1+d8,  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | R1,        | @RW1+d8,  |
| -+       | A,RL0   | @RW1+d8  | A, RLO  | @RW1+d8  | #16,rel      | #16,rel   | A,RL0   | @RW1+d8  | A,RL0   | @RW1+d8  | A,RL0   | @RW1+d8  | A,RL0   | @RW1+d8   | #8,rel     | #8,rel    |
|          | ADDL    |          | SUBL    | SUBL     | RW2,         | @ RW2+d8, | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | : XORL A, | R2,        | @ RW2+d8, |
| . + 2    | A,RL1   | @RW2+d8  | A,RL1   | @RW2+d8  | #16,rel      | #16,rel   | A,RL1   | @RW2+d8  | A,RL1   | @RW2+d8  | A,RL1   | @RW2+d8  | A,RL1   | @RW2+d8   | #8,rel     | #8,rel    |
|          | ADDL    |          | SUBL    | SUBL     | RW3,         | @RW3+d8,  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | R3,        | @RW3+d8,  |
| π        | A,RL1   | @RW3+d8  | A,RL1   | @RW3+d8  | #16,rel      | #16,rel   | A,RL1   | @RW3+d8  | A,RL1   | @RW3+d8  | A,RL1   | @RW3+d8  | A,RL1   | @RW3+d8   | #8,rel     | #8,rel    |
|          | ADDL    | ADDL A,  | SUBL    | SUBL     | RW4,         | @RW4+d8,  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | R4,        | @RW4+d8,  |
| + +      | A,RL2   | @RW4+d8  | A,RL2   | @RW4+d8  | #16,rel      | #16,rel   | A,RL2   | @RW4+d8  | A,RL2   | @RW4+d8  | A,RL2   | @RW4+d8  | A,RL2   | @RW4+d8   | #8,rel     | #8,rel    |
|          | ADDL    |          | SUBL    | SUBL     | RW5,         | @RW5+d8,  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | R5,        | @RW5+d8,  |
| ۰<br>+ ۲ | A,RL2   | @RW5+d8  | A,RL2   | @RW5+d8  | #16,rel      | #16,rel   | A,RL2   | @RW5+d8  | A,RL2   | @RW5+d8  | A,RL2   | @RW5+d8  | A,RL2   | @RW5+d8   | #8,rel     | #8,rel    |
|          | ADDL    | ADDL A,  | SUBL    | SUBL A,  | RW6,         | @RW6+d8,  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | R6,        | @RW6+d8,  |
| + 6      | A,RL3   | @RW6+d8  | A,RL3   | @RW6+d8  | #16,rel      | #16,rel   | A,RL3   | @RW6+d8  | A,RL3   | @RW6+d8  | A,RL3   | @RW6+d8  | A,RL3   | @RW6+d8   | #8,rel     | #8,rel    |
|          | ADDL    |          |         |          | RW7,         | @RW7+d8,  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | R7,        | @RW7+d8,  |
| . +      | A,RL3   | @RW7+d8  | A,RL3   | @RW7+d8  | #16,rel      | #16,rel   | A,RL3   | @RW7+d8  | A,RL3   | @RW7+d8  | A,RL3   | @RW7+d8  | A,RL3   | @RW7+d8   | #8,rel     | #8,rel    |
|          | ADDL    | ADDL A,  | SUBL    | SUBL A,  | @RW0,        | @RW0+d16  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | @RW0,      | @RW0+d16  |
| 8<br>+   | A,@RW0  | @RW0+d16 | A,@RW0  | @RW0+d16 | #16,rel      | , #16,rel | A,@RW0  | @RW0+d16 | A,@RW0  | @RW0+d16 | A,@RW0  | @RW0+d16 | A,@RW0  | @RW0+d16  | #8,rel     | ,#8,rel   |
|          | ADDL    | ADDL A,  | SUBL    | SUBL A,  |              | @RW1+d16  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | @RW1,      | @RW1+d16  |
| ი<br>+   | A,@RW1  | @RW1+d16 | A,@RW1  | @RW1+d16 | #16,rel      | , #16,rel | A,@RW1  | @RW1+d16 | A,@RW1  | @RW1+d16 | A,@RW1  | @RW1+d16 | A,@RW1  | @RW1+d16  | #8,rel     | ,#8,rel   |
|          | ADDL    | ADDL A,  | SUBL    |          | @RW2,        | @RW2+d16  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | @RW2,      | @RW2+d16  |
| ₹ +      | A,@RW2  |          | A,@RW2  | @RW2+d16 | #16,rel      | , #16,rel | A,@RW2  | @RW2+d16 | A,@RW2  | @RW2+d16 | A,@RW2  | @RW2+d16 | A,@RW2  | @RW2+d16  | #8,rel     | ,#8,rel   |
|          | ADDL    | ADDL A,  | SUBL    | SUBL A,  | @RW3,        | @RW3+d16  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | @RW3,      | @RW3+d16  |
| + B      | A,@RW3  |          | A,@RW3  | @RW3+d16 | #16,rel      | , #16,rel | A,@RW3  | @RW3+d16 | A,@RW3  | @RW3+d16 | A,@RW3  | @RW3+d16 | A,@RW3  | @RW3+d16  | #8,re      | ,#8,rel   |
| (        | ADDL    | ADDL A,  | SUBL    | SUBL A,  | Use          | @RW0+RW7  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | Use        | @RW0+RW7  |
|          | A,@RW0+ | @RW0+RW7 |         | @RW0+RW7 | prohibited : | , #16,rel | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7  | prohibited | ,#8,rel   |
|          | ADDL    | ADDL A,  | SUBL    | SUBL A,  |              | @RW1+RW7  | CMPL    | :CMPL A, | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | Use        | @RW1+RW7  |
| 2<br>+   | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 | prohibited : | , #16,rel | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7  | prohibited | ,#8,re    |
|          | ADDL    | ADDL A,  | SUBL    | SUBL A,  | Use          | @PC+d16,  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | Use        | @PC+d16,  |
| ш+       | A,@RW2+ | @PC+d16  | A,@RW2+ | @PC+d16  | prohibited   | #16,rel   |         | @PC+d16  | A,@RW2+ | @PC+d16  | A,@RW2+ | @PC+d16  | A,@RW2+ | @PC+d16   | prohibited | #8,rel    |
| .        | ADDL    | ADDL A,  | SUBL    | SUBL A,  | Use          | addr16,   | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | Use        | addr16,   |
| ц<br>+   | A.@RW3+ | addr16   | A,@RW3+ | addr16   | prohibited : | #16,re    | A,@RW3+ | addr16   | A,@RW3+ | addr16   | A,@RW3+ | addr16   | A,@RW3+ | : addr16  | prohibited | #8.re     |

et4U.com

DataSheet4U.com

www.DataSheet4U.com

| www.DataSheet4U.com |
|---------------------|
|---------------------|

## Table A.9-7 ea Instruction 2 (first byte = $71_H$ )

|         | 00              | 10            | 20         | 30         | 40    | 50       | 60    | 70       | 80      | 06       | AO      | BO        | S        | Q         | EO      | Fo         |
|---------|-----------------|---------------|------------|------------|-------|----------|-------|----------|---------|----------|---------|-----------|----------|-----------|---------|------------|
| -       | JMPP JMPP       |               | CALLP      | CALLP      | INCL  | INCL     | DECL  | DECL     | MOVL    | MOVL A,  | MOVL    | MOVL @R   | MOV      | MOV @R    | MOVEA   | MOVEA A,   |
|         | @BLO @(         | @ @RW0+d8     | @RL0       | @ @ RW0+d8 | RLO   | @RW0+d8  | RLO   | @RW0+d8  | A,RL0   | @RW0+d8  | RL0,A   | W0+d8,A   | R0,#8    | W0+d8,#8  | A,RW0   | @RW0+d8    |
|         | MU: AMML        | JMPP          | CALLP      |            | INCL  | INCL     | DECL  |          | MOVL    | MOVL A,  | MOVL    | MOVL @R   | MOV      | MOV @R    | MOVEA   | MOVEA A,   |
| -+      | @BL0 @(         | @ @RW1+d8     | @RL0       | @ @RW1+d8  | RLO   | @RW1+d8  | RLO   | @RW1+d8  | A,RL0   | @RW1+d8  | RL0,A   | W1+d8,A   | R1,#8    | W1+d8,#8  | A,RW1   | @RW1+d8    |
|         |                 | JMPP          | CALLP      |            | INCL  | INCL     | DECL  |          | MOVL    | MOVL A,  | MOVL    | MOVL @R   | MOV      | MOV @R    | MOVEA   | MOVEA A,   |
| + 2     | @RL1 @(         | @ @ RW2+d8    | @RL1       | @ @RW2+d8  | RL1   | @RW2+d8  | RL1   | @RW2+d8  | A,RL1   | @ RW2+d8 | RL1,A   | :W2+d8,A  | R2,#8    | :W2+d8,#8 | A,RW2   | @RW2+d8    |
|         | MU: AMML        |               | CALLP      | CALLP      | INCL  | INCL     | DECL  |          | MOVL    | MOVL A,  | MOVL    | MOVL @R   | MOV      | MOV @R    | MOVEA   | MOVEA A,   |
| + 3     | @RL1 : @(       | 1 : @ @RW3+d8 | @RL1       | @ @ RW3+d8 | RL1   | @RW3+d8  | RL1   | @RW3+d8  | A,RL1   | @RW3+d8  | RL1,A   | W3+d8,A   | R3,#8    | W3+d8,#8  | A,RW3   | @RW3+d8    |
|         | MPF - JM        |               | CALLP      |            | INCL  | INCL     | DECL  | DECL     | Movl    | MOVL A,  |         | MOVL @R   | MOV      | MOV @R    | MOVEA   | :MOVEA A,  |
| + 4     | @RL2 : @@RW4+d8 |               | @RL2       | @ @ RW4+d8 | RL2   | @RW4+d8  | RL2   | @RW4+d8  | A,RL2   | @RW4+d8  | RL2,A   | :W4+d8,A  | R4,#8    | W4+d8,#8  | A,RW4   | @RW4+d8    |
|         | MU: AMP         |               | CALLP      |            | NCL   | INCL     | DECL  |          | MOVL    | MOVL A,  |         | MOVL @R   | MOV      | MOV @R    | MOVEA   | MOVEA A,   |
| + 5     | @RL2 : @(       | @ @RW5+d8     | @RL2       | @ @RW5+d8  | RL2   | @RW5+d8  | RL2   | @RW5+d8  | A,RL2   | @RW5+d8  | RL2,A   | W5+d8,A   | R5,#8    | W5+d8,#8  | A,RW5   | @RW5+d8    |
|         | JMPP JMPP       |               |            |            | INCL  | INCL     | DECL  |          | Movl    | MOVL A,  |         | MOVL @R   | MOV      | MOV @R    | MOVEA   | MOVEA A,   |
| + 6     | @RL3 : @@RW6+d8 | @RW6+d8       | @RL3       | @ @ RW6+d8 | RL3   | @RW6+d8  | RL3   | @RW6+d8  | A,RL3   | @RW6+d8  | RL3,A   | :W6+d8,A  | R6,#8    | :W6+d8,#8 | A,RW6   | @RW6+d8    |
|         | MU: AMP         | JMPP          |            |            | INCL  | INCL     | DECL  | DECL     | MOVL    | MOVL A,  |         | MOVL @R   | MOV      | MOV @R    | MOVEA   | MOVEA A,   |
| + 7     | @BL3 @(         | @ @ RW7+d8    | @RL3       | @ @ RW7+d8 | RL3   | @RW7+d8  | RL3   | @RW7+d8  | A,RL3   | @RW7+d8  | RL3,A   | W7+d8,A   | R7,#8    | W7+d8,#8  | A,RW7   | @RW7+d8    |
|         |                 | JMPP @        | CALLP      | CALLP @    | INCL  | INCL     | DECL  | DECL     | MOVL    | MOVL A,  |         | MOVL @R   | MOV      | MOV @RW   | MOVEA   | MOVEA A,   |
| + 8     | @@RW0 @F        | @RW0+d16      | @ @ RWO    | @RW0+d16   | @RW0  | @RW0+d16 | @RW0  | @RW0+d16 | A,@RW0  | @RW0+d16 | @RW0,A  | W0+d16,A  | @RW0,#8  | 0+d16,#8  | A,@RW0  | @RW0+d16   |
|         | MPP 94ML        | JMPP @        |            | CALLP @    | INCL  | INCL     | DECL  | DECL     | MOVL    | MOVL A,  |         | MOVL @R   | MOV      | MOV @RW   | MOVEA   | MOVEA A,   |
| + 9     | @@RW1 :@F       | @RW1+d16      | @@RW1      | @RW1+d16   | @RW1  | @RW1+d16 | @RW1  | @RW1+d16 | A,@RW1  | @RW1+d16 | @RW1,A  | W1+d16,A  | @RW1,#8  | 1+d16,#8  | A,@RW1  | @RW1+d16   |
|         |                 | JMPP @        | CALLP      | CALLP @    | INCL  | INCL     | DECL  | DECL     | Movl    | MOVL A,  |         | MOVL @R   |          | MOV @RW   | MOVEA   | MOVEA A,   |
| + A     | @@RW2 @F        | @RW2+d16      | @ @ RW2    | @RW2+d16   | @RW2  | @RW2+d16 | @RW2  | @RW2+d16 | A,@RW2  | @RW2+d16 | @RW2,A  | :W2+d16,A | @RW2,#8  | 2+d16,#8  | A,@RW2  | @RW2+d16   |
|         | MPF AMM         | JMPP @        | CALLP      | CALLP @    | INCL  | INCL     | DECL  | DECL     | MOVL    | MOVL A,  | MOVL    | MOVL @R   | MOV      | MOV @RW   | MOVEA   | MOVEA A,   |
| + В     | @@RW3 @F        |               | @ @RW3     | @RW3+d16   | @RW3  | @RW3+d16 | @RW3  | 8+d16    | A,@RW3  | @RW3+d16 | ۲,      | W3+d16,A  | @RW3,#8  | 3+d16,#8  | A,@RW3  | @RW3+d16   |
|         |                 | JMPP @        | CALLP      | CALLP @    | INCL  | INCL     | DECL  | DECL     | MOVL    | MOVL A,  | MOVL    | MOVL @R   | MOV      | MOV @RW   | MOVEA   | MOVEA A,   |
| с<br>+  | @@RW0+ :@F      | @RW0+RW7      | @ @RW0+    | @RW0+RW7   | @RW0+ | @RW0+RW7 | @RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 | @RW0+,A | W0+RW7,A  | @RW0+,#8 | 0+RW7,#8  | A,@RW0+ | @RW0+RW7   |
|         | MU              | JMPP @        | CALLP      | CALLP @    | INCL  | INCL     | DECL  | DECL     | MOVL    | MOVL A,  | MOVL    | MOVL @R   | MOV      | MOV @RW   | MOVEA   | MOVEA A,   |
| □<br>+  | @@RW1+ @F       |               | @@RW1+     | @RW1+RW7   | @RW1+ | @RW1+RW7 | @RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 | @RW1+,A | :W1+RW7,A | @RW1+,#8 | :1+RW7,#8 | A,@RW1+ | @RW1+RW7   |
|         | JMPP AMU        | JMPP          | CALLP      | CALLP      | INCL  | INCL     | DECL  | DECL     | MOVL    | MOVL A,  | MOVL    | MOVL @P   | MOV      | MOV @P    | MOVEA   | MOVEA A,   |
| ш<br>+  | @@RW2+ @@       | @ @PC+d16     | @ @RW2+    | @@PC+d16   | @RW2+ | @PC+d16  | @RW2+ | @PC+d16  | A,@RW2+ | @PC+d16  | @RW2+,A | C+d16,A   | @RW2+,#8 | C+d16,#8  | A,@RW2+ | @PC+d16    |
|         | JMPP - JM       | JMPP          | CALLP      | CALLP      | INCL  | INCL     | DECL  | DECL     | MOVL    | MOVL A,  | MOVL    | MOVL      | MOV      | MOV a     | MOVEA   | : MOVEA A, |
| ц.<br>+ | @ @ RW3+        | @ addr10      | @ @ DM/0 . | 01-1       |       | 0        |       | 0        |         | 01-1-1-  |         | V OFFICE  |          |           |         |            |

DataShe

DataSheet4U.com

et4U.com

| www.DataSheet4U.co | m |
|--------------------|---|
|--------------------|---|

#### **APPENDIX A Instructions**

## Table A.9-8 ea Instruction 3 (first byte = $72_{H}$ )

| E0 F0 | хсн іхсн А, | A,R0 @RW0+d8 | хсн хсн А, | A,R1 : @RW1+d8 | хсн хсн а, | A,R2 : @RW2+d8 | хсн хсн а, | A,R3 : @RW3+d8 | хсн хсн а, | A,R4 @RW4+d8 | хсн хсн А, | A,R5 : @RW5+d8 | хсн хсн А, | A,R6 @RW6+d8 | хсн зхсн а, | A,R7 : @RW7+d8 | хсн хсн а, | A,@RW0 : @RW0+d16 | хсн хсн А, | A,@RW1 @RW1+d16 | хсн хсн а, | A,@RW2 @RW2+d16 | хсн хсн а, | A,@RW3 @RW3+d16 | хсн хсн А, |          | хсн хсн а, | BW1+     | хсн хсн а, | A,@RW2+ @PC+d16 | хсн хсн А, |             |
|-------|-------------|--------------|------------|----------------|------------|----------------|------------|----------------|------------|--------------|------------|----------------|------------|--------------|-------------|----------------|------------|-------------------|------------|-----------------|------------|-----------------|------------|-----------------|------------|----------|------------|----------|------------|-----------------|------------|-------------|
| D0    | MOVX A, XC  | @RW0+d8      |            | @RW1+d8        |            | @RW2+d8        | MOVX A, XO | @RW3+d8        |            | @RW4+d8      | MOVX A, XO | @ RW5+d8       | Movx A, X0 | @RW6+d8      |             | @RW7+d8        | MOVX A, XC | @RW0+d16          | MOVX A, XC |                 | MOVX A, XO |                 | MOVX A, XG |                 | MOVX A, XO | 7WF      | MOVX A, XC | RW7      | MOVX A, XO | @PC+d16         | MOVX A, XO | C Public C  |
| CO    | WOVX :      | A,R0         |            | A,R1           | MOVX       | A,R2           | MOVX       | A,R3           | MOVX       | A,R4         | MOVX       | A,R5           | MOVX       | A,R6         |             | A,R7           |            | A,@RW0            | MOVX       | • • • • •       | MOVX       | •••••           | MOVX       | A,@RW3          | MOVX       |          | MOVX       | N1+<br>  | MOVX       | A,@RW2+         | MOVX       |             |
| BO    | :MOV @R     | W0+d8,A      | MOV @R     | W1+d8,A        | MOV @R     | : W2+d8,A      | MOV @R     | W3+d8,A        | : MOV @R   | W4+d8,A      | MOV @R     | : W5+d8,A      | MOV @R     | : W6+d8,A    | MOV @R      | W7+d8,A        | MOV @R     | W0+d16,A          | MOV @R     | W1+d16,A        | MOV @R     | W2+d16,A        | MOV @R     | W3+d16,A        | MOV @R     | W0+RW7,A | MOV @R     | W1+RW7,A | MOV @P     | C+d16,A         | MOV        |             |
| AO    | NOV         | R0,A         | MOV        | R1,A           | MOV        | R2,A           | MOV        | R3,A           | MOV        | R4,A         | MOV        | R5,A           | MOV        | R6,A         | MOV         | R7,A           | MOV        | @RW0,A            | MOV        | @RW1,A          | MOV        | @RW2,A          | MOV        | @RW3,A          | MOV        | @RW0+,A  | MOV        | @RW1+,A  | MOV        | @RW2+,A         | MOV        | 0 0 0 0 0 0 |
| 90    | MOV A,      | @RW0+d8      | MOV A,     | @RW1+d8        | MOV A,     | @RW2+d8        | MOV A,     | @RW3+d8        | MOV A,     | @RW4+d8      | MOV A,     | @RW5+d8        | MOV A,     | @RW6+d8      | MOV A,      | @RW7+d8        | MOV A,     | @RW0+d16          | MOV A,     | @RW1+d16        | MOV A,     | @RW2+d16        | MOV A,     | @RW3+d16        | MOV A,     | @RW0+RW7 | MOV A,     | @RW1+RW7 | MOV A,     | @PC+d16         | MOV A,     | odde10      |
| 80    | MOV         | A,R0         | MOV        | A,R1           | MOV        | A,R2           | MOV        | A,R3           | MOV        | A,R4         | MOV        | A,R5           | MOV        | A,R6         | MOV         | A,R7           | MOV        | A,@RW0            | MOV        | A,@RW1          | MOV        | A,@RW2          | MOV        | A,@RW3          | MOV        | A,@RW0+  | MOV        | A,@RW1+  | MOV        | A,@RW2+         | MOV        |             |
| 70    | DEC         | @RW0+d8      | DEC        | @RW1+d8        | DEC        | @RW2+d8        | DEC        | @ RW3+d8       | DEC        | @RW4+d8      | DEC        | @RW5+d8        | DEC        | @ RW6+d8     | DEC         | @ RW7+d8       | DEC        | @RW0+d16          | DEC        | @RW1+d16        | DEC        | @RW2+d16        | DEC        | @RW3+d16        | DEC        | @RW0+RW7 | DEC        | @RW1+RW7 | DEC        | @PC+d16         | DEC        | 049940      |
| 60    | DEC         | Ro           | DEC        | R              | DEC        | R2             | DEC        | R3             | DEC        | R4           | DEC        | R5             | DEC        | R6           | DEC         | R7             | DEC        | @RW0              | DEC        | @RW1            | DEC        | @RW2            | DEC        | @RW3            | DEC        | @RW0+    | DEC        | @RW1+    | DEC        | @RW2+           | DEC        | @DWI0.      |
| 50    | INC         | @RW0+d8      | INC        | @RW1+d8        | INC        | @RW2+d8        | INC        | @ RW3+d8       | INC        | @RW4+d8      | INC        | @RW5+d8        | NC         | @ RW6+d8     | INC         | @ RW7+d8       | INC        | @RW0+d16          | INC        | @RW1+d16        | INC        | @RW2+d16        | INC        | @RW3+d16        | INC        | @RW0+RW7 | INC        | @RW1+RW7 | NC         | @PC+d16         | INC        | 049410      |
| 40    | INC         | R0           | NC         | R              | NC         | R2             | INC        | R3             | INC        | R4           | INC        | R5             | INC        | R6           | INC         | R7             | INC        | @RW0              | INC        | @RW1            | NC         | @RW2            | NC         | @RW3            | INC        | @RW0+    | INC        | @RW1+    | INC        | @RW2+           | NC         | . OMD.      |
| 30    | RORC        | @RW0+d8      | RORC       | R1 : @RW1+d8   | RORC       | @RW2+d8        | RORC       | @RW3+d8        | RORC       | @RW4+d8      | RORC       | @RW5+d8        | RORC       | @RW6+d8      | RORC        | @ RW7+d8       | RORC       | @RW0+d16          | RORC       | @RW1+d16        | RORC       | @RW2+d16        | RORC       | @RW3+d16        | RORC       | @RW0+RW7 | RORC       | @RW1+RW7 | RORC       | @PC+d16         | RORC       | 00000       |
| 20    | RORC        | RO           |            | RI             | RORC       | R2             |            | R3             |            | R4           |            | R5             |            | R6           |             | R7             | * • • • •  | @RW0              | * • • • •  | @RW1            | RORC       | @RW2            | RORC       | @RW3            | RORC       |          | RORC       | @RW1+    | RORC       | @RW2+           | RORC       | @DMD        |
| 10    | ROLC        | @RW0+d8      |            | @RW1+d8        | ROLC       | @RW2+d8        | ROLC       | @RW3+d8        | ROLC       | @RW4+d8      | ROLC       | @RW5+d8        |            | @RW6+d8      |             | @RW7+d8        | C ROLC     | @RW0+d16          | ROLC       | 116             | ROLC       | @RW2+d16        | ROLC       | @RW3+d16        | ROLC       |          | ROLC       | @RW1+RW7 | ROLC       | @PC+d16         | ROLC       | C Prime a   |
| 00    | ROLC        | 80           | ROLC       | R1             |            | R2             |            | R3             |            | R4           |            | R5             |            | R6           | ROLC        | R7             | ROLC       | @RW0              | ROLC       | @RW1            | ROLC       | @RW2            | ROLC       |                 | ROLC       |          | ROLC       | @RW1+    | ROLC       | @RW2+           | ROLC       |             |
|       | -           | ⊃<br>+       | -          | -+             |            | + ×            |            | ۳<br>+         | -          | +            |            | ი<br>+         |            | 9<br>+       |             | + 7            |            | ∞<br>+            |            | 6<br>+          |            | 4 +             |            | 8<br>+          |            | ပ<br>+   |            | 0<br>+   |            | ш<br>+          |            | ц.<br>+     |

et4U.com

DataSheet4U.com

www.DataSheet4U.com

## Table A.9-9 ea Instruction 4 (first byte = $73_{H}$ )

|        | 00      | 10         | 50       | 30         | 40       | 50       | 60    | 70       | 80      | 06       | AO        | BO         | S        | DO       | EO      |           |
|--------|---------|------------|----------|------------|----------|----------|-------|----------|---------|----------|-----------|------------|----------|----------|---------|-----------|
| с<br>+ | JMP     | JMP        | CALL     | CALL       | INCW     | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW      | MOVW @R    | MOVW     | MOVW @RW | XCHW    | XCHW A,   |
|        | @RW0    | @ @RW0+d8  | @RW0     | @ @ RW0+d8 | RWO      | @RW0+d8  | RW0   | @RW0+d8  | A,RW0   | @RW0+d8  | RW0,A     | W0+d8,A    | RW0,#16  | 0+d8,#16 | A,RW0   | @RW0+d8   |
| -      | JMP     | JMP        | CALL     | CALL       | INCW     | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW      |            | MOVW     | MOVW @RW | XCHW    | XCHW A,   |
| -<br>+ | @RW1    | @ @RW1+d8  | @RW1     | @@RW1+d8   | RW1      | @RW1+d8  | RW1   | @RW1+d8  | A,RW1   | @RW1+d8  | RW1,A     | W1+d8,A    | RW1,#16  | 1+d8,#16 | A,RW1   | @RW1+d8   |
|        | JMP     |            | CALL     | CALL       | INCW     | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW      |            | MOVW     | MOVW @RW | XCHW    | XCHW A,   |
| + 2    | @RW2    | @ @ RW2+d8 | @RW2     | @ @ RW2+d8 | RW2      | @RW2+d8  | RW2   | @RW2+d8  | A,RW2   | @RW2+d8  | RW2,A     | W2+d8,A    | RW2,#16  | 2+d8,#16 | A,RW2   | @RW2+d8   |
|        | JMP     | JMP        | CALL     | CALL       | INCW     | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW      | MOVW @R    | MOVW     |          | XCHW    | XCHW A,   |
| ÷      | @RW3    | @ @RW3+d8  | @RW3     | @ @RW3+d8  | RW3      | @RW3+d8  | RW3   | @RW3+d8  | A,RW3   | @RW3+d8  | RW3,A     | W3+d8,A    | RW3,#16  | 3+d8,#16 | A,RW3   | @RW3+d8   |
|        | JMP     |            |          | CALL       | INCW     | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW      |            | MOVW     |          | XCHW    | XCHW A,   |
| + 4    | @RW4    | @ @RW4+d8  | @RW4     | @ @ RW4+d8 | RW4      | @RW4+d8  | RW4   | @RW4+d8  | A,RW4   | @RW4+d8  | RW4,A     | W4+d8,A    | RW4,#16  | 4+d8,#16 | A,RW4   | @RW4+d8   |
|        | JMP     |            | CALL     | CALL       | INCW     | INCW     | DECW  | DECW     |         | MOVW A,  | MOVW      |            | MOVW     |          | XCHW    | XCHW A,   |
| 4 2    | @RW5    | @ @RW5+d8  | @RW5     | @ @ RW5+d8 | RW5      | @RW5+d8  | RW5   | @RW5+d8  | A,RW5   | @RW5+d8  | RW5,A     | W5+d8,A    | RW5,#16  | 5+d8,#16 | A,RW5   | @RW5+d8   |
|        | JMP     |            | CALL     | CALL       | INCW     | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW      |            | MOVW     |          | XCHW    | XCHW A,   |
| 9+     | @RW6    | @ @RW6+d8  | @RW6     | @@RW6+d8   | RW6      | @RW6+d8  | RW6   | @RW6+d8  | A,RW6   | @RW6+d8  | RW6,A     | W6+d8,A    | RW6,#16  | 6+d8,#16 | A,RW6   | @RW6+d8   |
|        | JMP     | JMP        | CALL     | CALL       | INCW     | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW      | MOVW @R    | MOVW     | MOVW @RW |         | XCHW A,   |
| + 7    | @RW7    | @ @ RW7+d8 | @RW7     | @@RW7+d8   | RW7      | @RW7+d8  | RW7   |          | A,RW7   | @RW7+d8  | RW7,A     | W7+d8,A    | RW7,#16  | 7+d8,#16 | A,RW7   | @RW7+d8   |
|        | JMP     | @ dwr      | CALL     | CALL @     | INCW     | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW      | MOVW @R    | MOVW     | MOVW@RW0 |         | XCHW A,   |
| + 8    | @ @RW0  | @RW0+d16   | @ @RW0   | @RW0+d16   | @RW0     | @RW0+d16 | @RW0  | @RW0+d16 | A,@RW0  | @RW0+d16 | @RW0,A    | W0+d16,A   | @RW0,#16 | +d16,#16 | A,@RW0  | @RW0+d16  |
|        | JMP     | OMP @      | CALL     | CALL @     | INCW     | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW      | MOVW @R    | MOVW     | MOVW@RW1 | XCHW    | XCHW A,   |
| 6+     | @@RW1   | @RW1+d16   |          | @RW1+d16   | @RW1     | @RW1+d16 | @RW1  | @RW1+d16 | A,@RW1  | @RW1+d16 | @RW1,A    |            | @RW1,#16 | +d16,#16 | A,@RW1  | @RW1+d16  |
| -      | JMP     | JMP @      | CALL     | CALL @     | INCW     | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW      | MOVW @R    | MOVW     | MOVW@RW2 |         | XCHW A,   |
| + A    | @ @RW2  | @RW2+d16   |          |            | @RW2     | @RW2+d16 | @RW2  | @RW2+d16 | A,@RW2  | @RW2+d16 | @RW2,A    | W2+d16,A   | @RW2;#16 | +d16,#16 | A,@RW2  | @RW2+d16  |
|        | JMP     | JMP @      | CALL     | CALL @     | INCW     | INCW     | DECW  | DECW     |         | MOVW A,  | MOVW      | MOVW @R    | MOVW     | MOVW@RW3 | XCHW    | XCHW A,   |
| а<br>+ | @ @RW3  | @RW3+d16   |          | @RW3+d16   | @RW3     | @RW3+d16 | @RW3  | @RW3+d16 | A,@RW3  | @RW3+d16 | @RW3,A    | W3+d16,A   | @RW3,#16 | +d16,#16 | A,@RW3  | @RW3+d16  |
|        | JMP     | JMP @      | CALL     | CALL @     | INCW     | INCW     | DECW  | DECW     | MOW     | MOVW A,  | MOVW      | MOVW @R    | MOVW @   | MOVW@RW0 | XCHW    | XCHW A,   |
| + C    | @ @RW0+ | @RW0+RW7   |          | @RW0+RW7   | @RW0+    | @RW0+RW7 | @RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 | @RW0+,A   | : W0+RW7,A | RW0+,#16 | +RW7,#16 | A,@RW0+ | @RW0+RW7  |
|        | JMP     | JMP @      | CALL     | CALL @     | INCW     | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW      | MOVW @R    | MOVW @   | MOVW@RW1 | XCHW    | XCHW A,   |
| ⊐<br>+ | @ @RW1+ | @RW1+RW7   |          | @RW1+RW7   | @RW1+    | @RW1+RW7 | @RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 | @RW1+,A   | W1+RW7,A   | RW1+,#16 | +RW7,#16 | A,@RW1+ | @RW1+RW7  |
|        | JMP     | JMP        | CALL     | CALL       | INCW     | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW      | MOVW @P    | MOVW @   | MOVW @PC | XCHW    | XCHW A,   |
| ц<br>+ | @ @RW2+ | @@PC+d16   |          | @@PC+d16   | @RW2+    | @PC+d16  | @RW2+ | @PC+d16  | A,@RW2+ | @PC+d16  | @RW2+,A   | C+d16,A    | RW2+,#16 | +d16,#16 | A,@RW2+ | @PC+d16   |
|        | JMP     | JMP        | CALL     | CALL       | INCW     | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW      | MOVW       | MOVW @   | MOVW ad  | XCHW    | : XCHW A, |
| ш<br>+ | @@DW/3  | - @oddr10  | © © DMO. | . @nddr16  | - OWID @ |          | OMUS. | - 4140   |         |          | S DIMO. A |            |          |          |         |           |

DataShe

DataSheet4U.com

et4U.com

| www.DataSheet4U.com |
|---------------------|
|---------------------|

#### APPENDIX A Instructions

## Table A.9-10 ea Instruction 5 (first byte = $74_{H}$ )

| FO | DBNZ @  | RW0+d8,r | DBNZ @  | : RW1+d8,r | DBNZ @  | RW2+d8,r | DBNZ @  | RW3+d8,r | DBNZ @  | RW4+d8,r | DBNZ @  | RW5+d8,r | DBNZ @  | : RW6+d8,r | DBNZ @  | RW7+d8,r | DBNZ @R | W0+d16,r | DBNZ @R | W1+d16,r | DBNZ @R | W2+d16,r | DBNZ @R | W3+d16,r | DBNZ @R | W0+RW7,r | DBNZ @R | : W1+RW7,r | DBNZ @  | PC+d16,r | DBNZ    | addr16.r |
|----|---------|----------|---------|------------|---------|----------|---------|----------|---------|----------|---------|----------|---------|------------|---------|----------|---------|----------|---------|----------|---------|----------|---------|----------|---------|----------|---------|------------|---------|----------|---------|----------|
| EO | DBNZ    | R0,r     | DBNZ    | R1,r       | DBNZ    | R2,r     | DBNZ    | R3,r     | DBNZ    | R4,r     | DBNZ    | R5,r     | DBNZ    | R6,r       | DBNZ    | R7,r     | DBNZ    | @RW0,r   | DBNZ    | @RW1,r   | DBNZ    | @RW2,r   | DBNZ    | @RW3,r   | DBNZ    | @RW0+,r  | DBNZ    | @RW1+,r    | DBNZ    | @RW2+,r  | DBNZ    | @ RW3⊥ r |
| DO | XOR A,  | @RW0+d8  | XOR A,  | @RW1+d8    | XOR A,  | @RW2+d8  | XOR A,  | @RW3+d8  | XOR A,  | @RW4+d8  | XOR A,  | @RW5+d8  | XOR A,  | @RW6+d8    | XOR A,  | @RW7+d8  | XOR A,  | @RW0+d16 | XOR A,  | @RW1+d16 | XOR A,  | @RW2+d16 | XOR A,  | @RW3+d16 | XOR A,  | @RW0+RW7 | XOR A,  | @RW1+RW7   | XOR A,  | @PC+d16  | XOR A,  | addr16   |
| CO | XOR     | A,R0     | XOR     | A,R1       | XOR     | A,R2     | XOR     | A,R3     | XOR     | A,R4     | XOR     | A,R5     | XOR     | A,R6       | XOR     | A,R7     | XOR     | A,@RW0   | XOR     | A,@RW1   | XOR     | A,@RW2   | XOR     | A,@RW3   | XOR     | A,@RW0+  | XOR     | A,@RW1+    | XOR     | A,@RW2+  | XOR     | 4 @RW3+  |
| BO | OR A,   | @RW0+d8  | OR A,   | @RW1+d8    | OR A,   | @RW2+d8  | OR A,   | @RW3+d8  | OR A,   | @RW4+d8  | OR A,   | @RW5+d8  | OR A,   | @ RW6+d8   | OR A,   | @RW7+d8  | OR A,   | @RW0+d16 | OR A,   | @RW1+d16 | OR A,   | @RW2+d16 | OR A,   | က်       | OR A,   | @RW0+RW7 | OR A,   | @RW1+RW7   | OR A,   | @PC+d16  | OR A,   | addr16   |
| AO | OR      | A,R0     | OR      | A,R1       | OR      | A,R2     | OR      | A,R3     | OR      | A,R4     | OR      | A,R5     | OR      | A,R6       | OR      | A,R7     | OR      | A,@RW0   | OR      | A,@RW1   | OR      | A,@RW2   | OR      | A,@RW3   | OR      | A,@RW0+  | OR      | A,@RW1+    | OR      | A,@RW2+  | OR      | ∆ @RW3⊥  |
| 06 | AND A,  | @RW0+d8  | AND A,  | @RW1+d8    | AND A,  | @RW2+d8  | AND A,  | @RW3+d8  | AND A,  | @RW4+d8  | AND A,  | @RW5+d8  | AND A,  | @RW6+d8    | AND A,  |          | AND A,  | @RW0+d16 | AND A,  | @RW1+d16 | AND A,  | @RW2+d16 | AND A,  | @RW3+d16 | AND A,  | @RW0+RW7 | AND A,  | @RW1+RW7   | AND A,  | @PC+d16  | AND A,  | addr16   |
| 80 | AND     | A,R0     | AND     | A,R1       | AND     | A,R2     | AND     | A,R3     | AND     | A,R4     | AND     | A,R5     | AND     | A,R6       | AND     | A,R7     | AND     | A,@RW0   | AND     | A,@RW1   | AND     | A,@RW2   | AND     | A,@RW3   | AND     | A,@RW0+  | AND     | A,@RW1+    | AND     | A,@RW2+  | AND     | A.@RW3+  |
| 70 | CMP A,  | @RW0+d8  | CMP A,  | @RW1+d8    | CMP A,  | @RW2+d8  | CMP A,  | @RW3+d8  | CMP A,  | @RW4+d8  | CMP A,  | @RW5+d8  | CMP A,  | @RW6+d8    | CMP A,  | @RW7+d8  | CMP A,  | @RW0+d16 | CMP A,  | @RW1+d16 | CMP A,  | @RW2+d16 | CMP A,  | @RW3+d16 | CMP A,  | @RW0+RW7 | CMP A,  | @RW1+RW7   | CMP A,  | @PC+d16  | CMP A,  | addr16   |
| 60 | CMP     | A,R0     | CMP     | A,R1       | CMP     | A,R2     | CMP     | A,R3     | CMP     | A,R4     | CMP     | A,R5     | CMP     | A,R6       | CMP     | A,R7     | CMP     | A,@RW0   | CMP     | A,@RW1   | CMP     | A,@RW2   | CMP     | A,@RW3   | CMP     | A,@RW0+  | CMP     | A,@RW1+    | CMP     | A,@RW2+  | CMP     | A @RW3+  |
| 50 | ADDC A, | @RW0+d8  | ADDC A, | @RW1+d8    | ADDC A, | @RW2+d8  | ADDC A, | @RW3+d8  | ADDC A, | @RW4+d8  | ADDC A, | @RW5+d8  | ADDC A, | @ RW6+d8   | ADDC A, | @RW7+d8  | ADDC A, | @RW0+d16 | ADDC A, | @RW1+d16 | ADDC A, | @RW2+d16 | ADDC A, | @RW3+d16 | ADDC A, | @RW0+RW7 | ADDC A, | @RW1+RW7   | ADDC A, | @PC+d16  | ADDC A, | addr16   |
| 40 | ADDC    | A,R0     | ADDC    | A,R1       | ADDC    | A,R2     | ADDC    | A,R3     | ADDC    | A,R4     | ADDC    | A,R5     | ADDC    | A,R6       | ADDC    | A,R7     | ADDC    | A,@RW0   | ADDC    | A,@RW1   | ADDC    | A,@RW2   | ADDC    | A,@RW3   | ADDC    | A,@RW0+  | ADDC    | A,@RW1+    | ADDC    | A,@RW2+  | ADDC    | A @RW3+  |
| 30 | SUB A,  | @RW0+d8  | SUB A,  | @RW1+d8    | SUB A,  | @RW2+d8  | SUB A,  | @RW3+d8  | SUB A,  | @RW4+d8  | SUB A,  | @RW5+d8  | SUB A,  | @RW6+d8    | SUB A,  | @RW7+d8  | SUB A,  | @RW0+d16 | SUB A,  | @RW1+d16 | SUB A,  | @RW2+d16 | SUB A,  | @RW3+d16 | SUB A,  | @RW0+RW7 | SUB A,  | @RW1+RW7   | SUB A,  | @PC+d16  | SUB A,  | addr16   |
| 20 | SUB     | A,R0     | SUB     | A,R1       | SUB     | A,R2     |         | A,R3     |         | A,R4     |         | A,R5     |         | A,R6       | SUB     | A,R7     | SUB     | A,@RW0   | SUB     | A,@RW1   | SUB     | A,@RW2   | SUB     | A,@RW3   | SUB     | A,@RW0+  | SUB     | W1+        | SUB     |          | SUB     | A @RW3+  |
| 10 | ADD A,  | @RW0+d8  | ADD A,  | @RW1+d8    |         | @RW2+d8  | ADD A,  | @RW3+d8  | ADD A,  | @RW4+d8  | ADD A,  | @RW5+d8  | ADD A,  | @RW6+d8    | ADD A,  | @RW7+d8  | ADD A,  | @RW0+d16 |         | @RW1+d16 | ADD A,  | @RW2+d16 | ADD A,  | @RW3+d16 | ADD A,  | @RW0+RW7 | ADD A,  | @RW1+RW7   | ADD A,  | @PC+d16  | ADD A,  | addr16   |
| 00 | ADD     | A,R0     | ADD     | A,R1       | ADD     | A,R2     |         | A,R3     |         | A,R4     |         | A,R5     |         | A,R6       |         | A,R7     |         | A,@RW0   | ADD     | A,@RW1   | ADD     | A,@RW2   | ADD     |          | ADD     | A,@RW0+  | ADD     | A,@RW1+    | ADD     | A,@RW2+  | ADD     | A @RW/3+ |
|    | -       | ><br>+   | -       | -+         |         | х<br>+ х |         | ε<br>+   | -       | + +      |         | ი<br>+   |         | 9+         |         | + 7      |         | ∞<br>+   |         | 6<br>+   |         | + +      |         | в<br>+   |         | ပ<br>+   |         | о<br>+     |         | ш<br>+   |         | ш<br>+   |

et4U.com

DataSheet4U.com

www.DataSheet4U.com

## Table A.9-11 ea Instruction 6 (first byte = $75_{H}$ )

| FO | NOT     | @RW0+d8  | NOT     | @RW1+d8  | NOT     | @RW2+d8  | NOT     | @RW3+d8  | NOT     | @RW4+d8  | NOT     | @RW5+d8  | NOT     | @RW6+d8   | NOT     | @RW7+d8  | NOT     | @RW0+d16 | NOT     | @RW1+d16 | NOT     | @RW2+d16 | NOT     | @RW3+d16  | NOT     | @RW0+RW7 | NOT     | @RW1+RW7 | NOT     | @PC+d16 | NOT     | addr16   |
|----|---------|----------|---------|----------|---------|----------|---------|----------|---------|----------|---------|----------|---------|-----------|---------|----------|---------|----------|---------|----------|---------|----------|---------|-----------|---------|----------|---------|----------|---------|---------|---------|----------|
| EO | NOT     | R0       | NOT     | R1       | NOT     | R2       | NOT     | R3       | NOT     | R4       | NOT     | R5       | NOT     | R6        | NOT     | R7       | NOT     | @RW0     | NOT     | @RW1     | NOT     | @RW2     | NOT     | @RW3      | NOT     | @RW0+    | NOT     | @RW1+    | NOT     | @RW2+   | NOT     | @RW3+    |
| DO | XOR @R  | W0+d8,A  | XOR @R  | W1+d8,A  | XOR @R  | W2+d8,A  | XOR @R  | W3+d8,A  | XOR @R  | W4+d8,A  | XOR @R  | W5+d8,A  | XOR @R  | W6+d8,A   | XOR @R  | W7+d8,A  | XOR @R  | W0+d16,A | XOR @R  | W1+d16,A | XOR @R  | W2+d16,A | XOR @R  | W3+d16,A  | XOR @R  | W0+RW7,A | XOR @R  | W1+RW7,A | XOR @P  | C+d16,A | XOR     | addr16,A |
| CO | XOR     | R0,A     | XOR     | R1,A     | XOR     | R2,A     | XOR     | R3,A     | XOR     | R4,A     | XOR     | R5,A     | XOR     | R6,A      | XOR     | R7,A     | XOR     | @RW0,A   | XOR     | @RW1,A   | XOR     | @RW2,A   | XOR     | @RW3,A    | XOR     | @RW0+,A  | XOR     | @RW1+,A  | XOR     | @RW2+,A | XOR     | @RW3+,A  |
| BO | OR @R   | W0+d8,A  | OR @R   | W1+d8,A  | OR @R   | W2+d8,A  | OR @R   | W3+d8,A  | OR @R   | W4+d8,A  | OR @R   | W5+d8,A  | OR @R   | W6+d8,A   | OR @R   | W7+d8,A  | OR @R   | W0+d16,A | OR @R   | W1+d16,A | OR @R   | W2+d16,A | OR @R   | W3+d16,A  | OR @R   | W0+RW7,A | OR @R   | W1+RW7,A | OR @P   | C+d16,A | OR      | addr16,A |
| AO | OR      | R0,A     | OR      | R1,A     | OR      | R2,A     | OR      | R3,A     | OR      | R4,A     | OR      | R5,A     | OR      | R6,A      | OR      | R7,A     | OR      | @RW0,A   | OR      | @RW1,A   | OR      | @RW2,A   | OR      | @RW3,A    | OR      | @RW0+,A  | OR      | @RW1+,A  | OR      | @RW2+,A | OR      | @RW3+,A  |
| 06 | AND @R  | W0+d8,A  | AND @R  | W1+d8,A  | AND @R  | W2+d8,A  | AND @R  | W3+d8,A  | AND @R  | W4+d8,A  | AND @R  | W5+d8,A  | AND @R  | W6+d8,A   | AND @R  | W7+d8,A  | AND @R  | W0+d16,A | AND @R  | W1+d16,A | AND @R  | W2+d16,A | AND @R  | W3+d16,A  | AND @R  | W0+RW7,A | AND @R  | W1+RW7,A | AND @P  | C+d16,A | AND     | addr16,A |
| 80 | AND     | R0,A     | AND     | R1,A     | AND     | R2,A     | AND     | R3,A     | AND     | R4,A     | AND     | R5,A     | AND     | R6,A      | AND     | R7,A     | AND     | @RW0,A   | AND     | @RW1,A   | AND     | @RW2,A   | AND     | @RW3,A    | AND     | @RW0+,A  | AND     | @RW1+,A  | AND     | @RW2+,A | AND     | @RW3+,A  |
| 70 | NEG     | @ RW0+d8 | NEG     | @ RW1+d8 | NEG     | @RW2+d8  | NEG     | @RW3+d8  | NEG     | @RW4+d8  | NEG     | @RW5+d8  | NEG     | @ RW6+d8  | NEG     | @RW7+d8  | NEG     | @RW0+d16 | NEG     | @RW1+d16 | NEG     | @RW2+d16 | NEG     | @RW3+d16  | NEG     | @RW0+RW7 | NEG     | @RW1+RW7 | NEG     | @PC+d16 | NEG     | addr16   |
| 60 | NEG     | RO       | NEG     | FB       | NEG     | R2       | NEG     | R3       | NEG     | R4       | NEG     | R5       | NEG     | R6        | NEG     | R7       | NEG     | @RW0     | NEG     | @RW1     | NEG     | @RW2     | NEG     | @RW3      | NEG     | @RW0+    | NEG     | @RW1+    | NEG     | @RW2+   | NEG     | @RW3+    |
| 50 | SUBC A, | @ RW0+d8 | SUBC A, | @ RW1+d8 | SUBC A, | @ RW2+d8 | SUBC A, | @ RW3+d8 | SUBC A, | @ RW4+d8 | SUBC A, | @ RW5+d8 | SUBC A, | @ RW6+d8  | SUBC A, | @ RW7+d8 | SUBC A, | @RW0+d16 | SUBC A, | @RW1+d16 | SUBC A, | @RW2+d16 | SUBC A, | @ RW3+d16 | SUBC A, | @RW0+RW7 | SUBC A, | @RW1+RW7 | SUBC A, | @PC+d16 | SUBC A, | addr16   |
| 40 | SUBC    | A,R0     | SUBC    | A,R1     | SUBC    | A,R2     | SUBC    | A,R3     | SUBC    | A,R4     | SUBC    | A,R5     | SUBC    | A,R6      | SUBC    | A,R7     | SUBC    | A,@RW0   | SUBC    | A,@RW1   | SUBC    | A,@RW2   | SUBC    | A,@RW3    | SUBC    | A,@RW0+  | SUBC    | A,@RW1+  | SUBC    | A,@RW2+ | SUBC    | A,@RW3+  |
| 30 | SUB @R  | W0+d8,A  | SUB @R  | W1+d8,A  | SUB @R  | W2+d8,A  | SUB @R  | W3+d8,A  | SUB @R  | W4+d8,A  | SUB @R  | W5+d8,A  | SUB @R  | W6+d8,A   | SUB @R  | W7+d8,A  | SUB @R  | W0+d16,A | SUB @R  | W1+d16,A | SUB @R  | W2+d16,A | SUB @R  | W3+d16,A  | SUB @R  | W0+RW7,A | SUB @R  | W1+RW7,A | SUB @P  | C+d16,A | SUB     | addr16,A |
| 20 | SUB     | R0,A     | SUB     | R1,A     | SUB     | R2,A     |         | R3,A     | SUB     | R4,A     |         | R5,A     |         | R6,A      |         | R7,A     | SUB     | @RW0,A   | SUB     | @RW1,A   | SUB     |          | SUB     | @RW3,A    | SUB     | @RW0+,A  | SUB     | @RW1+,A  | SUB     | @RW2+,A | SUB     | @RW3+,A  |
| 10 | ADD @R  | W0+d8,A  | ADD @R  | W1+d8,A  | ADD @R  | W2+d8,A  | ADD @R  | W3+d8,A  | ADD @R  | W4+d8,A  | ADD @R  | W5+d8,A  | ADD @R  | : W6+d8,A | ADD @R  | W7+d8,A  | ADD @R  | W0+d16,A | ADD @R  |          |         | W2+d16,A | ADD @R  | W3+d16,A  | ADD @R  | W0+RW7,A | ADD @R  | W1+RW7,A | ADD @P  | C+d16,A | ADD     | addr16,A |
| 00 | ADD     | R0,A     | ADD     | R1,A     | ADD     | R2,A     |         | R3,A     |         | R4,A     |         | R5,A     |         | R6,A      |         | R7,A     |         | @RW0,A   |         | @RW1,A   |         |          | ADD     | @RW3,A    | ADD     | @RW0+,A  |         | @RW1+,A  | ADD     | @RW2+,A | ADD     | @RW3+,A  |
|    |         | o +      | -       | -+       |         | 7 + 7    |         | + 3      |         | + 4      |         | + 5      |         | 9+        |         | + 7      |         | +        |         | 6+       |         | +        |         | + B       |         | с<br>+   |         | 0<br>+   |         | ш<br>+  |         | ц.<br>+  |

et4U.com

www.DataSheet4U.com

620

DataSheet4U.com

#### APPENDIX A Instructions

## Table A.9-12 ea Instruction 7 (first byte = $76_{H}$ )

| + 0 ADW<br>ADW<br>+ 1 ADW<br>+ 2 ADW<br>+ 3 ADW<br>+ 3 ARW2 | ADDW A,      |         | ĥ        | 40      | 50       | 60      | 70       | 80      | 06       | AO      | BO       | Ö       | DO       | EO      | ΡO         |
|-------------------------------------------------------------|--------------|---------|----------|---------|----------|---------|----------|---------|----------|---------|----------|---------|----------|---------|------------|
|                                                             |              | SUBW    | SUBW A,  | ADDCW   | ADDCW A, | CMPW    | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @    |
|                                                             | 0 @RW0+d8    | A,RW0   | @RW0+d8  | A,RW0   | @RW0+d8  | A,RW0   | @RW0+d8  | A,RW0   | @RW0+d8  | A,RW0   | @RW0+d8  | A,RW0   | @RW0+d8  | RW0,r   | RW0+d8,r   |
|                                                             | ADDW A,      | SUBW    | SUBW A,  | ADDCW   | ADDCW A, | CMPW :  | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @    |
| 3 5                                                         | 1 @RW1+d8    | A,RW1   | @RW1+d8  | A,RW1   | @RW1+d8  | A,RW1   | @RW1+d8  | A,RW1   | @RW1+d8  | A,RW1   | @RW1+d8  | A,RW1   | @RW1+d8  | RW1,r   | : RW1+d8,r |
| ν σ                                                         | ADDW A,      | SUBW    | SUBW A,  | ADDCW   | ADDCW A, | CMPW    |          |         | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @    |
| 8                                                           | 2 @RW2+d8    | A,RW2   | @RW2+d8  | A,RW2   | @RW2+d8  | A,RW2   | @RW2+d8  | A,RW2   | @RW2+d8  | A,RW2   | @RW2+d8  | A,RW2   | @RW2+d8  | RW2,r   | RW2+d8,r   |
| Σ                                                           | ADDW A,      | SUBW    | SUBW A,  | ADDCW   | ADDCW A, | CMPW    | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @    |
|                                                             | 3 @RW3+d8    | A,RW3   | @ RW3+d8 | A,RW3   | @RW3+d8  | RW3,r   | RW3+d8,r   |
|                                                             |              |         | SUBW A,  | ADDCW   |          | CMPW    |          |         | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @    |
| + 4<br>A,RW4                                                | 4 @RW4+d8    | A,RW4   | @RW4+d8  | A,RW4   | @RW4+d8  | A,RW4   | @RW4+d8  | A,RW4   | @RW4+d8  | A,RW4   | @RW4+d8  | A,RW4   | @RW4+d8  | RW4,r   | RW4+d8,r   |
| L                                                           | ADDW A,      |         | SUBW A,  | ADDCW   | ADDCW A, | CMPW    | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @    |
| + 5 A,RW5                                                   | 5 : @RW5+d8  | A,RW5   | @RW5+d8  | RW5,r   | : RW5+d8,r |
|                                                             | : ADDW A,    |         | SUBW A,  | ADDCW   | ADDCW A, | CMPW    | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @    |
| + 6 A,RW6                                                   | 6 @RW6+d8    | A,RW6   | @RW6-    | A,RW6   | @RW6+d8  | A,RW6   | @ RW6+d8 | A,RW6   | @RW6+d8  | A,RW6   | @RW6+d8  | A,RW6   | @ RW6+d8 | RW6,r   | RW6+d8,r   |
|                                                             |              | SUBW    | SUBW A,  | ADDCW   | ADDCW A, | CMPW    | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @    |
| + 7 A,RW7                                                   |              | A,RW7   | @RW7+d8  | RW7,r   | RW7+d8,r   |
|                                                             | ADDW A,      | SUBW    | SUBW A,  | ADDCW   | ADDCW A, | CMPW    |          | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @R   |
| + 8 A,@RW0                                                  | 0 @RW0+d16   | A,@RW0  | @RW0+d16 | A,@RW0  | @RW0+d16 | A,@RW0  | @RW0+d16 | A,@RW0  | @RW0+d16 | A,@RW0  | @RW0+d16 | A,@RW0  | @RW0+d16 | @RW0,r  | W0+d16,r   |
|                                                             | ADDW A,      | SUBW    | SUBW A,  | ADDCW   | ADDCW A, | CMPW    | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @R   |
| + 9 A,@RW1                                                  | 1 @RW1+d16   | A,@RW1  | @RW1+d16 | A,@RW1  | @RW1+d16 | A,@RW1  | @RW1+d16 | A,@RW1  | @RW1+d16 | A,@RW1  | @RW1+d16 | A,@RW1  | @RW1+d16 | @RW1,r  | : W1+d16,r |
|                                                             | ADDW A,      | SUBW    | SUBW A,  | ADDCW   | ADDCW A, | CMPW    | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @R   |
| + A A,@RW2                                                  |              | A,@RW2  | @RW2+d16 | V2      | _        |         |          |         |          | A,@RW2  | @RW2+d16 | A,@RW2  | @RW2+d16 | @RW2,r  | W2+d16,r   |
|                                                             | ADDW A,      | SUBW    | SUBW A,  | ADDCW   | ADDCW A, | CMPW    | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @R   |
| + B A,@RW3                                                  | @RW3+d16     | A,@RW3  | @RW3+d16 | A,@RW3  | @RW3+d16 | A,@RW3  | @RW3+d16 | A,@RW3  | @RW3+d16 | A,@RW3  | @RW3+d16 | A,@RW3  | @RW3+d16 | @RW3,r  | W3+d16,r   |
|                                                             | : ADDW A,    | SUBW    | SUBW A,  | ADDCW   | ADDCW A, | CMPW    | CMPW A,  |         | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @R   |
| + C A,@RW0+                                                 |              |         | @RW0+RW7 | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 | A,@RW0+ | •        | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 | @RW0+,r | W0+RW7,r   |
|                                                             | ADDW A,      | SUBW    | SUBW A,  | ADDCW   | ADDCW A, | CMPW    | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @R   |
| + D A,@RW1+                                                 |              | A,@RW1+ |          | <br>t   | @RW1+RW7 | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 | @RW1+,r | W1+RW7,r   |
| ADDW                                                        | ADDW A,      | SUBW    | SUBW A,  | ADDCW   | ADDCW A, | CMPW    | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @    |
| + E A,@RW2+                                                 | t+ : @PC+d16 | A,@RW2+ | @PC+d16  | A,@RW2+ | @PC+d16  | A,@RW2+ | @PC+d16  | A,@RW2+ | @PC+d16  | A,@RW2+ | @PC+d16  | A,@RW2+ | @PC+d16  | @RW2+,r | PC+d16,r   |
| ADDW                                                        | ADDW A,      | SUBW    | SUBW A,  | ADDCW   | ADDCW A, | CMPW    | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ      |
| + F A,@RW3+                                                 | 8+ addr16    | A,@RW3+ | addr16   | A,@RW3+ | addr16   | A,@RW3+ | addr16   | A,@RW3+ | addr16   | A,@RW3+ | addr16   | A,@RW3+ | addr16   | @RW3+,r | addr16,r   |

et4U.com

DataSheet4U.com

www.DataSheet4U.com

| www.DataSheet4U.com |
|---------------------|
|---------------------|

## Table A.9-13 ea Instruction 8 (first byte = $77_{H}$ )

|    | -         | ⊃<br>+  |          | +       |          | 4 7       |          | + 3     |         | +       | I<br>-   | + 2       |          | 9+        |          | + 1     |           | 8          |          | 6<br>+     |          | 4 +      |          | + B      |          | с<br>+   |          | 0<br>+     |          | ш<br>+   |          | ш<br>+      |
|----|-----------|---------|----------|---------|----------|-----------|----------|---------|---------|---------|----------|-----------|----------|-----------|----------|---------|-----------|------------|----------|------------|----------|----------|----------|----------|----------|----------|----------|------------|----------|----------|----------|-------------|
| 00 | ADDW      | RW0,A   | ADDW     | RW1,A   | ADDW     | RW2,A     | ADDW     | RW3,A   | ADDW    | RW4,A   | ADDW     | RW5,A     | ADDW     |           | ADDW     | RW7,A   | ADDW      | @RW0,A     | ADDW     | @RW1,A     | ADDW     | @RW2,A   | ADDW     | @RW3,A   | ADDW     | @RW0+,A  | ADDW     |            | ADDW     | @RW2+,A  | ADDW     | @ D/M/2 . A |
| 10 | : ADDW @R | W0+d8,A | ADDW @R  | W1+d8,A | ADDW @R  | W2+d8,A   | ADDW @R  | W3+d8,A | ADDW @R | W4+d8,A | ADDW @R  | : W5+d8,A | ADDW @R  | : W6+d8,A |          | W7+d8,A | ADDW @R   | W0+d16,A   | ADDW @R  | W1+d16,A   | ADDW @R  | W2+d16,A | ADDW @R  | W3+d16,A | ADDW @R  | W0+RW7,A | ADDW @R  | W1+RW7,A   | ADDW @P  | C+d16,A  | ADDW     | A Obubba    |
| 20 | SUBW      | RW0,A   |          | RW1,A   | _        | RW2,A     | SUBW     | RW3,A   | _       | RW4,A   | SUBW     | RW5,A     | SUBW     | RW6,A     | SUBW     | RW7,A   | SUBW      | @RW0,A     | SUBW     | @RW1,A     | SUBW     | @RW2,A   | SUBW     | @RW3,A   | SUBW     | @RW0+,A  | SUBW     | @RW1+,A    | SUBW     |          | SUBW     |             |
| 30 | SUBW @R   | W0+d8,A | SUBW     | W1+d8,A | SUBW     | W2+d8,A   | SUBW     | W3+d8,A | SUBW    | W4+d8,A | SUBW     | : W5+d8,A | SUBW @R  | : W6+d8,A | SUBW @R  | W7+d8,A | SUBW @R   | : W0+d16,A | SUBW @R  | W1+d16,A   | SUBW @R  | W2+d16,A | SUBW @R  | W3+d16,A | SUBW @R  |          | SUBW @R  | W1+RW7,A   | SUBW @P  |          | SUBW     | A Children  |
| 40 | SUBCW     | A,RW0   | SUBCW    | A,RW1   | SUBCW    | A,RW2     | SUBCW    | A,RW3   | SUBCW   | A,RW4   | SUBCW    | A,RW5     | SUBCW    | A,RW6     | SUBCW    | A,RW7   | SUBCW     | A,@RW0     | SUBCW    | A,@RW1     | SUBCW    | A,@RW2   | SUBCW    | A,@RW3   | SUBCW    | A,@RW0+  | SUBCW    | A,@RW1+    | SUBCW    | A,@RW2+  | SUBCW    |             |
| 50 | SUBCW A,  | @RW0+d8 | SUBCW A, | @RW1+d8 | SUBCW A, | @ RW2+d8  | SUBCW A, | @RW3+d8 |         | @RW4+d8 | SUBCW A, | @ RW5+d8  | SUBCW A, | @ RW6+d8  | SUBCW A, | @RW7+d8 | SUBCW A,  | @RW0+d16   | SUBCW A, | @RW1+d16   | SUBCW A, | @RW2+d16 | SUBCW A, | @RW3+d16 | SUBCW A, | @RW0+RW7 | SUBCW A, | @RW1+RW7   | SUBCW A, | @PC+d16  | SUBCW A, |             |
| 60 | NEGW      | RWO     | NEGW     | RW1     | NEGW     | RW2       | NEGW     | RW3     | NEGW    | RW4     | NEGW     | RW5       | NEGW     | RW6       | NEGW     | RW7     | NEGW      | @RW0       | NEGW     | @RW1       | NEGW     | @RW2     | NEGW     | @RW3     | NEGW     | @RW0+    | NEGW     | @RW1+      | NEGW     | @RW2+    | NEGW     | 01110       |
| 70 | NEGW      | @RW0+d8 | NEGW     | @RW1+d8 | NEGW     | @RW2+d8   | NEGW     | @RW3+d8 | NEGW    | @RW4+d8 | NEGW     | @ RW5+d8  | NEGW     | @RW6+d8   | NEGW     | @RW7+d8 | NEGW      | @RW0+d16   | NEGW     | @RW1+d16   | NEGW     | @RW2+d16 | NEGW     | @RW3+d16 | NEGW     | @RW0+RW7 | NEGW     | @RW1+RW7   | NEGW     | @PC+d16  | NEGW     |             |
| 80 | ANDW      | RW0,A   | ANDW     | RW1,A   | ANDW     | RW2,A     | ANDW     | RW3,A   | ANDW    | RW4,A   | ANDW     | RW5,A     | ANDW     | RW6,A     | ANDW     | RW7,A   | ANDW      | @RW0,A     | ANDW     | @RW1,A     | ANDW     | @RW2,A   | ANDW     | @RW3,A   | ANDW     | @RW0+,A  | ANDW     | @RW1+,A    | ANDW     | @RW2+,A  | ANDW     |             |
| 06 | ANDW @R   | W0+d8,A | ANDW @R  | W1+d8,A | ANDW @R  | W2+d8,A   | ANDW @R  | W3+d8,A | ANDW @R | W4+d8,A | ANDW @R  | : W5+d8,A | ANDW @R  | : W6+d8,A | ANDW @R  | W7+d8,A | : ANDW @R | W0+d16,A   | ANDW @R  | W1+d16,A   | ANDW @R  | W2+d16,A | ANDW @R  | W3+d16,A | ANDW @R  | W0+RW7,A | ANDW @R  | W1+RW7,A   | ANDW @P  | C+d16,A  | ANDW     | A Children  |
| AO | ORW       | RW0,A   | ORW      | RW1,A   | ORW      | RW2,A     | ORW      | RW3,A   | ORW     | RW4,A   | ORW      | RW5,A     | ORW      | RW6,A     | ORW      | RW7,A   | ORW       | @RW0,A     | ORW      | @RW1,A     | ORW      | @RW2,A   | ORW      | @RW3,A   | ORW      | @RW0+,A  | ORW      | @RW1+,A    | ORW      | @RW2+,A  | ORW      |             |
| BO | ORW @R    | W0+d8,A | ORW @R   | W1+d8,A | ORW @R   | : W2+d8,A | ORW @R   | W3+d8,A | ORW @R  | W4+d8,A | ORW @R   | W5+d8,A   | ORW @R   | : W6+d8,A | ORW @R   | W7+d8,A | ORW @R    | : W0+d16,A | ORW @R   | W1+d16,A   | ORW @R   | W2+d16,A | ORW @R   | W3+d16,A | ORW @R   | W0+RW7,A | ORW @R   | W1+RW7,A   | ORW @P   | C+d16,A  | ORW      |             |
| CO | XORW      | RW0,A   | XORW     | RW1,A   | XORW     | RW2,A     | XORW     | RW3,A   | XORW    | RW4,A   | XORW     | RW5,A     | XORW     | RW6,A     | XORW     | RW7,A   | XORW      | @RW0,A     | XORW     | @RW1,A     | XORW     | @RW2,A   | XORW     | @RW3,A   | XORW     | @ RW0+,A | XORW     | @RW1+,A    | XORW     | @ RW2+,A | XORW     |             |
| DO | XORW @R   | W0+d8,A | XORW @R  | W1+d8,A | XORW @R  | W2+d8,A   | XORW @R  | W3+d8,A | XORW @R | W4+d8,A | XORW @R  | W5+d8,A   | XORW @R  | W6+d8,A   | XORW @R  | W7+d8,A | XORW @R   | : W0+d16,A | XORW @R  | : W1+d16,A | XORW @R  | W2+d16,A | XORW @R  | W3+d16,A | XORW @R  | W0+RW7,A | XORW @R  | : W1+RW7,A | XORW @P  | C+d16,A  | XORW     |             |
| EO | NOTW      | RWO     | NOTW     | RW1     | NOTW     | RW2       | NOTW     | RW3     | NOTW    | RW4     | NOTW     | RW5       | NOTW     | RW6       | NOTW     | RW7     | NOTW      | @RW0       | NOTW     | @RW1       | NOTW     | @RW2     | NOTW     | @RW3     | NOTW     | @RW0+    | NOTW     | @RW1+      | NOTW     | @RW2+    | NOTW     |             |
| FO | NOTW      | @RW0+d8 | NOTW     | @RW1+d8 | NOTW     | @RW2+d8   | NOTW     | @RW3+d8 | NOTW    | @RW4+d8 | NOTW     | @RW5+d8   | NOTW     | @RW6+d8   | NOTW     | @RW7+d8 | NOTW      | @RW0+d16   | NOTW     | @RW1+d16   | NOTW     | @RW2+d16 | NOTW     | @RW3+d16 | NOTW     | @RW0+RW7 | NOTW     | @RW1+RW7   | NOTW     | @PC+d16  | NOTW     |             |

DataShe

DataSheet4U.com

et4U.com

#### **APPENDIX A Instructions**

#### @ RW0+RW7 @RW1+RW7 addr16 @ RW3+d8 @RW0+d16 @RW1+d16 @RW2+d16 @RW3+d16 Ł Ŕ Ś Ŕ Ą, Ą, Ŕ Ą, Ä Ą. 4 Ŕ Ś ć Å @ RW0+d8 @ RW1+d8 @ RW2+d8 @RW4+d8 @RW5+d8 @RW7+d8 @ RW6+d8 @ PC+d16 Ъ DIVW A,RW5 A,RW6 A,RW0 A.RW2 A,RW3 A,RW4 A,RW7 A,RW1 A,@RW0+ A,@RW2+ A,@RW0 A,@RW3 A,@RW3+ A,@RW1 A,@RW2 A,@RW1+ Ю DIVW NNIO DIVW DIVW DIVW DIV A, @RW1+RW7 @RW0+RW7 DIV A, @RW3+d16 @RW1+d16 DIV A, @RW2+d16 addr16 DIV A, @RW7+d8 @RW4+d8 DIV A, @RW5+d8 @ RW0+d16 @RW0+d8 @ RW3+d8 @PC+d16 Ŕ Ý <del>4</del>88 @ RW2+d8 Ý Ý Ŕ Ŕ Ś Ŕ Ŕ À, Ŕ @ RW6+d8 8 @RW1+ NO ≥IC NO NI Ν NO 20 N N NO N A.R3 A.R0 A, R2 A,R4 A,R5 A,R6 A.R7 A,R1 A,@RW0 A,@RW2 A,@RW3 A,@RW1+ A,@RW2+ A,@RW3+ A,@RW1 A, @RW0+ 8 N N N N N N N N NO N N N N N N No DIVUW A, @RW1+RW7 addr16 DIVUW A, @ RW0+RW7 DIVUW A, DIVUW A, DIVUW A, @RW3+d16 DIVUW A, @ RW0+d16 @RW1+d16 @RW2+d16 Ŕ Ŕ @RW7+d8 Ŕ Ŕ Ą, @RW0+d8 Ä @ RW1+d8 Ą DIVUW A, DIVUW A, @ RW5+d8 DIVUW A, @RW2+d8 @ RW3+d8 @RW4+d8 @ RW6+d8 @PC+d16 DIVUW DIVUW DIVUW DIVUW DIVUW В DIVUW DIVUW DIVUW A,RW6 A,RW3 A,@RW2 A,RW4 A,RW5 A,RW0 A,RW1 A,RW2 A,RW7 A,@RW1 A,@RW1+ A,@RW2+ A,@RW0 A,@RW3 A, @RW0+ A, @RW3+ Ao DIVUW @ RW0+RW7 addr16 @RW1+RW7 @RW0+d16 @ RW2+d16 @RW3+d16 @ RW0+d8 @RW7+d8 @RW1+d16 @RW1+d8 @RW2+d8 @ RW3+d8 @RW4+d8 @ RW5+d8 @ RW6+d8 Ŕ Ŕ Ŕ Ą Ý Ý Ý Ŕ Ý Ŕ Ý Ý Ŕ Ý Ŕ Ý @PC+d16 6 DIVU UVIC UNIC DIVU DIVU A, R3 A,R4 A,R5 A,R6 A.R7 A,R0 A, R2 A.R1 A,@RW0 A,@RW2 A,@RW3 A,@RW1+ A,@RW2+ A,@RW1 A,@RW0+ A, @RW3+ 80 DIVU addr16 @RW0+RW7 @RW1+RW7 MULW A, @RW7+d8 @ RW0+d16 @RW2+d16 Ŕ @RW3+d16 Ą Ŕ Ä Ŕ Ś Ŕ Ŕ Ą Ŕ Ŕ MULW A, Ŕ @RW1+d16 Ą Ä @RW0+d8 @ RW1+d8 @RW2+d8 @ RW3+d8 @RW4+d8 @ RW5+d8 @ RW6+d8 @PC+d16 MULW MULW MULW MULW MULW MULW MULW MULW MULW 20 MULW MULW MULW MULW MULW A RW3 A,RW0 A RW2 A RW4 A RW5 A,RW6 A.RW7 A,RW1 A,@RW0 A,@RW2 A,@RW3 A,@RW0+ A,@RW2+ A,@RW3+ A,@RW1+ A @RW 60 MULW addr16 @RW0+RW7 +RW7 @RW0+d8 @ RW3+d8 +d16 @RW2+d16 @ RW3+d16 @RW0+d16 Ý Ŕ Ŕ Ś Ś Ý ,+d8 Ś Ś Ś Ŕ Ś Ś Ý Ą Ŕ +d8 Ś +d8 @RW5+d8 @ RW6+d8 @ RW4+d8 @PC+d16 50 @RW7-@RW1-@RW1 @ RW2 @RW1 MUL M MUL M MUL A, R2 A,R3 A,R5 A R6 A R0 A,R4 **A.R7** A,@RW0 A,R1 A,@RW2 A,@RW3 A @RW2+ A,@RW1 A,@RW3+ A, @RW0+ A,@RW1+ 6 MUL MUL MUL MUL MUL MUL MUL MUL ٦ MUL MUL MUL ٦ MUL MUL addr16 @RW1+RW7 @RW1+d16 @ RW0+RW7 @ RW0+d16 @ RW2+d16 @ RW3+d16 MULUW A, MULUW A, @RW7+d8 MULUW A, MULUW A, MULUW A. MULUW A, @RW0+d8 @ RW1+d8 @RW2+d8 @ RW3+d8 @RW4+d8 @ RW5+d8 @ RW6+d8 @PC+d16 MULUW 30 A,RW3 A,RW6 A,RW2 A,RW4 A,RW5 A,RW7 A,@RW2 A,RW0 A,RW1 A,@RW0 A,@RW1 A,@RW3 A,@RW2+ A,@RW3+ A,@RW0+ A,@RW1+ MULUW 20 addr16 @ RW0+RW7 @RW1+RW7 @RW1+d8 MULU A, @RW7+d8 @ RW0+d16 @ RW2+d16 @RW3+d16 MULU A, @ RW6+d8 @RW1+d16 Ý @PC+d16 Ŕ Ä @RW0+d8 MULU A, MULU A, @ RW3+d8 @ RW4+d8 MULU A, @ RW5+d8 MULU A, MULU A, MULU A, MULU A, MULU A, @ RW2+d8 MULU A, MULU A, MULU A, 10 MULU MULU MULU A,@RW0 A,R2 A,R5 A,@RW1 A,R3 A,R4 A,R6 A,R7 A,@RW3 A,R0 A,@RW2 A.R1 A,@RW0+ A,@RW2+ A,@RW1-A, @RW3-8 MULU MULU MULU MULU MULU MULU MULU MULU VULU MULU MULU MULU MULU MULU MULU MULU 0 + + N С + 4 ŝ 9 ≻ + ω 6 + ∢ + ш 0 + ∩ + ш ш ++ ++++ $^{+}$

Table A.9-14 ea Instruction 9 (first byte =  $78_{H}$ )

et4U.com

DataSheet4U.com

www.DataSheet4U.com

| www.DataSheet4U.com |
|---------------------|
|---------------------|

## Table A.9-15 MOVEA RWi, ea Instruction (first byte = $79_{H}$ )

|    | -<br>+      | o +      |           | -<br>+   |           | + 2       |           | + 3      |           | + 4      |           | ¢<br>+   |           | + 6      |           | + /      |           | 8          |           | + 9       | -         | + A       |           | + B       |           | + C       |           | 0<br>+     |           | ш<br>+           |           | ц<br>+   |
|----|-------------|----------|-----------|----------|-----------|-----------|-----------|----------|-----------|----------|-----------|----------|-----------|----------|-----------|----------|-----------|------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|------------|-----------|------------------|-----------|----------|
| 00 | MOVEA       | RW0,RW0  | MOVEA     | RW0,RW1  | MOVEA     | RW0,RW2   | MOVEA     | RW0,RW3  | MOVEA     | RW0,RW4  | MOVEA     | RW0,RW5  | MOVEA     | RW0,RW6  | MOVEA     | RW0,RW7  | MOVEA     | RW0,@RW0   | MOVEA     | RW0,@RW1  | MOVEA     | RW0,@RW2  | MOVEA     | RW0,@RW3  | MOVEA R   | W0,@RW0+  | MOVEA R   | W0,@RW1+   | MOVEA R   | W0,@RW2+         | MOVEA R   | 00000000 |
| 10 | MOVEA RW0   | ,@RW0+d8 | MOVEA RW0 | ,@RW1+d8 | MOVEA RW0 | ,@RW2+d8  | MOVEA RW0 | @RW3+d8  | MOVEA RW0 | @RW4+d8  | MOVEA RW0 | @RW5+d8  | MOVEA RW0 | ,@RW6+d8 |           | ,@RW7+d8 | MOVEA RW0 | ,@RW0+d16  | MOVEA RW0 | ,@RW1+d16 | MOVEA RW0 | ,@RW2+d16 | MOVEA RW0 | ,@RW3+d16 | MOVEA RW0 | @RW0+RW7  | MOVEA RW0 | ,@RW1+RW7  | MOVEA RW0 | ,@PC+d16         | MOVEA RW0 |          |
| 20 | MOVEA       | RW1,RW0  | MOVEA     | RW1,RW1  | MOVEA     | RW1,RW2   | MOVEA     | RW1,RW3  | _         | RW1,RW4  | MOVEA     | RW1,RW5  | MOVEA     | RW1,RW6  | MOVEA     | RW1,RW7  | MOVEA     | RW1,@RW0   | MOVEA     | RW1,@RW1  | MOVEA     | RW1,@RW2  | MOVEA     | RW1,@RW3  | MOVEA R   | W1,@RW0+  | MOVEA R   | W1,@RW1+   | MOVEA R   | @PC+d16 W1,@RW2+ | MOVEA R   |          |
| 30 | MOVEA RW1   | ,@RW0+d8 | MOVEA RW1 | ,@RW1+d8 | MOVEA RW1 | @RW2+d8   | MOVEA RW1 | ,@RW3+d8 | MOVEA RW1 | ,@RW4+d8 | MOVEA RW1 | ,@RW5+d8 | MOVEA RW1 | ,@RW6+d8 | MOVEA RW1 | ,@RW7+d8 | MOVEA RW1 | @RW0+d16   | MOVEA RW1 | ,@RW1+d16 | MOVEA RW1 | ,@RW2+d16 | MOVEA RW1 | @RW3+d16  | MOVEA RW1 | ,@RW0+RW7 | MOVEA RW1 | .@RW1+RW7  | MOVEA RW1 | ,@PC+d16         | MOVEA RW1 |          |
| 40 | MOVEA       | RW2,RW0  | MOVEA     | RW2,RW1  | MOVEA     | RW2,RW2   | MOVEA     | RW2,RW3  | MOVEA     | RW2,RW4  | MOVEA     | RW2,RW5  | MOVEA     | RW2,RW6  | MOVEA     | RW2,RW7  | MOVEA     | RW2,@RW0   | MOVEA     | RW2,@RW1  | MOVEA     | RW2,@RW2  | MOVEA     | RW2,@RW3  | MOVEA R   | W2,@RW0+  | MOVEA R   | W2,@RW1+   | MOVEA R   | W2,@RW2+         | MOVEA R   |          |
| 50 | MOVEA RW2   | @RW0+d8  | MOVEA RW2 | ,@RW1+d8 | MOVEA RW2 | ; @RW2+d8 | MOVEA RW2 | ,@RW3+d8 | MOVEA RW2 | ,@RW4+d8 | MOVEA RW2 | ,@RW5+d8 | MOVEA RW2 | ,@RW6+d8 | MOVEA RW2 | ,@RW7+d8 | MOVEA RW2 | ,@RW0+d16  | MOVEA RW2 | ,@RW1+d16 | MOVEA RW2 | ,@RW2+d16 | MOVEA RW2 | ,@RW3+d16 | MOVEA RW2 | @RW0+RW7  | MOVEA RW2 | .@RW1+RW7  | MOVEA RW2 | @PC+d16          | MOVEA RW2 |          |
| 60 | MOVEA       | RW3,RW0  | _         | RW3,RW1  | -         | RW3,RW2   | MOVEA     | RW3,RW3  | _         | RW3,RW4  | _         | RW3,RW5  | MOVEA     | RW3,RW6  | MOVEA     | RW3,RW7  | MOVEA     | RW3,@RW0   | MOVEA     | RW3,@RW1  | MOVEA     | RW3,@RW2  | MOVEA     | RW3,@RW3  | MOVEA R   | W3,@RW0+  | MOVEA R   | W3,@RW1+   | MOVEA R   |                  | MOVEA R   |          |
| 70 | MOVEA RW3   | @RW0+d8  | MOVEA RW3 | ,@RW1+d8 | MOVEA RW3 | ,@RW2+d8  | MOVEA RW3 | @RW3+d8  | MOVEA RW3 | ,@RW4+d8 | MOVEA RW3 | ,@RW5+d8 | MOVEA RW3 | ,@RW6+d8 | MOVEA RW3 | ,@RW7+d8 | MOVEA RW3 | ,@RW0+d16  | MOVEA RW3 | ,@RW1+d16 | MOVEA RW3 | ,@RW2+d16 | MOVEA RW3 | @RW3+d16  | MOVEA RW3 | ,@RW0+RW7 | MOVEA RW3 | @RW1+RW7   | MOVEA RW3 | ,@PC+d16         | MOVEA RW3 |          |
| 80 | MOVEA       | RW4,RW0  | MOVEA     | RW4,RW1  | MOVEA     | RW4,RW2   | MOVEA     | RW4,RW3  | MOVEA     | RW4,RW4  | MOVEA     | RW4,RW5  | MOVEA     | RW4,RW6  | MOVEA     | RW4,RW7  | MOVEA     | RW4,@RW0   | MOVEA     | RW4,@RW1  | MOVEA     | RW4,@RW2  | MOVEA     | RW4,@RW3  | MOVEA R   | W4,@RW0+  | MOVEA R   | W4,@RW1+   | MOVEA R   | W4,@RW2+         | MOVEA R   |          |
| 06 | MOVEA RW4   | @RW0+d8  | MOVEA RW4 | @RW1+d8  | MOVEA RW4 | ,@RW2+d8  | MOVEA RW4 | ,@RW3+d8 | MOVEA RW4 | ,@RW4+d8 | MOVEA RW4 | ,@RW5+d8 | MOVEA RW4 | ,@RW6+d8 | MOVEA RW4 | ,@RW7+d8 | MOVEA RW4 | ; @RW0+d16 | MOVEA RW4 | ,@RW1+d16 | MOVEA RW4 | ,@RW2+d16 | MOVEA RW4 | ,@RW3+d16 | MOVEA RW4 | ,@RW0+RW7 | MOVEA RW4 | ; @RW1+RW7 | MOVEA RW4 | ,@PC+d16         | MOVEA RW4 |          |
| AO | MOVEA       | RW5,RW0  | MOVEA     | RW5,RW1  | MOVEA     | RW5,RW2   | MOVEA     | RW5,RW3  | 2         | RW5,RW4  | MOVEA     | RW5,RW5  | MOVEA     | RW5,RW6  | MOVEA     | RW5,RW7  | MOVEA     | RW5,@RW0   | MOVEA     | RW5,@RW1  | MOVEA     | RW5,@RW2  | MOVEA     | RW5,@RW3  | MOVEA R   | W5,@RW0+  | MOVEA R   | W5,@RW1+   | MOVEA R   | W5,@RW2+         | MOVEA R   |          |
| BO | : MOVEA RW5 | ,@RW0+d8 | MOVEA RW5 | ,@RW1+d8 | MOVEA RW5 | @RW2+d8   | MOVEA RW5 | ,@RW3+d8 | MOVEA RW5 | ,@RW4+d8 | MOVEA RW5 | ,@RW5+d8 | MOVEA RW5 | ,@RW6+d8 | MOVEA RW5 | ,@RW7+d8 | MOVEA RW5 | ,@RW0+d16  | MOVEA RW5 | ,@RW1+d16 | MOVEA RW5 | ,@RW2+d16 | MOVEA RW5 | ,@RW3+d16 | MOVEA RW5 | ,@RW0+RW7 | MOVEA RW5 | @RW1+RW7   | MOVEA RW5 | ,@PC+d16         | MOVEA RW5 |          |
| CO | MOVEA       | RW6,RW0  | MOVEA     | RW6,RW1  | MOVEA     | RW6,RW2   | MOVEA     | RW6,RW3  | 2         | RW6,RW4  | MOVEA     | RW6,RW5  | MOVEA     | RW6,RW6  | MOVEA     | RW6,RW7  | MOVEA     | RW6,@RW0   | MOVEA     | RW6,@RW1  | MOVEA     | RW6,@RW2  | MOVEA     | RW6,@RW3  | MOVEA R   | W6,@RW0+  | MOVEA R   | W6,@RW1+   | MOVEA R   | W6,@RW2+         | MOVEA R   |          |
| DO | MOVEA RW6   | ,@RW0+d8 | MOVEA RW6 | @RW1+d8  | MOVEA RW6 | . @RW2+d8 | MOVEA RW6 | @RW3+d8  | MOVEA RW6 | ,@RW4+d8 | MOVEA RW6 | ,@RW5+d8 | MOVEA RW6 | ,@RW6+d8 | MOVEA RW6 | ,@RW7+d8 | MOVEA RW6 | ,@RW0+d16  | MOVEA RW6 | ,@RW1+d16 | MOVEA RW6 | ,@RW2+d16 | MOVEA RW6 | ,@RW3+d16 | MOVEA RW6 | ,@RW0+RW7 | MOVEA RW6 | @RW1+RW7   | MOVEA RW6 | ,@PC+d16         | MOVEA RW6 |          |
| EO | MOVEA       | RW7,RW0  | ≥         | RW7,RW1  | MOVEA     | RW7,RW2   | MOVEA     | RW7,RW3  | _         | RW7,RW4  | MOVEA     | RW7,RW5  | MOVEA     | RW7,RW6  | MOVEA     | RW7,RW7  | MOVEA     | RW7,@RW0   | MOVEA     | RW7,@RW1  | MOVEA     | RW7,@RW2  | MOVEA     | RW7,@RW3  | MOVEA R   | W7,@RW0+  | MOVEA R   | W7,@RW1+   | MOVEA R   |                  | MOVEA R   |          |
| FO | MOVEA RW7   | ,@RW0+d8 | MOVEA RW7 | ,@RW1+d8 | MOVEA RW7 | .@RW2+d8  | MOVEA RW7 | ,@RW3+d8 | MOVEA RW7 | ,@RW4+d8 | MOVEA RW7 | ,@RW5+d8 | MOVEA RW7 | @RW6+d8  | MOVEA RW7 | ,@RW7+d8 | MOVEA RW7 | ,@RW0+d16  | MOVEA RW7 | ,@RW1+d16 | MOVEA RW7 | ,@RW2+d16 | MOVEA RW7 | ,@RW3+d16 | MOVEA RW7 | ,@RW0+RW7 | MOVEA RW7 | .@RW1+RW7  | MOVEA RW7 | ,@PC+d16         | MOVEA RW7 |          |

DataShe

DataSheet4U.com

et4U.com

624

| +0         0000         00000         000000         0000000         0000000         0000000         0000000         0000000         0000000         00000000         00000000         00000000         00000000         00000000         00000000         00000000         000000000         000000000         0000000000         0000000000000         00000000000000000         000000000000000000000000         000000000000000000000000000000000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         | 00      | 10       | 20      | 30      | 40      | 50       | 60      | 70       | 80      | 06       | AO      | BO       | C       | DO       | EO      | FO       |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------|----------|---------|---------|---------|----------|---------|----------|---------|----------|---------|----------|---------|----------|---------|----------|
| No.         No. <th>c<br/>+</th> <th>MOV</th> <th></th> <th>NOM</th> <th></th>                                                                                                                                                                      | c<br>+  | MOV     |          | MOV     |         | MOV     |          | MOV     |          | MOV     |          | MOV     |          | MOV     |          | NOM     |          |
| Work         Moving         Moving <th>-</th> <th></th> <th>@ RW0+d8</th> <th>R1,R0</th> <th></th> <th>R2,R0</th> <th>@RW0+d8</th> <th>R3,R0</th> <th>@RW0+d8</th> <th>R4,R0</th> <th>@RW0+d8</th> <th>R5,R0</th> <th>@RW0+d8</th> <th>R6,R0</th> <th>@ RW0+d8</th> <th>R7,R0</th> <th>@RW0+d8</th> | -       |         | @ RW0+d8 | R1,R0   |         | R2,R0   | @RW0+d8  | R3,R0   | @RW0+d8  | R4,R0   | @RW0+d8  | R5,R0   | @RW0+d8  | R6,R0   | @ RW0+d8 | R7,R0   | @RW0+d8  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Ŧ       |         | MOV R0,  | MOV     |         |         |          |         |          |         |          |         | MOV R5,  |         | MOV R6,  |         | MOV R7,  |
| MUU         MUU <th>-+</th> <td>R0,R1</td> <td>@RW1+d8</td> <td>R1,R1</td> <td></td> <td>R2,R1</td> <td>@RW1+d8</td> <td>R3,R1</td> <td>@RW1+d8</td> <td>R4,R1</td> <td>@RW1+d8</td> <td>R5,R1</td> <td>@RW1+d8</td> <td>R6,R1</td> <td>@RW1+d8</td> <td>R7,R1</td> <td>@RW1+d8</td>                                                                                                          | -+      | R0,R1   | @RW1+d8  | R1,R1   |         | R2,R1   | @RW1+d8  | R3,R1   | @RW1+d8  | R4,R1   | @RW1+d8  | R5,R1   | @RW1+d8  | R6,R1   | @RW1+d8  | R7,R1   | @RW1+d8  |
| PERP         ENNOLIS         CHURG         ENNOLIS         CHURG         ENNOLIS         CHURG                                                                                                                                                                                                                                                                                                      | -       | MOV     | MOV R0,  | MOV     |         | MOV     |          | MOV     |          | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,  | MOV     | MOV R7,  |
| MUC         MUC <th>z<br/>+</th> <td>R0,R2</td> <td>@RW2+d8</td> <td>R1,R2</td> <td>••••</td> <td>R2,R2</td> <td>@RW2+d8</td> <td>R3,R2</td> <td>@RW2+d8</td> <td>R4,R2</td> <td>@RW2+d8</td> <td>R5,R2</td> <td>@RW2+d8</td> <td>R6,R2</td> <td>@RW2+d8</td> <td>R7,R2</td> <td>@RW2+d8</td>                                                                                                 | z<br>+  | R0,R2   | @RW2+d8  | R1,R2   | ••••    | R2,R2   | @RW2+d8  | R3,R2   | @RW2+d8  | R4,R2   | @RW2+d8  | R5,R2   | @RW2+d8  | R6,R2   | @RW2+d8  | R7,R2   | @RW2+d8  |
| (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1) <th>-</th> <td></td> <td>Ъ,</td> <td>MOV</td> <td></td> <td></td> <td></td> <td></td> <td>MOV R3,</td> <td></td> <td></td> <td></td> <td>MOV R5,</td> <td></td> <td>MOV R6,</td> <td></td> <td></td>                                                                                                                                                                          | -       |         | Ъ,       | MOV     |         |         |          |         | MOV R3,  |         |          |         | MOV R5,  |         | MOV R6,  |         |          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | +<br>+  | R0,R3   | @RW3+d8  | R1,R3   | 8       | R2,R3   | @RW3+d8  | R3,R3   | @ RW3+d8 | R4,R3   | @RW3+d8  | R5,R3   | @RW3+d8  | R6,R3   | @RW3+d8  | R7,R3   | @RW3+d8  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         |         | Ъ,       | MOV     |         |         |          | MOV     |          | MOV     |          | MOV     | MOV R5,  | MOV     |          | MOV     | MOV R7,  |
| MOV         MOV <th>+ 4</th> <td>R0,R4</td> <td></td> <td>R1,R4</td> <td>@RW4+d8</td> <td>R2,R4</td> <td>@RW4+d8</td> <td>R3,R4</td> <td>@RW4+d8</td> <td>R4,R4</td> <td>@RW4+d8</td> <td>R5,R4</td> <td>@RW4+d8</td> <td>R6,R4</td> <td>@RW4+d8</td> <td>R7,R4</td> <td>@RW4+d8</td>                                                                                                         | + 4     | R0,R4   |          | R1,R4   | @RW4+d8 | R2,R4   | @RW4+d8  | R3,R4   | @RW4+d8  | R4,R4   | @RW4+d8  | R5,R4   | @RW4+d8  | R6,R4   | @RW4+d8  | R7,R4   | @RW4+d8  |
| <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | L<br>-  | MOV     |          | MOV     |         | MOV     | MOV R2,  |         | MOV R3,  | MOV     |          | MOV     | MOV R5,  |         |          | MOV     |          |
| NOV         NOV <th>م<br/>+</th> <td>R0,R5</td> <td></td> <td>R1,R5</td> <td>@RW5+d8</td> <td>R2,R5</td> <td>@RW5+d8</td> <td>R3,R5</td> <td>@RW5+d8</td> <td>R4,R5</td> <td>@RW5+d8</td> <td>R5,R5</td> <td>@RW5+d8</td> <td>R6,R5</td> <td>@RW5+d8</td> <td>R7,R5</td> <td>@RW5+d8</td>                                                                                                     | م<br>+  | R0,R5   |          | R1,R5   | @RW5+d8 | R2,R5   | @RW5+d8  | R3,R5   | @RW5+d8  | R4,R5   | @RW5+d8  | R5,R5   | @RW5+d8  | R6,R5   | @RW5+d8  | R7,R5   | @RW5+d8  |
| RD:06         R1:16         entruete         R2:16         entruete         R3:16         entruete         entruete         R5:17                                                                                                                                                                                                                                                      |         | MOV     | MOV R0,  | MOV     | MOV R1, | MOV     |          | MOV     |          | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,  | MOV     | MOV R7,  |
| NOV         NOV <th>9+</th> <td>R0,R6</td> <td>@RW6+d8</td> <td>R1,R6</td> <td>@RW6+d8</td> <td>R2,R6</td> <td>@RW6+d8</td> <td>R3,R6</td> <td>@RW6+d8</td> <td>R4,R6</td> <td>@RW6+d8</td> <td>R5,R6</td> <td>@RW6+d8</td> <td>R6,R6</td> <td>@RW6+d8</td> <td>R7,R6</td> <td>@RW6+d8</td>                                                                                                   | 9+      | R0,R6   | @RW6+d8  | R1,R6   | @RW6+d8 | R2,R6   | @RW6+d8  | R3,R6   | @RW6+d8  | R4,R6   | @RW6+d8  | R5,R6   | @RW6+d8  | R6,R6   | @RW6+d8  | R7,R6   | @RW6+d8  |
| FDCMT         ERMT-445         FLAT         FLAT         ERMT-445         FLAT         ERMT-445         FLAT         FLAT <t< th=""><th></th><td>MOV</td><td>MOV R0,</td><td>MOV</td><td></td><td></td><td></td><td>MOV</td><td>MOV R3,</td><td>MOV</td><td>MOV R4,</td><td></td><td>MOV R5,</td><td></td><td>MOV R6,</td><td></td><td>MOV R7,</td></t<>                                                                           |         | MOV     | MOV R0,  | MOV     |         |         |          | MOV     | MOV R3,  | MOV     | MOV R4,  |         | MOV R5,  |         | MOV R6,  |         | MOV R7,  |
| MOV         MOV <th>× +</th> <td>R0,R7</td> <td></td> <td>R1,R7</td> <td></td> <td>R2,R7</td> <td>@RW7+d8</td> <td>R3,R7</td> <td></td> <td>R4,R7</td> <td>@RW7+d8</td> <td>R5,R7</td> <td>@RW7+d8</td> <td>R6,R7</td> <td>@RW7+d8</td> <td></td> <td>@RW7+d8</td>                                                                                                                            | × +     | R0,R7   |          | R1,R7   |         | R2,R7   | @RW7+d8  | R3,R7   |          | R4,R7   | @RW7+d8  | R5,R7   | @RW7+d8  | R6,R7   | @RW7+d8  |         | @RW7+d8  |
| R0.0 FW0         R1.0 FW0-d16                                                                                                           |         | MOV     |          | MOV     | MOV     |         |          | MOV     |          | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,  |         | MOV R7,  |
| MOV         MOV <th>8</th> <td></td> <td>@RW0+d16</td> <td>R1,@RW0</td> <td></td> <td>R2,@RW0</td> <td>@RW0+d16</td> <td>R3,@RW0</td> <td>@RW0+d16</td> <td>R4,@RW0</td> <td>@RW0+d16</td> <td>R5,@RW0</td> <td></td> <td>R6,@RW0</td> <td>@RW0+d16</td> <td>R7,@RW0</td> <td>@RW0+d16</td>                                                                                                   | 8       |         | @RW0+d16 | R1,@RW0 |         | R2,@RW0 | @RW0+d16 | R3,@RW0 | @RW0+d16 | R4,@RW0 | @RW0+d16 | R5,@RW0 |          | R6,@RW0 | @RW0+d16 | R7,@RW0 | @RW0+d16 |
| R0, @RW1         CRW1+d16         R2, @RW1         CRW1+d16         R2, @RW1         CRW1+d16         R2, @RW1         CRW1+d16         R3, @RW1         GRW1+d16         R3, @RW1         GRW1         R4, @RW1         MOV         <                                                                                                                                                                                                                                                                    |         |         | MOV R0,  | MOV     | MOV     |         |          | MOV     |          | MOV     | MOV R4,  | MOV     |          | MOV     | MOV R6,  | MOV     | MOV R7,  |
| MOV         MOV <th>ი<br/>+</th> <td>R0,@RW1</td> <td>@RW1+d16</td> <td>R1,@RW1</td> <td></td> <td>R2,@RW1</td> <td>@RW1+d16</td> <td>R3,@RW1</td> <td>@RW1+d16</td> <td>R4,@RW1</td> <td>@RW1+d16</td> <td>R5,@RW1</td> <td>@RW1+d16</td> <td>R6,@RW1</td> <td>@RW1+d16</td> <td>R7,@RW1</td> <td>@RW1+d16</td>                                                                              | ი<br>+  | R0,@RW1 | @RW1+d16 | R1,@RW1 |         | R2,@RW1 | @RW1+d16 | R3,@RW1 | @RW1+d16 | R4,@RW1 | @RW1+d16 | R5,@RW1 | @RW1+d16 | R6,@RW1 | @RW1+d16 | R7,@RW1 | @RW1+d16 |
| Ro, @RW2-difb         R1, @RW2-difb         R2, @RW2-difb         R4, @RW2-difb         R4, @RW2-difb         R5, @RW2-difb         R6, @RW2-difb         R7, R1,                                                                                     |         | MOV     | MOV R0,  | MOV     |         | MOV     |          | MOV     |          | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,  | MOV     | MOV R7,  |
| MOV         MOV <th>+</th> <td>R0,@RW2</td> <td></td> <td>R1,@RW2</td> <td></td> <td>R2,@RW2</td> <td>@RW2+d16</td> <td>R3,@RW2</td> <td>@RW2+d16</td> <td>R4,@RW2</td> <td>@RW2+d16</td> <td>R5,@RW2</td> <td>@RW2+d16</td> <td>R6,@RW2</td> <td>@RW2+d16</td> <td>R7,@RW2</td> <td>@RW2+d16</td>                                                                                            | +       | R0,@RW2 |          | R1,@RW2 |         | R2,@RW2 | @RW2+d16 | R3,@RW2 | @RW2+d16 | R4,@RW2 | @RW2+d16 | R5,@RW2 | @RW2+d16 | R6,@RW2 | @RW2+d16 | R7,@RW2 | @RW2+d16 |
| R0,0HW3         6FW3-d16         R1,0FW3         6FW3-d16         R2,0FW3         6FW3-d16         R3,0FW3         86         R3,0FW3         6FW3-d16         R3,0FW3         86         R3,0F         86         R3,0FW3         86         R3,0F         8                                                                                                                                                                                                                                                      |         | MOV     |          | MOV     | MOV     | MOV     |          | MOV     |          | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,  | MOV     | MOV R7,  |
| MOV         MOV <th></th> <td>3W3</td> <td></td> <td>R1,@RW3</td> <td></td> <td>R2,@RW3</td> <td>@RW3+d16</td> <td>@RW3</td> <td>@RW3+d16</td> <td>R4,@RW3</td> <td>@RW3+d16</td> <td>R5,@RW3</td> <td>@RW3+d16</td> <td>R6,@RW3</td> <td>@RW3+d16</td> <td>R7,@RW3</td> <td>@RW3+d16</td>                                                                                                    |         | 3W3     |          | R1,@RW3 |         | R2,@RW3 | @RW3+d16 | @RW3    | @RW3+d16 | R4,@RW3 | @RW3+d16 | R5,@RW3 | @RW3+d16 | R6,@RW3 | @RW3+d16 | R7,@RW3 | @RW3+d16 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         | R0,     |          | MOV R1, | MOV     |         |          | R3,     | MOV R3,  | R4,     | MOV R4,  |         | MOV R5,  |         | MOV R6,  |         | MOV R7,  |
| MOV         ROV         ROV <th>0<br/>+</th> <td></td> <td>@RW0+RW7</td> <td></td> <td></td> <td>@RW0+</td> <td>@RW0+RW7</td> <td></td> <td>@RW0+RW7</td> <td></td> <td>@RW0+RW7</td> <td>@RW0+</td> <td>@RW0+RW7</td> <td>@RW0+</td> <td>@RW0+RW7</td> <td>@RW0+</td> <td>@RW0+RW7</td>                                                                                                                  | 0<br>+  |         | @RW0+RW7 |         |         | @RW0+   | @RW0+RW7 |         | @RW0+RW7 |         | @RW0+RW7 | @RW0+   | @RW0+RW7 | @RW0+   | @RW0+RW7 | @RW0+   | @RW0+RW7 |
| @RW1+         @RW1+RW7         @RW1+         @RW1+RW7         @RW1+RW7         @RW1+RW7         @RW1+RW7         @RW1+         @RW1+         @RW1+         @RW1+         @RW1+         @RW1+RW7         @RW1+         @RW1+RW7         @RW1+         @RW1+<                                                                                                                                                                                                                                                                                 |         | •       | MOV R0,  |         | MOV     |         |          | MOV R3, |          | R4,     | MOV R4.  |         | MOV R5,  | MOV R6, | MOV R6,  | MOV R7, | MOV R7,  |
| Miov         Riov         Riov <th< th=""><th></th><td></td><td>@RW1+RW7</td><td></td><td></td><td>@RW1+</td><td>@RW1+RW7</td><td>@RW1+</td><td>@RW1+RW7</td><td></td><td>@RW1+RW7</td><td>@RW1+</td><td>@RW1+RW7</td><td>@RW1+</td><td>@RW1+RW7</td><td>@RW1+</td><td>@RW1+RW7</td></th<>                                                                                   |         |         | @RW1+RW7 |         |         | @RW1+   | @RW1+RW7 | @RW1+   | @RW1+RW7 |         | @RW1+RW7 | @RW1+   | @RW1+RW7 | @RW1+   | @RW1+RW7 | @RW1+   | @RW1+RW7 |
| @RW2+         @PC+d16         @RW2+         @RW2+         @RW2+ <th></th> <td></td> <td>MOV R0,</td> <td>_</td> <td>MOV</td> <td>MOV R2,</td> <td></td> <td>MOV R3,</td> <td></td> <td>R4,</td> <td>MOV R4</td> <td></td> <td>MOV R5,</td> <td></td> <td>MOV R6,</td> <td></td> <td>MOV R7,</td>                                  |         |         | MOV R0,  | _       | MOV     | MOV R2, |          | MOV R3, |          | R4,     | MOV R4   |         | MOV R5,  |         | MOV R6,  |         | MOV R7,  |
| MOV R0, MOV R0, MOV R1, MOV R1, MOV R2, MOV R2, MOV R3, MOV R3, MOV R4, MOV R5, MOV R5, MOV R6, MOV R6, MOV R7, MOV<br>@RW3+ addr16 @RW3+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         | @RW2+   | @PC+d16  |         | @PC+d16 | @RW2+   | @PC+d16  | @RW2+   | @PC+d16  | @RW2+   | @PC+d16  | @RW2+   | @PC+d16  | @RW2+   | @PC+d16  | @RW2+   | @PC+d16  |
| @RW3+ j addr16 @RW3+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |         | MOV R0, | MOV R0,  |         | MOV R1, |         |          |         |          | R4,     | MOV R4,  | :       | MOV R5,  |         | MOV R6,  |         | MOV R7,  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ц.<br>+ | @RW3+   | addr16   | @RW3+   | addr16  | @RW3+   | addr16   | @RW3+   | addr16   | @RW3+   | addr16   | @RW3+   | addr16   | @RW3+   | addr16   | @RW3+   | addr16   |

## Table A.9-16 MOV Ri, ea Instruction (first byte = $7A_H$ )

DataSheet4U.com

et4U.com

www.DataSheet4U.com

| www.DataSheet4U.com |
|---------------------|
|---------------------|

## Table A.9-17 MOVW RWi, ea Instruction (first byte = $7B_H$ )

|          | 00       | 10                  | 20       | 30        | 40       | 50        | 60       | 70        | 80       | 06        | AO                | BO              | CO       | DO        | EO       | FO        |
|----------|----------|---------------------|----------|-----------|----------|-----------|----------|-----------|----------|-----------|-------------------|-----------------|----------|-----------|----------|-----------|
| -        | MOVW     | MOVW RW0            | MOVW     | MOVW RW1  | MOVW     | MOVW RW2  | MOVW     | MOVW RW3  | MOVW     | MOVW RW4  | MOVW              | MOVW RW5        | MOVW     | MOVW RW6  | MOVW     | MOVW RW7  |
| 0+       | RW0,RW0  | @RW0+d8             | RW1,RW0  | @RW0+d8   | RW2,RW0  | ,@RW0+d8  | RW3,RW0  | @ RW0+d8  | RW4,RW0  | @ RW0+d8  | RW5,RW0           | @RW0+d8         | RW6,RW0  | @RW0+d8   | RW7,RW0  | @RW0+d8   |
| -        | MOVW     | MOVW RW0            |          | MOVW RW1  | MOVW     | MOVW RW2  | ~        | MOVW RW3  | MOVW     |           | MOVW              | MOVW RW5        |          | MOVW RW6  | MOVW     | MOVW RW7  |
| +        | RW0,RW1  | @RW1+d8             | RW1,RW1  | @RW1+d8   | RW2,RW1  | ,@RW1+d8  | RW3,RW1  | @RW1+d8   | RW4,RW1  | ,@RW1+d8  | RW5,RW1           | @RW1+d8         | RW6,RW1  | @RW1+d8   | RW7,RW1  | @RW1+d8   |
|          |          |                     | MOVW     | MOVW RW1  | MOVW     | MOVW RW2  | 2        | MOVW RW3  | MOVW     | MOVW RW4  | MOVW              | MOVW RW5        |          | MOVW RW6  | 2        | MOVW RW7  |
| + 2      | RW0,RW2  | ,@RW2+d8            | RW1,RW2  | ,@RW2+d8  | RW2,RW2  | ,@RW2+d8  | RW3,RW2  | ,@RW2+d8  | RW4,RW2  | ,@RW2+d8  | RW5,RW2           | ,@RW2+d8        | RW6,RW2  | ,@RW2+d8  | RW7,RW2  | , @RW2+d8 |
|          | MOVW     | MOVW RW0            |          | MOVW RW1  | MOVW     | MOVW RW2  | MOVW     | MOVW RW3  | _        | MOVW RW4  | MOVW              | MOVW RW5        |          | MOVW RW6  | MOVW     | MOVW RW7  |
| + 3      | RW0,RW3  | ,@RW3+d8            | RW1,RW3  | ,@RW3+d8  | RW2,RW3  | ,@RW3+d8  | RW3,RW3  | @ RW3+d8  | RW4,RW3  | ,@RW3+d8  | RW5,RW3           | ,@RW3+d8        | RW6,RW3  | ,@RW3+d8  | RW7,RW3  | @RW3+d8   |
|          | MOVW     | MOVW RW0            | MOVW     | MOVW RW1  | MOVW     | MOVW RW2  | MOVW     | MOVW RW3  |          | MOVW RW4  | MOVW              | MOVW RW5        |          | MOVW RW6  |          | MOVW RW7  |
| + 4      | RW0,RW4  | @RW4+d8             | RW1,RW4  | @RW4+d8   | RW2,RW4  | ,@RW4+d8  | RW3,RW4  | @RW4+d8   | RW4,RW4  | ,@RW4+d8  | RW5,RW4           | @RW4+d8         | RW6,RW4  | ,@ RW4+d8 | RW7,RW4  | @RW4+d8   |
|          | MOVW     | MOVW RW0            | MOVW     | MOVW RW1  | MOVW     | MOVW RW2  | MOVW     |           | MOVW     | MOVW RW4  | MOVW              | MOVW RW5        |          | MOVW RW6  | MOVW     | MOVW RW7  |
| ¢ +      | RW0,RW5  | ,@RW5+d8            | RW1,RW5  | ,@RW5+d8  | RW2,RW5  | ,@RW5+d8  | RW3,RW5  | ,@RW5+d8  | RW4,RW5  | ,@RW5+d8  | RW5,RW5           | ,@RW5+d8        | RW6,RW5  | ,@RW5+d8  | RW7,RW5  | @RW5+d8   |
|          | MOVW     | MOVW RW0            | MOVW     | MOVW RW1  | MOVW     | MOVW RW2  | MOVW     | MOVW RW3  | MOVW     | MOVW RW4  | MOVW              | MOVW RW5        | MOVW     | MOVW RW6  | MOVW     | MOVW RW7  |
| + 6      | RW0,RW6  | ,@RW6+d8            | RW1,RW6  | @RW6+d8   | RW2,RW6  | ,@RW6+d8  | RW3,RW6  | @RW6+d8   | RW4,RW6  | ,@RW6+d8  | RW5,RW6           | ,@RW6+d8        | RW6,RW6  | @RW6+d8   | RW7,RW6  | @RW6+d8   |
|          | MOVW     |                     |          | MOVW RW1  | MOVW     | MOVW RW2  | MOVW     | MOVW RW3  | MOVW     | MOVW RW4  | MOVW              | MOVW RW5 MOVW   | MOVW     | MOVW RW6  | MOVW     | MOVW RW7  |
| + /      | RW0,RW7  | ,@RW7+d8            | RW1,RW7  | @RW7+d8   | RW2,RW7  | ,@RW7+d8  | RW3,RW7  | @RW7+d8   | RW4,RW7  | @RW7+d8   | RW5,RW7           | ,@RW7+d8        | RW6,RW7  | @RW7+d8   | RW7,RW7  | @RW7+d8   |
|          | MOVW     | MOVW RWO,           | MOVW     | MOVW RW1, | MOVW     | MOVW RW2, | MOVW     | MOVW RW3, | MOVW     | MOVW RW4, | MOVW              | MOVW RW5,       | MOVW     | MOVW RW6, | MOVW     | MOVW RW7, |
| + 8      | RWO,@RW0 | @RW0+d16            | RW1,@RW0 | @RW0+d16  | RW2,@RW0 | @RW0+d16  | RW3,@RW0 | @RW0+d16  | RW4,@RW0 | @RW0+d16  | RW5,@RW0          | @RW0+d16        | RW6,@RW0 | @RW0+d16  | RW7,@RW0 | @RW0+d16  |
|          | MOVW     | MOVW RWO,           | MOVW     | MOVW RW1, | MOVW     | MOVW RW2, | MOVW     | MOVW RW3, | MOVW     | MOVW RW4, | MOVW              | MOVW RW5,       | MOVW     | MOVW RW6, | MOVW     | MOVW RW7, |
| 6+       | RWO,@RW1 | @RW1+d16            | RW1,@RW1 | @RW1+d16  | RW2,@RW1 | @RW1+d16  | RW3,@RW1 | @RW1+d16  | RW4,@RW1 | @RW1+d16  | RW5,@RW1          | @RW1+d16        | RW6,@RW1 | @RW1+d16  | RW7,@RW1 | @RW1+d16  |
|          | MOVW     | MOVW RWO,           | MOVW     | MOVW RW1, | MOVW     | MOVW RW2, | MOVW     | MOVW RW3, | MOVW     | MOVW RW4, | MOVW              | MOVW RW5,       | MOVW     | MOVW RW6, | MOVW     | MOVW RW7, |
| + A      | RWO,@RW2 | RWO,@RW2 : @RW2+d16 | RW1,@RW2 | @RW2+d16  | RW2,@RW2 | @RW2+d16  | RW3,@RW2 | @RW2+d16  | RW4,@RW2 | @RW2+d16  | RW5,@RW2          | @RW2+d16        | RW6,@RW2 | @RW2+d16  | RW7,@RW2 | @RW2+d16  |
|          | MOVW     | MOVW RWO,           | MOVW     | MOVW RW1, | MOVW     | MOVW RW2, | MOVW     | MOVW RW3, | MOVW     | MOVW RW4, | MOVW              | MOVW RW5,       | MOVW     | MOVW RW6, | MOVW     | MOVW RW7, |
| н н<br>Н | RWO,@RW3 | RWO,@RW3 @RW3+d16   | RW1,@RW3 | @RW3+d16  | RW2,@RW3 | @RW3+d16  | RW3,@RW3 | @RW3+d16  | RW4,@RW3 | @RW3+d16  | RW5,@RW3          | @RW3+d16        | RW6,@RW3 | @RW3+d16  | RW7,@RW3 | @RW3+d16  |
|          | MOVW R   | MOVW R MOVW RWO,    | MOVW R   | MOVW RW1, | MOVW R   | MOVW RW2, | MOVW R   | MOVW RW3, | MOVW R   | MOVW RW4, | MOVW R            | MOVW RW5,       | MOVW R   | MOVW Å@R  | MOVW R   | MOVW Å@R  |
| с<br>+   | W0,@RW0+ | @RW0+RW7            | W1,@RW0+ | @RW0+RW7  | W2,@RW0+ | @RW0+RW7  | W3,@RW0+ | @RW0+RW7  | W4,@RW0+ | @RW0+RW7  | W5,@RW0+          | @RW0+RW7        | W6,@RW0+ | @RW0+RW7  | W7,@RW0+ | @RW0+RW7  |
|          | MOVW R   | MOVW R MOVW RWO,    | MOVW R   | MOVW RW1, | MOVW R   | MOVW RW2, | MOVW R   | MOVW RW3, | MOVW R   | MOVW RW4, | MOVW R            | MOVW RW5,       | MOVW R   | MOVW RW6, | MOVW R   | MOVW RW7, |
| 0<br>+   | W0,@RW1+ | @RW1+RW7            | W1,@RW1+ | @RW1+RW7  | W2,@RW1+ | @RW1+RW7  | W3,@RW1+ | @RW1+RW7  | W4,@RW1+ | @RW1+RW7  | W5,@RW1+          | @RW1+RW7        | W6,@RW1+ | @RW1+RW7  | W7,@RW1+ | @RW1+RW7  |
|          | MOVW R   | MOVW RW0            | MOVW R   | MOVW RW1  | MOVW R   | MOVW RW2  | MOVW R   | MOVW RW3  | MOVW R   | MOVW RW4  | MOVW R            | MOVW RW5 MOVW R | MOVW R   | MOVW RW6  | MOVW R   | MOVW RW7  |
| н<br>Н   | W0,@RW2+ | ,@PC+d16            | W1,@RW2+ | ,@PC+d16  | 5+       | ,@PC+d16  | +        |           | W4,@RW2+ | ,@PC+d16  | ,@PC+d16 W5,@RW2+ | ,@PC+d16        |          | ,@PC+d16  |          | ,@PC+d16  |
|          | MOVW R   | MOVW RW             | MOVW R   | MOVW RW   | MOVW R   | MOVW RW   | MOVW R   | MOVW RW   | MOVW R   | MOVW RW   | MOVW R            | MOVW RW         | MOVW R   | MOVW RW   | MOVW R   | MOVW RW   |
| ⊥<br>+   | W0.@RW3+ | : 0.addr16          | W1.@RW3+ | 1 addr16  | W2.@RW3+ | 2.addr16  | W3.@RW3+ | 3.addr16  | W4 @RW3+ | 4.addr16  | W5.@RW3+          | 5.addr16        | W6.@RW3+ | 6.addr16  | W7.@RW3+ | 7.addr16  |

DataShe

DataSheet4U.com

et4U.com

et4U.com

|        | 00               | 10               | 20       | 30               | 40         | 50       | 60       | 20       | 80         | 06       | AO       | BO       | S        | DO       | EO       | FO       |
|--------|------------------|------------------|----------|------------------|------------|----------|----------|----------|------------|----------|----------|----------|----------|----------|----------|----------|
| -      | NOM              | MOV @R           | MOV      | MOV @R           | MOV        | MOV @R   | MOV      | MOV @R   | NOM        | MOV @R   | MOV      | MOV @R   | MOV      | MOV @R   | MOV      | MOV @R   |
| ⊃<br>+ | R0,R0            | R0,R0 W0+d8,R0   | R0,R1    | R0,R1 W0+d8,R1   | R0,R2      | W0+d8,R2 | R0,R3    | W0+d8,R3 | R0,R4      | W0+d8,R4 | R0,R5    | W0+d8,R5 | R0,R6    | W0+d8,R6 | R0,R7    | W0+d8,R7 |
| Ŧ      | MOV              | MOV @R           | MOV      | MOV @R           | MOV        | MOV @R   | MOV      | MOV @R   | MOV        | MOV @R   | MOV      | MOV @R   | MOV      | MOV @R   | MOV      | MOV @R   |
| -<br>+ | R1,R0            | R1,R0 W1+d8,R0   | R1,R1    | W1+d8,R1         | R1,R2      | W1+d8,R2 | R1,R3    | W1+d8,R3 | R1,R4      | W1+d8,R4 | R1,R5    | W1+d8,R5 | R1,R6    | W1+d8,R6 | R1,R7    | W1+d8,R7 |
| -      | MOV              | MOV @R           | MOV      | MOV @R           | MOV        | MOV @R   |          | MOV @R   |            | MOV @R   |          | MOV @R   | MOV      | MOV @R   |          | MOV @R   |
| х<br>+ | R2,R0 : W2+d8,R0 | W2+d8,R0         | R2,R1    | W2+d8,R1         | R2,R2      | W2+d8,R2 | R2,R3    | W2+d8,R3 | R2,R4      | W2+d8,R4 | R2,R5    | W2+d8,R5 | R2,R6    | W2+d8,R6 | R2,R7    | W2+d8,R7 |
|        | MOV              | MOV @R           | MOV      | MOV @R           | MOV        | MOV @R   | MOV      | MOV @R   | NOM        | MOV @R   | MOV      | MOV @R   | MOV      | MOV @R   | MOV      | MOV @R   |
| ю<br>+ | R3,R0            | R3,R0 W3+d8,R0   | R3,R1    | W3+d8,R1         | R3,R2      | W3+d8,R2 | R3,R3    | W3+d8,R3 | R3,R4      | W3+d8,R4 | R3,R5    | W3+d8,R5 | R3,R6    | W3+d8,R6 | R3,R7    | W3+d8,R7 |
| -      | MOV              | MOV @R           | MOV      | MOV @R           | MOV        | MOV @R   | MOV      | MOV @R   |            | MOV @R   | MOV      | MOV @R   | MOV      | MOV @R   | MOV      | MOV @R   |
| + 4    | R4,R0            | R4,R0 W4+d8,R0   | R4,R1    | R4,R1 W4+d8,R1   | R4,R2      | W4+d8,R2 | R4,R3    | W4+d8,R3 | R4,R4      | W4+d8,R4 | R4,R5    | W4+d8,R5 | R4,R6    | W4+d8,R6 | R4,R7    | W4+d8,R7 |
|        | MOV              | MOV @R           | MOV      | MOV @R           | MOV        | MOV @R   | MOV      | MOV @R   | MOV        | MOV @R   | MOV      | MOV @R   | MOV      | MOV @R   | MOV      | MOV @R   |
| ۹<br>+ | R5,R0            | R5,R0 : W5+d8,R0 | R5,R1    | W5+d8,R1         | R5,R2      | W5+d8,R2 | R5,R3    | W5+d8,R3 | R5,R4      | W5+d8,R4 | R5,R5    | W5+d8,R5 | R5,R6    | W5+d8,R6 | R5,R7    | W5+d8,R7 |
|        | MOV              | MOV @R           | MOV      | MOV @R           | MOV        | MOV @R   | MOV      | MOV @R   | MOV        | MOV @R   | MOV      | MOV @R   | MOV      | MOV @R   | MOV      | MOV @R   |
| + 6    | R6,R0            | R6,R0 : W6+d8,R0 | R6,R1    | R6,R1 : W6+d8,R1 | R6,R2      | W6+d8,R2 | R6,R3    | W6+d8,R3 | R6,R4      | W6+d8,R4 | R6,R5    | W6+d8,R5 | R6,R6    | W6+d8,R6 | R6,R7    | W6+d8,R7 |
| 1      | MOV              | MOV @R           |          | MOV @R           | MOV        | MOV @R   | MOV      | MOV @R   | NOM        | MOV @R   | MOV      | MOV @R   | MOV      | MOV @R   | MOV      | MOV @R   |
| \ +    | R7,R0            | R7,R0 W7+d8,R0   | R7,R1    | W7+d8,R1         | R7,R2      | W7+d8,R2 | R7,R3    | W7+d8,R3 | R7,R4 : 1  | W7+d8,R4 | R7,R5    | W7+d8,R5 | R7,R6    | W7+d8,R6 | R7,R7    | W7+d8,R7 |
|        | MOV              | MOV @RW          | MOV      | MOV @RW          | MOV        | MOV @RW  | MOV      | MOV @RW  |            | MOV @RW  | MOV      | MOV @RW  | MOV      | MOV @RW  | MOV      | MOV @RW  |
| o<br>+ | @RW0,R0          | 0+d16,R0         | @RW0,R1  | 0+d16,R1         | @RW0,R2    | 0+d16,R2 | @RW0,R3  | 0+d16,R3 | @RW0,R4    | 0+d16,R4 | @RW0,R5  | 0+d16,R5 | @RW0,R6  | 0+d16,R6 | @RW0,R7  | 0+d16,R7 |
| -      | MOV              | MOV @RW          | MOV      | MOV @RW          | MOV        | MOV @RW  | MOV      | MOV @RW  | MOV        | MOV @RW  | MOV      | MOV @RW  | MOV      | MOV @RW  | MOV      | MOV @RW  |
| ה<br>+ | @RW1,R0          | 1+d16,R0         | @RW1,R1  | 1+d16,R1         | N1,R2      | 1+d16,R2 | @RW1,R3  | 1+d16,R3 | @RW1,R4    | 1+d16,R4 | @RW1,R5  | 1+d16,R5 | @RW1,R6  | 1+d16,R6 | @RW1,R7  | 1+d16,R7 |
| ▼ +    |                  | MOV @RW          | NOV      | MOV @RW          | MOV        | MOV @RW  | NOV      | MOV @RW  | NOW        | <        | NOM      | MOV @RW  | MOV      | MOV @RW  |          | MOV @RW  |
|        | @RW2,R0          | 2+d16,R0         | @RW2,R1  | 2+d16,R1         | @RW2,R2    | 2+d16,R2 | @RW2,R3  | 2+d16,R3 | @RW2,R4    | 2+d16,R4 | @RW2,R5  | 2+d16,R5 | @RW2,R6  | 2+d16,R6 | @RW2,R7  | 2+d16,R7 |
| а<br>Н | NOM              | MOV @RW          | MOV      | MOV @RW          | MOV        | MOV @RW  | NOV      | MOV @RW  | NOW        | MOV @RW  | MOV      | MOV @RW  | MOV      | MOV @RW  | MOV      | MOV @RW  |
|        | @RW3,R0          | : 3+d16,R0       | @RW3,R1  | 3+d16,R1         | @RW3,R2    | 3+d16,R2 | @RW3,R3  | 3+d16,R3 | @RW3,R4    | 3+d16,R4 | @RW3,R5  | 3+d16,R5 | @RW3,R6  | 3+d16,R6 | @RW3,R7  | 3+d16,R7 |
| -<br>- |                  | >                | MOV      | MOV @RW          | MOV        | MOV @RW  | NOV      | MOV @RW  | NOW        | MOV @RW  |          | MOV @RW  | MOV      | MOV @RW  | MOV      | MOV @RW  |
|        | @RW0+,R0         | 0+RW7,R0         | @RW0+,R1 | 0+RW7,R1         | @RW0+,R2   | 0+RW7,R2 | @RW0+,R3 | 0+RW7,R3 | @RW0+,R4 ( | 0+RW7,R4 | @RW0+,R5 | 0+RW7,R5 | @RW0+,R6 | 0+RW7,R6 | @RW0+,R7 | 0+RW7,R7 |
|        | NOM              | MOV @RW          | MOV      | MOV @RW          | MOV        | MOV @RW  | MOV      | MOV @RW  | NOV        | MOV @RW  | MOV      | MOV @RW  | MOV      | MOV @RW  | MOV      | MOV @RW  |
| ב<br>+ | @RW1+,R0         | 1+RW7,R0         | @RW1+,R1 | 1+RW7,R1         | @RW1+,R2   | 1+RW7,R2 | @RW1+,R3 | 1+RW7,R3 | @RW1+,R4   | 1+RW7,R4 | @RW1+,R5 | 1+RW7,R5 | @RW1+,R6 | 1+RW7,R6 | @RW1+,R7 | 1+RW7,R7 |
|        | NOM              | MOV P            |          | MOV P            | MOV        | MOV P    | MOV      | MOV P    | NOM        | MOV P    | MOV      | MOV P    | MOV      | MOV P    | MOV      | MOV P    |
| u<br>F | @RW2+,R0         | C+d16,R0         | @RW2+,R1 | C+d16,R1         | @RW2+,R2   | C+d16,R2 | @RW2+,R3 | C+d16,R3 | @RW2+,R4 : | C+d16,R4 | @RW2+,R5 | C+d16,R5 | @RW2+,R6 | C+d16,R6 | @RW2+,R7 | C+d16,R7 |
| ц<br>+ | NOM              | MOV a            | NOV      | MOV a            | MOV        | MOV a    | NOV      | MOV a    | NON        |          |          | MOV a    | MOV      | MOV a    | MOV      | MOV a    |
| -      | @RW3+,R0 :       | : ddr16,R0       | @RW3+,R1 | : ddr16,R1       | @RW3+,R2 : | ddr16,R2 | @RW3+,R3 | ddr16,R3 | @RW3+,R4 : | ddr16,R4 | @RW3+,R5 | ddr16,R5 | @RW3+,R6 | ddr16,R6 | @RW3+,R7 | ddr16,R7 |

## Table A.9-18 MOV ea, Ri Instruction (first byte = $7C_H$ )

DataSheet4U.com

DataShe

et4U.com

DataSheet4U.com

APPENDIX

## Table A.9-19 MOVW ea, Rwi Instruction (first byte = $7D_H$ )

| Fo | @RW        | 0+d8,RW7 | @RW               | 8,RW7    | @RW        | 2+d8,RW7 | @RW        | 3+d8,RW7 | @RW        | 4+d8,RW7 | @RW        | 5+d8,RW7 | @RW        | 6+d8,RW7         | @RW        | 7+d8,RW7 | 3 RW0       | +d16,RW7   | 3RW1        | +d16,RW7   | 3 RW2       | +d16,RW7   | 3RW3        | +d16,RW7   | 3 RW0       | +RW7,RW7 | 3RW1        | +RW7,RW7 | @PC+        | d16,RW7  | addr        | 16,RW7   |                    |    |
|----|------------|----------|-------------------|----------|------------|----------|------------|----------|------------|----------|------------|----------|------------|------------------|------------|----------|-------------|------------|-------------|------------|-------------|------------|-------------|------------|-------------|----------|-------------|----------|-------------|----------|-------------|----------|--------------------|----|
| Ľ. | MOVW @RW   | • • • •  |                   | 1+d8,RW7 | MOVW @RW   |          | MOVW @RW   | 3+d      | MOVW @RW   |          | MOVW @RW   | 2+q      | MOVW @RW   | 9 <del>4</del> 9 | MOVW @RW   | 2+q      | MOVW @RW0   |            | MOVW @RW1   |            | MOVW @RW2   |            | MOVW @RW3   |            | MOVW @RW0   | +RV      | MOVW @RW1   | HRW ::   | :MOVW @PC+  |          | MOVW addr   |          |                    |    |
| EO | MOVW       | RW0,RW7  | MOVW              | RW1,RW7  | MOVW       | RW2,RW7  | MOVW       | RW3,RW7  | MOVW       | RW4,RW7  | MOVW       | RW5,RW7  | MOVW       | RW6,RW7          | WOW        | RW7,RW7  | MOVW        | @RW0,RW7   | MOVW        | @RW1,RW7   | MOVW        | @RW2,RW7   | MOVW        | @RW3,RW7   | MOVW @      | RW0+,RW7 | MOVW @      | RW1+,RW7 | MOVW @      | RW2+,RW7 | MOVW @      | RW3+,RW7 |                    |    |
| DO | MOVW @RW   | 0+d8,RW6 | MOVW @RW          | 1+d8,RW6 | MOVW @RW   | 2+d8,RW6 | MOVW @RW   | 3+d8,RW6 | MOVW @RW   | 4+d8,RW6 | MOVW @RW   | 5+d8,RW6 | MOVW @RW   | 6+d8,RW6         | MOVW @RW   | 7+d8,RW6 | MOVW @RW0   | +d16,RW6   | MOVW @RW1   | +d16,RW6   | MOVW @RW2   | +d16,RW6   | MOVW @RW3   | +d16,RW6   | MOVW @RW0   | +RW7,RW6 | MOVW @RW1   | +RW7,RW6 | MOVW @PC+   | d16,RW6  | MOVW addr   | 16,RW6   |                    |    |
| CC | MOVW       | RW0,RW6  | MOVW              | RW1,RW6  |            | RW2,RW6  | MOVW       | RW3,RW6  | MOVW       | RW4,RW6  | MOVW       | RW5,RW6  | MOVW       | RW6,RW6          | WOW        | RW7,RW6  | MOVW        | @RW0,RW6   | MOVW        | @RW1,RW6   | MOVW        | @RW2,RW6   | MOVW        | @RW3,RW6   | MOVW @      | RW0+,RW6 | MOVW @      | RW1+,RW6 | MOVW @      |          | MOVW @      | RW3+,RW6 |                    |    |
| BO | MOVW @RW   | 0+d8,RW5 |                   | 1+d8,RW5 | •          | 2+d8,RW5 | MOVW @RW   | 3+d8,RW5 | MOVW @RW   | 4+d8,RW5 | MOVW @RW   | 5+d8,RW5 | MOVW @RW   |                  | MOVW @RW   | 7+d8,RW5 | MOVW @RW0   |            | MOVW @RW1   | +d16,RW5   | MOVW @RW2   |            | MOVW @RW3   | +d16,RW5   | MOVW @RW0   |          | MOVW @RW1   |          | MOVW @PC+   |          | MOVW addr   | 16,RW5   |                    |    |
| AO |            | RW0,RW5  |                   | RW1, RW5 | MOVW       | RW2,RW5  | MOVW       | RW3,RW5  | MOVW       | RW4,RW5  | MOVW       | RW5,RW5  | MOVW       | ,RW5             | WOW        | RW7,RW5  | MOW         | @RW0,RW5   | MOW         | @RW1,RW5   | MOVW        | @RW2,RW5   | MOVW        | @RW3,RW5   | MOVW @      |          | MOVW @      |          | MOVW @      |          | MOVW @      | RW3+,RW5 |                    |    |
| 06 | MOVW @RW I | 0+d8,RW4 |                   | 1+d8,RW4 | MOVW @RW   | 2+d8,RW4 | MOVW @RW   | 3+d8,RW4 | MOVW @RW 1 | 4+d8,RW4 | MOVW @RW   | 5+d8,RW4 | MOVW @RW I |                  | MOVW @RW   | 7+d8,RW4 | MOVW @RW0   | +d16,RW4   | MOVW @RW1   | +d16,RW4   | MOVW @RW2 1 | +d16,RW4   | MOVW @RW3   | +d16,RW4   | MOVW @RW0   |          | MOVW @RW1   | -        | MOVW @PC+ 1 |          | MOVW addr 1 | 16,RW4   |                    | Ŀ  |
| 80 | MOVW       | RW0,RW4  |                   | RW1,RW4  | MOVW       | RW2,RW4  | MOVW       | RW3,RW4  | MOW        | RW4,RW4  | MOVW       | RW5,RW4  | MOVW       | RW4              | WOW        | RW7,RW4  | MOVW        | @RW0,RW4   | MOVW        | @RW1,RW4   | MOVW        | @RW2,RW4   | MOVW        | @RW3,RW4   | MOWW @      |          | MOVW @      |          | I: @ MVOM   |          | MOVW @      | RW3+,RW4 | DataS              | he |
| 70 | MOVW @RW   | 0+d8,RW3 |                   | 1+d8,RW3 | MOWW @RW   | 2+d8,RW3 | MOVW @RW   | 3+d8,RW3 | MOVW @RW   | 4+d8,RW3 | MOVW @RW   | 5+d8,RW3 |            |                  | MOVW @RW   |          | MOVW @RW0   | +d16,RW3   | MOVW @RW1   |            | MOVW @RW2   |            | MOVW @RW3   |            | MOVW @RW0   |          | MOVW @RW1   |          | MOVW @PC+   |          | MOVW addr   | 16,RW3   |                    |    |
| 60 | MOVW       | RW0,RW3  | ; . <del></del> . | RW1,RW3  |            | RW2,RW3  | MOVW .     | RW3,RW3  | MOWW N     | RW4,RW3  | MOVW       | RW5,RW3  | MOWW N     | 3,RW3            | MOVW       | RW7,RW3  | MOW         | @RW0,RW3   | MOWW        |            | MOVW :      | · · · · ·  | MOWW :      | @RW3,RW3   | MOVW @ NVOM |          | MOWW @      |          | MOW @ NVOM  |          | MOVW @ .    | RW3+,RW3 |                    |    |
| 50 | MOVW @RW N | 0+d8,RW2 |                   | 1+d8,RW2 | MOVW @RW N | 2+d8,RW2 | MOVW @RW N | 3+d8,RW2 | MOVW @RW N | 4+d8,RW2 | MOVW @RW N | 5+d8,RW2 | MOVW @RW N | 6+d8,RW2         | MOVW @RW N | 7+d8,RW2 | MOVW @RW0 N | +d16,RW2 ( | MOVW @RW1 N | +d16,RW2 ( | MOVW @RW2 N | +d16,RW2 ( | MOVW @RW3 N | +d16,RW2 0 | MOVW @RW0 N |          | MOVW @RW1 N |          | MOVW @PC+ N |          | MOVW addr N | 16,RW2 F | •                  |    |
| 40 | MOVW       | RW0,RW2  |                   | RW1,RW2  |            | RW2,RW2  | MOVW       | RW3,RW2  | MOVW       | RW4,RW2  | MOVW       | RW5,RW2  |            | RW6,RW2          | MOVW       | RW7,RW2  | MOVW        | @RW0,RW2   | MOW         | @RW1,RW2   | MOVW        | @RW2,RW2   | MOVW :      | @RW3,RW2   | MOVW @      | ••••     | MOVW @      |          | MOVW @      |          | MOVW @      | RW3+,RW2 |                    |    |
| 08 | MOVW @RW   | 0+d8,RW1 | _                 | 1+d8,RW1 |            | 2+d8,RW1 |            | 3+d8,RW1 | :          | 4+d8,RW1 | :          | 5+d8,RW1 |            |                  | MOVW @RW   | 7+d8,RW1 | MOVW @RW0   | +d16,RW1   | MOVW @RW1   |            | MOVW @RW2   |            | MOVW @RW3   | +d16,RW1 ( | MOVW @RW0   |          | MOVW @RW1   |          | MOVW @PC+ 1 | RW1      | MOVW addr   | 16,RW1 F |                    |    |
| 20 | MOWW       | RW0,RW1  |                   | RW1,RW1  |            | RW2,RW1  |            | -        | MOW        | ·····    | MOW        | RW5,RW1  |            | 5                | MOW        | RW7,RW1  | MOVW        | @RW0,RW1   | MOVW :      |            | MOVW        |            | MOVW        | @RW3,RW1   | MOVW @      |          | MOVW @      |          | MOVW @      |          | MOVW @      | RW3+,RW1 |                    |    |
| 10 | MOVW @RW   | 0+d8,RW0 |                   | _        |            | 2+d8,RW0 | :          |          |            | 4+d8,RW0 | MOVW @RW   |          |            |                  | MOVW @RW   |          | MOVW @RW0   | +d16,RW0   | MOVW @RW1   |            | MOVW @RW2   |            | MOVW @RW3   | +d16,RW0   | MOVW @RW0   |          | MOVW @RW1   |          | MOVW @PC+   |          | MOVW addr   | 16,RW0   |                    |    |
| 00 | MOW        | RW0,RW0  |                   | RW1,RW0  | MOW        | RW2,RW0  | MOW        | RW3,RW0  |            | RW4,RW0  | MOW        | RW5,RW0  | MOW        | 6,RW0            | MOW        |          | MOW         | @RW0,RW0   | MOVW        | @RW1,RW0   | MOW         |            | MOVW        | @RW3,RW0   | MOVW @      |          | MOVW @      |          | MOVW @      |          | MOVW @      | RW3+,RW0 |                    |    |
|    | -          | 0<br>+   |                   | +        |            | 7        |            | ε<br>+   |            | + 4      |            | + 5      |            | 9+               |            | 2 +      |             | +          |             | 6+         |             | +          |             | 8<br>+     |             | с<br>+   |             | 0 +      |             | ш<br>+   |             | ш<br>+   | www.DataSheet4U.co | m  |

| FO | XCH R7, | @RW0+d8   | NOTW R7, | @RW1+d8 | XCH R7, | @RW2+d8   | NOTW R7, | @RW3+d8   | NOTW R7, | @RW4+d8   | XCH R7, | @RW5+d8 | XCH R7, | @RW6+d8 | XCH R7, | @RW7+d8   | XCH R7, | @RW0+d16 | XCH R7, | @RW1+d16         | KCH R7, | W2+d16,A   | (CH R7, | @RW3+d16 | XCH R7, | ÷.         | XCH R7, | @RW1+RW7   | (CH R7, | @PC+d16  | XCH R7, | addr16   |                   |
|----|---------|-----------|----------|---------|---------|-----------|----------|-----------|----------|-----------|---------|---------|---------|---------|---------|-----------|---------|----------|---------|------------------|---------|------------|---------|----------|---------|------------|---------|------------|---------|----------|---------|----------|-------------------|
| EO | X       | R7,R0 : @ |          | R7,R1 @ | X       | R7,R2 : @ | N        | R7,R3 : @ | N        | R7,R4 : @ | X       | R7,R5 @ | ×       | R7,R6 @ | X       | R7,R7 🔅 @ | X       | 9        |         | R7,@RW1 @        | ×       | R7,@RW2 :W | X       | @RW3     |         | R7,@RW0+ @ | X       | R7,@RW1+ @ | X       |          |         | R7,@RW3+ |                   |
|    | , XCH   | ш.<br>    | XC       | R7      | XCH     |           | , XCH    |           | , XCH    |           | XCH     |         | , XCH   |         | , XCH   |           | , XCH   |          | XCH     |                  | , XCH   |            | XCH     |          | . XCH   | _          | XCH     |            | XCH     |          | XCH     |          | -                 |
| B  | XCH R6  | @ RW0+d8  | XCH R6,  | @RW1+d8 | XCH R6, | @ RW2+d8  | XCH R6,  | @ RW3+d8  | XCH R6,  | @RW4+d8   | XCH R6, | @RW5+d8 | XCH R6, | @RW6+d8 | XCH R6, |           | XCH R6, | @RW0+d16 | XCH R6, | @RW1+d16         | XCH R6, | W2+d16,A   | XCH R6, | @RW3+d16 | XCH R6, | o :        | XCH R6, | @RW1+RW7   | XCH R6, | @PC+d16  | XCH R6, | addr16   |                   |
| 8  | XCH     | R6,R0     | ХСН      | R6,R1   | XCH     | R6,R2     | XCH      | R6,R3     | XCH      | R6,R4     | XCH     | R6,R5   | ХСН     | R6,R6   | XCH     | R6,R7     | XCH     | R6,@RW0  | XCH     | R6,@RW1          | XCH     | R6,@RW2    | XCH     | R6,@RW3  | XCH     | R6,@RW0+   | XCH     | R6,@RW1+   | XCH     | R6,@RW2+ | XCH     | R6,@RW3+ |                   |
| B0 | XCH R5, | @RW0+d8   | XCH R5,  | @RW1+d8 | XCH R5, | @RW2+d8   | XCH R5,  | @RW3+d8   | XCH R5,  | @RW4+d8   | XCH R5, | @RW5+d8 | XCH R5, |         | XCH R5, | @RW7+d8   | XCH R5, | @RW0+d16 | XCH R5, | @RW1+d16         | XCH R5, | W2+d16,A   | XCH R5, | @RW3+d16 | XCH R5, | ò.         | XCH R5, |            | XCH R5, | @PC+d16  | XCH R5, | addr16   |                   |
| AO | XCH     | R5,R0     | XCH      | R5,R1   | XCH     | R5,R2     | XCH      | R5,R3     | XCH      | R5,R4     | XCH     | R5,R5   | ХСН     | R5,R6   | XCH     | R5,R7     | XCH     | R5,@RW0  | XCH     | R5,@RW1          | XCH     | R5,@RW2    | XCH     | R5,@RW3  | хсн     | R5,@RW0+   | XCH     | R5,@RW1+   | XCH     | R5,@RW2+ | XCH     | R5,@RW3+ |                   |
| 06 | XCH R4, | @ RW0+d8  | XCH R4,  | @RW1+d8 | XCH R4, |           | XCH R4,  | @RW3+d8   | XCH R4,  | @RW4+d8   | XCH R4, |         | XCH R4, | @RW6+d8 | XCH R4, |           | XCH R4, | @RW0+d16 | XCH R4, | @RW1+d16         | XCH R4, | W2+d16,A   | XCH R4, | @RW3+d16 | XCH R4, | 0:         | XCH R4, | @RW1+RW7   | XCH R4, | @PC+d16  | XCH R4, | addr16   | Data              |
| 80 | XCH     | R4,R0     | хсн      | R4,R1   | XCH     | R4,R2     | ХСН      | R4,R3     | XCH      | R4,R4     | XCH     | R4,R5   | хсн     | R4,R6   | XCH     | R4,R7     | XCH     | R4,@RW0  | XCH     | R4,@RW1          | XCH     | R4,@RW2    | XCH     | R4,@RW3  | ХСН     | R4,@RW0+   | ХСН     | R4,@RW1+   | XCH     | R4,@RW2+ | XCH     | R4,@RW3+ | Data              |
| 20 | XCH R3, | @RW0+d8   | XCH R3,  | @RW1+d8 | XCH R3, | @RW2+d8   | XCH R3,  |           | XCH R3,  | @RW4+d8   | XCH R3, | @RW5+d8 | XCH R3, | @RW6+d8 | XCH R3, | @RW7+d8   | XCH R3, | @RW0+d16 | XCH R3, | @RW1+d16         | XCH R3, | W2+d16,A   | XCH R3, |          | XCH R3, | Ċ.         | XCH R3, | @RW1+RW7   | XCH R3, | @PC+d16  | XCH R3, | addr16   |                   |
| 60 | XCH     | R3,R0     | XCH      | R3,R1   | XCH     | R3,R2     | XCH      | R3,R3     | XCH      | R3,R4     | XCH     | R3,R5   | XCH     | R3,R6   | XCH     | R3,R7     | XCH     | R3,@RW0  | XCH     | R3,@RW1          | XCH     | R3,@RW2    | XCH     | R3,@RW3  | XCH     | R3,@RW0+   | XCH     | R3,@RW1+   | XCH     | R3,@RW2+ | XCH     | R3,@RW3+ |                   |
| 50 | XCH R2, | @RW0+d8   | XCH R2,  | @RW1+d8 | XCH R2, | @RW2+d8   | XCH R2,  | @RW3+d8   | XCH R2,  | 4         | XCH R2, |         | XCH R2, | @RW6+d8 | XCH R2, | @RW7+d8   | XCH R2, | @RW0+d16 | XCH R2, | @RW1+d16         | XCH R2, | W2+d16,A   | XCH R2, | @RW3+d16 | XCH R2, | ÷ :        | XCH R2, | @RW1+RW7   | XCH R2, | @PC+d16  | XCH R2, | addr16   |                   |
| 40 | XCH     | R2,R0     | XCH      | R2,R1   | XCH     |           | XCH      | R2,R3     | XCH      | R2,R4     | XCH     |         | XCH     | R2,R6   | XCH     | R2,R7     | XCH     | R2,@RW0  | XCH     | R2,@RW1          | XCH     | R2,@RW2    | XCH     | R2,@RW3  | XCH     | R2,@RW0+   | XCH     | R2,@RW1+   | XCH     | R2,@RW2+ | XCH     | R2,@RW3+ |                   |
| 30 | XCH R1, | @RW0+d8   | XCH R1,  | @RW1+d8 | XCH R1, | @RW2+     | XCH R1,  | @ RW3+    | XCH R1,  | @RW4+     | XCH R1, | @RW5+   | XCH R1, | @RW6+   | XCH R1, | @RW7+     | XCH R1, | @RW0+d16 | XCH R1, | @RW1+            | XCH R1, | W2+d16     | XCH R1, | @RW3+d16 | XCH R1, | @RW0+RW7   | XCH R1, | @RW1+RW7   | XCH R1, | @PC+d16  | XCH R1, | addr16   |                   |
| 20 | XCH     | R1,R0     | XCH      | R1,R1   | XCH     | R1,R2     | XCH      | R1,R3     | XCH      | R1,R4     | XCH     | R1,R5   | ХСН     | R1,R6   | XCH     | R1,R7     | XCH     | R1,@RW0  | XCH     |                  | XCH     |            | XCH     | R1,@RW3  | ХСН     |            | XCH     |            | XCH     |          | XCH     | R1,@RW3+ |                   |
| 10 | XCH R0, | @RW0+d8   | XCH R0,  | @RW1+d8 | XCH R0, | @RW2+d8   | XCH R0,  | @RW3+d8   | XCH R0,  | @RW4+d8   | XCH R0, | @RW5+d8 | XCH R0, | @RW6+d8 | XCH R0, | @RW7+d8   | XCH R0, | @RW0+d16 | XCH R0, | R0,@RW1 @RW1+d16 | XCH R0, |            | XCH R0, | @RW3+d16 | XCH R0, | @RW0+RW7   | XCH R0, |            | XCH R0, | @PC+d16  | XCH R0, | addr16   |                   |
| 0  | ХСН     | R0,R0     | хсн      | R0,R1   | ХСН     | R0,R2     | XCH      | R0,R3     | хсн      | R0,R4     | ХСН     | R0,R5   | XCH     |         | XCH     | R0,R7     | XCH     | R0,@RW0  | XCH     | R0,@RW1          | XCH     | R0,@RW2    | хсн     | R0,@RW3  | XCH     | R0,@RW0+   | XCH     | R0,@RW1+   | XCH     | R0,@RW2+ | XCH     | R0,@RW3+ |                   |
|    | -       | ><br>+    | +<br>-   | -<br>-  |         | N<br>+    |          | ო<br>+    |          | +         |         | م<br>+  | -       | 0<br>+  |         | × +       |         | 8+       |         | 6+               |         | 4 +        |         | е<br>+   |         | ວ<br>+     | -       | ⊐<br>+     |         | ш<br>+   |         | ш<br>+   | www.DataSheet4U.c |

DataSheet4U.com

et4U.com

|         | 00       | 10        | 20       | 30        | 40       | 50        | 60       | 70        | 80       | 06        | AO       | BO        | C        | DO        | EO       | FO        |
|---------|----------|-----------|----------|-----------|----------|-----------|----------|-----------|----------|-----------|----------|-----------|----------|-----------|----------|-----------|
| -<br>-  | XCHW     | XCHW RW0, | XCHW     | XCHW RW1, | XCHW     | XCHW RW2, | XCHW     | XCHW RW3, | хсни     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6, | хснм     | XCHW RW7, |
| 5       | RW0,RW0  | @RW0+d8   | RW1,RW0. | @ RW0+d8  | RW2,RW0  | @RW0+d8   | RW3, RW0 | @RW0+d8   | RW4, RW0 | @RW0+d8   | RW5,RW0  | @RW0+d8   | RW6,RW0  | @RW0+d8   | RW7,RW0  | @RW0+d8   |
| -       | XCHW     | XCHW RW0, | XCHW     | XCHW RW1, | XCHW     | e î       | XCHW     | XCHW RW3, | XCHW     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6, | XCHW     | XCHW RW7, |
| +       | RW0,RW1  | @RW1+d8   | RW1.RW1  | @RW1+d8   | RW2,RW1  | @RW1+d8   | RW3,RW1  | @RW1+d8   | RW4,RW1  | @RW1+d8   | RW5, RW1 | @RW1+d8   | RW6,RW1  | @RW1+d8   | RW7,RW1  | @RW1+d8   |
| с<br>Н  | XCHW     | XCHW RW0, | XCHW     | XCHW RW1, | XCHW     | XCHW RW2, | XCHW     | XCHW RW3, | XCHW     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6, | XCHW     | XCHW RW7, |
| N<br>+  | RW0,RW2  | @RW2+d8   | RW1,RW2  | @RW2+d8   | RW2,RW2  | @RW2+d8   | RW3,RW2  | @RW2+d8   | RW4, RW2 | @RW2+d8   | RW5,RW2  | @RW2+d8   | RW6,RW2  | @RW2+d8   | RW7, RW2 | @RW2+d8   |
| с<br>Н  | XCHW     | XCHW RW0, | XCHW     | XCHW RW1, | XCHW     | XCHW RW2, | XCHW     | XCHW RW3, | XCHW     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6, | XCHW     | XCHW RW7, |
| r,<br>+ | RW0,RW3  | @RW3+d8   | RW1,RW3  | @RW3+d8   | RW2,RW3  | @RW3+d8   | RW3,RW3  | @RW3+d8   | RW4, RW3 | @RW3+d8   | RW5,RW3  | @RW3+d8   | RW6,RW3  | @RW3+d8   | RW7,RW3  | @RW3+d8   |
| -       | XCHW     | XCHW RW0, | XCHW     | XCHW RW1, | XCHW     | XCHW RW2, | XCHW     | XCHW RW3, | XCHW     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6, | XCHW     | XCHW RW7, |
| + 4     | RW0,RW4  | @RW4+d8   | RW1,RW4  | @RW4+d8   | RW2,RW4  | @RW4+d8   | RW3,RW4  | @RW4+d8   | RW4, RW4 | @RW4+d8   | RW5,RW4  | @RW4+d8   | RW6,RW4  | @RW4+d8   | RW7,RW4  | @RW4+d8   |
|         | XCHW     |           | XCHW     | XCHW RW1, | XCHW     | XCHW RW2, | XCHW     | XCHW RW3, | XCHW     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6, | XCHW     | XCHW RW7, |
| + 2     | RW0,RW5  | @RW5+d8   | RW1,RW5  | @RW5+d8   | RW2,RW5  | @RW5+d8   | RW3,RW5  | @RW5+d8   | RW4, RW5 | @RW5+d8   | RW5,RW5  | @ RW5+d8  | RW6,RW5  | @RW5+d8   | RW7, RW5 | @RW5+d8   |
| -       | XCHW     |           | XCHW     | XCHW RW1, | XCHW     | XCHW RW2, | XCHW     | XCHW RW3, | XCHW     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6, | XCHW     | XCHW RW7, |
| 9+      | RW0,RW6  | @RW6+d8   | RW1,RW6  | @RW6+d8   | RW2,RW6  | @RW6+d8   | RW3,RW6  | @RW6+d8   | RW4, RW6 | @RW6+d8   | RW5,RW6  | @RW6+d8   | RW6,RW6  | @RW6+d8   | RW7,RW6  | @RW6+d8   |
| -       | XCHW     | XCHW RW0, | XCHW     | XCHW RW1, | XCHW     | XCHW RW2, | XCHW     | XCHW RW3, | XCHW     | XCHW RW4, | XCHW     |           | XCHW     | XCHW RW6, | XCHW     | XCHW RW7, |
| - +     | RW0,RW7  | @RW7+d8   | RW1,RW7  | @RW7+d8   | RW2,RW7  | @RW7+d8   | RW3,RW7  | @RW7+d8   | RW4,RW7  | @RW7+d8   | RW5,RW7  | @RW7+d8   | RW6,RW7  | @RW7+d8   | RW7,RW7  | @RW7+d8   |
| -       | XCHW     | XCHW RW0, | XCHW     | XCHW RW1, | XCHW     | XCHW RW2, | XCHW     | XCHW RW3, | XCHW     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6, | XCHW     | XCHW RW7, |
| 8 +     | RW0,@RW0 | @RW0+d16  | RW1,@RW0 | @RW0+d16  | RW2,@RW0 | @RW0+d16  | RW3,@RW0 | @RW0+d16  | RW4,@RW0 | @RW0+d16  | RW5,@RW0 | @RW0+d16  | RW6,@RW0 | @RW0+d16  | RW7,@RW0 | @RW0+d16  |
| -       | XCHW     | XCHW RW0, | XCHW     | XCHW RW1, | XCHW     | XCHW RW2, | XCHW     | XCHW RW3, | XCHW     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6, | XCHW     | XCHW RW7, |
| 6<br>+  | RW0,@RW1 | @RW1+d16  | RW1,@RW1 | @RW1+d16  | RW2,@RW1 | @RW1+d16  | RW3,@RW1 | @RW1+d16  | RW4,@RW1 | @RW1+d16  | RW5,@RW1 | @RW1+d16  | RW6,@RW1 | @RW1+d16  | RW7,@RW1 | @RW1+d16  |
|         | XCHW     |           |          | XCHW RW1, | XCHW     |           | XCHW     | XCHW RW3, | XCHW     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6, | XCHW     | XCHW RW7, |
| 4 +     | RW0,@RW2 | @RW2+d16  | RW1,@RW2 | @RW2+d16  | RW2,@RW2 | @RW2+d16  | RW3,@RW2 | @RW2+d16  | RW4,@RW2 | @RW2+d16  | RW5,@RW2 | @RW2+d16  | RW6,@RW2 | @RW2+d16  | RW7,@RW2 | @RW2+d16  |
|         | XCHW     | XCHW RW0, | XCHW     | XCHW RW1, | XCHW     | XCHW RW2, | XCHW     | XCHW RW3, | XCHW     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6, | XCHW     | XCHW RW7, |
| н<br>Н  | RW0,@RW3 | @RW3+d16  | RW1,@RW3 | @RW3+d16  | RW2,@RW3 | @RW3+d16  | RW3,@RW3 | @RW3+d16  | RW4,@RW3 | @RW3+d16  | RW5,@RW3 | @RW3+d16  | RW6,@RW3 | @RW3+d16  | RW7,@RW3 | @RW3+d16  |
|         | XCHW R   |           | XCHW R   | XCHW RW1, | XCHW R   | XCHW RW2, | XCHW R   | XCHW RW3, | XCHW R   | XCHW RW4, | XCHW R   | XCHW RW5, | XCHW R   | XCHW RW6, | XCHW R   | XCHW RW7, |
| + c     | W0,@RW0+ | @RW0+RW7  | W1,@RW0+ | @RW0+RW7  | W2,@RW0+ | @RW0+RW7  | W3,@RW0+ | @RW0+RW7  | W4,@RW0+ | @RW0+RW7  | W5,@RW0+ | @RW0+RW7  | W6,@RW0+ | @RW0+RW7  | W7,@RW0+ | @RW0+RW7  |
|         | XCHW R   |           | XCHW R   | XCHW RW1, | XCHW R   | XCHW RW2, | XCHW R   | XCHW RW3, | XCHW R   | XCHW RW4, | XCHW R   | XCHW RW5, | XCHW R   | XCHW RW6, | XCHW R   | XCHW RW7, |
| 0<br>+  | WO,@RW1+ | @RW1+RW7  | W1,@RW1+ | @RW1+RW7  | W2,@RW1+ | @RW1+RW7  | W3,@RW1+ | @RW1+RW7  | W4,@RW1+ | @RW1+RW7  | W5,@RW1+ | @RW1+RW7  | W6,@RW1+ | @RW1+RW7  | W7,@RW1+ | @RW1+RW7  |
|         | XCHW R   | XCHW RW0, | XCHW R   | XCHW RW1, | XCHW R   | XCHW RW2, | XCHW R   | XCHW RW3, | XCHW R   | XCHW RW4, | XCHW R   | XCHW RW5, | XCHW R   | XCHW RW6, | XCHW R   | XCHW RW7, |
| ш<br>+  | WO,@RW2+ | @PC+d16   | W1,@RW2+ | @PC+d16   | W2,@RW2+ | @PC+d16   | W3,@RW2+ | @PC+d16   | W4,@RW2+ | @PC+d16   | W5,@RW2+ | @PC+d16   | W6,@RW2+ | @PC+d16   | W7,@RW2+ | @PC+d16   |
|         | XCHW R   | XCHW RW0, | XCHW R   | XCHW RW1, | XCHW R   | XCHW RW2, | XCHW R   | XCHW RW3, | XCHW R   | XCHW RW4, | XCHW R   | XCHW RW5, | XCHW R   | XCHW RW6, | XCHW R   | XCHW RW7, |
| ш<br>+  | WO,@RW3+ | addr16    | W1,@RW3+ | addr16    | W2,@RW3+ | addr16    | W3,@RW3+ | addr16    | W4,@RW3+ | addr16    | W5,@RW3+ | addr16    | W6,@RW3+ | addr16    | W7,@RW3+ | addr16    |

Table A.9-21 XCHW RWi, ea Instruction (first byte = 7F<sub>H</sub>)

et4U.com

www.DataSheet4U.com

APPENDIX

DataSheet4U.com

DataShe

# APPENDIX B Register Index

## Register Index

## Table B-1 Register Index (1/9)

| 163<br>168<br>173 |
|-------------------|
| 168               |
|                   |
| 173               |
| 1                 |
| 178               |
| 183               |
|                   |
| 163               |
| 168               |
| 173               |
| 178               |
| 183               |
|                   |
| 362               |
|                   |
| 387               |
| 385               |
| 391/392           |
|                   |
| 389               |
| 389               |
|                   |

DataSheet4U.com

et4U.com

## Table B-1 Register Index (2/9)

| Address                                          | Abbreviation of Register Name | Register Name                                         | Reset Value           | Resource Name                 | Page<br>Number |
|--------------------------------------------------|-------------------------------|-------------------------------------------------------|-----------------------|-------------------------------|----------------|
| 00002C <sub>H</sub><br>to<br>00002F <sub>H</sub> | (Reserved area) *             |                                                       |                       |                               |                |
| 000030 <sub>H</sub>                              | ENIR                          | DTP/external interrupt enable register                | 00000000 <sub>B</sub> |                               | 333            |
| 000031 <sub>H</sub>                              | EIRR                          | DTP/external interrupt factor register                | XXXXXXXX <sub>B</sub> | DTP/external<br>interrupt     | 332            |
| 000032 <sub>H</sub>                              | FLVD                          | Detection 1 and a strike services                     | 00000000 <sub>B</sub> |                               | 335            |
| 000033 <sub>H</sub>                              | ELVR                          | Detection level setting register                      | 00000000 <sub>B</sub> |                               | 334            |
| 000034 <sub>H</sub>                              |                               |                                                       | 00000000 <sub>B</sub> |                               | 356            |
| 000035 <sub>H</sub>                              | ADCS                          | A/D control status register                           | 00000000 <sub>B</sub> | 8/10-bit                      | 354            |
| 000036 <sub>H</sub>                              |                               |                                                       | XXXXXXXX <sub>B</sub> | A/D converter                 | 361            |
| 000037 <sub>H</sub>                              | ADCR                          | A/D data register                                     | 00101XXX <sub>B</sub> |                               | 359            |
| 000038 <sub>H</sub><br>to<br>00003F <sub>H</sub> | (Reserved area) *             |                                                       |                       |                               |                |
| 000040 <sub>H</sub>                              | PPGC0                         | PPG0 operation mode control <sup>40.cc</sup> register | 0X000XX1 <sub>B</sub> |                               | 298            |
| 000041 <sub>H</sub>                              | PPGC1                         | PPG1 operation mode control register                  | 0X000001 <sub>B</sub> | 8/16-bit PPG<br>PPG timer 0/1 | 300            |
| $000042_{\rm H}$                                 | PPG01                         | PPG0/1 count clock select register                    | 000000XX <sub>B</sub> |                               | 302            |
| 000043 <sub>H</sub>                              | (Reserved area) *             | 1                                                     |                       |                               |                |
| 000044 <sub>H</sub>                              | PPGC2                         | PPG2 operation mode control register                  | 0X000XX1 <sub>B</sub> |                               | 298            |
| 000045 <sub>H</sub>                              | PPGC3                         | PPG3 operation mode control register                  | 0X000001 <sub>B</sub> | 8/16-bit<br>PPG timer 2/3     | 300            |
| $000046_{\mathrm{H}}$                            | PPG23                         | PPG2/3 count clock select register                    | 000000XX <sub>B</sub> |                               | 302            |
| 000047 <sub>H</sub><br>to<br>00004F <sub>H</sub> | (Reserved area)*              |                                                       |                       |                               |                |

DataShee

DataSheet4U.com

et4U.com

632

|         | Address                                                                                   | Abbreviation of Register Name | Register Name                                    | Reset Value            | Resource Name                 | Page<br>Number |
|---------|-------------------------------------------------------------------------------------------|-------------------------------|--------------------------------------------------|------------------------|-------------------------------|----------------|
|         | 000050 <sub>H</sub>                                                                       | UD CIDA                       |                                                  | XXXXXXXXAB             |                               |                |
|         | 000051 <sub>H</sub>                                                                       | - IPCP0                       | Input capture data register 0                    | XXXXXXXXAB             |                               | 232            |
|         | 000052 <sub>H</sub>                                                                       | IDCD1                         | <b>T</b> <i>i i</i> <b>i</b> <i>i i</i> <b>i</b> | XXXXXXXXAB             | -                             | 232            |
|         | 000053 <sub>H</sub>                                                                       | IPCP1                         | Input capture data register 1                    | XXXXXXXXAB             |                               |                |
|         | 000054 <sub>H</sub>                                                                       | ICS01                         | Input capture control status                     | 00000000 <sub>B</sub>  | 16-bit                        | 220            |
|         | 000055 <sub>H</sub>                                                                       | ICS23                         | register                                         | 00000000 <sub>B</sub>  | - I/O timers                  | 229            |
| -       | 000056 <sub>H</sub>                                                                       | TODT                          | Times to be a side                               | 00000000 <sub>B</sub>  |                               | 207            |
|         | 000057 <sub>H</sub>                                                                       | - TCDT                        | Timer counter data register                      | 00000000 <sub>B</sub>  |                               | 227            |
|         | 000058 <sub>H</sub>                                                                       | TCCS                          | Timer counter control status register            | 00000000 <sub>B</sub>  |                               | 225            |
|         | 000059 <sub>H</sub>                                                                       | (Reserved area) *             | 1                                                | 1                      |                               |                |
| t4U.com | 00005A <sub>H</sub>                                                                       | ID CD2                        |                                                  | XXXXXXXXAB             |                               | 222            |
|         | 00005B <sub>H</sub>                                                                       | IPCP2                         | Input capture data register 2                    | XXXXXXXXAB             | 16-bit                        | 232            |
|         | 00005C <sub>H</sub>                                                                       | IDCD2                         | XXX                                              | XXXXXXXXAB             | I/O timers                    | 222            |
|         | 00005D <sub>H</sub>                                                                       | - IPCP3                       | Input capture data register 3<br>DataSheet4U.co  | "XXXXXXXX <sub>B</sub> |                               | 232            |
|         | $\begin{array}{c} 00005 \mathrm{E_{H}} \\ \mathrm{to} \\ 000065_{\mathrm{H}} \end{array}$ | (Reserved area)*              |                                                  |                        |                               |                |
|         | 000066 <sub>H</sub>                                                                       |                               |                                                  | 00000000 <sub>B</sub>  | 16-bit reload timer<br>0      | 253            |
|         | 000067 <sub>H</sub>                                                                       | TMCSR0                        |                                                  | XXXX0000B              |                               | 251            |
|         | 000068 <sub>H</sub>                                                                       |                               | Timer control status register                    | 00000000 <sub>B</sub>  | 16-bit reload timer           | 253            |
|         | 000069 <sub>H</sub>                                                                       | TMCSR1                        |                                                  | XXXX0000B              | 1                             | 251            |
| -       | 00006A <sub>H</sub><br>to<br>00006E <sub>H</sub>                                          | (Reserved area)*              |                                                  |                        |                               |                |
|         |                                                                                           |                               |                                                  |                        | ROM mirroring function select | 526            |
|         | 00006F <sub>H</sub>                                                                       | ROMM                          | ROM mirroring function select register           | XXXXXXX1 <sub>B</sub>  | module                        |                |
|         | $00006F_{\rm H} \\ 000070_{\rm H} \\ to \\ 00007F_{\rm H}$                                | ROMM (Reserved area)*         |                                                  | XXXXXXX1 <sub>B</sub>  |                               |                |
|         | 000070 <sub>H</sub><br>to                                                                 |                               |                                                  | XXXXXXX1 <sub>B</sub>  |                               | 450            |
|         | 000070 <sub>H</sub><br>to<br>00007F <sub>H</sub>                                          | (Reserved area) *             | register                                         |                        | module                        |                |

## Table B-1 Register Index (3/9)

### APPENDIX

# Table B-1 Register Index (4/9)

| Address                                                                                                                                            | Abbreviation of<br>Register Name                                                                                                                                        | Register Name                                                                               | Reset Value                                       | Resource Name                                                 | Page<br>Number    |
|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------|---------------------------------------------------------------|-------------------|
| 000083 <sub>H</sub>                                                                                                                                | (Reserved area) *                                                                                                                                                       |                                                                                             | <u></u>                                           |                                                               |                   |
| 000084 <sub>H</sub>                                                                                                                                | TCANR                                                                                                                                                                   | Transmission cancel register                                                                | 00000000 <sub>B</sub>                             | CAN controller                                                | 460               |
| 000085 <sub>H</sub>                                                                                                                                | (Reserved area) *                                                                                                                                                       |                                                                                             |                                                   |                                                               |                   |
| 000086 <sub>H</sub>                                                                                                                                | TCR                                                                                                                                                                     | Transmission complete register                                                              | 00000000 <sub>B</sub>                             | CAN controller                                                | 462               |
| 000087 <sub>H</sub>                                                                                                                                | (Reserved area) *                                                                                                                                                       |                                                                                             |                                                   |                                                               |                   |
| 000088 <sub>H</sub>                                                                                                                                | RCR                                                                                                                                                                     | Reception complete register                                                                 | 00000000 <sub>B</sub>                             | CAN controller                                                | 466               |
| 000089 <sub>H</sub>                                                                                                                                | (Reserved area) *                                                                                                                                                       |                                                                                             | 1                                                 |                                                               |                   |
| 00008A <sub>H</sub>                                                                                                                                | RRTRR                                                                                                                                                                   | Reception RTR register                                                                      | 00000000 <sub>B</sub>                             | CAN controller                                                | 468               |
| 00008B <sub>H</sub>                                                                                                                                | (Reserved area) *                                                                                                                                                       | 1                                                                                           | 1                                                 |                                                               |                   |
| 00008C <sub>H</sub>                                                                                                                                | I ROVRR                                                                                                                                                                 | Reception overrun register                                                                  | 00000000 <sub>B</sub>                             | CAN controller                                                | 470               |
| 00008D <sub>H</sub>                                                                                                                                | (Reserved area) *                                                                                                                                                       |                                                                                             | 1                                                 |                                                               |                   |
| 00008E <sub>H</sub>                                                                                                                                | RIER                                                                                                                                                                    | Reception complete interrupt enable register                                                | 00000000 <sub>B</sub>                             | CAN controller                                                | 472               |
| 00008F <sub>H</sub><br>to<br>00009D <sub>H</sub>                                                                                                   | (Reserved area) *                                                                                                                                                       | DataSheet4U.co                                                                              | om                                                |                                                               |                   |
| 00009E <sub>H</sub>                                                                                                                                | PACSR                                                                                                                                                                   | Address detection control register                                                          | 00000000 <sub>B</sub>                             | Address match detecting function                              | 511               |
| 00009F <sub>H</sub>                                                                                                                                | DIRR                                                                                                                                                                    | Delayed interrupt request<br>generate/cancel register                                       | XXXXXXX0 <sub>B</sub>                             | Delayed interrupt generation module                           | 323               |
|                                                                                                                                                    |                                                                                                                                                                         | Low-power consumption mode                                                                  | 00011000 <sub>B</sub>                             | Low-power                                                     |                   |
| 0000A0 <sub>H</sub>                                                                                                                                | I LPMCR                                                                                                                                                                 | control register                                                                            | 00011000 <sub>B</sub>                             | consumption mode                                              | 130               |
| 0000A0 <sub>H</sub><br>0000A1 <sub>H</sub>                                                                                                         | -                                                                                                                                                                       | control register Clock select register                                                      | 11111100 <sub>B</sub>                             | -                                                             | 130<br>115        |
|                                                                                                                                                    | CKSCR (Reserved area)*                                                                                                                                                  |                                                                                             | 2                                                 | consumption mode                                              |                   |
| 0000A1 <sub>H</sub><br>0000A2 <sub>H</sub><br>to                                                                                                   | CKSCR<br>(Reserved area) <sup>*</sup>                                                                                                                                   |                                                                                             | 2                                                 | consumption mode                                              |                   |
| 0000A1 <sub>H</sub><br>0000A2 <sub>H</sub><br>to<br>0000A7 <sub>H</sub>                                                                            | I     CKSCR       I     (Reserved area)*       I     WDTC                                                                                                               | Clock select register                                                                       | 11111100 <sub>B</sub>                             | consumption mode<br>Clock                                     | 115               |
| 0000A1 <sub>H</sub><br>0000A2 <sub>H</sub><br>to<br>0000A7 <sub>H</sub><br>0000A8 <sub>H</sub>                                                     | I     CKSCR       I     (Reserved area)*       I     WDTC       I     TBTC                                                                                              | Clock select register<br>Watchdog timer control register                                    | 11111100 <sub>B</sub><br>XXXXX111 <sub>B</sub>    | consumption mode<br>Clock<br>Watchdog timer                   | 208               |
| 0000A1 <sub>H</sub><br>0000A2 <sub>H</sub><br>to<br>0000A7 <sub>H</sub><br>0000A8 <sub>H</sub><br>0000A9 <sub>H</sub>                              | I       CKSCR         I       (Reserved area)*         I       WDTC         I       TBTC         H       WTC         I       (Reserved area)*                           | Clock select register<br>Watchdog timer control register<br>Timebase timer control register | 11111100B           XXXXX111B           1XX00100B | consumption mode<br>Clock<br>Watchdog timer<br>Timebase timer | 115<br>208<br>193 |
| 0000A1 <sub>H</sub><br>0000A2 <sub>H</sub><br>to<br>0000A7 <sub>H</sub><br>0000A8 <sub>H</sub><br>0000A9 <sub>H</sub><br>0000AA <sub>F</sub><br>to | I       CKSCR         I       (Reserved area)*         I       WDTC         I       TBTC         I       WTC         I       (Reserved area)*         I       Iteration | Clock select register<br>Watchdog timer control register<br>Timebase timer control register | 11111100B           XXXXX111B           1XX00100B | consumption mode<br>Clock<br>Watchdog timer<br>Timebase timer | 115<br>208<br>193 |

| Address                                          | Abbreviation of Register Name | Register Name                                 | Reset Value           | Resource Name        | Page<br>Number |    |
|--------------------------------------------------|-------------------------------|-----------------------------------------------|-----------------------|----------------------|----------------|----|
| 0000B0 <sub>H</sub>                              | ICR00                         | Interrupt control register 00                 | 00000111 <sub>B</sub> |                      |                |    |
| 0000B1 <sub>H</sub>                              | ICR01                         | Interrupt control register 01                 | 00000111 <sub>B</sub> |                      |                |    |
| 0000B2 <sub>H</sub>                              | ICR02                         | Interrupt control register 02                 | 00000111 <sub>B</sub> |                      |                |    |
| 0000B3 <sub>H</sub>                              | ICR03                         | Interrupt control register 03                 | 00000111 <sub>B</sub> |                      |                |    |
| 0000B4 <sub>H</sub>                              | ICR04                         | Interrupt control register 04                 | 00000111 <sub>B</sub> |                      |                |    |
| 0000B5 <sub>H</sub>                              | ICR05                         | Interrupt control register 05                 | 00000111 <sub>B</sub> |                      |                |    |
| 0000B6 <sub>H</sub>                              | ICR06                         | Interrupt control register 06                 | 00000111 <sub>B</sub> |                      |                |    |
| 0000B7 <sub>H</sub>                              | ICR07                         | Interrupt control register 07                 | 00000111 <sub>B</sub> | Interment controller | 66             |    |
| 0000B8 <sub>H</sub>                              | ICR08                         | Interrupt control register 08                 | 00000111 <sub>B</sub> | Interrupt controller | UU             |    |
| 0000B9 <sub>H</sub>                              | ICR09                         | Interrupt control register 09                 | 00000111 <sub>B</sub> | ]                    |                |    |
| 0000BA <sub>H</sub>                              | ICR10                         | Interrupt control register 10                 | 00000111 <sub>B</sub> |                      |                |    |
| 0000BB <sub>H</sub>                              | ICR11                         | Interrupt control register 11                 | 00000111 <sub>B</sub> | -                    |                |    |
| 0000BC <sub>H</sub>                              | ICR12                         | Interrupt control register 12                 | 00000111 <sub>B</sub> |                      |                | Da |
| 0000BD <sub>H</sub>                              | ICR13                         | Interrupt control register 13                 | 00000111 <sub>B</sub> |                      |                |    |
| 0000BE <sub>H</sub>                              | ICR14                         | Interrupt control register 14                 | 00000111 <sub>B</sub> |                      |                |    |
| 0000BF <sub>H</sub>                              | ICR15                         | Interrupt control register 15                 | 00000111 <sub>B</sub> |                      |                |    |
| 0000C0 <sub>H</sub><br>to<br>0000FF <sub>H</sub> | (Reserved area)*              |                                               |                       |                      |                |    |
| 001FF0 <sub>H</sub>                              |                               | Detect address setting register 0 (Low)       | XXXXXXXXB             |                      |                |    |
| 001FF1 <sub>H</sub>                              | PADR0                         | Detect address setting register 0<br>(Middle) | XXXXXXXXXB            |                      | 513            |    |
| 001FF2 <sub>H</sub>                              | ]                             | Detect address setting register 0<br>(High)   | XXXXXXXX <sub>B</sub> | Address match        |                |    |
| 001FF3 <sub>H</sub>                              |                               | Detect address setting register 1<br>(Low)    | XXXXXXXX <sub>B</sub> | detecting function   |                |    |
| 001FF4 <sub>H</sub>                              | PADR1                         | Detect address setting register 1<br>(Middle) | XXXXXXXX <sub>B</sub> |                      | 513            |    |
| 001FF5 <sub>H</sub>                              |                               | Detect address setting register 1<br>(High)   | XXXXXXXX <sub>B</sub> |                      |                |    |
|                                                  |                               | 16-bit timer register 0/                      | XXXXXXXXAB            | 16-bit reload timer  |                |    |
| 003900 <sub>H</sub>                              | TMR0/TMRLR0                   | 16-bit reload register 0                      |                       | 10 off feload times  | 255/256        |    |

## Table B-1 Register Index (5/9)

DataSheet4U.com

et4U.com

### APPENDIX

| Address                                                                                                                                                                                                                                 | Abbreviation of<br>Register Name                                                                                                                    | Register Name                               | Reset Value                                                                                   | Resource Name       | Page<br>Number |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|-----------------------------------------------------------------------------------------------|---------------------|----------------|--|--|
| 003902 <sub>H</sub>                                                                                                                                                                                                                     |                                                                                                                                                     | 16-bit timer register 1/                    | XXXXXXXXAB                                                                                    | 16-bit reload timer | 0.5510.55      |  |  |
| 003903 <sub>H</sub>                                                                                                                                                                                                                     | TMR1/TMRLR1                                                                                                                                         | 16-bit reload register 1                    | XXXXXXXXB                                                                                     | 1                   | 255/256        |  |  |
| 003904 <sub>H</sub><br>to<br>00390F <sub>H</sub>                                                                                                                                                                                        | (Reserved area) *                                                                                                                                   |                                             |                                                                                               |                     |                |  |  |
| 003910 <sub>H</sub>                                                                                                                                                                                                                     | PRLL0                                                                                                                                               | PPG0 reload register L                      | XXXXXXXXAB                                                                                    |                     | 304            |  |  |
| 003911 <sub>H</sub>                                                                                                                                                                                                                     | PRLH0                                                                                                                                               | PPG0 reload register H                      | XXXXXXXXAB                                                                                    |                     | 304            |  |  |
| 003912 <sub>H</sub>                                                                                                                                                                                                                     | PRLL1                                                                                                                                               | PPG1 reload register L                      | XXXXXXXXAB                                                                                    |                     | 304            |  |  |
| 003913 <sub>H</sub>                                                                                                                                                                                                                     | PRLH1                                                                                                                                               | PPG1 reload register H                      | XXXXXXXX <sub>B</sub>                                                                         |                     | 304            |  |  |
| 003914 <sub>H</sub>                                                                                                                                                                                                                     | PRLL2                                                                                                                                               | PPG2 reload register L                      | XXXXXXXXAB                                                                                    | 8/16-bit PPG timer  | 304            |  |  |
| 003915 <sub>H</sub>                                                                                                                                                                                                                     | PRLH2                                                                                                                                               | PPG2 reload register H                      | XXXXXXXXAB                                                                                    |                     | 304            |  |  |
| 003916 <sub>H</sub>                                                                                                                                                                                                                     | PRLL3                                                                                                                                               | PPG3 reload register L                      | XXXXXXXXAB                                                                                    |                     | 304            |  |  |
| 003917 <sub>H</sub>                                                                                                                                                                                                                     | PRLH3                                                                                                                                               | PPG3 reload register H                      | XXXXXXXXAB                                                                                    |                     | 304            |  |  |
| n 003918 <sub>11</sub>                                                                                                                                                                                                                  |                                                                                                                                                     | •                                           | <u>.</u>                                                                                      |                     |                |  |  |
| n 003918 <sub>H</sub><br>to<br>00392F <sub>H</sub>                                                                                                                                                                                      | (Reserved area) *                                                                                                                                   | DataSheet4                                  | U.com                                                                                         |                     |                |  |  |
| to                                                                                                                                                                                                                                      | (Reserved area) *                                                                                                                                   | DataSheet4                                  | U.com                                                                                         |                     |                |  |  |
| to<br>00392F <sub>H</sub><br>003930 <sub>H</sub><br>to                                                                                                                                                                                  | (Reserved area) *                                                                                                                                   |                                             | U.com                                                                                         |                     |                |  |  |
| to<br>$00392F_{\rm H}$<br>$003930_{\rm H}$<br>to<br>$003BFF_{\rm F}$<br>$003C00_{\rm H}$<br>to                                                                                                                                          | (Reserved area) * RAM (general-put                                                                                                                  |                                             | U.com<br>XXXXXXXXB<br>to<br>XXXXXXXXB                                                         |                     | 479            |  |  |
| $\begin{array}{c} to \\ to \\ 00392F_{\rm H} \\ 003930_{\rm H} \\ to \\ 003BFF_{\rm F} \\ 003C00_{\rm H} \\ to \\ 003C0F_{\rm F} \\ 003C10_{\rm H} \\ to \end{array}$                                                                   | (Reserved area) * (RAM (general-put) IDR0 IDR1                                                                                                      | pose RAM)                                   | XXXXXXXXXB<br>to                                                                              |                     | 479            |  |  |
| $\begin{array}{c} to \\ to \\ 00392F_{\rm H} \\ 003930_{\rm H} \\ to \\ 003BFF_{\rm F} \\ 003C00_{\rm H} \\ to \\ 003C0F_{\rm H} \\ 003C10_{\rm H} \\ to \\ 003C13_{\rm H} \\ 003C14_{\rm H} \\ to \end{array}$                         | <pre>(Reserved area)* (Reserved area)* RAM (general-put) IDR0 IDR1 IDR1</pre>                                                                       | pose RAM)<br>ID register 0                  | XXXXXXXXXB<br>to<br>XXXXXXXXB<br>XXXXXXXXB<br>to                                              | CAN controller      |                |  |  |
| $\begin{array}{c} to \\ to \\ 00392F_{\rm H} \\ 003930_{\rm H} \\ to \\ 003BFF_{\rm F} \\ 003C00_{\rm F} \\ to \\ 003C0F_{\rm F} \\ 003C10_{\rm F} \\ to \\ 003C13_{\rm F} \\ 003C14_{\rm F} \\ to \\ 003C18_{\rm F} \\ to \end{array}$ | <ul> <li>(Reserved area) *</li> <li>(Reserved area) *</li> <li>RAM (general-put)</li> <li>IDR0</li> <li>IDR1</li> <li>IDR2</li> <li>IDR3</li> </ul> | pose RAM)<br>ID register 0<br>ID register 1 | XXXXXXXXXB<br>to<br>XXXXXXXXB<br>XXXXXXXXB<br>to<br>XXXXXXXXB<br>XXXXXXXXB<br>to<br>XXXXXXXXB | CAN controller      | 479            |  |  |

# Table B-1 Register Index (6/9)

| Address                                          | Abbreviation of Register Name | Register Name                    | Reset Value                                                 | Resource Name  | Page<br>Number |        |
|--------------------------------------------------|-------------------------------|----------------------------------|-------------------------------------------------------------|----------------|----------------|--------|
| 003C24 <sub>H</sub><br>to<br>003C27 <sub>H</sub> | IDR5                          | ID register 5                    | XXXXXXXXXB<br>to<br>XXXXXXXXB                               |                | 479            |        |
| 003C28 <sub>H</sub><br>to<br>003C2B <sub>H</sub> | IDR6                          | ID register 6                    | XXXXXXXXAB<br>to<br>XXXXXXXXB                               |                | 479            |        |
| 003C2C <sub>H</sub><br>to<br>003C2F <sub>H</sub> | IDR7                          | ID register 7                    | XXXXXXXXXB<br>to<br>XXXXXXXXB                               | -              | 479            |        |
| 003C30 <sub>H</sub><br>003C31 <sub>H</sub>       | DLCR0                         | DLC register 0                   | XXXXXXXXXB<br>XXXXXXXXB                                     |                | 482            |        |
| 003C32 <sub>H</sub><br>003C33 <sub>H</sub>       | DLCR1                         | DLC register 1                   | XXXXXXXXXB<br>XXXXXXXXB                                     |                | 482            |        |
| 003C34 <sub>H</sub><br>003C35 <sub>H</sub>       | DLCR2                         | DLC register 2                   | XXXXXXXXXB<br>XXXXXXXXB                                     |                | 482            |        |
| 003C36 <sub>H</sub><br>003C37 <sub>H</sub>       | DLCR3                         | DLC register 3                   | XXXXXXXX <sub>B</sub><br>XXXXXXX <sub>B</sub>               |                | 482            | DataSt |
| 003C38 <sub>H</sub><br>003C39 <sub>H</sub>       | DLCR4                         | DataSheet4U.co<br>DLC register 4 | <sup>m</sup> XXXXXXXX <sub>B</sub><br>XXXXXXXX <sub>B</sub> | CAN controller | 482            |        |
| 003C3A <sub>H</sub><br>003C3B <sub>H</sub>       | DLCR5                         | DLC register 5                   | XXXXXXXX <sub>B</sub><br>XXXXXXX <sub>B</sub>               |                | 482            |        |
| 003C3C <sub>H</sub><br>003C3D <sub>H</sub>       | DLCR6                         | DLC register 6                   | XXXXXXXXAB<br>XXXXXXXXB                                     |                | 482            |        |
| 003C3E <sub>H</sub><br>003C3F <sub>H</sub>       | DLCR7                         | DLC register 7                   | XXXXXXXXAB<br>XXXXXXXXB                                     |                | 482            |        |
| 003C40 <sub>H</sub><br>to<br>003C47 <sub>H</sub> | DTR0                          | Data register 0                  | XXXXXXXX <sub>B</sub><br>to<br>XXXXXXXX <sub>B</sub>        |                | 483            |        |
| 003C48 <sub>H</sub><br>to<br>003C4F <sub>H</sub> | DTR1                          | Data register 1                  | XXXXXXXX <sub>B</sub><br>to<br>XXXXXXXX <sub>B</sub>        |                | 483            |        |
| 003C50 <sub>H</sub><br>to<br>003C57 <sub>H</sub> | DTR2                          | Data register 2                  | XXXXXXXXXB<br>to<br>XXXXXXXXB                               |                | 483            |        |
| 003C58 <sub>H</sub><br>to<br>003C5F <sub>H</sub> | DTR3                          | Data register 3                  | XXXXXXXXXB<br>to<br>XXXXXXXXB                               |                | 483            |        |

## Table B-1 Register Index (7/9)

DataSheet4U.com

et4U.com

### APPENDIX

| Address                                          | Abbreviation of Register Name | Register Name                                   | Reset Value                                    | Resource Name  | Page<br>Number |
|--------------------------------------------------|-------------------------------|-------------------------------------------------|------------------------------------------------|----------------|----------------|
| 003C60 <sub>H</sub><br>to<br>003C67 <sub>H</sub> | DTR4                          | Data register 4                                 | XXXXXXXXXB<br>to<br>XXXXXXXXB                  |                | 483            |
| 003C68 <sub>H</sub><br>to<br>003C6F <sub>H</sub> | DTR5                          | Data register 5                                 | XXXXXXXXXB<br>to<br>XXXXXXXXB                  |                | 483            |
| 003C70 <sub>H</sub><br>to<br>003C77 <sub>H</sub> | DTR6                          | Data register 6                                 | XXXXXXXXXB<br>to<br>XXXXXXXXB                  | CAN controller | 483            |
| 003C78 <sub>H</sub><br>to<br>003C7F <sub>H</sub> | DTR7                          | Data register 7                                 | XXXXXXXXXB<br>to<br>XXXXXXXXB                  |                | 483            |
| 003C80 <sub>H</sub><br>to<br>003CFF <sub>H</sub> | (Reserved area)*              |                                                 | 1                                              |                |                |
| 003D00 <sub>H</sub><br>003D01 <sub>H</sub>       | CSR                           | Control status register                         | CAN controller                                 | 437/439        |                |
| 003D02 <sub>H</sub>                              | LEIR                          | Last event indicate register                    | 000XX000 <sub>B</sub>                          |                | 442            |
| 003D03 <sub>H</sub>                              | (Reserved area) *             | I                                               | I                                              | 1              |                |
| 003D04 <sub>H</sub><br>003D05 <sub>H</sub>       | RTEC                          | Receive/transmit error counter                  | 00000000 <sub>B</sub><br>00000000 <sub>B</sub> |                | 444            |
| 003D06 <sub>H</sub><br>003D07 <sub>H</sub>       | BTR                           | Bit timing register                             | 11111111 <sub>B</sub><br>X1111111 <sub>B</sub> | CAN controller | 446            |
| 003D08 <sub>H</sub>                              | IDER                          | IDE register                                    | XXXXXXXXB                                      |                | 452            |
| 003D09 <sub>H</sub>                              | (Reserved area) *             | I                                               | I                                              | 1              |                |
| 003D0A <sub>H</sub>                              | TRTRR                         | Transmission RTR register                       | 00000000 <sub>B</sub>                          | CAN controller | 456            |
| 003D0B <sub>H</sub>                              | (Reserved area) *             | 1                                               | 1                                              | 1              |                |
| 003D0C <sub>H</sub>                              | RFWTR                         | Remote frame receiving wait register            | XXXXXXXX                                       | CAN controller | 458            |
| 003D0D <sub>H</sub>                              | (Reserved area) *             | •                                               | •                                              | • • • •        |                |
| 003D0E <sub>H</sub>                              | TIER                          | Transmission complete interrupt enable register | 00000000 <sub>B</sub>                          | CAN controller | 464            |
| $003D0F_{\rm H}$                                 | (Reserved area) *             |                                                 |                                                |                |                |
| 003D10 <sub>H</sub><br>003D11 <sub>H</sub>       | AMSR                          | Acceptance mask select register                 | XXXXXXXXXB<br>to<br>XXXXXXXXB                  | CAN controller | 474            |

# Table B-1 Register Index (8/9)

DataSheet4U.com

et4U.com

638

www.DataSheet4U.com

| Address                                          | Abbreviation of Register Name | Register Name              | Reset Value                   | Resource Name   | Page<br>Number |
|--------------------------------------------------|-------------------------------|----------------------------|-------------------------------|-----------------|----------------|
| 003D12 <sub>H</sub><br>003D13 <sub>H</sub>       | (Reserved area) *             |                            |                               |                 |                |
| 003D14 <sub>H</sub><br>to<br>003D17 <sub>H</sub> | AMR0                          | Acceptance mask register 0 | XXXXXXXXXB<br>to<br>XXXXXXXXB | CAN controller  | 476            |
| 003D18 <sub>H</sub><br>to<br>003D1B <sub>H</sub> | AMR1                          | Acceptance mask register 1 | XXXXXXXXXB<br>to<br>XXXXXXXXB | CAIV controller | 476            |
| 003D1C <sub>H</sub><br>to<br>003DFF <sub>H</sub> | (Reserved area) *             |                            |                               |                 |                |
| 003E00 <sub>H</sub><br>to<br>003EFF <sub>H</sub> | (Reserved area) *             |                            |                               |                 |                |
| 003FF0 <sub>H</sub><br>to<br>003FFF <sub>H</sub> | (Reserved area) *             |                            |                               |                 |                |

#### Table B-1 Register Index (9/9)

et4U.com

Explanation of reset value

0: The reset value of this bit is 0.

1: The reset value of this bit is 1.

X: The reset value of this bit is unfixed.

\*: Do not write the data to "(Reserved area)". If the data is read from "(Reserved area)", it is undefined values.

DataSheet4U.com

# **APPENDIX C** Pin Function Index

# ■ Pin Function Index

#### Table C-1 Pin Function Index (1/2)

|            | Pin<br>Number<br>M05 | Pin Name         | Circuit<br>Type | Function                                             | Page<br>Number for<br>Function | Page<br>Number for<br>Block |            |
|------------|----------------------|------------------|-----------------|------------------------------------------------------|--------------------------------|-----------------------------|------------|
|            |                      | 43.7             |                 |                                                      | Explanation                    | Diagram                     | -          |
|            | 1                    | AV <sub>CC</sub> | -               | V <sub>CC</sub> input pin for A/D converter          | 350                            | 349                         | _          |
|            | 2                    | AVR              | -               | Vref + input pin for A/D converter                   | 350                            | 349                         |            |
|            | 3 to 10              | P50 to P57       | Е               | General-purpose I/O ports                            | 181                            | 182                         | _          |
| -          |                      | AN0 to AN7       |                 | Analog input pins for A/D converter                  | 350                            | 349                         |            |
|            | 11                   | P37              | D               | General-purpose I/O port                             | 171                            | 172                         |            |
|            | 11                   | ADTG             |                 | External trigger input pin for A/D converter         | 352                            | 349                         |            |
| t4U.com    | 12                   | P20              | D               | General-purpose I/O port                             | 166                            | 167                         |            |
|            | 12                   | TIN0             |                 | Event input pin for reload timer 0                   | 248                            | 246                         | 1          |
|            | 13                   | P21              | D               | General-purpose I/O port                             | 166                            | 167                         | 1          |
|            | 13                   | ТОТО             |                 | Event output pin for reload timer 0                  | 248                            | 246                         | - L Ch     |
|            | 14                   | P22              | D               | General-purpose I/O port                             | 166                            | 167                         | DataShe    |
|            |                      | TIN1             |                 | Event input pin for reload timer 1                   | 248                            | 246                         |            |
|            | 15                   | P23              | D               | General-purpose I/O ports                            | 166                            | 167                         |            |
|            | 15                   | TOT1             |                 | Event output pin for reload timer 1                  | 248                            | 246                         |            |
|            | 164-10               | P24 to P27       | D               | General-purpose I/O ports                            | 166                            | 167                         |            |
|            | 16 to 19             | INT4 to INT7     | D               | External interrupt input pins                        | 331                            | 329                         | -          |
|            | 20                   | MD2              | F               | Operation mode select input pin                      | 150                            | _                           |            |
|            | 21                   | MD1              | С               | Operation mode select input pin                      | 150                            | _                           |            |
|            | 22                   | MD0              | С               | Operation mode select input pin                      | 150                            | _                           |            |
|            | 23                   | RST              | В               | External reset input pin                             | 103                            | 103                         |            |
|            | 24                   | V <sub>CC</sub>  |                 | Power (5 V) input pin                                | _                              | _                           |            |
|            | 25                   | V <sub>SS</sub>  | _               | Power (0 V) input pin                                | _                              | _                           |            |
|            | 26                   | С                | _               | Power stabilization capacitance pin                  | _                              | _                           |            |
|            | 27                   | X0               | А               | High-speed oscillation pin                           | 109                            | 112                         |            |
|            | 28                   | X1               | А               | High-speed oscillation pin                           | 109                            | 112                         | 1          |
|            |                      | P10 to P13       |                 | General-purpose I/O ports                            | 161                            | 162                         | 1          |
|            | 29 to 32             | IN0 to IN3       | D               | Trigger input pins for input capture channels 0 to 3 | 222                            | 220                         |            |
|            | 224-26               | P14 to P17       | D               | General-purpose I/O ports                            | 161                            | 162                         | 1          |
| DataSheet4 | 33 to 36             | PPG0 to PPG3     | D               | Output pins for PPG timers 01 and 23                 | 296                            | 290/293<br>www.DataSh       | eet411.com |

| Pin<br>Number | Pin Name         | Circuit<br>Type | Function                                    | Page<br>Number for<br>Function | Page<br>Number for<br>Block |
|---------------|------------------|-----------------|---------------------------------------------|--------------------------------|-----------------------------|
| M05           |                  | 51 -            |                                             | Explanation                    | Diagram                     |
| 37            | P40              | D               | General-purpose I/O port                    | 176                            | 177                         |
| 57            | SIN1             |                 | Serial data input pin for UART1             | 383                            | 380                         |
| 38            | P41              | D               | General-purpose I/O port                    | 176                            | 177                         |
| 30            | SCK1             |                 | Serial clock input/output pin for UART1     | 383                            | 380                         |
| 39            | P42              | D               | General-purpose I/O port                    | 176                            | 177                         |
| 39            | SOT1             |                 | Serial data output pin for UART1            | 383                            | 380                         |
| 40            | P43              | D               | General-purpose I/O port                    | 176                            | 177                         |
| 40            | TX               |                 | Transmit output pin for CAN controller      | 433                            | 429                         |
| 41            | P44              | D               | General-purpose I/O port                    | 176                            | 177                         |
| 41            | RX               |                 | Receive input pin for CAN controller        | 433                            | 429                         |
| 42 to 45      | P30 to P33       | D               | General-purpose I/O port                    | 171                            | 172                         |
| 46            | X0A*             |                 | Low-speed oscillation pin                   | 109                            | 112                         |
| 40            | P35*             | A               | General-purpose I/O port                    | 171                            | 172                         |
| 47            | X1A*             | А               | Low-speed oscillation pin                   | 109                            | 112                         |
| 4/            | P36*             | A               | General-purpose I/O port                    | 171                            | 172                         |
| 48            | AV <sub>SS</sub> | -               | V <sub>SS</sub> input pin for A/D converter | 350                            | 349                         |

#### Table C-1 Pin Function Index (2/2)

et4U.com

\*:MB90387, MB90F387: X1A, X0A MB90387S, MB90F387S: P36, P35

DataSheet4U.com

www.DataSheet4U.com

# **APPENDIX D** Interrupt Vector Index

# ■ Interrupt Vector Index

## Table D-1 Interrupt Vector Index (1/2)

| Interrupt | Interrupt Factor                                                | Interru      | pt Control                          | Addre                            | Address in Vector Table |                     |        |
|-----------|-----------------------------------------------------------------|--------------|-------------------------------------|----------------------------------|-------------------------|---------------------|--------|
| Number    | Interrupt Factor                                                | ICR          | Address                             | Low                              | Middle                  | High                | Number |
| #08       | Reset                                                           | _            | -                                   | FFFFDC <sub>H</sub>              | FFFFDD <sub>H</sub>     | FFFFDE <sub>H</sub> | 99     |
| #09       | INT9 instruction                                                | -            | _                                   | FFFFD8 <sub>H</sub>              | FFFFD9 <sub>H</sub>     | FFFFDA <sub>H</sub> | 508    |
| #10       | Exception processing                                            | _            | _                                   | FFFFD4 <sub>H</sub>              | FFFFD5 <sub>H</sub>     | FFFFD6 <sub>H</sub> | 91     |
| #11       | CAN controller receive completion                               |              |                                     | FFFFD0 <sub>H</sub>              | FFFFD1 <sub>H</sub>     | FFFFD2 <sub>H</sub> | 484    |
| #12       | CAN controller receive<br>completion/<br>node status transition | ICR00        | 0000B0 <sub>H</sub>                 | FFFFCC <sub>H</sub>              | FFFFCD <sub>H</sub>     | FFFFCE <sub>H</sub> | 484    |
| #13       | Reserved                                                        | ICD01        | 0000B1 <sub>H</sub>                 | FFFFC8 <sub>H</sub>              | FFFFC9 <sub>H</sub>     | FFFFCA <sub>H</sub> | -      |
| #14       | Reserved                                                        | ICR01        | 0000B1H                             | FFFFC4 <sub>H</sub>              | FFFFC5 <sub>H</sub>     | FFFFC6 <sub>H</sub> | _      |
| #15       | CAN wake-up                                                     | ICR02<br>Dat | 000082                              | FFFFC0 <sub>H</sub>              | FFFFC1 <sub>H</sub>     | FFFFC2 <sub>H</sub> | 62     |
| #16       | Timebase timer                                                  |              | 0000B2 <sub>H</sub><br>ataSheet4U.o | <sup>⊙</sup> FFFFBC <sub>H</sub> | FFFFBD <sub>H</sub>     | FFFFBE <sub>H</sub> | 195    |
| #17       | 16-bit reload timer 0                                           | ICD02        | 0000₽2                              | FFFFB8 <sub>H</sub>              | FFFFB9 <sub>H</sub>     | FFFFBA <sub>H</sub> | 257    |
| #18       | 8/10-bit A/D converter                                          | - ICR03      | 0000B3 <sub>H</sub>                 | FFFFB4 <sub>H</sub>              | FFFFB5 <sub>H</sub>     | FFFFB6 <sub>H</sub> | 364    |
| #19       | 16-bit free-run timer<br>overflow                               | ICR04        | 0000B4 <sub>H</sub>                 | FFFFB0 <sub>H</sub>              | FFFFB1 <sub>H</sub>     | FFFFB2 <sub>H</sub> | 233    |
| #20       | Reserved                                                        |              |                                     | FFFFAC <sub>H</sub>              | FFFFAD <sub>H</sub>     | FFFFAE <sub>H</sub> | _      |
| #21       | Reserved                                                        |              |                                     | FFFFA8 <sub>H</sub>              | FFFFA9 <sub>H</sub>     | FFFFAA <sub>H</sub> | -      |
| #22       | PPG timer channel 0/1<br>underflow                              | ICR05        | 0000B5 <sub>H</sub>                 | FFFFA4 <sub>H</sub>              | FFFFA5 <sub>H</sub>     | FFFFA6 <sub>H</sub> | 305    |
| #23       | Input capture 0 fetched                                         |              |                                     | FFFFA0 <sub>H</sub>              | FFFFA1 <sub>H</sub>     | FFFFA2 <sub>H</sub> | 233    |
| #24       | External interrupt 4 (INT4)/<br>external interrupt 5 (INT5)     | ICR06        | 0000B6 <sub>H</sub>                 | FFFF9C <sub>H</sub>              | FFFF9D <sub>H</sub>     | FFFF9E <sub>H</sub> | 328    |
| #25       | Input capture 1 fetched                                         |              |                                     | FFFF98 <sub>H</sub>              | FFFF99 <sub>H</sub>     | FFFF9A <sub>H</sub> | 233    |
| #26       | PPG timer channel 2/3<br>underflow                              | ICR07        | 0000B7 <sub>H</sub>                 | FFFF94 <sub>H</sub>              | FFFF95 <sub>H</sub>     | FFFF96 <sub>H</sub> | 305    |
| #27       | External interrupt 6 (INT6)/<br>external interrupt 7 (INT7)     | ICR08        | 0000B8 <sub>H</sub>                 | FFFF90 <sub>H</sub>              | FFFF91 <sub>H</sub>     | FFFF92 <sub>H</sub> | 328    |
| #28       | Watch timer                                                     |              |                                     | FFFF8C <sub>H</sub>              | FFFF8D <sub>H</sub>     | FFFF8E <sub>H</sub> | 281    |

DataSheet4U.com

et4U.com

DataShe

| Interrupt<br>Number | Interrupt Factor                                   | Interru | pt Control          | Addre                 | Address in Vector Table |                     |        |
|---------------------|----------------------------------------------------|---------|---------------------|-----------------------|-------------------------|---------------------|--------|
| Number              | Interrupt Factor                                   | ICR     | Address             | Low                   | Middle                  | High                | Number |
| #29                 | Reserved                                           |         |                     | FFFF88 <sub>H</sub>   | FFFF89 <sub>H</sub>     | FFFF8A <sub>H</sub> | -      |
| #30                 | Input capture 2 fetched<br>Input capture 3 fetched | ICR09   | 0000B9 <sub>H</sub> | FFFF84 <sub>H</sub>   | FFFF85 <sub>H</sub>     | FFFF86 <sub>H</sub> | 233    |
| #31                 | Reserved                                           | ICR10   | 0000B A             | FFFF80 <sub>H</sub>   | FFFF81 <sub>H</sub>     | FFFF82 <sub>H</sub> | _      |
| #32                 | Reserved                                           |         | 0000BA <sub>H</sub> | FFFF7C <sub>H</sub>   | FFFF7D <sub>H</sub>     | FFFF7E <sub>H</sub> | _      |
| #33                 | Reserved                                           | ICR11   | 0000BB <sub>H</sub> | FFFF78 <sub>H</sub>   | FFFF79 <sub>H</sub>     | FFFF7A <sub>H</sub> | -      |
| #34                 | Reserved                                           |         | OOODBH              | FFFF74 <sub>H</sub>   | FFFF75 <sub>H</sub>     | FFFF76 <sub>H</sub> | _      |
| #35                 | Reserved                                           | ICR12   | 0000BC <sub>H</sub> | FFFF70 <sub>H</sub>   | FFFF71 <sub>H</sub>     | FFFF72 <sub>H</sub> | _      |
| #36                 | 16-bit reload timer 1                              | ICK12   |                     | FFFF6C <sub>H</sub>   | FFFF6D <sub>H</sub>     | FFFF6E <sub>H</sub> | 257    |
| #37                 | UART1 receive                                      | ICR13   | 0000BD <sub>H</sub> | FFFF68 <sub>H</sub>   | FFFF69 <sub>H</sub>     | FFFF6A <sub>H</sub> | 395    |
| #38                 | UART1 transmit                                     | ICKIS   | 0000DD <sub>H</sub> | FFFF64 <sub>H</sub>   | FFFF65 <sub>H</sub>     | FFFF66 <sub>H</sub> | 395    |
| #39                 | Reserved                                           | ICR14   | 0000BE <sub>H</sub> | FFFF60 <sub>H</sub>   | FFFF61 <sub>H</sub>     | FFFF62 <sub>H</sub> | _      |
| #40                 | Reserved                                           |         | itaSheet4U.c        | orFFFF5C <sub>H</sub> | FFFF5D <sub>H</sub>     | FFFF5E <sub>H</sub> | _      |
| #41                 | Flash memory                                       |         |                     | FFFF58 <sub>H</sub>   | FFFF59 <sub>H</sub>     | FFFF5A <sub>H</sub> | 528    |
| #42                 | Delayed interrupt generation module                | ICR15   | 0000BF <sub>H</sub> | FFFF54 <sub>H</sub>   | FFFF55 <sub>H</sub>     | FFFF56 <sub>H</sub> | 320    |

### Table D-1 Interrupt Vector Index (2/2)

et4U.com

www.DataSheet4U.com

#### APPENDIX

et4U.com

DataSheet4U.com

DataSheet4U.com

644

DataSheet4U.com

DataShe

The index follows on the next page. This is listed in alphabetic order.

et4U.com

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

# Index

#### Numerics

|          | 16-bit Free-run Timer                                       |           |   |
|----------|-------------------------------------------------------------|-----------|---|
|          | Block Diagram of 16-bit Free-run Timer                      | 218       |   |
|          | Operation of 16-bit Free-run Timer                          |           |   |
|          | Operation Timing of 16-bit Free-run Timer                   |           |   |
|          | Setting of 16-bit Free-run Timer                            |           | 2 |
|          | 16-bit Input/Output Timer                                   |           |   |
|          | 16-bit Input/Output Timer Interrupts and EI <sup>2</sup> OS |           |   |
|          | Function                                                    | 222       | 2 |
|          |                                                             | 233       |   |
|          | Block Diagram of 16-bit Input/Output Timer                  | 047       |   |
|          |                                                             |           | • |
|          | Block Diagram of Pins for 16-bit Input/Output T             |           | ` |
|          |                                                             |           |   |
|          | Configuration of 16-bit Input/Output Timer                  |           |   |
|          | Correspondence between 16-bit Input/Output Tir              | ner       | Ę |
|          | Interrupt and EI <sup>2</sup> OS                            |           |   |
|          | Functions of 16-bit Input/Output Timer                      | 216       |   |
|          | Generation of Interrupt Request from                        |           |   |
|          | 16-bit Input/Output Timer                                   | 224       |   |
|          | Interrupt Control Bits and Interrupt Factors of             |           |   |
| et4U.com | 16-bit Input/Output Timer                                   | 233       | 8 |
|          | List of Registers and Reset Values of                       |           |   |
|          | 16-bit Input/Output Timer                                   | 223taShee | _ |
|          | Pins of 16-bit Input/Output Timer                           |           |   |
|          | Precautions when 16-bit Input/Output Timer                  |           | C |
|          | 16-bit PPG Output Operation Mode                            |           |   |
|          | Setting for 16-bit PPG Output Operation Mode                |           |   |
|          | Setting for To-bit FFG Output Operation Mode                | 210       |   |
|          |                                                             | 310       |   |
|          | 16-bit Reload Registers                                     |           |   |
|          | 16-bit Reload Registers (TMRLR0,TMRLR1)                     |           |   |
|          |                                                             | 256       |   |
|          | 16-bit Reload Timer                                         |           |   |
|          | Baud Rate by Internal Timer                                 |           |   |
|          | (16-bit Reload Timer Output)                                | 405       |   |
|          | Block Diagram for Pins of 16-bit Reload Timer               |           |   |
|          |                                                             | 248       |   |
|          | Block Diagram of 16-bit Reload Timer                        | 246       |   |
|          | Correspondence between 16-bit Reload Timer                  |           |   |
|          | Interrupt and EI <sup>2</sup> OS                            | 257       |   |
|          | EI <sup>2</sup> OS Function of 16-bit Reload Timer          | 257       |   |
|          | Generation of Interrupt Request from                        |           | 8 |
|          | 16-bit Reload Timer                                         | 250       |   |
|          | Interrupts of 16-bit Reload Timer                           |           |   |
|          | List of Registers and Reset Values of                       | -         |   |
|          | 16-bit Reload Timer                                         | 249       |   |
|          | Operation Modes of 16-bit Reload Timer                      |           |   |
|          | Pins of 16-bit Reload Timer                                 |           |   |
|          | Precautions when Using 16-bit Reload Timer                  | 270       |   |
|          | Frecautions when Osing 10-on Reload Thile                   | 268       |   |
|          |                                                             |           |   |
| DataShee | Setting of 16-bit Reload Timer                              | 200       |   |

| 16-bit Timer Register<br>16-bit Timer Registers (TMR0,TMR1) | 255    |
|-------------------------------------------------------------|--------|
|                                                             |        |
| Operating State of 16-bit Timer Register                    | 259    |
| Operation as 16-bit Timer Register Underflows               | 000    |
| 261 24-bit Operand                                          | , 266  |
| Linear Addressing by Specifying 24-bit Operand              | d      |
|                                                             |        |
| 2-channel Independent Operation Mode                        |        |
| Setting for 8-bit PPG Output 2-channel Indepe               | endent |
| Operation Mode                                              | 308    |
| 32-bit Register                                             |        |
| Addressing by Indirect-specifying 32-bit Regist             | er     |
|                                                             |        |
|                                                             |        |
| 512 Kbit Flash Memory                                       | 500    |
| Features of 512 Kbit Flash Memory                           |        |
| Overview of 512 Kbit Flash Memory                           |        |
| Program Example of 512 Kbit Flash Memory                    |        |
| Sector Configuration of 512 Kbit Flash Memory               |        |
|                                                             | 529    |
| 8+8-bit PPG Output Operation Mode                           |        |
| Setting for 8+8-bit PPG Output Operation Mode               | 9      |
| et4U.com                                                    | 313    |
| 8-/10-bit A/D Converter                                     |        |
| 8-/10-bit A/D Converter Interrupt and EI <sup>2</sup> OS    |        |
| 1<br>                                                       | 364    |
| A/D-converted Data Protection Function                      |        |
| in 8-/10-bit A/D Converter                                  | 373    |
| Block Diagram of 8-/10-bit A/D Converter                    |        |
| Conversion Modes of 8-/10-bit A/D Converter                 |        |
|                                                             |        |
| EI <sup>2</sup> OS Function of 8-/10-bit A/D Converter      |        |
| Function of 8-/10-bit A/D Converter                         |        |
| Generation of Interrupt from 8-/10-bit A/D Con              |        |
|                                                             |        |
| List of Registers and Reset Values of                       |        |
| 8-/10-bit A/D Converter                                     | 353    |
| Pins of 8-/10-bit A/D Converter                             |        |
| Precautions when Using 8-/10-bit A/D Converter              |        |
|                                                             |        |
|                                                             |        |
| 8-/16-bit PPG Timer                                         | •      |
| 8-/16-bit PPG Timer Interrupt and EI <sup>2</sup> OS Funct  |        |
| $\mathbf{D}_{1} + \mathbf{D}_{2}$                           |        |
| Block Diagram of 8-/16-bit PPG Timer 0                      |        |
| Block Diagram of 8-/16-bit PPG Timer 1                      |        |
| Block Diagram of 8-/16-bit PPG Timer Pins                   | 296    |
| Correspondence between 8-/16-bit PPG Timer                  | 005    |
| Interrupt and EI <sup>2</sup> OS                            |        |
| Functions of 8-/16-bit PPG Timer                            | 286    |

DataShe

| Generation of Interrupt Request from                           |     |
|----------------------------------------------------------------|-----|
| 8-/16-bit PPG Timer                                            | 297 |
| Interrupts of 8-/16-bit PPG Timer                              | 305 |
| List of Registers and Reset Values of                          |     |
| 8-/16-bit PPG Timer                                            | 297 |
| Operation Modes of 8-/16-bit PPG Timer                         | 286 |
| Operation of 8-/16-bit PPG Timer                               | 307 |
| Pins of 8-/16-bit PPG Timer                                    | 296 |
| Precautions when Using 8-/16-bit PPG Timer                     |     |
|                                                                | 316 |
| 8-bit PPG Output                                               |     |
| Setting for 8-bit PPG Output 2-channel Indep<br>Operation Mode |     |

Α

| 297          | А                                                         |            |
|--------------|-----------------------------------------------------------|------------|
| 305          | Accumulator (A)                                           | 6          |
|              |                                                           | 0          |
| 297          | A/D Control Status Register                               |            |
|              | A/D Control Status Register (High) (ADCS: H)              | . 1        |
| 307          |                                                           | 4          |
| 296          | A/D Control Status Register (Low) (ADCS: L)               |            |
| ler          |                                                           | δ          |
| 316          | A/D Converter                                             |            |
|              | 8-/10-bit A/D Converter Interrupt and EI <sup>2</sup> OS  |            |
| dependent    |                                                           | 4          |
|              | A/D-converted Data Protection Function                    |            |
|              | in 8-/10-bit A/D Converter                                | 3          |
|              | Block Diagram of 8-/10-bit A/D Converter 34               | .9         |
|              | Conversion Modes of 8-/10-bit A/D Converter               |            |
|              |                                                           | 8          |
|              | EI <sup>2</sup> OS Function of 8-/10-bit A/D Converter 36 |            |
|              | Function of 8-/10-bit A/D Converter34                     |            |
|              | Generation of Interrupt from 8-/10-bit A/D Converted      |            |
|              |                                                           |            |
|              | Interrupt of A/D Converter                                |            |
|              | List of Registers and Reset Values of                     | -          |
|              | 8-/10-bit A/D Converter                                   | 3          |
|              | Pins of 8-/10-bit A/D Converter                           | -          |
|              | Precautions when Using 8-/10-bit A/D Converter            | 2          |
|              |                                                           | 5 - U Cho  |
|              |                                                           | 5 DataShe  |
| DataShoot411 | A/D Data Register                                         | 0          |
| DataSheet40. | A/D Data Register (High) (ADCR: H)                        |            |
|              | A/D Data Register (Low) (ADCR: L)                         | ( <b>I</b> |
|              | A/D-converted Data                                        |            |
|              | A/D-converted Data Protection Function                    |            |
|              | in 8-/10-bit A/D Converter37                              | 3          |
|              | Acceptance Mask Register                                  |            |
|              | Acceptance Mask Register (AMR) 47                         | 6          |
|              | Acceptance Mask Select Register                           |            |
|              | Acceptance Mask Select Register (AMSR) 47                 | 4          |
|              | Access Space                                              | •          |
|              | •                                                         | 0          |
|              | Bank Registers and Access Space2                          | .9         |
|              | Accumulator                                               |            |
|              | Accumulator (A)3                                          | 6          |
|              | ADB                                                       |            |
|              | Additional Bank Register (ADB)4                           |            |
|              | Bank Select Prefix (PCB,DTB,ADB,SPB)5                     | 3          |
|              | ADCR                                                      |            |
|              | A/D Data Register (High) (ADCR: H)                        | 9          |
|              | A/D Data Register (Low) (ADCR: L)                         |            |
|              | ADCS                                                      |            |
|              |                                                           |            |
|              | A/D Control Status Register (High) (ADCS: H)              | 1          |
|              | A/D Control Status Register (Low) (ADCS: L)               | 7          |
|              |                                                           | 6          |
|              |                                                           | 0          |
|              | Continuous Conversion Mode                                | · E        |
|              | (ADCS: MD1,MD0= "10 <sub>B</sub> ")36                     |            |
|              | www.DataSh                                                | eet4U.com  |

et4U.com

|          | Pause-conversion Mode (ADCS: MD1,MD0= "11                                                                                 |                                                                                 |
|----------|---------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
|          | Single Conversion Mode (ADCS: MD1,MD0=                                                                                    |                                                                                 |
|          | "00 <sub>B</sub> " or "01 <sub>B</sub> ")                                                                                 | 365                                                                             |
|          | Additional Bank Register<br>Additional Bank Register (ADB)                                                                | . 49                                                                            |
|          | Address                                                                                                                   |                                                                                 |
|          | Effective Address Field                                                                                                   | 590                                                                             |
|          | Address Detection Control Register                                                                                        |                                                                                 |
|          | Address Detection Control Register (PACSR)                                                                                | 511                                                                             |
|          | Address Match Detection Function                                                                                          |                                                                                 |
|          | Block Diagram of Address Match Detection Func                                                                             |                                                                                 |
|          | List of Registers and Reset Values of Address                                                                             |                                                                                 |
|          | Match Detection Function<br>Operation of Address Match Detection Function                                                 | 510                                                                             |
|          |                                                                                                                           | 515                                                                             |
|          | Operation of Address Match Detection Function<br>at Storing Patch Program in E <sup>2</sup> PROM                          |                                                                                 |
|          |                                                                                                                           | 519                                                                             |
|          | Overview of Address Match Detection Function                                                                              | 508                                                                             |
|          | Program Example for Address Match Detection<br>Function                                                                   |                                                                                 |
|          |                                                                                                                           |                                                                                 |
| et4U.com | Addressing                                                                                                                |                                                                                 |
| et4U.com | Addressing                                                                                                                |                                                                                 |
| et4U.com | Addressing<br>Addressing by Indirect-specifying 32-bit Register                                                           | Data                                                                            |
| et4U.com | Addressing<br>Addressing by Indirect-specifying 32-bit Register                                                           | Data<br>. 28                                                                    |
| et4U.com | Addressing<br>Addressing by Indirect-specifying 32-bit Register<br>Bank Addressing and Default Space<br>Direct Addressing | Data<br>. 28<br>. 30<br>574                                                     |
| et4U.com | Addressing                                                                                                                | Data<br>. 28<br>. 30<br>574<br>580                                              |
| et4U.com | Addressing                                                                                                                | Data<br>. 28<br>. 30<br>574<br>580                                              |
| et4U.com | Addressing                                                                                                                | Data<br>. 28<br>. 30<br>574<br>580<br>. 27                                      |
| et4U.com | Addressing                                                                                                                | Data<br>. 28<br>. 30<br>574<br>580<br>. 27                                      |
| et4U.com | Addressing                                                                                                                | Data<br>. 28<br>. 30<br>574<br>580<br>. 27<br>362                               |
| et4U.com | Addressing                                                                                                                | Data<br>. 28<br>. 30<br>574<br>580<br>. 27<br>362                               |
| et4U.com | Addressing                                                                                                                | Data<br>. 28<br>. 30<br>574<br>580<br>. 27<br>362<br>548                        |
| et4U.com | Addressing                                                                                                                | Data<br>. 28<br>. 30<br>574<br>580<br>. 27<br>362<br>548<br>476                 |
| et4U.com | Addressing                                                                                                                | Data<br>. 28<br>. 30<br>574<br>580<br>. 27<br>362<br>548<br>476                 |
| et4U.com | Addressing                                                                                                                | Data<br>. 28<br>. 30<br>574<br>580<br>. 27<br>362<br>548<br>476<br>474          |
| et4U.com | Addressing                                                                                                                | Data<br>. 28<br>. 30<br>574<br>580<br>. 27<br>362<br>548<br>476<br>474          |
| et4U.com | Addressing                                                                                                                | Data<br>28<br>30<br>574<br>580<br>27<br>362<br>548<br>476<br>474<br>362         |
| et4U.com | Addressing                                                                                                                | Data<br>28<br>30<br>574<br>580<br>27<br>362<br>548<br>476<br>474<br>362<br>. 58 |

## В

| В | а | n | k |
|---|---|---|---|
|   |   |   |   |

| Access to FF Bank by ROM Mirroring Function |     |
|---------------------------------------------|-----|
|                                             | 524 |
| DataSheet4U.Register Bank                   |     |

| Setting of Each Bank and Data Access                |               |
|-----------------------------------------------------|---------------|
| Bank Addressing                                     |               |
| Bank Addressing and Default Space                   |               |
| Linear Addressing and Bank Addressing               |               |
| Bank Registers                                      |               |
| Bank Registers and Access Space                     |               |
| <b>č</b> 1                                          |               |
| Bank Select Prefix                                  |               |
| Bank Select Prefix (PCB,DTB,ADB,SPB)53              |               |
| BAP                                                 |               |
| Buffer Address Pointer (BAP)86                      |               |
| Basic Configuration                                 |               |
| Basic Configuration of Serial Programming           |               |
| Connection for MB90F387/S558                        |               |
| Baud Rate                                           |               |
|                                                     |               |
| Baud Rate by Dedicated Baud Rate Generator          |               |
|                                                     |               |
| Baud Rate by External Clock                         |               |
| Baud Rate by Internal Timer                         |               |
| (16-bit Reload Timer Output)405                     |               |
| Select of UART1 Baud Rate400                        |               |
| Bidirectional Communication                         |               |
| Bidirectional Communication Function                |               |
| Bit Timing                                          |               |
| Calculation of Bit Timing                           |               |
| -                                                   |               |
| Bit Timing Register                                 | DataShe       |
| Bit Timing Register (BTR)446                        | Dataon        |
| aShe Bit Timing Segment                             |               |
| Definition of Bit Timing Segment447                 |               |
| Block Diagram                                       |               |
| Block Diagram for Pins of 16-bit Reload Timer       |               |
|                                                     |               |
| Block Diagram for Pins of CAN Controller433         |               |
| Block Diagram of 16-bit Free-run Timer              |               |
| Block Diagram of 16-bit Input/Output Timer217       |               |
| Block Diagram of 16-bit Reload Timer                |               |
| Block Diagram of 8-/10-bit A/D Converter            |               |
| Block Diagram of 8-/16-bit PPG Timer 0              |               |
|                                                     |               |
| Block Diagram of 8-/16-bit PPG Timer 1              |               |
| Block Diagram of 8-/16-bit PPG Timer Pins296        |               |
| Block Diagram of Address Match Detection Function   |               |
|                                                     |               |
| Block Diagram of CAN Controller                     |               |
| Block Diagram of Clock Generation Section112        |               |
| Block Diagram of Delayed Interrupt Generation       |               |
| Module                                              |               |
| Block Diagram of DTP/External Interrupt             |               |
| Block Diagram of External Reset Pin103              |               |
| Block Diagram of Input Capture220                   |               |
| Block Diagram of Low-power Consumption Circuit      |               |
|                                                     |               |
| Block Diagram of MB90385 Series8                    |               |
| Block Diagram of Pins                               |               |
| Block Diagram of Pins for 16-bit Input/Output Timer |               |
|                                                     |               |
| www.Da                                              | taSheet4U.com |
|                                                     |               |

| Block Diagram of Pins of Port 2                    | (        |
|----------------------------------------------------|----------|
| (General-purpose I/O Port)                         | ,        |
| Block Diagram of Pins of Port 3172                 |          |
| Block Diagram of Pins of Port 4                    |          |
| Block Diagram of Pins of Port 5                    |          |
| Block Diagram of Pins of UART1                     |          |
| Block Diagram of Port 1 Pins (in Single Chip Mode) | 1        |
| Block Diagram of Fort FFins (in Single Cinp Mode)  | , (      |
| Block Diagram of ROM Mirroring Function            |          |
| Select Module                                      |          |
| Block Diagram of Timebase Timer                    |          |
|                                                    |          |
| Block Diagram of UART1                             |          |
| Block Diagram of Watch Timer                       |          |
| Block Diagram of Watchdog Timer                    |          |
| Details of Pins in Block Diagram218, 221           |          |
| BTR                                                |          |
| Bit Timing Register (BTR)446                       | i        |
| Buffer Address Pointer                             |          |
| Buffer Address Pointer (BAP)86                     | ;        |
| Bus Mode                                           |          |
| Bus Mode154                                        | . (      |
| BVAL                                               |          |
| Caution for Disabling Message Buffers by BVAL bits | s        |
| 503                                                |          |
| BVALR                                              |          |
|                                                    |          |
| Message Buffer Valid Register (BVALR)450           | )        |
|                                                    |          |
| C DataShe                                          | ;e[4U.C( |
| CAN                                                | ,        |
| Program Example of CAN Transmission and            |          |

| Circuit<br>Block Diagram of Low-power Consumption Circuit           |   |
|---------------------------------------------------------------------|---|
| Block Diagram of Low-power Consumption Circuit                      |   |
| CKSCR                                                               |   |
| Configuration of Clock Select Register (CKSCR)                      |   |
|                                                                     |   |
| Clock                                                               |   |
| Baud Rate by External Clock                                         |   |
| Block Diagram of Clock Generation Section 112<br>Clock              |   |
| Clock Supply Map 110                                                |   |
| Connection of Oscillator and External Clock 123                     |   |
| Machine Clock 119                                                   |   |
| Oscillation Clock Frequency and                                     |   |
| Serial Clock Input Frequency                                        |   |
| Register in Clock Generation Section and List of<br>Reset Values114 |   |
| Setting Operation Clock of Watchdog Timer                           |   |
|                                                                     |   |
| Supply of Operation Clock 199                                       |   |
| Clock Generation                                                    |   |
| Block Diagram of Clock Generation Section                           |   |
|                                                                     |   |
| Register in Clock Generation Section and<br>List of Reset Values    |   |
| Cleak Made                                                          |   |
| Clock Mode                                                          | 9 |
| Com Transition of Clock Mode 118, 147                               |   |
| Clock Select Register                                               |   |
| Configuration of Clock Select Register (CKSCR)                      |   |
|                                                                     |   |
| Clock Supply                                                        |   |
| Clock Supply                                                        |   |
| Cycle of Clock Supply                                               |   |
| Clock Synchronous Mode<br>Operation in Clock Synchronous Mode       |   |
| (Operation Mode 2)                                                  |   |
| CMR                                                                 |   |
| Common Register Bank Prefix (CMR)                                   |   |
| Command Sequence                                                    |   |
| Command Sequence Table533                                           |   |
| Common Register Bank Prefix                                         |   |
| Common Register Bank Prefix (CMR)55                                 |   |
| Communication                                                       |   |
| Bidirectional Communication Function                                |   |
| Master/Slave Type Communication Function                            |   |
|                                                                     |   |
| Communication Prescaler Control Register 1                          |   |
| (CDCR1)                                                             |   |
| Condition Code Register                                             |   |
| Configuration of Condition Code Register (CCR)                      |   |
|                                                                     |   |
|                                                                     |   |

| et4U | .com |  |
|------|------|--|
|      |      |  |

| 0/1             |                                                     |
|-----------------|-----------------------------------------------------|
|                 | Program Example of CAN Transmission and             |
|                 | Reception                                           |
| CAI             | N Controller                                        |
|                 | Block Diagram for Pins of CAN Controller433         |
|                 | Block Diagram of CAN Controller                     |
|                 | CAN Controller Registers                            |
|                 | Explanation of Operation of CAN Controller486       |
|                 | Generation of Interrupt Request by CAN Controller   |
|                 |                                                     |
|                 | Interrupts of CAN Controller484                     |
|                 | Overview of CAN Controller428                       |
|                 | Pins of CAN Controller433                           |
|                 | Registers and Vector Tables Related to Interrupt of |
|                 | CAN Controller485                                   |
| CC              | R                                                   |
|                 | Configuration of Condition Code Register (CCR)      |
|                 |                                                     |
| CD              | CR                                                  |
|                 | Communication Prescaler Control Register 1          |
|                 | (CDCR1)                                             |
| Cha             | annels                                              |
|                 | Channels and PPG Pins of PPG Timers                 |
| Chi             | p Erase                                             |
| On              | All Data Erase from Flash Memory (Chip Erase)       |
|                 |                                                     |
| DataSheet4U.com |                                                     |

|          | Connection                                                 |
|----------|------------------------------------------------------------|
|          | Example of Minimum Connection to                           |
|          | Flash Microcontroller Programmer                           |
|          | (Power Supplied from Flash Microcontroller                 |
|          | Programmer)                                                |
|          | Example of Minimum Connection to                           |
|          | Flash Microcontroller Programmer                           |
|          | (User Power Supply Used)                                   |
|          |                                                            |
|          | Connection Example                                         |
|          | Connection Example in Single-chip Mode                     |
|          | (Power Supplied from Flash Microcontroller                 |
|          | Programmer) 563                                            |
|          | Connection Example in Single-chip Mode                     |
|          | (User Power Supply Used) 561                               |
|          | Consumption                                                |
|          | Block Diagram of Low-power Consumption Circuit             |
|          |                                                            |
|          | CPU Operation Modes and Current Consumption                |
|          |                                                            |
|          |                                                            |
|          | Continuous Conversion Mode                                 |
|          | Continuous Conversion Mode                                 |
|          | (ADCS: MD1,MD0= "10 <sub>B</sub> ")                        |
|          | Operation of Continuous Conversion Mode                    |
|          |                                                            |
|          | Continuous Conversion mode                                 |
| HILOOM   | Setting of Continuous Conversion mode                      |
| et4U.com | -                                                          |
|          | Control Status Register                                    |
|          | Control Status Register (High) (CSR: H)                    |
|          | Control Status Register (Low) (CSR: L) 439                 |
|          | Conversion                                                 |
|          | Conversion Using EI <sup>2</sup> OS 372                    |
|          | Conversion Mode                                            |
|          | Continuous Conversion Mode                                 |
|          | $(ADCS: MD1, MD0 = "10_B")$                                |
|          | Conversion Modes of 8-/10-bit A/D Converter                |
|          |                                                            |
|          | Operation of Continuous Conversion Mode                    |
|          |                                                            |
|          |                                                            |
|          | Operation of Pause-conversion Mode                         |
|          | Operation of Single Conversion Mode                        |
|          | Pause-conversion Mode (ADCS: MD1, MD0= "11 <sub>B</sub> ") |
|          |                                                            |
|          | Setting of Continuous Conversion mode                      |
|          | Setting of Pause-conversion Mode                           |
|          | Setting of Single Conversion Mode                          |
|          | Single Conversion Mode (ADCS: MD1, MD0=                    |
|          | "00 <sub>B</sub> " or "01 <sub>B</sub> ")                  |
|          |                                                            |
|          | Count Clock Select Register                                |
|          | PPG0/1 Count Clock Select Register (PPG01)                 |
|          |                                                            |
|          | CPU                                                        |
|          | CPU and Resources for MB90385 Series6                      |
|          | CPU Intermittent Operation Mode                            |
|          | CPU Intermittent Operation Mode                            |
| DataShar | of a manifest operation mode                               |
|          |                                                            |

| DataSheet4U.com |  |
|-----------------|--|
|-----------------|--|

| Operation in CPU Intermittent Operation Mode    |  |
|-------------------------------------------------|--|
|                                                 |  |
| CPU Operation Modes                             |  |
| CPU Operation Modes and Current Consumption     |  |
| 124                                             |  |
| CSR                                             |  |
| Control Status Register (High) (CSR: H)437      |  |
| Control Status Register (Low) (CSR: L)439       |  |
| Current Consumption                             |  |
| CPU Operation Modes and Current Consumption     |  |
| 124                                             |  |
| Cycle                                           |  |
| Cycle of Clock Supply275                        |  |
| Processing of Program for Measuring Cycle Using |  |
| Input Capture240                                |  |

# D

| Data Access                                         |                     |
|-----------------------------------------------------|---------------------|
| Setting of Each Bank and Data Access                | 9                   |
| Data Bank Register                                  | -                   |
| Data Bank Register (DTB)49                          | Q                   |
| Data Counter                                        | -                   |
| Data Counter (DCT)84                                | 1                   |
| Data Polling Flag                                   | •                   |
| Data Polling Flag (DQ7)53                           | DataShe             |
| Data Programming                                    | Dataone             |
| aSheet4UDataProgramming Procedure                   | 5                   |
| Data Programming to Flash Memory                    |                     |
| Data Register                                       |                     |
| Data Register (DTR)                                 | 3                   |
| DCT                                                 | -                   |
| Data Counter (DCT)84                                | 4                   |
| Dedicated Baud Rate Generator                       |                     |
| Baud Rate by Dedicated Baud Rate Generator          |                     |
|                                                     | 2                   |
| Dedicated Registers                                 |                     |
| Configuration of Dedicated Registers                | 3                   |
| Dedicated Registers and General-purpose Register    | -                   |
|                                                     | 5                   |
| Default Space                                       |                     |
| Bank Addressing and Default Space                   | C                   |
| Delayed Interrupt Generation Module                 |                     |
| Block Diagram of Delayed Interrupt Generation       |                     |
| Module                                              | 1                   |
| Explanation of Operation of Delayed Interrupt       |                     |
| Generation Module                                   | 4                   |
| List of Registers and Reset Values in Delayed       |                     |
| Interrupt Generation Module                         | 2                   |
| Overview of Delayed Interrupt Generation Module     | _                   |
|                                                     |                     |
| Precautions when Using Delayed Interrupt Generation |                     |
| Module                                              |                     |
| Program Example of Delayed Interrupt Generatio      | n<br>ataSheet4U.com |
|                                                     | -                   |

# DataShe

| C              | Delayed Interrupt Request Generate/Cancel Regist<br>Delayed Interrupt Request Generate/Cancel Regist |                 |
|----------------|------------------------------------------------------------------------------------------------------|-----------------|
|                | (DIRR)                                                                                               |                 |
| C              | Descriptor                                                                                           |                 |
|                | Configuration of EI <sup>2</sup> OS Descriptor (ISD)                                                 | .82             |
| Г              | Detect Address                                                                                       |                 |
| -              | Setting Detect Address5                                                                              | 515 D           |
| г              | Detect Address Setting Registers                                                                     |                 |
| L              | Detect Address Setting Registers (PADR0 and                                                          |                 |
|                | PADR1)                                                                                               | 513 D           |
|                | Functions of Detect Address Setting Registers                                                        | 15 2            |
|                | Functions of Detect Address Setting Registers                                                        | 11              |
| г              |                                                                                                      | D               |
| L              | Detection Level Setting Register                                                                     | D               |
|                | Detection Level Setting Register (ELVR) (High)                                                       |                 |
|                | Detection Level Setting Register (ELVR) (Low)                                                        | 334 D           |
|                |                                                                                                      | 225             |
| -              |                                                                                                      |                 |
| L              | Direct Addressing                                                                                    | E               |
|                | Direct Addressing5                                                                                   | <sup>74</sup> Е |
| C              | Direct Page Register                                                                                 |                 |
|                | Direct Page Register (DPR)                                                                           | .48             |
| C              | DIRR                                                                                                 |                 |
|                | Delayed Interrupt Request Generate/Cancel Regist                                                     | ter E           |
|                | (DIRR)                                                                                               | 123 -           |
|                | Disabling Message Buffers                                                                            | E               |
| et4U.com       | Caution for Disabling Message Buffers by BVAL                                                        | bits            |
|                | 5                                                                                                    | 503             |
| C              | DLC Register                                                                                         | Sheet4U.co      |
|                | DLC Register (DLCR)4                                                                                 | 82              |
| Г              | DLCR                                                                                                 |                 |
| _              | DLC Register (DLCR)4                                                                                 | 82              |
| г              | )PR                                                                                                  |                 |
| L              | Direct Page Register (DPR)                                                                           | 18              |
| г              |                                                                                                      | -+0             |
| L              |                                                                                                      | 40              |
| _              | Toggle Bit Flag (DQ2)5                                                                               | 942             |
| L              | DQ3                                                                                                  |                 |
|                | Sector Erase Timer Flag (DQ3)5                                                                       | 941             |
| C              | DQ5                                                                                                  |                 |
|                | Timing Limit Over Flag (DQ5)5                                                                        | 540             |
| C              | DQ6                                                                                                  |                 |
|                | Toggle Bit Flag (DQ6)5                                                                               | 539             |
| C              | DQ7                                                                                                  |                 |
|                | Data Polling Flag (DQ7)5                                                                             | 537             |
| Г              | DTB                                                                                                  |                 |
| -              | Bank Select Prefix (PCB,DTB,ADB,SPB)                                                                 | 53              |
|                | Data Bank Register (DTB)                                                                             |                 |
| г              | DTP Function                                                                                         | 10              |
| L              | DTP Function                                                                                         | 240             |
|                |                                                                                                      |                 |
| -              | Program Example of DTP Function                                                                      | ·++             |
| E              | DTP/External Interrupt                                                                               |                 |
|                | Block Diagram of DTP/External Interrupt                                                              | 529             |
|                | DTP/External Interrupt Operation                                                                     | 337<br>E        |
| DataSheet4U.co | List of Registers and Reset Values                                                                   | _               |
|                | in DTP/External Interrupt                                                                            | 531             |

| Pins of DTP/External Interrupt                | 331 |
|-----------------------------------------------|-----|
| Precautions when Using DTP/External Interrupt |     |
|                                               | 341 |
| Program Example of DTP/External Interrupt Fun |     |
|                                               | 343 |
| Setting of DTP/External Interrupt             | 336 |
| DTP/External Interrupt Enable Register        |     |
| DTP/External Interrupt Enable Register (ENIR) |     |
|                                               | 333 |
| DTP/External Interrupt Factor Register        |     |
| DTP/External Interrupt Factor Register (EIRR) |     |
|                                               | 332 |
| DTP/External Interrupt Function               |     |
| DTP/External Interrupt Function               | 328 |
| DTR                                           |     |
| Data Register (DTR)                           | 483 |
| 2 www.reg.sver (2 rrs)                        |     |

# Ε

| E <sup>2</sup> PROM                                                |          |
|--------------------------------------------------------------------|----------|
| E <sup>2</sup> PROM Memory Map517                                  |          |
| System Configuration and E <sup>2</sup> PROM Memory Map            |          |
| 516                                                                |          |
| Effective Address                                                  |          |
| Effective Address Field 573, 590                                   |          |
| EI <sup>2</sup> OS                                                 | DataShe  |
| 16-bit Input/Output Timer Interrupts and EI <sup>2</sup> OS        | Dataone  |
| Function                                                           |          |
| 8-/10-bit A/D Converter Interrupt and EI <sup>2</sup> OS           |          |
|                                                                    |          |
| 8-/16-bit PPG Timer Interrupt and EI <sup>2</sup> OS Function      |          |
|                                                                    |          |
| Conversion Using EI <sup>2</sup> OS                                |          |
| Correspondence between 16-bit Input/Output Timer                   |          |
| Interrupt and EI <sup>2</sup> OS                                   |          |
| Correspondence between 16-bit Reload Timer                         |          |
| Interrupt and EI <sup>2</sup> OS                                   |          |
| Correspondence between 8-/16-bit PPG Timer                         |          |
| Interrupt and EI <sup>2</sup> OS                                   |          |
| Correspondence between Timebase Timer Interrupt                    |          |
| and EI <sup>2</sup> OS                                             |          |
| EI <sup>2</sup> OS80                                               |          |
| EI <sup>2</sup> OS Function of 16-bit Reload Timer                 |          |
| EI <sup>2</sup> OS Function of 8-/10-bit A/D Converter 364         |          |
| EI <sup>2</sup> OS Function of UART1                               |          |
| EI <sup>2</sup> OS Processing Time (time for one transfer)         |          |
|                                                                    |          |
| Interrupt Related to UART1 and EI <sup>2</sup> OS                  |          |
| Operation of EI <sup>2</sup> OS                                    |          |
| Procedure for Use of EI <sup>2</sup> OS                            |          |
| Program Example of EI <sup>2</sup> OS                              |          |
| Watch Timer Interrupt and EI <sup>2</sup> OS Function 281          |          |
| EI <sup>2</sup> OS Descriptor                                      |          |
| Configuration of EI <sup>2</sup> OS Descriptor (ISD)               |          |
| EI2OS Status Degister                                              |          |
| EI OS Status Register<br>EI <sup>2</sup> OS Status Register (ISCS) | et4U.com |

|          | EIRR                                           |         |
|----------|------------------------------------------------|---------|
|          | DTP/External Interrupt Factor Register (EIRR)  |         |
|          |                                                | 332     |
|          | ELVR                                           |         |
|          | Detection Level Setting Register (ELVR) (High) |         |
|          | Detection Level Setting Register (ELVR) (High) | 224     |
|          |                                                | 334     |
|          | Detection Level Setting Register (ELVR) (Low)  | 005     |
|          |                                                | 335     |
|          | ENIR                                           |         |
|          | DTP/External Interrupt Enable Register (ENIR)  |         |
|          |                                                | 333     |
|          | Erase                                          |         |
|          | All Data Erase from Flash Memory (Chip Erase)  |         |
|          | An Data Erase from Flash Memory (Chip Erase)   | 548     |
|          |                                                |         |
|          | Sector Erase Suspension in Flash Memory        | 551     |
|          | Erase Resumption                               |         |
|          | Erase Resumption in Flash Memory               | 552     |
|          | Erasing                                        |         |
|          | Detailed Explanation of Programming            |         |
|          | and Erasing Flash Memory                       | 544     |
|          | Erasing Any Data in Flash Memory (Sector Erasi |         |
|          |                                                | U,      |
|          | Programming and Erasing Flash Memory           |         |
|          |                                                | 520     |
|          | Erasing Procedure                              |         |
|          | Erasing Procedure for Flash Memory Sectors     |         |
| et4U.com |                                                | 549     |
|          | Error                                          |         |
|          | Node Status Transition due to Error Occurrence | DataShe |
|          |                                                | 445     |
|          | Event Count Mode                               |         |
|          | Event Count Mode                               | 244     |
|          |                                                |         |
|          | Operation in Event Count Mode                  |         |
|          | Program Example in Event Count Mode            |         |
|          | Setting of Event Count Mode                    | 265     |
|          | Exception Processing                           |         |
|          | Exception Processing                           | 91      |
|          | Execution Cycle Count                          |         |
|          | Calculating the Execution Cycle Count          | 588     |
|          | Execution Cycle Count                          |         |
|          | Extended I/O                                   | 001     |
|          |                                                | 00      |
|          | Extended I/O Area                              | 23      |
|          | External Clock                                 |         |
|          | Baud Rate by External Clock                    | 407     |
|          | Connection of Oscillator and External Clock    |         |
|          |                                                | 123     |
|          | External Interrupt                             |         |
|          | External Interrupt Function                    | 339     |
|          | _                                              | 000     |
|          | External Reset                                 | 4.00    |
|          | Block Diagram of External Reset Pin            | 103     |
|          |                                                |         |
|          | F                                              |         |

| Factor                                                               |
|----------------------------------------------------------------------|
| Correspondence of Reset Factor Bit and Reset Factor<br>107           |
| Notes on Reset Factor Bit107                                         |
| Fetch Mode Fetch105                                                  |
| FF Bank                                                              |
| Access to FF Bank by ROM Mirroring Function                          |
| Flag Change Inhibit Prefix                                           |
| Flag Change Inhibit Prefix (NCC)                                     |
| Flag Set                                                             |
| Generation of Receive Interrupt                                      |
| and Timing of Flag Set                                               |
| Generation of Transmit Interrupt<br>and Timing of Flag Set           |
|                                                                      |
| Flags<br>Hardware Sequence Flags                                     |
| Flash Memory                                                         |
| All Data Erase from Flash Memory (Chip Erase)                        |
| 548                                                                  |
| Data Programming to Flash Memory546                                  |
| Detailed Explanation of Programming                                  |
| and Erasing Flash Memory544                                          |
| Erase Resumption in Flash Memory552                                  |
| Erasing Any Data in Flash Memory (Sector Erasing)                    |
| et4UErasing Procedure for Flash Memory Sectors                       |
|                                                                      |
| Features of 512 Kbit Flash Memory528                                 |
| List of Registers and Reset Values of Flash Memory<br>529            |
| Overview of 512 Kbit Flash Memory528                                 |
| Program Example of 512 Kbit Flash Memory                             |
| Programming and Erasing Flash Memory528                              |
| Read/Reset State in Flash Memory                                     |
| Sector Configuration of 512 Kbit Flash Memory                        |
|                                                                      |
| Sector Erase Suspension in Flash Memory551                           |
| Flash Memory Control Status Register                                 |
| Flash Memory Control Status Register (FMCS)                          |
| 530                                                                  |
| Flash Microcontroller Programmer                                     |
| Connection Example in Single-chip Mode                               |
| (Power Supplied from Flash Microcontroller                           |
| Programmer)563<br>Example of Minimum Connection to                   |
| Example of Minimum Connection to<br>Flash Microcontroller Programmer |
| (Power Supplied from Flash Microcontroller                           |
| Programmer)                                                          |

Example of Minimum Connection to

Flash Microcontroller Programmer

(User Power Supply Used)......565

#### -

| F <sup>2</sup> MC-16LX                  |     |
|-----------------------------------------|-----|
| F <sup>2</sup> MC-16LX Instruction List | 594 |
| taSheet4U.com                           |     |

www.DataSheet4U.com

DataShe

| Flash Microcontroller Programmer System     |     |
|---------------------------------------------|-----|
| Flash Microcontroller Programmer System     |     |
| Configuration (Made by Yokogawa Digi        | tal |
| Computer Corporation)                       | 560 |
| FMCS                                        |     |
| Flash Memory Control Status Register (FMCS) |     |
| -                                           | 530 |
| FPT-48P-M26                                 |     |
| Package Dimension of FPT-48P-M26            | 10  |
| Pin Assignment (FPT-48P-M26)                |     |
| Free-run Timer                              |     |
| Block Diagram of 16-bit Free-run Timer      | 218 |
| Operation of 16-bit Free-run Timer          | 234 |
| Operation Timing of 16-bit Free-run Timer   | 235 |
| Setting of 16-bit Free-run Timer            | 234 |
| Frequency                                   |     |
| Oscillation Clock Frequency                 |     |
| and Serial Clock Input Frequency            | 560 |
|                                             |     |
|                                             |     |

# G

et4U.com

| General                                          | I                |
|--------------------------------------------------|------------------|
| Operation of Port 3 (General - purpose I/O port) |                  |
|                                                  | 74               |
| General-purpose I/O Port                         | I                |
| Block Diagram of Pins of Port 2                  |                  |
| (General-purpose I/O Port)1                      | 67 j             |
| Operation of Port 2 (General-purpose I/O Port)   | boot/III.or      |
| Datay                                            | 69 I             |
| General-purpose Register                         | •                |
| Configuration of General-purpose Register        | 50 r             |
| Dedicated Registers and General-purpose Register |                  |
|                                                  | 35 ,             |
| General-purpose Register Area                    | I                |
| and Register Bank Pointer                        |                  |
| Generator                                        |                  |
| Baud Rate by Dedicated Baud Rate Generator       |                  |
|                                                  | 02 <sup>II</sup> |
|                                                  |                  |

### Н

| Handling Devices                         |   |
|------------------------------------------|---|
| Precautions when Handling Devices1       | 8 |
| Hardware Interrupt                       |   |
| Hardware Interrupt7                      | 1 |
| Hardware Interrupt Inhibition7           | 2 |
| Mechanism of Hardware Interrupt7         |   |
| Operation of Hardware Interrupt7         | 5 |
| Procedure for Use of Hardware Interrupt7 | 6 |
| Return from Hardware Interrupt7          | 4 |
| Start of Hardware Interrupt7             | 4 |
| Hardware Sequence Flags                  |   |
| Hardware Sequence Flags53                | 5 |

DataSheet4U.com

#### INDEX

| I                                                     |   |
|-------------------------------------------------------|---|
| I/O                                                   |   |
| I/O Area                                              |   |
| I/O Address Pointer                                   |   |
| I/O Address Pointer (IOA)84                           |   |
| I/O Circuit                                           |   |
| I/O Circuit14                                         |   |
| I/O Port                                              |   |
| Block Diagram of Pins of Port 2                       |   |
| (General-purpose I/O Port) 167                        |   |
| I/O Port Function                                     |   |
| Operation of Port 2 (General-purpose I/O Port)<br>    |   |
| Operation of Port 3 (General - purpose I/O port)      |   |
|                                                       |   |
| Registers of I/O Ports160                             |   |
| ICR                                                   |   |
| Bit Configuration of Interrupt Control Register (ICR) |   |
|                                                       |   |
| Interrupt Control Register (ICR00 to ICR15)66         |   |
| ICS                                                   |   |
| Input Capture Control Status Registers                |   |
| (ICS01 and ICS23)                                     |   |
| ID Register                                           |   |
| ID Register (IDR)                                     | 3 |
| IDE Register (IDER) 452                               |   |
| COM IDE Register (IDER) 452                           |   |
| IDER<br>IDE Register (IDER)                           |   |
| IDE Register (IDER)                                   |   |
| ID Register (IDR)                                     |   |
| ILM                                                   |   |
| Interrupt Level Mask Register (ILM)                   |   |
| Image Access                                          |   |
| Image Access to Internal ROM                          |   |
| Independent Operation Mode                            |   |
| Setting for 8-bit PPG Output 2-channel                |   |
| Independent Operation Mode                            |   |
| Index                                                 |   |
| Interrupt Vector Index642                             |   |
| Pin Function Index640                                 |   |
| Register Index631                                     |   |
| Indirect Addressing                                   |   |
| Indirect Addressing                                   |   |
| Indirect-specifying                                   |   |
| Addressing by Indirect-specifying 32-bit Register     |   |
|                                                       |   |
| Input Capture<br>Block Diagram of Input Capture       |   |
| Operation of Input Capture                            |   |
| Operation Timing of Input Capture                     |   |
| Processing of Program for Measuring Cycle             |   |
|                                                       |   |
| Using Input Capture                                   |   |

|          | Input Capture Control Status Registers                   |
|----------|----------------------------------------------------------|
|          | Input Capture Control Status Registers                   |
|          | (ICS01 and ICS23) 229                                    |
|          |                                                          |
|          | Input Capture Data Registers                             |
|          | Input Capture Data Registers 0 to 3 (IPCP0 to IPCP3)     |
|          |                                                          |
|          | Operation of Input Capture Data Registers 0 to 3         |
|          | (IPCP0 to IPCP3)                                         |
|          |                                                          |
|          | Input/Output Pins                                        |
|          | State of Input/Output Pins (Single-chip Mode)            |
|          |                                                          |
|          | Input/Output Timer                                       |
|          | 16-bit Input/Output Timer Interrupts                     |
|          |                                                          |
|          | and EI <sup>2</sup> OS Function                          |
|          | Block Diagram of 16-bit Input/Output Timer               |
|          |                                                          |
|          | Block Diagram of Pins for 16-bit Input/Output Timer      |
|          |                                                          |
|          | Configuration of 16-bit Input/Output Timer 216           |
|          |                                                          |
|          | Correspondence between 16-bit Input/Output Timer         |
|          | Interrupt and EI <sup>2</sup> OS 233                     |
|          | Functions of 16-bit Input/Output Timer 216               |
|          | Generation of Interrupt Request from                     |
|          | 16-bit Input/Output Timer 224                            |
|          |                                                          |
|          | Interrupt Control Bits and Interrupt Factors of          |
| et4U.com | 16-bit Input/Output Timer 233                            |
|          | List of Registers and Reset Values of                    |
|          | 16-bit Input/Output Timer 223                            |
|          | Pins of 16-bit Input/Output Timer                        |
|          | Precautions when 16-bit Input/Output Timer               |
|          | 239                                                      |
|          |                                                          |
|          | Instruction                                              |
|          | Description of instruction presentation items            |
|          | and symbols                                              |
|          | F <sup>2</sup> MC-16LX Instruction List                  |
|          | Prefix Code and Interrupt Inhibit Instruction 57         |
|          | _                                                        |
|          | Instruction Map                                          |
|          | Structure of Instruction Map 609                         |
|          | Instruction Types                                        |
|          | Instruction Types                                        |
|          | •••                                                      |
|          | Internal Clock Mode                                      |
|          | Internal Clock Mode 244                                  |
|          | Operation in Internal Clock Mode 261                     |
|          | Program Example in Internal Clock Mode                   |
|          | Setting of Internal Clock Mode                           |
|          | e                                                        |
|          | Internal ROM                                             |
|          | Image Access to Internal ROM 25                          |
|          | Internal Timer                                           |
|          | Baud Rate by Internal Timer                              |
|          | •                                                        |
|          | (16-bit Reload Timer Output) 405                         |
|          | Interrupt                                                |
|          | 16-bit Input/Output Timer Interrupts                     |
|          | and EI <sup>2</sup> OS Function                          |
|          | 8-/10-bit A/D Converter Interrupt and EI <sup>2</sup> OS |
| DataOli  | -                                                        |
| DataShee | et4U.com                                                 |

| 8-/16-bit PPG Timer Interrupt and EI <sup>2</sup> OS Function |
|---------------------------------------------------------------|
|                                                               |
| Block Diagram of DTP/External Interrupt                       |
| Cancellation of Standby Mode by Interrupt                     |
| Correspondence between 16-bit Input/Output Timer              |
|                                                               |
| Interrupt and EI <sup>2</sup> OS233                           |
| Correspondence between 16-bit Reload Timer                    |
| Interrupt and EI <sup>2</sup> OS257                           |
| Correspondence between 8-/16-bit PPG Timer                    |
| Interrupt and EI <sup>2</sup> OS                              |
| Correspondence between Timebase Timer Interrupt               |
| and EI <sup>2</sup> OS195                                     |
| Details of Pins and Interrupt Numbers                         |
| DTP/External Interrupt Function                               |
| DTP/External Interrupt Operation                              |
| External Interrupt Function                                   |
| Generation of Interrupt from 8-/10-bit A/D Converter          |
|                                                               |
| Generation of Receive Interrupt and Timing of                 |
|                                                               |
| Flag Set                                                      |
| Generation of Transmit Interrupt and Timing of                |
| Flag Set                                                      |
| Hardware Interrupt71                                          |
| Hardware Interrupt Inhibition72                               |
| Interrupt Control Bits and Interrupt Factors of               |
| 16-bit Input/Output Timer233                                  |
| Interrupt Number                                              |
| Interrupts of 16-bit Reload Timer257                          |
| Unterrupts of 8-/16-bit PPG Timer                             |
| Interrupt of A/D Converter                                    |
| Interrupts of CAN Controller                                  |
| Interrupt of UART1                                            |
|                                                               |
| Interrupt Operation                                           |
| Interrupt Related to UART1 and EI <sup>2</sup> OS             |
| List of Registers and Reset Values                            |
| in DTP/External Interrupt331                                  |
| Mechanism of Hardware Interrupt72                             |
| Multiple Interrupts77                                         |
| Operation of Hardware Interrupt75                             |
| Pins of DTP/External Interrupt                                |
| Precautions when Using DTP/External Interrupt                 |
|                                                               |
| Procedure for Use of Hardware Interrupt76                     |
| Program Example of DTP/External Interrupt Function            |
|                                                               |
| Registers and Vector Tables Related to Interrupt of           |
|                                                               |
| CAN Controller                                                |
| Return from Hardware Interrupt                                |
| Setting of DTP/External Interrupt                             |
| Start and Operation of Software Interrupt                     |
| Start of Hardware Interrupt74                                 |
| Timebase Timer Interrupt195                                   |
| Type and Function of Interrupt59                              |
| Watch Timer Interrupt                                         |
| Watch Timer Interrupt and EI <sup>2</sup> OS Function281      |

|               | Interrupt Control Register                                               |
|---------------|--------------------------------------------------------------------------|
|               | Bit Configuration of Interrupt Control Register (ICR)                    |
|               | 68                                                                       |
|               | Function of Interrupt Control Register                                   |
|               | Interrupt Control Register (ICR00 to ICR15)66                            |
|               | Interrupt Control Register List64<br>Interrupt Factor, Interrupt Vector, |
|               | and Interrupt Control Register                                           |
|               | Interrupt Factor                                                         |
|               | Interrupt Control Bits and Interrupt Factors of                          |
|               | 16-bit Input/Output Timer                                                |
|               | Interrupt Factor, Interrupt Vector,                                      |
|               | and Interrupt Control Register                                           |
|               | Interrupt Inhibit Instruction                                            |
|               | Prefix Code and Interrupt Inhibit Instruction                            |
|               | Interrupt Level Mask Register                                            |
|               | Interrupt Level Mask Register (ILM)                                      |
|               | Interrupt Number                                                         |
|               | Interrupt Number                                                         |
|               | Interrupt Processing                                                     |
|               | Program Example of Interrupt Processing                                  |
|               | Stack Operation at Return from Interrupt Processing                      |
|               | 94                                                                       |
|               | Stack Operation at Starting Interrupt Processing                         |
|               |                                                                          |
| et4U.com      | Time Required to Start Interrupt Processing92                            |
|               | Interrupt Request                                                        |
|               | Generation of Interrupt Request by CAN Controller                        |
|               |                                                                          |
|               | Generation of Interrupt Request from<br>16-bit Input/Output Timer224     |
|               | Generation of Interrupt Request from                                     |
|               | 16-bit Reload Timer                                                      |
|               | Generation of Interrupt Request from                                     |
|               | 8-/16-bit PPG Timer297                                                   |
|               | Generation of Interrupt Request from Timebase Timer                      |
|               | Generation of Interrupt Request from Watch Timer                         |
|               | 278                                                                      |
|               | Interrupt Request Generation by UART1                                    |
|               | Interrupt Vector                                                         |
|               | Interrupt Factor, Interrupt Vector,                                      |
|               | and Interrupt Control Register                                           |
|               | Interrupt Vector61                                                       |
|               | Interrupt Vector Index                                                   |
|               | Interrupt Vector Index642                                                |
|               | Interval Timer                                                           |
|               | Functions of Interval Timer188                                           |
|               | Interval Timer Function196, 274, 282                                     |
|               | IOA                                                                      |
|               | I/O Address Pointer (IOA)84                                              |
|               | IPCP                                                                     |
|               | Input Capture Data Registers 0 to 3 (IPCP0 to IPCP3)                     |
|               |                                                                          |
| DataSheet4U.c | om                                                                       |

| I | Ν | D | Ε | Х |
|---|---|---|---|---|
| - |   | _ | _ | - |

| Operation of Input Capture Data Registers 0 to 3<br>(IPCP0 to IPCP3)                       |         |
|--------------------------------------------------------------------------------------------|---------|
| ISCS<br>EI <sup>2</sup> OS Status Register (ISCS)85                                        |         |
| ISD                                                                                        |         |
| Configuration of EI <sup>2</sup> OS Descriptor (ISD)82                                     |         |
| L                                                                                          |         |
| Last Event Indicate Register                                                               |         |
| Last Event Indicate Register (LEIR) 442                                                    |         |
| LEIR                                                                                       |         |
| Last Event Indicate Register (LEIR)                                                        |         |
| Linear Addressing and Bank Addressing27                                                    |         |
| Linear Addressing by Specifying 24-bit Operand                                             |         |
|                                                                                            |         |
| Lineup                                                                                     |         |
| Product Lineup for MB90385 Series5                                                         |         |
| List                                                                                       |         |
| List of Registers and Reset Values of<br>16-bit Reload Timer249                            |         |
| Low-power Consumption                                                                      |         |
| Block Diagram of Low-power Consumption Circuit                                             |         |
|                                                                                            |         |
| Low-Power Consumption Mode Control Register<br>Low-power Consumption Mode Control Register | DataShe |
| com (LPMCR)                                                                                |         |
| Low-power Consumption Mode Control Register                                                |         |
| and Reset Values                                                                           |         |
| Notes on Accessing the Low-Power Consumption<br>Mode Control Register (LPMCR) to Enter     |         |
| the Standby Mode                                                                           |         |
| LPMCR                                                                                      |         |
| Low-power Consumption Mode Control Register                                                |         |
| (LPMCR)                                                                                    |         |
| Notes on Accessing the Low-Power Consumption                                               |         |
| Mode Control Register (LPMCR) to Enter<br>the Standby Mode                                 |         |
| the Standby MOde                                                                           |         |

#### Μ

| Machine Clock                            |     |
|------------------------------------------|-----|
| Machine Clock                            | 119 |
| Master/Slave Type Communication          |     |
| Master/Slave Type Communication Function |     |
|                                          | 420 |
| MB90385 Series                           |     |
| Block Diagram of MB90385 Series          | 8   |
| CPU and Resources for MB90385 Series     | 6   |
| Features of MB90385 Series               | 2   |
| Memory Map for MB90385 Series            | 24  |
| Product Lineup for MB90385 Series        | 5   |
|                                          |     |

|          | MB90F387/S                                                |
|----------|-----------------------------------------------------------|
|          | Basic Configuration of Serial Programming                 |
|          | Connection for MB90F387/S558                              |
|          | MD                                                        |
|          | Continuous Conversion Mode                                |
|          | (ADCS: MD1,MD0= "10 <sub>B</sub> ")                       |
|          | Pause-conversion Mode (ADCS: MD1,MD0= "11 <sub>B</sub> ") |
|          |                                                           |
|          | Setting of Mode Pins (MD2 to MD0) 150                     |
|          | Single Conversion Mode (ADCS: MD1, MD0=                   |
|          | "00 <sub>B</sub> " or "01 <sub>B</sub> " ) 365            |
|          | Memory Access Mode                                        |
|          | Selection of Memory Access Mode 155                       |
|          | Memory Map                                                |
|          | E <sup>2</sup> PROM Memory Map 517                        |
|          | Memory Map 26                                             |
|          | Memory Map for MB90385 Series 24                          |
|          | System Configuration and E <sup>2</sup> PROM Memory Map   |
|          |                                                           |
|          | Memory Space                                              |
|          | Memory Space 22                                           |
|          | Memory Space when ROM Mirroring Function                  |
|          | Enabled/Disabled 525                                      |
|          | Message Buffer                                            |
|          | Caution for Disabling Message Buffers by BVAL bits        |
| et4U.com |                                                           |
|          | Message Buffers                                           |
|          | Procedure for Receiving Message Buffer (x)                |
|          |                                                           |
|          | Procedure for Transmitting message Buffer (x)<br>         |
|          | Setting Configuration of Multiple Message Buffer          |
|          | 501                                                       |
|          | Message Buffer Valid Register                             |
|          | Message Buffer Valid Register (BVALR)                     |
|          | Minimum Connection                                        |
|          | Example of Minimum Connection to                          |
|          | Flash Microcontroller Programmer                          |
|          | (Power Supplied from Flash Microcontroller                |
|          | Programmer)                                               |
|          | Example of Minimum Connection to                          |
|          | Flash Microcontroller Programmer                          |
|          | (User Power Supply Used) 565                              |
|          | Mode                                                      |
|          | Block Diagram of Port 1 Pins (in Single Chip Mode)        |
|          |                                                           |
|          | Bus Mode 154                                              |
|          | Cancellation of Standby Mode by Interrupt 146             |
|          | Classification of Modes 149                               |
|          | Clock Mode 118, 125                                       |
|          | Connection Example in Single-chip Mode                    |
|          | (Power Supplied from Flash Microcontroller                |
|          | Programmer)                                               |
|          | Connection Example in Single-chip Mode                    |
| DataShee | (User Power Supply Used) 561                              |

|          | Continuous Conversion Mode                                        |            |
|----------|-------------------------------------------------------------------|------------|
|          | (ADCS: MD1, MD0= "10 <sub>B</sub> ")                              |            |
|          | Conversion Modes of 8-/10-bit A/D Converter                       |            |
|          |                                                                   |            |
|          | CPU Intermittent Operation Mode125                                |            |
|          | CPU Operation Modes and Current Consumption                       |            |
|          |                                                                   |            |
|          | Notes on Accessing the Low-Power Consumption                      |            |
|          | •                                                                 |            |
|          | Mode Control Register (LPMCR) to Enter                            |            |
|          | the Standby Mode148                                               |            |
|          | Event Count Mode                                                  |            |
|          | Function of Registers for Port 1 (in Single Chip Mode)            |            |
|          | 163                                                               |            |
|          | Internal Clock Mode244                                            |            |
|          | Mode Pin104                                                       |            |
|          | Note on Cancelling Standby Mode146                                |            |
|          | Notes on the Transition to Standby Mode146                        |            |
|          | Operating State in Each Standby Mode                              |            |
|          | Operation in Asynchronous Mode                                    |            |
|          | Operation in Clock Synchronous Mode                               |            |
|          | (Operation Mode 2)                                                |            |
|          | Operation in CPU Intermittent Operation Mode                      |            |
|          |                                                                   |            |
|          |                                                                   |            |
|          | Operation in Event Count Mode                                     |            |
|          | Operation in Internal Clock Mode                                  |            |
|          | Operation Mode149                                                 |            |
|          | Operation Modes of 16-bit Reload Timer244                         | DataShe    |
|          | Operation Modes of 8-/16-bit PPG Timer                            |            |
| aSheet4L | Operation of Continuous Conversion Mode                           |            |
|          | Operation of Pause-conversion Mode                                |            |
|          | Operation of Port 1 (in Single Chip Mode)                         |            |
|          | Operation of Single Conversion Mode                               |            |
|          | Oscillation Stabilization Wait Time in Standby Mode               |            |
|          |                                                                   |            |
|          | Pause-conversion Mode (ADCS: MD1, MD0= "11 <sub>B</sub> ")        |            |
|          | 365                                                               |            |
|          | Program Example in Event Count Mode271                            |            |
|          | Program Example in Internal Clock Mode                            |            |
|          |                                                                   |            |
|          | Registers for Port 1 (in Single Chip Mode)                        |            |
|          | Return from Sleep Mode136                                         |            |
|          | Return from Stop Mode                                             |            |
|          | Return from Timebase Timer Mode                                   |            |
|          | Return from Watch mode138                                         |            |
|          | Selection of Memory Access Mode155                                |            |
|          | Setting for 16-bit PPG Output Operation Mode                      |            |
|          |                                                                   |            |
|          | Setting for 8+8-bit PPG Output Operation Mode                     |            |
|          |                                                                   |            |
|          | Setting for 8-bit PPG Output 2-channel                            |            |
|          | Independent Operation Mode                                        |            |
|          | Setting of Continuous Conversion mode                             |            |
|          | Setting of Event Count Mode                                       |            |
|          | Setting of Internal Clock Mode                                    |            |
|          | Setting of Pause-conversion Mode                                  |            |
|          | -                                                                 |            |
|          | Setting of Single Conversion Mode                                 |            |
|          | Single Conversion Mode (ADCS: MD1, MD0=<br>$"00_B"$ or $"01_B"$ ) | neet4U.com |
|          | $00_{\rm B}$ or $01_{\rm B}$ )                                    |            |

| Standby Mode125                                  |
|--------------------------------------------------|
| State of Input/Output Pins (Single-chip Mode)    |
| 145                                              |
| Stop Mode141                                     |
| Transition of Clock Mode118, 147                 |
| Transition to Sleep Mode135                      |
| Transition to Standby Mode146                    |
| Transition to Timebase Timer Mode139             |
| Transition to Watch mode137                      |
| Mode Data                                        |
| Mode Data152                                     |
| Setting Mode Data153                             |
| State of Pins after Mode Data Read108            |
| Mode Fetch                                       |
| Mode Fetch105                                    |
| Mode Pins                                        |
| Setting Mode Pins151                             |
| Setting of Mode Pins (MD2 to MD0)150             |
| Multi-byte Data                                  |
| Access to Multi-byte Data                        |
| Storage of Multi-byte Data in Stack              |
| Store of Multi-byte Data in RAM                  |
| Multi-byte Length                                |
| Storage of Multi-byte Length Operand             |
| Multiple Interrupts                              |
| Multiple Interrupts                              |
| Multiple Message Buffer                          |
| Setting Configuration of Multiple Message Buffer |
|                                                  |
|                                                  |
| Multiplication Rate                              |
| Selection of PLL Clock Multiplication Rate119    |

# Ν

et4U.com

| NCC                                            |
|------------------------------------------------|
| Flag Change Inhibit Prefix (NCC)56             |
| Node Status Transition                         |
| Node Status Transition due to Error Occurrence |
|                                                |

### 0

| Operand                                        |
|------------------------------------------------|
| Linear Addressing by Specifying 24-bit Operand |
|                                                |
| Storage of Multi-byte Length Operand31         |
| Operating State                                |
| Setting and Operating State518                 |
| Operation Clock                                |
| Supply of Operation Clock199                   |
| Operation Mode                                 |
| CPU Intermittent Operation Mode125             |
| CPU Operation Modes and Current Consumption    |
| 124                                            |

DataSheet4U.com

| Operation in CPU Intermittent Operation Mode             |           |
|----------------------------------------------------------|-----------|
|                                                          |           |
| Operation Mode149                                        |           |
| Operation Modes of 16-bit Reload Timer                   |           |
| Setting for 8-bit PPG Output 2-channel                   |           |
| Independent Operation Mode                               |           |
| Operation Mode Control Register                          |           |
| PPG0 Operation Mode Control Register (PPGC0)             |           |
|                                                          |           |
| PPG1 Operation Mode Control Register (PPGC1)             |           |
|                                                          |           |
| Oscillation Clock Frequency                              |           |
| Oscillation Clock Frequency                              |           |
| and Serial Clock Input Frequency 560                     |           |
| Oscillation Stabilization Wait Time                      |           |
| Operation as Oscillation Stabilization Wait Time         |           |
| Timer 197                                                |           |
| Operation During Oscillation Stabilization Wait Time     |           |
|                                                          |           |
| Oscillation Stabilization Wait Time 147                  |           |
| Oscillation Stabilization Wait Time in Standby Mode      |           |
|                                                          |           |
| Oscillation Stabilization Wait Time Timer of             |           |
| Subclock                                                 |           |
| Reset Sources and Oscillation Stabilization Wait Time    |           |
|                                                          | D. t. Cho |
| Oscillator                                               | DataShe   |
| et4U.com Connection of Oscillator and External Clock 123 |           |
|                                                          |           |

#### Ρ

| Package Dimension                                         |
|-----------------------------------------------------------|
| Package Dimension of FPT-48P-M2610                        |
| -                                                         |
| PACSR                                                     |
| Address Detection Control Register (PACSR)                |
| -                                                         |
|                                                           |
| PADR                                                      |
| Detect Address Setting Registers                          |
|                                                           |
| (PADR0 and PADR1)513                                      |
| Patch                                                     |
| Operation of Address Match Detection Function             |
|                                                           |
| at Storing Patch Program in E <sup>2</sup> PROM           |
| 519                                                       |
| Patch Processing                                          |
|                                                           |
| Flow of Patch Processing                                  |
| Pause-conversion Mode                                     |
| Operation of Pause-conversion Mode                        |
| Pause-conversion Mode (ADCS: MD1,MD0= "11 <sub>B</sub> ") |
|                                                           |
|                                                           |
| Setting of Pause-conversion Mode                          |
| PC                                                        |
|                                                           |
| Program Counter (PC)47                                    |
| PCB                                                       |
| Bank Select Prefix (PCB,DTB,ADB,SPB)                      |
| Program Bank Register (PCB)                               |
|                                                           |

|           | Pin Assignment                                     |      |
|-----------|----------------------------------------------------|------|
|           | Pin Assignment (FPT-48P-M26)                       | 9    |
|           | Pin Assignment of Port 1                           |      |
|           | Pin Assignment of Port 2                           |      |
|           | Pin Assignment of Port 3                           |      |
|           | Pin Assignment of Port 4                           |      |
|           | •                                                  |      |
|           | Pin Assignment of Port 5                           | 101  |
|           | Pin Description                                    |      |
|           | Pin Description                                    | . 11 |
|           | Pin Function Index                                 |      |
|           | Pin Function Index                                 | 640  |
|           | PLL Clock Multiplication Rate                      |      |
|           | Selection of PLL Clock Multiplication Rate         | 119  |
|           | Port 1                                             | 110  |
|           |                                                    | da)  |
|           | Block Diagram of Port 1 Pins (in Single Chip Mo    |      |
|           |                                                    |      |
|           | Configuration of Port 1                            |      |
|           | Function of Registers for Port 1 (in Single Chip M | ,    |
|           |                                                    |      |
|           | Operation of Port 1 (in Single Chip Mode)          | 164  |
|           | Pin Assignment of Port 1                           |      |
|           | Registers for Port 1 (in Single Chip Mode)         | 162  |
|           | Port 2                                             |      |
|           | Block Diagram of Pins of Port 2                    |      |
|           | (General-purpose I/O Port)                         | 167  |
| et4U.com  | Configuration of Port 2                            |      |
| 5140.0011 | Function of Registers for Port 2                   |      |
|           | Operation of Port 2 (General-purpose I/O Port)     |      |
|           |                                                    |      |
|           |                                                    |      |
|           | Pin Assignment of Port 2                           |      |
|           | Registers for Port 2                               | 107  |
|           | Port 3                                             |      |
|           | Block Diagram of Pins of Port 3                    |      |
|           | Configuration of Port 3                            |      |
|           | Function of Registers for Port 3                   | 173  |
|           | Operation of Port 3 (General - purpose I/O port)   |      |
|           |                                                    | 174  |
|           | Pin Assignment of Port 3                           | 171  |
|           | Registers for Port 3                               | 172  |
|           | Port 4                                             |      |
|           | Block Diagram of Pins of Port 4                    | 177  |
|           | Configuration of Port 4                            |      |
|           | Function of Registers for Port 4                   |      |
|           | Operation of Port 4                                |      |
|           | Pin Assignment of Port 4                           |      |
|           | •                                                  |      |
|           | Registers for Port 4                               | 177  |
|           | Port 5                                             |      |
|           | Block Diagram of Pins of Port 5                    |      |
|           | Configuration of Port 5                            |      |
|           | Function of Registers for Port 5                   |      |
|           | Operation of Port 5                                |      |
|           | Pin Assignment of Port 5                           |      |
|           | Registers for Port 5                               |      |
|           |                                                    |      |

| Data | Cha  | $\rightarrow 111$ | 0000 |
|------|------|-------------------|------|
| Dala | SILE | 614U              | .com |
|      |      |                   |      |

| Power Supply                                                                      |  |
|-----------------------------------------------------------------------------------|--|
| Connection Example in Single-chip Mode                                            |  |
| (User Power Supply Used)561                                                       |  |
| Connection Example in Single-chip Mode                                            |  |
| (Power Supplied from Flash Microcontroller                                        |  |
| Programmer)563                                                                    |  |
| Example of Minimum Connection to                                                  |  |
| Flash Microcontroller Programmer                                                  |  |
| (Power Supplied from Flash Microcontroller                                        |  |
| Programmer)567                                                                    |  |
| Example of Minimum Connection to                                                  |  |
| Flash Microcontroller Programmer                                                  |  |
| (User Power Supply Used)565                                                       |  |
| PPG                                                                               |  |
| Channels and PPG Pins of PPG Timers                                               |  |
| PPG0 Operation Mode Control Register (PPGC0)                                      |  |
|                                                                                   |  |
| PPG0/1 Count Clock Select Register (PPG01)                                        |  |
|                                                                                   |  |
| PPG1 Operation Mode Control Register (PPGC1)                                      |  |
|                                                                                   |  |
| PPG Output                                                                        |  |
| Setting for 8-bit PPG Output 2-channel                                            |  |
| Independent Operation Mode                                                        |  |
| PPG Output Operation Mode                                                         |  |
| Setting for 16-bit PPG Output Operation Mode                                      |  |
|                                                                                   |  |
| Setting for 8+8-bit PPG Output Operation Mode                                     |  |
|                                                                                   |  |
| PPG Reload Registers                                                              |  |
| PPG Reload Registers                                                              |  |
| (PRLL0/PRLH0,PRLL1/PRLH1)                                                         |  |
| PPG Timer                                                                         |  |
| 8-/16-bit PPG Timer Interrupt and EI <sup>2</sup> OS Function                     |  |
|                                                                                   |  |
| Block Diagram of 8-/16-bit PPG Timer 0                                            |  |
| Block Diagram of 8-/16-bit PPG Timer 1                                            |  |
| Block Diagram of 8-/16-bit PPG Timer Pins                                         |  |
| 296<br>Channels and PPG Pins of PPG Timers289                                     |  |
|                                                                                   |  |
| Correspondence between 8-/16-bit PPG Timer<br>Interrupt and EI <sup>2</sup> OS305 |  |
| Functions of 8-/16-bit PPG Timer                                                  |  |
| Generation of Interrupt Request from                                              |  |
| 8-/16-bit PPG Timer                                                               |  |
| Interrupts of 8-/16-bit PPG Timer                                                 |  |
| List of Registers and Reset Values of                                             |  |
| 8-/16-bit PPG Timer                                                               |  |
| Operation Modes of 8-/16-bit PPG Timer                                            |  |
| Operation of 8-/16-bit PPG Timer                                                  |  |
| Pins of 8-/16-bit PPG Timer                                                       |  |
| Precautions when Using 8-/16-bit PPG Timer                                        |  |

| PPGC |
|------|
|------|

| PPG0 Operation Mode Control Register (PPGC0)<br>www.DataSheet4U.com |  |
|---------------------------------------------------------------------|--|
| 298                                                                 |  |

| PPG1 Operation Mode Control Register (PPGC1)                            |   |
|-------------------------------------------------------------------------|---|
|                                                                         |   |
|                                                                         |   |
| Bank Select Prefix (PCB,DTB,ADB,SPB)                                    |   |
| Common Register Bank Prefix (CMR)55<br>Flag Change Inhibit Prefix (NCC) |   |
|                                                                         |   |
| Prefix Code                                                             |   |
| Array of Prefix Codes                                                   |   |
| Prefix Code52<br>Prefix Code and Interrupt Inhibit Instruction57        |   |
| Presentation items                                                      |   |
| Description of instruction presentation items                           |   |
| and symbols                                                             |   |
| -                                                                       |   |
| Presetting<br>Presetting                                                |   |
| -                                                                       |   |
| PRLH                                                                    |   |
| PPG Reload Registers                                                    |   |
| (PRLL0/PRLH0,PRLL1/PRLH1)                                               |   |
| PRLL                                                                    |   |
| PPG Reload Registers                                                    |   |
| (PRLL0/PRLH0,PRLL1/PRLH1)                                               |   |
| Processing                                                              |   |
| Exception Processing                                                    |   |
| Program Example of Interrupt Processing                                 |   |
| Stack Operation at Return from Interrupt Processing<br>                 |   |
| Stack Operation at Starting Interrupt Processing                        |   |
| DataS <b>6</b> 4                                                        | e |
| Time Required to Start Interrupt Processing92                           |   |
| Processing Time                                                         |   |
| EI <sup>2</sup> OS Processing Time (time for one transfer)              |   |
|                                                                         |   |
| Processor Status                                                        |   |
| Configuration of Processor Status (PS)42                                |   |
| Product Lineup                                                          |   |
| Product Lineup for MB90385 Series                                       |   |
| Program                                                                 |   |
| Operation of Address Match Detection Function                           |   |
| at Storing Patch Program in E <sup>2</sup> PROM                         |   |
| 519                                                                     |   |
| Processing of Program for Measuring Cycle                               |   |
| Using Input Capture240                                                  |   |
| Program Execution515                                                    |   |
| Program Bank Register                                                   |   |
| Program Bank Register (PCB)49                                           |   |
| Program Counter                                                         |   |
| Program Counter (PC)47                                                  |   |
| Program Example                                                         |   |
| Program Example for Address Match Detection                             |   |
| Function                                                                |   |
| Program Example for UART1                                               |   |
| Program Example in Event Count Mode                                     |   |
| Program Example in Internal Clock Mode                                  |   |
|                                                                         |   |

| <u>م</u> | ata | Sh  | 00 | +7    | LТ. | com   |
|----------|-----|-----|----|-------|-----|-------|
|          | วเต | OII | CC | 7 L** | Ο.  | COIII |

et4U.com

| Program Example of 512 Kbit Flash Memory          |         |
|---------------------------------------------------|---------|
|                                                   | 5       |
| Program Example of CAN Transmission               | 4       |
| and Reception                                     | Ŧ       |
| Program Example of Delayed Interrupt              | -       |
| Generation Module                                 |         |
| Program Example of DTP Function                   |         |
| Program Example of DTP/External Interrupt Functio |         |
|                                                   |         |
| Program Example of EI <sup>2</sup> OS             |         |
| Program Example of Interrupt Processing           |         |
| Program Example of Timebase Timer                 | 1       |
| Program Example of Watch Timer                    | 1       |
| Program Example of Watchdog Timer214              | 1       |
| Programming                                       |         |
| Data Programming Procedure                        | 5       |
| Data Programming to Flash Memory                  | 5       |
| Detailed Explanation of Programming               |         |
| and Erasing Flash Memory                          | 4       |
| Programming and Erasing Flash Memory              |         |
| Protection                                        |         |
| A/D-converted Data Protection Function            |         |
| in 8-/10-bit A/D Converter                        | 3       |
| PS                                                | -       |
|                                                   | 2       |
| Configuration of Processor Status (PS)42          | 2       |
| <b>D</b>                                          | DataShe |

#### R

| et4U.c <b>R/AM</b>                                  |   |
|-----------------------------------------------------|---|
| RAM Area                                            |   |
| Store of Multi-byte Data in RAM31                   |   |
| RCR                                                 |   |
| Reception Complete Register (RCR) 466               |   |
| Read                                                |   |
| Read/Reset State in Flash Memory                    |   |
| Receive Interrupt                                   |   |
| Generation of Receive Interrupt and Timing of       |   |
| Flag Set                                            |   |
| Receive/Transmit Error Counter                      |   |
| Receive/Transmit Error Counter (RTEC)               |   |
| Receiving                                           |   |
| Procedure for Receiving Message Buffer (x) 498      |   |
| Reception                                           |   |
| Program Example of CAN Transmission                 |   |
| and Reception                                       |   |
| Reception                                           |   |
| Reception Complete Interrupt Enable Register        |   |
| Reception Complete Interrupt Enable Register (RIER) |   |
| Reception Complete Register                         |   |
| Reception Complete Register (RCR)                   |   |
| Reception Overrun Register                          |   |
| Reception Overrun Register (ROVRR)                  |   |
| Reception RTR Register                              |   |
| Reception RTR Register (RRTRR)                      | m |
| r                                                   |   |

|          | Register Bank                                          |
|----------|--------------------------------------------------------|
|          | Register Bank 51                                       |
|          | Register Bank Pointer                                  |
|          | General-purpose Register Area                          |
|          | and Register Bank Pointer                              |
|          | Register Bank Pointer (RP)                             |
|          | -                                                      |
|          | Register Index                                         |
|          | Register Index 631                                     |
|          | Reload Registers                                       |
|          | 16-bit Reload Registers (TMRLR0,TMRLR1)                |
|          |                                                        |
|          | Reload Timer                                           |
|          | Baud Rate by Internal Timer                            |
|          | (16-bit Reload Timer Output)                           |
|          | Block Diagram for Pins of 16-bit Reload Timer          |
|          | 248                                                    |
|          | Block Diagram of 16-bit Reload Timer                   |
|          | -                                                      |
|          | Correspondence between 16-bit Reload Timer             |
|          | Interrupt and EI <sup>2</sup> OS                       |
|          | EI <sup>2</sup> OS Function of 16-bit Reload Timer 257 |
|          | Generation of Interrupt Request from                   |
|          | 16-bit Reload Timer 250                                |
|          | Interrupts of 16-bit Reload Timer 257                  |
|          | List of Registers and Reset Values of                  |
|          | 16-bit Reload Timer 249                                |
| et4U.com | Operation Modes of 16-bit Reload Timer 244             |
| 5140.000 | Pins of 16-bit Reload Timer                            |
|          | Descentions when Using 16 hit Dalaged Times            |
|          | Precautions when Using To-bit Reload Timer Data        |
|          | Setting of 16-bit Reload Timer                         |
|          | -                                                      |
|          | Remote Frame Receiving Wait Register                   |
|          | Remote Frame Receiving Wait Register (RFWTR)           |
|          |                                                        |
|          | Reset                                                  |
|          | Block Diagram of External Reset Pin 103                |
|          | Flowchart of Reset Operation 104                       |
|          | List of Registers and Reset Values in Delayed          |
|          | Interrupt Generation Module                            |
|          | List of Registers and Reset Values                     |
|          | in DTP/External Interrupt                              |
|          | List of Registers and Reset Values of                  |
|          | 16-bit Input/Output Timer                              |
|          | List of Registers and Reset Values of                  |
|          | 16-bit Reload Timer                                    |
|          |                                                        |
|          | List of Registers and Reset Values of                  |
|          | 8-/10-bit A/D Converter                                |
|          | List of Registers and Reset Values of                  |
|          | 8-/16-bit PPG Timer 297                                |
|          | List of Registers and Reset Values of                  |
|          | Address Match Detection Function                       |
|          |                                                        |
|          | List of Registers and Reset Values of Flash Memory     |
|          |                                                        |
|          | List of Registers and Reset Values of                  |
|          | ROM Mirroring Function Select Module                   |
| DataShee | t4U.com                                                |
|          |                                                        |

|      | List of Registers and Reset Values of Timebase Timer               |               |
|------|--------------------------------------------------------------------|---------------|
|      | List of Registers and Reset Values of Watch Timer                  |               |
|      | 278                                                                |               |
|      | List of Registers and Reset Values of Watchdog Timer<br>           |               |
|      | Low-power Consumption Mode Control Register<br>and Reset Values129 |               |
|      | Read/Reset State in Flash Memory                                   |               |
|      | Register in Clock Generation Section and List of                   |               |
|      | Reset Values                                                       |               |
|      | Reset Factor Bit106                                                |               |
|      | Reset Factors                                                      |               |
|      | Reset Sources and Oscillation Stabilization Wait Time              |               |
|      | State of Pins at Reset                                             |               |
|      | Reset Factor                                                       |               |
|      | Correspondence of Reset Factor Bit and Reset Factor                |               |
|      | 107                                                                |               |
|      | Notes on Reset Factor Bit107                                       |               |
|      | Reset Factor Bit                                                   |               |
|      | Reset Factors                                                      |               |
|      | Reset Sources                                                      |               |
|      | Reset Sources and Oscillation Stabilization Wait Time              |               |
|      | 101                                                                |               |
|      | Reset State                                                        |               |
|      | Read/Reset State in Flash Memory                                   | DataShe       |
|      | -                                                                  |               |
| aShe | CPU and Resources for MB90385 Series                               |               |
|      | RFWTR                                                              |               |
|      | Remote Frame Receiving Wait Register (RFWTR)                       |               |
|      | 458                                                                |               |
|      | RIER                                                               |               |
|      | Reception Complete Interrupt Enable Register (RIER)                |               |
|      |                                                                    |               |
|      | ROM                                                                |               |
|      | ROM Area                                                           |               |
|      | ROM Mirror Function Select Register                                |               |
|      | ROM Mirror Function Select Register (ROMM)                         |               |
|      |                                                                    |               |
|      | ROM Mirroring Function                                             |               |
|      | Access to FF Bank by ROM Mirroring Function                        |               |
|      |                                                                    |               |
|      | Memory Space when ROM Mirroring Function                           |               |
|      | Enabled/Disabled525                                                |               |
|      | ROM Mirroring Function Select Module                               |               |
|      | Block Diagram of ROM Mirroring Function Select                     |               |
|      | Module                                                             |               |
|      | List of Registers and Reset Values of                              |               |
|      | ROM Mirroring Function Select Module                               |               |
|      | 525                                                                |               |
|      | ROMM                                                               |               |
|      | ROM Mirror Function Select Register (ROMM)                         |               |
|      |                                                                    | Choot III ann |
|      | www.Data                                                           | Sheet4U.com   |

|    | -  | _        |
|----|----|----------|
|    |    | <b>D</b> |
| RU | VR | ĸ        |
|    |    |          |

| Reception Overrun Register (ROVRR)470    | ) |
|------------------------------------------|---|
| RP                                       |   |
| Register Bank Pointer (RP)45             | , |
| RRTRR                                    |   |
| Reception RTR Register (RRTRR)468        | 5 |
| RTEC                                     |   |
| Receive/Transmit Error Counter (RTEC)444 | ŀ |

# S

|             | SCR                                                                    | 0.05      | S |
|-------------|------------------------------------------------------------------------|-----------|---|
|             | Serial Control Register 1 (SCR1)                                       | .385      |   |
|             | Erasing Procedure for Flash Memory Sectors                             | 5/0       |   |
|             | Sector Configuration of 512 Kbit Flash Memory                          |           | S |
|             | Sector Configuration                                                   | .020      |   |
|             | Sector Configuration of 512 Kbit Flash Memory                          | .529      | S |
|             | Sector Erase Suspension<br>Sector Erase Suspension in Flash Memory     |           | S |
|             | Sector Erase Timer Flag<br>Sector Erase Timer Flag (DQ3)               |           | S |
| et4U.com    | Sector Erasing<br>Erasing Any Data in Flash Memory (Sector Erasi       | ing)      | S |
|             | Data                                                                   | 549 et4U. |   |
|             | Segment<br>Definition of Bit Timing Segment                            | .447      | S |
|             | Serial Clock Input Frequency<br>Oscillation Clock Frequency            |           |   |
|             | and Serial Clock Input Frequency                                       | .560      | S |
|             | Serial Control Register<br>Serial Control Register 1 (SCR1)            | .385      | S |
|             | Serial Input Data Register<br>Serial Input Data Register 1 (SIDR1)     | .391      | S |
|             | Serial Mode Register<br>Serial Mode Register 1 (SMR1)                  | 397       |   |
|             | Serial Output Data Register                                            |           |   |
|             | Serial Output Data Register 1 (SODR1)<br>Serial Programming Connection | .392      |   |
|             | Basic Configuration of Serial Programming<br>Connection for MB90F387/S | .558      | ~ |
|             | Serial Status Register<br>Serial Status Register 1 (SSR1)              | .389      | S |
|             | Setting<br>Setting of Internal Clock Mode                              | .260      |   |
|             | SIDR<br>Serial Input Data Register 1 (SIDR1)                           | .391      |   |
|             | Single Chip Mode<br>Block Diagram of Port 1 Pins (in Single Chip Mo    |           |   |
|             |                                                                        |           |   |
| DataSheet4U | J.com                                                                  |           |   |

|     | Connection Example in Single-chip Mode<br>(Power Supplied from Flash Microcontroller<br>Programmer)                                              |         |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------|---------|
|     | Connection Example in Single-chip Mode                                                                                                           |         |
|     | (User Power Supply Used)561<br>Function of Registers for Port 1 (in Single Chip Mode)                                                            |         |
|     |                                                                                                                                                  |         |
|     | Operation of Port 1 (in Single Chip Mode) 164<br>Registers for Port 1 (in Single Chip Mode) 162<br>State of Input/Output Pins (Single-chip Mode) |         |
|     |                                                                                                                                                  |         |
|     | Single Conversion Mode<br>Operation of Single Conversion Mode                                                                                    |         |
|     | Setting of Single Conversion Mode                                                                                                                |         |
|     | $"00_{\rm B}"$ or $"01_{\rm B}"$ )                                                                                                               |         |
|     | Sleep Mode                                                                                                                                       |         |
|     | Return from Sleep Mode    136      Transition to Sleep Mode    135                                                                               |         |
|     | SMR                                                                                                                                              |         |
|     | Serial Mode Register 1 (SMR1)                                                                                                                    |         |
|     | Serial Output Data Register 1 (SODR1)                                                                                                            |         |
|     | Software Interrupt                                                                                                                               |         |
|     | Return from Software Interrupt                                                                                                                   | DataShe |
|     | SPB                                                                                                                                              | Dataono |
| U.c | COM Bank Select Prefix (PCB,DTB,ADB,SPB)                                                                                                         |         |
|     | SSB                                                                                                                                              |         |
|     | User Stack Bank Register (USB)<br>and System Stack Bank Register (SSB)                                                                           |         |
|     |                                                                                                                                                  |         |
|     | SSP<br>Sustam Stock Dointon (SSD) 40                                                                                                             |         |
|     | System Stack Pointer (SSP) 40<br>SSR                                                                                                             |         |
|     | Serial Status Register 1 (SSR1)                                                                                                                  |         |
|     | Stack                                                                                                                                            |         |
|     | Stack Area                                                                                                                                       |         |
|     | Stack Operation at Return from Interrupt Processing                                                                                              |         |
|     | Stack Operation at Starting Interrupt Processing<br>                                                                                             |         |
|     | Stack Selection                                                                                                                                  |         |
|     | Standby Mode                                                                                                                                     |         |
|     | Cancellation of Standby Mode by Interrupt 146                                                                                                    |         |
|     | Notes on Accessing the Low-Power Consumption                                                                                                     |         |
|     | Mode Control Register (LPMCR) to Enter<br>the Standby Mode                                                                                       |         |
|     | Note on Cancelling Standby Mode                                                                                                                  |         |
|     | Notes on the Transition to Standby Mode                                                                                                          |         |
|     | Operating State in Each Standby Mode 134                                                                                                         |         |
|     | Oscillation Stabilization Wait Time in Standby Mode                                                                                              |         |
|     | 104<br>Standby Mode                                                                                                                              | t4U.com |

|          | Transition to Standby Mode 146                               |
|----------|--------------------------------------------------------------|
|          | Start Interrupt Processing                                   |
|          | Time Required to Start Interrupt Processing                  |
|          | Starting Interrupt Processing                                |
|          | Stack Operation at Starting Interrupt Processing             |
|          |                                                              |
|          | State                                                        |
|          | Read/Reset State in Flash Memory                             |
|          | State Transition Diagram<br>State Transition Diagram         |
|          | State Transition Diagram                                     |
|          | Node Status Transition due to Error Occurrence               |
|          | 445                                                          |
|          | Stop Mode                                                    |
|          | Return from Stop Mode 142                                    |
|          | Stop Mode 141                                                |
|          | Storing Patch Program                                        |
|          | Operation of Address Match Detection Function                |
|          | at Storing Patch Program in E <sup>2</sup> PROM              |
|          |                                                              |
|          | Subclock                                                     |
|          | Oscillation Stabilization Wait Time Timer of<br>Subclock 283 |
|          | Supply Map                                                   |
| et4U.com | Clock Supply Map 110                                         |
|          | Symbols                                                      |
|          | Description of instruction presentation items                |
|          | and symbols                                                  |
|          | Synchronous Mode                                             |
|          | Operation in Clock Synchronous Mode<br>(Operation Mode 2)    |
|          | System Configuration                                         |
|          | System Configuration and E <sup>2</sup> PROM Memory Map      |
|          |                                                              |
|          | System Stack Bank Register                                   |
|          | User Stack Bank Register (USB)                               |
|          | and System Stack Bank Register (SSB)                         |
|          |                                                              |
|          | System Stack Pointer                                         |
|          | System Stack Pointer (SSP) 40                                |
|          | -                                                            |
|          | T                                                            |

| TBTC                                           |     |
|------------------------------------------------|-----|
| Timebase Timer Control Register (TBTC) 1       | 193 |
| TCANR                                          |     |
| Transmission Cancel Register (TCANR)           | 460 |
| TCCS                                           |     |
| Timer Counter Control Status Register (TCCS)   |     |
|                                                | 225 |
| TCDT                                           |     |
| Count Operation of Timer Counter Data Register |     |
| (TCDT)                                         |     |
| DataSheet4U.Timer Counter Data Register (TCDT) | 227 |

| Transmission Complete Register (TCR)462                                      |         |
|------------------------------------------------------------------------------|---------|
| TIER                                                                         |         |
| Transmission Complete Interrupt Enable Register<br>(TIER)464                 |         |
| Timebase Timer                                                               |         |
| Block Diagram of Timebase Timer 190                                          |         |
| Correspondence between Timebase Timer Interrupt<br>and EI <sup>2</sup> OS195 |         |
| Generation of Interrupt Request from Timebase Timer 192                      |         |
| List of Registers and Reset Values of Timebase Timer<br>                     |         |
| Precautions when Using Timebase Timer                                        |         |
| Program Example of Timebase Timer201                                         |         |
| Timebase Timer Interrupt195                                                  |         |
| Timebase Timer Control Register<br>Timebase Timer Control Register (TBTC)    |         |
| Timebase Timer Mode                                                          |         |
| Return from Timebase Timer Mode140                                           |         |
| Transition to Timebase Timer Mode139                                         |         |
| Timer Control Status Registers                                               |         |
| Timer Control Status Registers (High)                                        |         |
| (TMCSR0: H,TMCSR1: H)                                                        |         |
| Timer Control Status Registers (Low)                                         |         |
| (TMCSR0: L,TMCSR1: L)253                                                     | DataShe |
| Timer Counter Control Status Register                                        | Datas   |
| Sheet4UTimer Counter Control Status Register (TCCS)                          |         |
|                                                                              |         |
| Timer Counter Data Register                                                  |         |
| Count Operation of Timer Counter Data Register                               |         |
| (TCDT)227                                                                    |         |
| Timer Counter Data Register (TCDT)227                                        |         |
| Timer Registers                                                              |         |
| 16-bit Timer Registers (TMR0,TMR1)255                                        |         |
| Timing Limit Over Flag                                                       |         |
| Timing Limit Over Flag (DQ5)540                                              |         |
| TMCSR                                                                        |         |
| Timer Control Status Registers (High)                                        |         |
| (TMCSR0: H,TMCSR1: H)                                                        |         |
| Timer Control Status Registers (Low)                                         |         |
| (TMCSR0: L,TMCSR1: L)253                                                     |         |
| TMR                                                                          |         |
| 16-bit Timer Registers (TMR0,TMR1)255                                        |         |
| TMRLR                                                                        |         |
| 16-bit Reload Registers (TMRLR0,TMRLR1)                                      |         |
|                                                                              |         |
| Toggle Bit Flag                                                              |         |
|                                                                              |         |
| Toggle Bit Flag (DO2) $542$                                                  |         |
| Toggle Bit Flag (DQ2)542<br>Toggle Bit Flag (DQ6)                            |         |
| Toggle Bit Flag (DQ6)539                                                     |         |
| Toggle Bit Flag (DQ6)539<br>Transfer                                         |         |
| Toggle Bit Flag (DQ6)539                                                     |         |

| Transition                                      |
|-------------------------------------------------|
| Node Status Transition due to Error Occurrence  |
|                                                 |
| Notes on the Transition to Standby Mode146      |
| State Transition Diagram144                     |
| Transition of Clock Mode147                     |
| Transition to Sleep Mode135                     |
| Transition to Standby Mode146                   |
| Transition to Timebase Timer Mode139            |
| Transition to Watch mode137                     |
| Transmission                                    |
| Program Example of CAN Transmission             |
| and Reception504                                |
| Transmission487                                 |
| Transmission Cancel Register                    |
| Transmission Cancel Register (TCANR)460         |
| Transmission Complete Interrupt Enable Register |
| Transmission Complete Interrupt Enable Register |
| (TIER)464                                       |
| Transmission Complete Register                  |
| Transmission Complete Register (TCR)462         |
| Transmission Request Register                   |
| Transmission Request Register (TREQR)454        |
| Transmission RTR Register                       |
| Transmission RTR Register (TRTRR)456            |
| Transmit Interrupt                              |
| Generation of Transmit Interrupt and Timing of  |
| Flag SetData 399 e                              |
| Transmitting                                    |
| Procedure for Transmitting message Buffer (x)   |
|                                                 |
| TREQR                                           |
| Transmission Request Register (TREQR)454        |
| TRTRR                                           |
| Transmission RTR Register (TRTRR)456            |
|                                                 |

#### U

et4U.com

| UART1                                             |     |
|---------------------------------------------------|-----|
| Block Diagram of Pins of UART1                    | 383 |
| Block Diagram of UART1                            | 380 |
| EI <sup>2</sup> OS Function of UART1              | 396 |
| Function of UART1                                 | 378 |
| Interrupt of UART1                                | 395 |
| Interrupt Related to UART1 and EI <sup>2</sup> OS | 396 |
| Interrupt Request Generation by UART1             | 384 |
| List of Registers in UART1                        | 383 |
| Operation of UART1                                |     |
| Precautions when Using UART1                      | 423 |
| Program Example for UART1                         | 424 |
| Select of UART1 Baud Rate                         | 400 |
| UART1 Pin                                         | 383 |
| Underflow                                         |     |
| Operation at Underflow                            | 245 |

| ~ |     |    | $\sim$ |   |           |   |    |     |        |            |   |  |
|---|-----|----|--------|---|-----------|---|----|-----|--------|------------|---|--|
|   | 2   | ta | 5      | n | $\square$ |   | řΖ |     | $\cap$ | $\cap$     | m |  |
| 1 | CI. | ιu | $\sim$ |   | $\sim$    | 5 |    | · U |        | $_{\circ}$ |   |  |

| Underflows                                    |
|-----------------------------------------------|
| Operation as 16-bit Timer Register Underflows |
|                                               |
| USB                                           |
| User Stack Bank Register (USB)                |
| and System Stack Bank Register (SSB)          |
|                                               |
| User Power Supply                             |
| Example of Minimum Connection to              |
| Flash Microcontroller Programmer              |
| (User Power Supply Used)                      |
| Connection Example in Single-chip Mode        |
| (User Power Supply Used)561                   |
| User Stack Bank Register                      |
| User Stack Bank Register (USB)                |
| and System Stack Bank Register (SSB)          |
|                                               |
| User Stack Pointer                            |
| User Stack Pointer (USP) 40                   |
| USP                                           |
| User Stack Pointer (USP) 40                   |

| Vector Tables                                       |         |
|-----------------------------------------------------|---------|
| Registers and Vector Tables Related to Interrupt of | - L Cho |
| CAN Controller                                      | DataShe |

| . I. A |    |     |
|--------|----|-----|
| 914    | U. | com |
|        |    | w   |

| Watch mode                                                |
|-----------------------------------------------------------|
| Return from Watch mode138                                 |
| Transition to Watch mode137                               |
| Watch Timer                                               |
| Block Diagram of Watch Timer                              |
| Generation of Interrupt Request from Watch Timer          |
|                                                           |
| List of Registers and Reset Values of Watch Timer         |
|                                                           |
| Program Example of Watch Timer                            |
| Watch Timer Counter                                       |
| Watch Timer Interrupt                                     |
| Watch Timer Interrupt and EI <sup>2</sup> OS Function 281 |
| Watch Timer Control Register                              |
| Watch Timer Control Register (WTC) 279                    |
| Watchdog Timer                                            |
| Block Diagram of Watchdog Timer                           |
| Functions of Watchdog Timer                               |
| List of Registers and Reset Values of Watchdog Timer      |
|                                                           |
| Operation of Watchdog Timer                               |
| Precautions when Using Watchdog Timer 213                 |
| Program Example of Watchdog Timer                         |
| Setting Operation Clock of Watchdog Timer                 |
|                                                           |
| www.DataSheet4U.com                                       |

| Watchdog Timer Control Register            |
|--------------------------------------------|
| Watchdog Timer Control Register (WDTC) 208 |
| WDTC                                       |
| Watchdog Timer Control Register (WDTC) 208 |
| WTC                                        |
| Watch Timer Control Register (WTC) 279     |

et4U.com

DataShee

DataSheet4U.com

www.DataSheet4U.com

et4U.com

DataSheet4U.com

DataShe

CM44-10118-2E

# FUJITSU SEMICONDUCTOR • CONTROLLER MANUAL

F<sup>2</sup>MC<sup>TM</sup>-16LX 16-BIT MICROCONTROLLER MB90385 Series HARDWARE MANUAL

November 2005 the second edition

Published **FUJITSU LIMITED** Electronic Devices

Edited Business Promotion Dept.

DataSheet4U.com

www.DataSheet4U.com

et4U.com

DataSheet4U.com

DataSheet4U.com

www.DataSheet4U.com

DataSheet4U.com