CM44-10116-2E

www.DatasheetAU.com

# FUJITSU SEMICONDUCTOR CONTROLLER MANUAL

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

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

**FUJITSU LIMITED** 



#### Objectives and Intended Reader

Thank you for purchasing a Fujitsu semiconductor product.

The MB90M405 series is a series of general-purpose 16-bit microcontrollers with 60 built-in high-tension-resistant output pins required for fluorescent display control. The MB90M405 series was developed for applications that require the control of a vacuum fluorescent tube panel.

This manual, intended for engineers who design products using the MB90M405 series, describes the functions and operations of MB90M405 series products.

#### Trademark

F<sup>2</sup>MC is the abbreviation of FUJITSU Flexible Microcontroller.

Embedded Algorithm is a trademark of Advanced Micro Devices Corporation.

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

The symbols <sup>TM</sup> and <sup>®</sup> are sometimes omitted in the text.

#### License

Purchase of FUJITSU Ltd,  $I^2C$  components conveys a license under the Philips  $I^2C$  Patent Right to use.

These components in an I<sup>2</sup>C system, provided that the system conforms to the I<sup>2</sup>C Standard Specification as defined by Philips.

#### Organization of This Manual

This manual consists of the following 24 chapters and an appendix:

#### **CHAPTER 1 "OVERVIEW"**

This chapter summarizes the features and basic specifications of the MB90M405 series of microcontrollers.

#### CHAPTER 2 "CPU"

This chapter describes the CPU and the memory space provided by the MB90M405 series

#### CHAPTER 3 "RESETS"

This chapter describes resets for the MB90M405 series.

#### **CHAPTER 4 "CLOCKS"**

This chapter describes the clocks used by MB90M405 series.

#### CHAPTER 5 "LOW POWER CONSUMPTION MODE"

This chapter describes the low power consumption mode of MB90M405 series.

#### **CHAPTER 6 "INTERRUPTS"**

This chapter explains the interrupts and extended intelligent I/O service (EI<sup>2</sup>OS) in the MB90M405 series.

#### CHAPTER 7 "SETTING A MODE"

This chapter describes the operating modes and the memory access modes of the MB90M405 series.

#### CHAPTER 8 "I/O PORTS"

This chapter describes the functions and operations of the MB90M405 series I/O ports.

#### CHAPTER 9 "SERIAL I/O"

This chapter describes the functions and operations of the serial I/O unit of the MB90M405 series.

#### CHAPTER 10 "TIMEBASE TIMER"

This chapter describes the functions and operation of the timebase timer of the MB90M405 series.

#### CHAPTER 11 "WATCHDOG TIMER"

This chapter describes the functions and operations of the watchdog timer of the MB90M405 series.

#### CHAPTER 12 "16-BIT RELOAD TIMER"

This chapter describes the functions and operations of the 16-bit reload timer of the MB90M405 series.

#### CHAPTER 13 "16-BIT I/O TIMER"

This chapter describes the functions and operations of the 16-bit I/O timer of the MB90M405 series.

#### CHAPTER 14 "UART"

This chapter describes the functions and operations of the MB90M405 series UART.

#### CHAPTER 15 "DTP/EXTERNAL INTERRUPT CIRCUIT"

This chapter describes the functions and operations of the DTP/external interrupt circuit of the MB90M405 series.

#### CHAPTER 16 "I<sup>2</sup>C INTERFACE"

This chapter describes the functions and operations of the I<sup>2</sup>C interface of the MB90M405 series.

#### CHAPTER 17 "8/10-BIT A/D CONVERTER"

This chapter describes the functions and operations of the MB90M405 series 8/10-bit A/D converter.

#### CHAPTER 18 "FL CONTROL CIRCUIT"

This chapter explains the functions and operation of the MB90M405 series FL control circuit.

#### CHAPTER 19 "WATCH CLOCK OUTPUT"

This chapter describes the functions and operations of MB90M405 series watch clock output.

#### CHAPTER 20 "DELAYED INTERRUPT GENERATOR MODULE"

This chapter describes the functions and operation of the MB90M405 series delayed interrupt generator module.

#### CHAPTER 21 "ADDRESS MATCH DETECTION FUNCTION"

This chapter describes the address match detection function of the MB90M405 series and its operations.

#### CHAPTER 22 "ROM MIRRORING FUNCTION SELECTION MODULE"

This chapter describes the function and operation of the MB90M405 series ROM mirroring function selection module.

#### CHAPTER 23 "1M-BIT FLASH MEMORY"

This chapter describes the functions and operations of the MB90M405 series 1M-bit flash memory.

#### CHAPTER 24 "EXAMPLE OF MB90MF408 SERIAL PROGRAMMING CONNECTION"

This chapter provides examples of connection for serial programming using the AF220 flash microcomputer programmer manufactured by YDC Corporation.

#### APPENDIX

This appendix includes I/O maps, instruction lists, and other information.

- The contents of this document are subject to change without notice. Customers are advised to consult with FUJITSU sales representatives before ordering.
- The information and circuit diagrams in this document are presented as examples of semiconductor device applications, and are not intended to be incorporated in devices for actual use. Also, FUJITSU is unable to assume responsibility for infringement of any patent rights or other rights of third parties arising from the use of this information or circuit diagrams.
- 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.

# CONTENTS

| CHAP | TER 1 OVERVIEW                               | 1  |
|------|----------------------------------------------|----|
| 1.1  | Features                                     | 2  |
| 1.2  | Product Lineup                               | 5  |
| 1.3  | Block Diagram                                | 7  |
| 1.4  | Package Dimensions                           | 8  |
| 1.5  | Pin Assignments                              |    |
| 1.6  | Pin Functions                                | 10 |
| 1.7  | I/O Circuit Types                            |    |
| 1.8  | Notes on Handling Devices                    |    |
| 1.9  | Clock Supply Map                             | 19 |
| 1.10 | Low Power Consumption Mode                   | 20 |
| СНАР | TER 2 CPU                                    | 21 |
| 2.1  | CPU                                          | 22 |
| 2.2  | Memory Space                                 | 23 |
| 2.3  | Memory Maps                                  |    |
| 2.4  | Addressing                                   | 28 |
| 2.4  | Address Specification by Linear Addressing   | 29 |
| 2.4  | Address Specification by Bank Addressing     | 30 |
| 2.5  | Memory Location of Multibyte Data            | 32 |
| 2.6  | Registers                                    | 34 |
| 2.7  | Dedicated Registers                          | 35 |
| 2.7  | 7.1 Accumulator (A)                          | 37 |
| 2.7  | 7.2 Stack Pointers (USP, SSP)                | 40 |
| 2.7  | 7.3 Processor Status (PS)                    | 42 |
| 2.7  | 7.4 Condition Code Register (PS: CCR)        | 43 |
| 2.7  | 7.5 Register Bank Pointer (PS: RP)           | 45 |
| 2.7  | 7.6 Interrupt Level Mask Register (PS: ILM)  | 46 |
| 2.7  | 7.7 Program Counter (PC)                     | 47 |
| 2.7  | 7.8 Direct Page Register (DPR)               | 48 |
| 2.7  | 7.9 Bank Registers (PCB, DTB, USB, SSB, ADB) | 49 |
| 2.8  | General-Purpose Registers                    | 50 |
| 2.9  | Prefix Codes                                 | 52 |
| 2.9  | 0.1 Bank Select Prefix (PCB, DTB, ADB, SPB)  | 53 |
| 2.9  | 0.2 Common Register Bank Prefix (CMR)        | 55 |
| 2.9  | 9.3 Flag Change Suppression Prefix (NCC)     | 56 |
| 2.9  | 0.4 Restrictions on Prefix Codes             | 57 |

| СНАР       | TER 3 RESETS                                                                    | 59  |
|------------|---------------------------------------------------------------------------------|-----|
| 3.1        | Resets                                                                          | 60  |
| 3.2        | Reset Causes and Oscillation Stabilization Wait Time                            | 62  |
| 3.3        | External Reset Pin                                                              | 63  |
| 3.4        | Reset Operation                                                                 |     |
| 3.5        | Reset Cause Bits                                                                |     |
| 3.6        | Status of Pins in a Reset                                                       |     |
| СНАР       | TER 4 CLOCKS                                                                    |     |
| 4.1        | Clocks                                                                          |     |
| 4.2        | Block Diagram of the Clock Generation Block                                     |     |
| 4.3        | Clock Selection Register (CKSCR)                                                |     |
| 4.4        | Clock Mode                                                                      |     |
| 4.5        | Oscillation Stabilization Wait Time                                             |     |
| 4.6        | Connection of an Oscillator or an External Clock to the Microcontroller         |     |
| СНАР       | TER 5 LOW POWER CONSUMPTION MODE                                                | 81  |
| 5.1        | Low Power Consumption Mode                                                      |     |
| 5.2        | Block Diagram of the Low Power Consumption Control Circuit                      |     |
| 5.3        | Low Power Consumption Mode Control Register (LPMCR)                             |     |
| 5.4        | CPU Intermittent Operation Mode                                                 |     |
| 5.4        | Standby Mode                                                                    |     |
| 5.5<br>5.5 | -                                                                               |     |
| 5.5        | •                                                                               |     |
| 5.5<br>5.5 |                                                                                 |     |
| 5.6        | •                                                                               |     |
| 5.0<br>5.7 | Status Change Diagram                                                           |     |
|            | Pin Status in Standby Mode and during Reset                                     |     |
| 5.8        | Usage Notes on Low Power Consumption Mode                                       |     |
| СНАР       | TER 6 INTERRUPTS                                                                | 101 |
| 6.1        | Interrupts                                                                      | 102 |
| 6.2        | Interrupt Causes and Interrupt Vectors                                          | 104 |
| 6.3        | Interrupt Control Registers and Peripheral Functions                            | 106 |
| 6.3        | .1 Interrupt Control Registers (ICR00 to ICR15)                                 | 108 |
| 6.3        | .2 Interrupt Control Register Functions                                         | 110 |
| 6.4        | Hardware Interrupts                                                             | 113 |
| 6.4        | .1 Operation of Hardware Interrupts                                             | 116 |
| 6.4        | .2 Processing for Interrupt Operation                                           | 118 |
| 6.4        | .3 Procedure for Using Hardware Interrupts                                      | 119 |
| 6.4        | .4 Multiple Interrupts                                                          | 121 |
| 6.4        | .5 Hardware Interrupt Processing Time                                           | 123 |
| 6.5        | Software Interrupts                                                             | 125 |
| 6.6        | Interrupt of Extended Intelligent I/O Service (EI <sup>2</sup> OS)              |     |
| 6.6        |                                                                                 |     |
| 6.6        |                                                                                 |     |
| 6.6        |                                                                                 |     |
| 6.6        |                                                                                 |     |
| 6.6        | .5 Processing Time of the Extended Intelligent I/O Service (EI <sup>2</sup> OS) | 136 |

| 149 |
|-----|
|     |
|     |
|     |
| 153 |
|     |
| 156 |
| 158 |
| 160 |
|     |
|     |
|     |
|     |
|     |
|     |
|     |
|     |
|     |
|     |
|     |
|     |
|     |
|     |
|     |
|     |
|     |
|     |
|     |
|     |
|     |
| 195 |
| 197 |
| 199 |
| 200 |
| 202 |
|     |
|     |
| 207 |
| 210 |
|     |

| CHAPTER 11 WATCHDOG TIMER                                                       | 211 |
|---------------------------------------------------------------------------------|-----|
| 11.1 Overview of the Watchdog Timer                                             | 212 |
| 11.2 Configuration of the Watchdog Timer                                        | 213 |
| 11.3 Watchdog Timer Control Register (WDTC)                                     | 215 |
| 11.4 Operation of the Watchdog Timer                                            | 217 |
| 11.5 Usage Notes on the Watchdog Timer                                          | 219 |
| CHAPTER 12 16-BIT RELOAD TIMER                                                  | 221 |
| 12.1 Overview of the 16-Bit Reload Timer                                        | 222 |
| 12.2 Configuration of the 16-Bit Reload Timer                                   |     |
| 12.3 16-Bit Reload Timer Pins                                                   |     |
| 12.4 16-Bit Reload Timer Registers                                              | 228 |
| 12.4.1 Timer Control Status Register, Higher (TMCSR)                            | 229 |
| 12.4.2 Timer Control Status Register, Lower (TMCSR)                             | 231 |
| 12.4.3 16-bit Timer Register (TMR)                                              | 233 |
| 12.4.4 16-bit Reload Register (TMRLR)                                           | 234 |
| 12.5 16-Bit Reload Timer Interrupts                                             | 235 |
| 12.6 Operation of the 16-Bit Reload Timer                                       | 236 |
| 12.6.1 Internal Clock Mode (Reload Mode)                                        | 238 |
| 12.6.2 Internal Clock Mode (Single-shot Mode)                                   | 240 |
| 12.6.3 Event Count Mode                                                         | 242 |
| 12.7 Usage Notes on the 16-Bit Reload Timer                                     | 244 |
| CHAPTER 13 16-BIT I/O TIMER                                                     | 245 |
| 13.1 Overview of the 16-Bit I/O Timer                                           | 246 |
| 13.2 16-Bit I/O Timer Block Diagram                                             | 247 |
| 13.3 16-Bit I/O Timer Registers                                                 | 248 |
| 13.3.1 16-Bit Free-Running Timer Registers (TCDT and TCCS)                      | 249 |
| 13.3.2 Output Compare Registers (OCCP0 and OCS0)                                | 252 |
| 13.3.3 Input Capture Registers (IPC0/IPC1 and ICSSS0)                           | 255 |
| 13.4 16-Bit Free-Running Timer Operations                                       | 258 |
| 13.5 16-Bit Output Compare Operations                                           | 260 |
| 13.6 16-Bit Input Capture Operations                                            | 261 |
| CHAPTER 14 UART                                                                 | 263 |
| 14.1 Overview of UART                                                           |     |
| 14.2 Configuration of UART                                                      | 266 |
| 14.3 UART Pins                                                                  |     |
| 14.4 UART Registers                                                             | 271 |
| 14.4.1 Control Register (SCR0/SCR1)                                             | 272 |
| 14.4.2 Mode Register (SMR0/SMR1)                                                | 275 |
| 14.4.3 Status Register (SSR0/SSR1)                                              |     |
| 14.4.4 Input Data Register (SIDR0/SIDR1) and Output Data Register (SODR0/SODR1) | 280 |
| 14.4.5 Communication Prescaler Control Register (CDCR0/CDCR1)                   | 282 |
| 14.5 UART Interrupts                                                            | 284 |
| 14.5.1 Reception Interrupt Generation and Flag Set Timing                       | 286 |
| 14.5.2 Transmission Interrupt Generation and Flag Set Timing                    | 288 |
| 14.6 UART Baud Rates                                                            | 289 |

| 14.6.1 Baud Rates Determined Using the Dedicated Baud Rate Generator                                                                                                | 291                                                  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|
| 14.6.2 Baud Rates Determined Using the Internal Timer                                                                                                               | 293                                                  |
| 14.6.3 Baud Rates Determined Using the External Clock                                                                                                               | 295                                                  |
| 14.7 Operation of UART                                                                                                                                              |                                                      |
| 14.7.1 Operation in Asynchronous Mode (Operation Modes 0 and 1)                                                                                                     |                                                      |
| 14.7.2 Operation in Synchronous Mode (Operation Mode 2)                                                                                                             |                                                      |
| 14.7.3 Bidirectional Communication Function (Normal Mode)                                                                                                           |                                                      |
| 14.7.4 Master-slave Communication Function (Multiprocessor Mode)                                                                                                    |                                                      |
| 14.8 Notes on Using UART                                                                                                                                            | 307                                                  |
| CHAPTER 15 DTP/EXTERNAL INTERRUPT CIRCUIT                                                                                                                           | 200                                                  |
| 15.1 Overview of the DTP/External Interrupt Circuit                                                                                                                 |                                                      |
| 15.2 Configuration of the DTP/External Interrupt Circuit                                                                                                            |                                                      |
| 15.3 DTP/External Interrupt Circuit Pins                                                                                                                            |                                                      |
| 15.4 DTP/External Interrupt Circuit Registers                                                                                                                       |                                                      |
| 15.4 DTP/External Interrupt Circuit Registers                                                                                                                       |                                                      |
| 15.4.2 DTP/Interrupt Enable Register (ENIR)                                                                                                                         |                                                      |
| 15.4.2 DTP/Interrupt Enable Register (ENIR)                                                                                                                         |                                                      |
| 15.5 Operation of the DTP/External Interrupt Circuit                                                                                                                |                                                      |
| 15.5 Operation of the DTP/External Interrupt Circuit                                                                                                                |                                                      |
| 15.5.2 DTP Function                                                                                                                                                 |                                                      |
| 15.6 Usage Notes on the DTP/External Interrupt Circuit                                                                                                              | -                                                    |
|                                                                                                                                                                     |                                                      |
| CHAPTER 16 I <sup>2</sup> C INTERFACE                                                                                                                               | 331                                                  |
| 16.1 Overview of the I <sup>2</sup> C Interface                                                                                                                     |                                                      |
| 16.2 Block Diagram and Configuration of the I <sup>2</sup> C Interface                                                                                              |                                                      |
| 16.3 I <sup>2</sup> C Interface Registers                                                                                                                           | 335                                                  |
| 16.3.1 I <sup>2</sup> C Status Register (IBSR)                                                                                                                      | 336                                                  |
| 16.3.2 I <sup>2</sup> C Control Register (IBCR)                                                                                                                     | 338                                                  |
| 16.3.3 I <sup>2</sup> C Clock Control Register (ICCR)                                                                                                               | 341                                                  |
| 16.3.4 I <sup>2</sup> C Address Register (IADR)                                                                                                                     |                                                      |
| 16.3.5 I <sup>2</sup> C Data Register (IDAR)                                                                                                                        |                                                      |
| 16.3.6 I <sup>2</sup> C Port Select Register (ISEL)                                                                                                                 |                                                      |
| 16.4 Operation of the I <sup>2</sup> C Interface                                                                                                                    |                                                      |
| 16.4.1 Transfer Flow of the I <sup>2</sup> C Interface                                                                                                              | 349                                                  |
| 16.4.2 Mode Flow of the I <sup>2</sup> C Interface                                                                                                                  | 351                                                  |
| 16.4.3 Operation Flow of the I <sup>2</sup> C Interface                                                                                                             | 352                                                  |
| •                                                                                                                                                                   |                                                      |
| ·                                                                                                                                                                   |                                                      |
|                                                                                                                                                                     |                                                      |
| 17.1 Overview of the 8/10-Bit A/D Converter                                                                                                                         | 356                                                  |
| <ul><li>17.1 Overview of the 8/10-Bit A/D Converter</li><li>17.2 Configuration of the 8/10-Bit A/D Converter</li></ul>                                              | 356<br>358                                           |
| <ul> <li>17.1 Overview of the 8/10-Bit A/D Converter</li> <li>17.2 Configuration of the 8/10-Bit A/D Converter</li> <li>17.3 8/10-Bit A/D Converter Pins</li> </ul> |                                                      |
| <ul> <li>17.1 Overview of the 8/10-Bit A/D Converter</li></ul>                                                                                                      |                                                      |
| <ul> <li>17.1 Overview of the 8/10-Bit A/D Converter</li></ul>                                                                                                      |                                                      |
| <ul> <li>17.1 Overview of the 8/10-Bit A/D Converter</li></ul>                                                                                                      |                                                      |
| <ul> <li>17.1 Overview of the 8/10-Bit A/D Converter</li></ul>                                                                                                      | 356<br>358<br>360<br>362<br>363<br>365<br>365<br>367 |
| <ul> <li>17.2 Configuration of the 8/10-Bit A/D Converter</li> <li>17.3 8/10-Bit A/D Converter Pins</li> <li>17.4 8/10-Bit A/D Converter Registers</li></ul>        |                                                      |

| 17.6  | Operation of the 8/10-Bit A/D Converter                                                               | 372 |
|-------|-------------------------------------------------------------------------------------------------------|-----|
|       | 6.1 Conversion Using El <sup>2</sup> OS                                                               |     |
| 17.6  | 6.2 A/D Conversion Data Protection Function                                                           | 376 |
| 17.7  | Usage Notes on the 8/10-Bit A/D Converter                                                             | 378 |
| CHAP  | TER 18 FL CONTROL CIRCUIT                                                                             | 379 |
| 18.1  | Overview of FL Control Circuit                                                                        | 380 |
| 18.2  | Configuration of FL Control Circuit                                                                   | 382 |
| 18.3  | FL Control Circuit Pins                                                                               | 383 |
| 18.3  | 3.1 Display Control Register 1 (FLC1)                                                                 | 385 |
| 18.3  | 3.2 Display Control Register 2 (FLC2)                                                                 | 387 |
| 18.3  | 3.3 Digit Setting Register (FLDG)                                                                     | 389 |
|       | 3.4 Digit Count Register (FLDC)                                                                       |     |
| 18.3  | 3.5 Port Register (FLPD)                                                                              | 393 |
|       | 3.6 Status/Authorization Register (FLST)                                                              |     |
| 18.3  | 3.7 Display RAM                                                                                       | 396 |
| 18.3  | 3.8 Segment Dimmer Setting Register (SEGD)                                                            | 397 |
| 18.4  | FL Control Circuit Operation                                                                          | 398 |
| СНАРТ | TER 19 WATCH CLOCK OUTPUT                                                                             | 403 |
|       | Overview of the Watch Clock Output Circuit                                                            |     |
|       | Configuration of the Watch Clock Output Circuit                                                       |     |
|       | Watch Clock Output Control Register (TMCS)                                                            |     |
| 10.0  |                                                                                                       | 400 |
| CHAP  | TER 20         DELAYED INTERRUPT GENERATOR MODULE                                                     |     |
| 20.1  |                                                                                                       |     |
| 20.2  | Delayed Interrupt Cause/Cancel Register (DIRR)                                                        |     |
|       | Operation of the Delayed Interrupt Generator Module                                                   |     |
| 20.4  | Precautions to Follow when Using the Delayed Interrupt Generator Module                               | 411 |
| CHAPT | FER 21 ADDRESS MATCH DETECTION FUNCTION                                                               | 413 |
| 21.1  | Overview of the Address Match Detection Function                                                      | 414 |
| 21.2  | Registers of the Address Match Detection Function                                                     | 415 |
| 21.2  | 2.1 Program Address Detection Register for Upper, Middle, and Lower Parts of Address<br>(PADR0/PADR1) | 416 |
| 21 2  | 2.2 Program Address Detection Control Status Register (PACSR)                                         |     |
|       | Operation of the Address Match Detection Function                                                     |     |
|       | Example of Using the Address Match Detection Function                                                 |     |
| СНАРТ | TER 22 ROM MIRRORING FUNCTION SELECTION MODULE                                                        | 123 |
| 22.1  | Overview of the ROM Mirroring Function Selection Module                                               |     |
|       | •                                                                                                     |     |
| 22.2  | ROM Mirroring Function Selection Register (ROMM)                                                      | 425 |
| CHAP  | TER 23 1M-BIT FLASH MEMORY                                                                            |     |
| 23.1  | Overview of the 1M-Bit Flash Memory                                                                   |     |
| 23.2  | Registers and Sector Configuration of the Flash Memory                                                |     |
| 23.3  | Flash Memory Control Status Register (FMCS)                                                           |     |
| 23.4  | Starting the Automatic Algorithm of the Flash Memory                                                  | 433 |

| 23.5 De | etailed Description of Flash Memory Writing and Deletion       | . 434 |
|---------|----------------------------------------------------------------|-------|
| 23.5.1  | Placing the Flash Memory in Read/Reset Status                  | . 435 |
| 23.5.2  | Writing Data to the Flash Memory                               | . 436 |
| 23.5.3  | Deleting All Data Items from the Flash Memory (Chip Deletion)  | . 438 |
| 23.5.4  | Deleting a Data Item from the Flash Memory (Sector Deletion)   | . 439 |
| 23.5.5  | Temporarily Stopping Deletion of Sectors from the Flash Memory | . 441 |
| 23.5.6  | Resuming Flash Memory Sector Deletion                          | . 442 |
|         |                                                                |       |

# CHAPTER 24 EXAMPLE OF MB90MF408/MF408A SERIAL PROGRAMMING

|       |                                                                                                            | 443 |
|-------|------------------------------------------------------------------------------------------------------------|-----|
| 24.1  | Standard Configuration for Serial Programming Connection to MB90MF408/MF408A                               | 444 |
| 24.2  | Example of Connection for Serial Programming (Power Supplied by User)                                      | 446 |
| 24.3  | Example of Connection for Serial Programming (When Power Supplied from Programmer)                         | 448 |
| 24.4  | Example of Minimum Connection with Flash Microcomputer Programmer<br>(When Power Supplied from User)       | 450 |
| 24.5  | Example of Minimum Connection with Flash Microcomputer Programmer<br>(When Power Supplied from Programmer) | 452 |
| APPEN |                                                                                                            | 455 |
| APPE  | NDIX A I/O Map                                                                                             | 456 |
| APPE  | NDIX B Instructions                                                                                        | 463 |
| B.1   | Instruction Types                                                                                          | 464 |
| B.2   | Addressing                                                                                                 | 465 |
| B.3   | Direct Addressing                                                                                          | 467 |
| B.4   | Indirect Addressing                                                                                        | 472 |
| B.5   | Execution Cycle Count                                                                                      | 478 |
| B.6   | Effective Address Field                                                                                    | 481 |
| B.7   | How to Read the Instruction List                                                                           | 482 |
| B.8   | F <sup>2</sup> MC-16LX Instruction List                                                                    | 485 |
| B.9   | Instruction Map                                                                                            | 499 |
| APPE  | NDIX C Index of Registers                                                                                  | 521 |
| APPE  | NDIX D Index of Pin Functions                                                                              | 525 |

| INDEX | 529 |
|-------|-----|
|-------|-----|

# CHAPTER 1 OVERVIEW

# This chapter summarizes the features and basic specifications of the MB90M405 series of microcontrollers.

- 1.1 "Features"
- 1.2 "Product Lineup"
- 1.3 "Block Diagram"
- 1.4 "Package Dimensions"
- 1.5 "Pin Assignments"
- 1.6 "Pin Functions"
- 1.7 "I/O Circuit Types"
- 1.8 "Notes on Handling Devices"
- 1.9 "Clock Supply Map"
- 1.10 "Low Power Consumption Mode"

### 1.1 Features

The MB90M405 series of general-purpose 16-bit microcontrollers was developed for applications that require control of fluorescent display tube panels. The microcontrollers in this series have 60 high dielectric output pins for fluorescent display control.

The instruction set inherits the AT architecture of the  $F^2MC-8L$  and  $F^2MC-16L$ , and has additional instructions that support the C language. In addition, the instruction set supports extended addressing mode, enhanced signed multiply/divide instructions, and more powerful bit manipulation instructions. The microcontrollers also have a 32bit accumulator that enables processing of long-word data.

#### ■ MB90M405 Series Features

- O Clocks
  - Built-in PLL clock multiplier circuit
  - Source oscillation

Main clock that divides the source oscillation by two

PLL clock that multiplies the source oscillation by 1 to 4 (2.1 to 16.8 MHz when the source oscillation is 4.2 MHz), which can be configured from the machine clock

- Minimum instruction execution time: 59.5 ns (when the source oscillation is 4.2 MHz, the PLL clock is multiplied by 4, and  $V_{CC}$  is 3 V)
- The source oscillation can be divided by 16, 32, 64, or 128 for external clock output.

#### O Maximum memory address space: 16 M bytes

24-bit addressing can also be used.

#### O Optimum instruction set for controller applications

- Many data types (bit, byte, and long word) can be handled.
- As many as 23 addressing modes are available.
- Efficient code (compiler)
- Enhanced high-precision arithmetic operations with a 32-bit accumulator
- Enhanced signed multiply/divide instructions and RETI instruction function

#### O Instruction set supporting the C language and multitasking

- System stack pointer
- · Instruction set symmetry and barrel shift instructions
- Program patch function (two-address pointer)

#### **O** Improved execution speed

The built-in 4-byte instruction queue prereads instructions to improve execution speed.

#### O Interrupt function

- Eight programmable priority levels can be set.
- An enhanced interrupt function with 32 interrupt causes is supported.

#### **O** Data transfer function

O Extended intelligent I/O service function: Up to 16 channels can be set.

#### O Low-power mode

- Sleep mode (in which the CPU operating clock stops)
- Timebase timer mode (in which only the source oscillation clock and Timebase timer are active)
- Stop mode (in which the source oscillation stops)
- CPU intermittent operation mode (in which the CPU operates at every specified cycle)

#### O Package

• QFP-100 (FPT-100P-M06: 0.65 mm pin pitch)

#### **O** Process

CMOS technology

#### Internal Peripheral Functions (resources)

- O I/O ports: Up to 26 ports (used also for internal resources)
- **O** Timebase timer: 1 channel
- O Watchdog timer: 1 channel
- O 16-bit reload timer: 3 channels
- O 16-bit free-running timer: 1 channel

#### O Output compare: 1 channel

• When the counter value of the 16-bit free-running timer matches the value set in the compare register, an interrupt request can be output.

#### **O** Input capture: 2 channels

• When the effective edge of a signal that is output from an external input pin is detected, the counter value of the 16-bit free-running timer can be read into the input capture data register and an interrupt request can be output.

#### ○ Serial I/O: 2 channels

#### O UART: 2 channels

- With full-duplex double buffer (8-bit length)
- Capable of asynchronous or clock synchronous serial transfer (I/O extended serial)

#### **O DTP/external interrupt (4 channels)**

- The input of an external interrupt can be used to activate the extended intelligent I/O service.
- The input of an external interrupt can be used to cause an internal hardware interrupt.

#### O Delayed interrupt generator module

Generates an interrupt request for task switching.

#### O 8/10-bit A/D converter (16 channels)

Selectable resolution of 8 or 10 bits

#### **O FL-control circuit**

- Enables FL driver control (automatic display control of up to 32 digit lines and up to 59 segment lines)
  - Up to 32 digit lines (can be set line by line)
  - Dimmer setting
- Permits LED driver control (automatic display control of up to 16 lines)
  - Automatic display control of up to 16 lines with a 1/2 duty factor

#### • Clock output circuit

• Enables the source oscillation to be divided by 32, 64, 128, or 256 for clock output.

# 1.2 Product Lineup

# Table 1.2-1 "MB90M405 Series Product Lineup" shows the MB90M405 series product lineup.

#### Product Lineup

#### Table 1.2-1 MB90M405 Series Product Lineup

| Model                          | MB90MV405                                                                                                                                                                                                                                                             | MB90MF408 (*1)<br>MB90MF408A (*2) | MB90M408 (*1)<br>MB90M408A (*2) | MB90M407 (*1)<br>MB90M407A (*2) |
|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|---------------------------------|---------------------------------|
| Туре                           | Evaluation device                                                                                                                                                                                                                                                     | Built-in flash<br>memory          | Built-in r                      | mask ROM                        |
| ROM size                       | Not installed                                                                                                                                                                                                                                                         | 128K                              | bytes                           | 96K bytes                       |
| RAM size                       | 4K bytes                                                                                                                                                                                                                                                              | 4K I                              | oytes                           | 4K bytes                        |
| CPU function                   | Number of basic instructions: 351<br>Minimum instruction execution time: 59.5 ns/4.2 MHz (when PLL clock is multiplied by 4)<br>Number of addressing modes: 23<br>Program patch function: 2-address pointer<br>Maximum memory address space: 16M bytes                |                                   |                                 |                                 |
| Port                           | I/O ports (CMOS):                                                                                                                                                                                                                                                     | 26 (also used for resou           | irces)                          |                                 |
| FL control circuit             | 60 FL output lines (43 FL output lines and 17 LED control lines in LED control mode)<br>Capable of FL driver control and LED driver control<br>Enables dimmer setting for both digit and segment lines in FL driver control mode                                      |                                   |                                 |                                 |
| Serial I/O (UART)              | With a full-duplex double buffer<br>Capable of synchronous or asynchronous clock transfer<br>Also can be used for clock synchronous extended serial I/O<br>Dedicated built-in baud rate generator<br>Four built-in channels (two channels are also used for the UART) |                                   |                                 |                                 |
| 16-bit reload<br>timer         | 16-bit reload timer operation (can be set for toggle or one-shot output)<br>Supports an event count function<br>Three built-in channels                                                                                                                               |                                   |                                 |                                 |
| 16-bit free-<br>running timer  | 16-bit output compare x 1 channel (for clearing the free-running timer)<br>16-bit input capture x 2 channels                                                                                                                                                          |                                   |                                 |                                 |
| 8/10-bit A/D<br>converter      | 16 channels (input multiplexing)<br>Capable of 8-bit or 10-bit resolution<br>Conversion time: 5.9 μs (for an the operating machine clock of 16.8 MHz)                                                                                                                 |                                   |                                 |                                 |
| Timing clock<br>output circuit | An external input clock frequency can be divided and output externally.<br>Specifiable division ratio: Programmable to 1/16, 1/32, 1/64, or 1/128                                                                                                                     |                                   |                                 |                                 |
| I <sup>2</sup> C bus           | One built-in I <sup>2</sup> C interface channel                                                                                                                                                                                                                       |                                   |                                 |                                 |
| DTP/external<br>interrupt      | Four independent channels (can also be used for A/D input)<br>Interrupt source: "L"> "H" edge, "H"> "L" edge, "L" level, or "H" level can be set.                                                                                                                     |                                   |                                 |                                 |

#### **CHAPTER 1 OVERVIEW**

#### Table 1.2-1 MB90M405 Series Product Lineup (Continued)

| Model                | MB90MV405                                                             | MB90MF408 (*1)<br>MB90MF408A (*2) | MB90M408 (*1)<br>MB90M408A (*2) | MB90M407 (*1)<br>MB90M407A (*2) |
|----------------------|-----------------------------------------------------------------------|-----------------------------------|---------------------------------|---------------------------------|
| Low-power mode       | Sleep mode, Timebase timer mode, stop mode, and CPU intermittent mode |                                   |                                 |                                 |
| Process              | CMOS                                                                  |                                   |                                 |                                 |
| Package              | PGA256 QFP-100 (0.65 mm pitch)                                        |                                   |                                 | ch)                             |
| Operating<br>voltage | $3.3V\pm0.3V$ (16.8 MHz: 4.2 MHz multiplied by 4)                     |                                   |                                 | y 4)                            |

\*1: The FL output pins (FIP00 to FIP59) are output with a pull-down resistor.

\*2: The FL output pins (FIP00 to FIP16) are output without a pull-down resistor. The FL output pins (FIP17 to FIP59) are output with a pull-down resistor.

## 1.3 Block Diagram

Figure 1.3-1 "Block Diagram" shows a block diagram of the MB90M405 series of microcontrollers.

#### Block Diagram



Figure 1.3-1 Block Diagram

# 1.4 Package Dimensions

This section provides the dimensions of the MB90M405 series package.

#### ■ FPT-100P-M06 Dimensions





## 1.5 Pin Assignments



#### Pin Assignments





# 1.6 **Pin Functions**

Table 1.6-1 "Pin Functions" summarizes the pin names and functions, as well as the related circuit types and states at reset.

#### Pin Functions

Table 1.6-1 Pin Functions

| Pin number                       | Pin name       | Circuit | State/function                | Function                                                                                                                     |                     |                                                                                                                              |
|----------------------------------|----------------|---------|-------------------------------|------------------------------------------------------------------------------------------------------------------------------|---------------------|------------------------------------------------------------------------------------------------------------------------------|
| QFP-100M06                       | Fill Hallie    | type    | at reset                      | Function                                                                                                                     |                     |                                                                                                                              |
| 82, 23                           | X0, X1         | A       | Oscillating                   | Oscillation input pin<br>When an external clock is connected, leave the<br>X1 pin open.                                      |                     |                                                                                                                              |
| 77                               | RST            | В       | Reset input                   | External reset input pin                                                                                                     |                     |                                                                                                                              |
| 85 to 100                        | FIP0 to FIP15  |         |                               | Set when the FL driver is enabled                                                                                            |                     |                                                                                                                              |
| 85 10 100                        | LED0 to LED15  |         |                               | Set when the LED driver is enabled                                                                                           |                     |                                                                                                                              |
| 1                                | FIP16          | С       | V <sub>KK</sub> pull-down     | Set when the FL driver is enabled                                                                                            |                     |                                                                                                                              |
| I                                | LED16          |         | output (when a                | Set when the LED driver is enabled                                                                                           |                     |                                                                                                                              |
| 2 to 10<br>12 to 19              | FIP17 to FIP33 |         | pull-down<br>resistor is set) |                                                                                                                              |                     |                                                                                                                              |
| 20 to 22<br>24 to 41<br>43 to 47 | FIP34 to FIP59 | D       |                               | Pin dedicated to FL driver output                                                                                            |                     |                                                                                                                              |
|                                  | P80            |         |                               | I/O port                                                                                                                     |                     |                                                                                                                              |
| 50                               | IC0            |         |                               | External trigger input pin for input capture channel 0                                                                       |                     |                                                                                                                              |
| 52                               | INTO           | Е       | _                             | E Dert in such /                                                                                                             | Dest is such (UK e) | External cause input pin for external interrupt<br>input channel 0<br>Input is enabled when the EN0 bit enables this<br>pin. |
|                                  | P81            |         | Port input (Hi-z)             | I/O port                                                                                                                     |                     |                                                                                                                              |
|                                  | IC1            |         |                               | External trigger input pin for input capture channel 1                                                                       |                     |                                                                                                                              |
| 53                               | INT1           |         |                               | External cause input pin for external interrupt<br>input channel 1<br>Input is enabled when the EN1 bit enables this<br>pin. |                     |                                                                                                                              |

| Table 1.6-1 | Pin | Functions | (Continued) |
|-------------|-----|-----------|-------------|
|-------------|-----|-----------|-------------|

| Pin number | Pin name | Circuit | State/function | Function                                                                                                                                                                                                                                           |               |                                                                                                                                            |                   |                                                                                                                                                                                                                                                   |
|------------|----------|---------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| QFP-100M06 | Finnanie | type    | at reset       | i unction                                                                                                                                                                                                                                          |               |                                                                                                                                            |                   |                                                                                                                                                                                                                                                   |
|            | P82      |         |                | I/O port                                                                                                                                                                                                                                           |               |                                                                                                                                            |                   |                                                                                                                                                                                                                                                   |
| 54         | SIO      |         |                | Serial data input pin for serial I/O channel 0<br>This pin is used occasionally while serial I/O<br>channel 0 is performing an input operation. Do<br>not use this pin for any other purpose during an<br>input operation on serial I/O channel 0. |               |                                                                                                                                            |                   |                                                                                                                                                                                                                                                   |
|            | P83      |         |                | I/O port                                                                                                                                                                                                                                           |               |                                                                                                                                            |                   |                                                                                                                                                                                                                                                   |
| 55         | SC0      |         |                | Serial clock I/O pin for serial I/O channel 0<br>This function is enabled when serial I/O channel 0<br>is enabled for serial clock output.                                                                                                         |               |                                                                                                                                            |                   |                                                                                                                                                                                                                                                   |
|            | P84      |         |                | I/O port                                                                                                                                                                                                                                           |               |                                                                                                                                            |                   |                                                                                                                                                                                                                                                   |
| 56         | SO0      | E       |                | Serial data output pin for serial I/O channel 0<br>This function is enabled when serial I/O channel 0<br>is enabled for serial data output.                                                                                                        |               |                                                                                                                                            |                   |                                                                                                                                                                                                                                                   |
|            | P85      | E       |                | I/O port                                                                                                                                                                                                                                           |               |                                                                                                                                            |                   |                                                                                                                                                                                                                                                   |
| 57         | SI1      |         |                | -                                                                                                                                                                                                                                                  | Port input (F | Port input (Hi-z                                                                                                                           | Port input (Hi-z) | Serial data input pin for serial I/O channel1<br>This pin is used occasionally while serial I/O<br>channel 1 is performing an input operation. Do<br>not use this pin for any other purpose during an<br>input operation on serial I/O channel 1. |
|            | P86      |         |                | I/O port                                                                                                                                                                                                                                           |               |                                                                                                                                            |                   |                                                                                                                                                                                                                                                   |
| 58         | SC1      |         |                |                                                                                                                                                                                                                                                    |               | Serial clock I/O pin for serial I/O channel 1<br>This function is enabled when serial I/O channel 1<br>is enabled for serial clock output. |                   |                                                                                                                                                                                                                                                   |
|            | P87      |         |                | I/O port                                                                                                                                                                                                                                           |               |                                                                                                                                            |                   |                                                                                                                                                                                                                                                   |
| 59         | SO1      |         |                | Serial data output pin for serial I/O channel 1<br>This function is enabled when serial I/O channel 1<br>is enabled for serial data output.                                                                                                        |               |                                                                                                                                            |                   |                                                                                                                                                                                                                                                   |
|            | P90      |         |                | I/O port (N-channel open drain)                                                                                                                                                                                                                    |               |                                                                                                                                            |                   |                                                                                                                                                                                                                                                   |
| 60         | SDA      | G       |                | $I^2C$ interface data I/O pin. This function is<br>enabled when $I^2C$ interface operation is enabled.<br>Set the port to the input setting (DDR9 bit 8 = 0)<br>while the $I^2C$ interface is active.                                              |               |                                                                                                                                            |                   |                                                                                                                                                                                                                                                   |
|            | SO3      |         |                | Serial data output pin for serial I/O channel 3<br>This function is enabled when serial I/O channel 3<br>is enabled for serial data output.                                                                                                        |               |                                                                                                                                            |                   |                                                                                                                                                                                                                                                   |

#### **CHAPTER 1 OVERVIEW**

Table 1.6-1 Pin Functions (Continued)

| Pin number<br>QFP-100M06 | Pin name    | Circuit<br>type | State/function<br>at reset | Function                                                                                                                                                                                                 |  |                                                                                                                                                                                                                                                    |
|--------------------------|-------------|-----------------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          | P91         |                 |                            | I/O port (N-channel open drain)                                                                                                                                                                          |  |                                                                                                                                                                                                                                                    |
| 61                       | SCL         | G               | Port input (Hi-z)          | $I^2C$ interface clock I/O pin. This function is<br>effective when $I^2C$ interface operation is enabled.<br>Set the port to the input setting (DDR9 bit 9 = 0)<br>while the $I^2C$ interface is active. |  |                                                                                                                                                                                                                                                    |
|                          | SC3         |                 |                            | Serial clock I/O pin for serial I/O channel 3<br>This function is enabled when serial I/O channel 3<br>is enabled for serial clock output.                                                               |  |                                                                                                                                                                                                                                                    |
|                          | PA0         |                 |                            | I/O port                                                                                                                                                                                                 |  |                                                                                                                                                                                                                                                    |
| 64                       | AN0         |                 |                            | Analog input pin channel 0 for the A/D converter<br>This function is enabled when analog input is<br>enabled (set by the ADER).                                                                          |  |                                                                                                                                                                                                                                                    |
|                          | ТМСК        |                 |                            | Timing clock output pin. This function is enabled<br>when output is enabled.<br>The function is disabled when the ADER enables<br>analog input.                                                          |  |                                                                                                                                                                                                                                                    |
|                          | PA1 to PB2  |                 |                            | I/O port                                                                                                                                                                                                 |  |                                                                                                                                                                                                                                                    |
| 65 to 74                 | AN1 to AN10 |                 |                            | Analog input pin channels 1 to 10 for the A/D<br>converter<br>This function is enabled when analog input is<br>enabled (set by the ADER).                                                                |  |                                                                                                                                                                                                                                                    |
|                          | PB3         |                 |                            | I/O port                                                                                                                                                                                                 |  |                                                                                                                                                                                                                                                    |
|                          | AN11        | F               | Analog input               | Analog input pin channel 11 for the A/D converter<br>This function is enabled when analog input is<br>enabled (set by the ADER).                                                                         |  |                                                                                                                                                                                                                                                    |
| 75                       | SI2         |                 |                            |                                                                                                                                                                                                          |  | Serial data input pin for serial I/O channel 2<br>This pin is used occasionally while serial I/O<br>channel 2 is performing an input operation. Do<br>not use this pin for any other purpose during an<br>input operation on serial I/O channel 2. |
|                          | PB4         |                 |                            | I/O port                                                                                                                                                                                                 |  |                                                                                                                                                                                                                                                    |
|                          | AN12        |                 |                            | Analog input pin channel 12 for the A/D converter<br>This function is enabled when analog input is<br>enabled (set by the ADER).                                                                         |  |                                                                                                                                                                                                                                                    |
| 76                       | SC2         |                 |                            | Serial clock I/O pin for serial I/O channel 2<br>This function is enabled when serial I/O channel 2<br>is enabled for serial clock output.                                                               |  |                                                                                                                                                                                                                                                    |
|                          | TINO        |                 |                            | External clock input pin for reload timer channel 0<br>This function is enabled when external clock input<br>is enabled (the ADER setting has precedence).                                               |  |                                                                                                                                                                                                                                                    |

Table 1.6-1 Pin Functions (Continued)

| Pin number | Pin name             | Circuit       | State/function<br>at reset | Function                                                                                                                                                           |  |  |
|------------|----------------------|---------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| QFP-100M06 |                      | type at reset |                            |                                                                                                                                                                    |  |  |
|            | PB5                  |               |                            | I/O port                                                                                                                                                           |  |  |
|            | AN13                 | -             |                            | Analog input pin channel 13 for the A/D converter<br>This function is enabled when analog input is<br>enabled (set by the ADER).                                   |  |  |
| 78         | SO2                  |               |                            | Serial data output pin for serial I/O channel 2<br>This function is enabled when serial I/O channel 2<br>is enabled for serial data output.                        |  |  |
|            | TO0                  | F             | Analog input               | External event output pin for reload timer channel<br>0<br>This function is enabled when external event<br>output is enabled (the ADER setting has<br>precedence). |  |  |
|            | PB6 to PB7           |               |                            | I/O port                                                                                                                                                           |  |  |
| 79, 80     | AN14 to AN15         |               |                            | Analog input pin channels 14 and 15 for the A/D<br>converter<br>This function is enabled when analog input is<br>enabled (set by the ADER).                        |  |  |
|            | INT2 to INT3         | ii<br>li<br>e |                            | External cause input pin for external interrupt<br>input channels 2 and 3<br>Input is enabled when the EN2 and EN3 bits<br>enable these pins.                      |  |  |
| 62         | AV <sub>CC</sub>     | Н             |                            | V <sub>CC</sub> power input pin for analog macro                                                                                                                   |  |  |
| 63         | AV <sub>SS</sub>     | П             | Power input                | V <sub>SS</sub> power input pin for analog macro                                                                                                                   |  |  |
| 48         | V <sub>KK</sub>      | -             |                            | Power pin on pull-down side in high dielectric output mode                                                                                                         |  |  |
| 49         | MD0                  |               |                            | Input pin for operation mode specification.<br>Connect this pin to $V_{CC}$ .<br>When a flash boot program is used, be sure to<br>change the pin to $V_{SS}$ .     |  |  |
| 50         | MD1                  | В             | Mode pin                   | Input pin for operation mode specification. Connect this pin to $V_{CC}.$                                                                                          |  |  |
| 51         | MD2                  |               |                            | Input pin for operation mode specification. Connect this pin to $V_{SS}$ . When a flash boot program is used, be sure to change the pin to $V_{CC}$ .              |  |  |
| 11, 42     | V <sub>SS</sub> -IO  |               |                            | I/O power (0 V: GND) input pin                                                                                                                                     |  |  |
| 23         | V <sub>DD</sub> -FIP |               | Davids                     | FIP power (3 V: V <sub>CC</sub> ) input pin                                                                                                                        |  |  |
| 81         | V <sub>SS</sub> -CPU | -             | Power input                | Control circuit power (0 V: GND) input pin                                                                                                                         |  |  |
| 84         | V <sub>CC</sub> -CPU |               |                            | Control circuit power (3 V: V <sub>CC</sub> ) input pin                                                                                                            |  |  |

# 1.7 I/O Circuit Types

Table 1.7-1 "I/O Circuit Types (continued next page)" summarizes the circuit types of individual pins.

#### ■ I/O Circuit Types

| Table 1.7-1 I/O Circuit Types (continued next page | Table 1.7-1 | I/O Circuit | Types | (continued | next | page |
|----------------------------------------------------|-------------|-------------|-------|------------|------|------|
|----------------------------------------------------|-------------|-------------|-------|------------|------|------|

| Classification | Circuit type                                          | Remarks                                                                                                                                                                                                                                                                                                                                                  |
|----------------|-------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A              | X1 Nch<br>Pch<br>Nch<br>Nch<br>Standby control signal | <ul> <li>Oscillation circuit<br/>Oscillation feedback resistance =<br/>about 1 MΩ</li> </ul>                                                                                                                                                                                                                                                             |
| В              | Rp<br>D                                               | <ul> <li>Hysteresis input pin<br/>Built-in pull-up resistor (Rp)</li> </ul>                                                                                                                                                                                                                                                                              |
| С              | Pch Pout<br>R <sub>KK</sub>                           | <ul> <li>P-ch open drain output         <ul> <li>High dielectric port output<br/>IOL = 25 mA</li> </ul> </li> <li>When this pin is used as an ordinary port, connect a diode clamp circuit to it to prevent V<sub>KK</sub> voltage from being applied to the pin when the "L" level is output. (See Section 1.8, "Notes on Handling Devices."</li> </ul> |
| D              | Pch Pout<br>Rкк<br>Vкк                                | <ul> <li>P-ch open drain output         <ul> <li>High dielectric port output<br/>IOL = 12 mA</li> </ul> </li> <li>When this pin is used as a normal port, connect a diode clamp circuit to it to prevent V<sub>KK</sub> voltage from being applied to the pin when the "L" level is output. (See Section 1.8 "Notes on Handling Devices."</li> </ul>     |

| Classification | Circuit type                                                                  | Remarks                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|-------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| E              | Pch Pout<br>Nch Nout<br>R Hysteresis input<br>Standby control                 | <ul> <li>CMOS hysteresis I/O pin         <ul> <li>CMOS output</li> <li>CMOS hysteresis input (with standby control for input rejection)<br/>IOL = 4 mA</li> </ul> </li> </ul>                                                                                                                                                                                                                  |
| F              | Pch Pout<br>Nch Nout<br>R Hysteresis input<br>Standby control<br>Analog input | <ul> <li>Analog/CMOS hysteresis I/O pin         <ul> <li>CMOS output</li> <li>CMOS hysteresis input (with standby control for input rejection)</li> <li>Analog input (Analog input is enabled when the corresponding ADER bit is "1".)</li> <li>IOL = 4 mA</li> </ul> </li> </ul>                                                                                                              |
| G              | Pch Nout<br>R Hysteresis input<br>Standby control                             | <ul> <li>N-ch open drain output         <ul> <li>CMOS hysteresis input (with standby control for input rejection)</li> </ul> </li> <li>Unlike the CMOS I/O pin, this pin has no Pch transistor. Therefore, even when voltage is applied externally to this pin while the device power is off, no current flows into the device power supply (V<sub>CC</sub>-IO/V<sub>CC</sub>-CPU).</li> </ul> |
| Н              | Pch IN<br>Nch                                                                 | Analog power input protection circuit                                                                                                                                                                                                                                                                                                                                                          |

| Table 1.7-1 | I/O Circuit Types | (continued next page) |
|-------------|-------------------|-----------------------|
|-------------|-------------------|-----------------------|

## 1.8 Notes on Handling Devices

When handling devices, note the following:

- Strict observation of maximum rated voltage (latchup prevention)
- Stabilization of supply voltage
- Note on power-on
- · Treatment of unused input pins
- Note on external clocks
- Power supply pins
- Crystal oscillation circuit
- Power-on sequence for A/D converter power supply analog input
- Treating pins when the A/D converter is not used
- Output of high dielectric output pin (circuit type C or D)
- Note on during operation of PLL clock mode

Strict Observation of Maximum Rated Voltage (Latchup Prevention)

- Do not apply a voltage higher than V<sub>CC</sub> or lower than V<sub>SS</sub> to CMOS IC input and output pins that are not medium or high dielectric pins. Also, do not apply a voltage higher than the rating between V<sub>CC</sub> and V<sub>SS</sub>. Disregard of these precautions may result in latchup.
- A latchup rapidly increases supply current and may result in thermal damage to elements. Be careful not to apply voltage exceeding the maximum rating.
- When turning power to analog circuits on or off, ensure that the analog power supply (AV<sub>CC</sub>) and analog input voltage do not exceed the digital supply voltage (V<sub>CC</sub>).

#### Stabilization of Supply Voltage

Even within the operation guarantee range of the V<sub>CC</sub> supply voltage, a malfunction can be caused if the supply voltage changes abruptly. To prevent problems from occurring, stabilize the V<sub>CC</sub> supply voltage.

As guidelines for voltage stabilization, the V<sub>CC</sub> ripple fluctuations (peak-to-peak value) at commercial frequencies (50 to 60 Hz) should be suppressed to 10% or less of the reference V<sub>CC</sub> value. During a momentary change such as when a supply voltage is switched, voltage functions should also be suppressed so that the transient fluctuation rate does not exceed 0.1 V/ms.

#### Note on Power-on

To prevent a malfunction in the built-in voltage drop circuit during power-on, ensure 50  $\mu s$  (between 0.2 V and 2.7 V) or more for the supply voltage (V<sub>CC</sub>) rise time.

#### Treatment of Unused Input Pins

An unused input pin, if left open, may cause a malfunction or a permanent damage due to a latchup. Every unused input pin must be pulled up or down using resistance of 2 k $\Omega$  or more. An unused I/O pin must be either opened by setting it to output mode or handled in the same way as an input pin after it has been set to input mode.

#### Note on External Clocks

When an external clock is used, connect only the X0 pin; leave the X1 pin open. A sample application of the external clock is shown below:



#### Power Supply Pins

- When a device has two or more V<sub>CC</sub> or V<sub>SS</sub> pins, the pins that should have equal potential are connected within the device in order to prevent a latchup or other malfunction. To reduce extraneous emissions, to prevent a malfunction of the strobe signal due to an increase in the ground level, and to maintain the total output current rating, connect the V<sub>CC</sub> or V<sub>SS</sub> pins to the power supply or to ground.
- Connect the current supply source to the V<sub>CC</sub> and V<sub>SS</sub> pins of the MB90M405 series device with minimum impedance.
- As a measure against power supply noise in an MB90M405 series device, connect a bypass capacitor of about 0.1  $\mu$ F between V<sub>CC</sub> and V<sub>SS</sub> near the V<sub>CC</sub> and V<sub>SS</sub> pins.

#### Crystal Oscillation Circuit

Noise at the X0 and X1 pins can cause malfunctioning of MB90M405 series devices. Design the printed wiring board so that bypass capacitors to the X0 and X1 pins, crystal oscillator (or ceramic oscillator), and ground are provided near the X0 and X1 pins and that the X0 and X1 pin wirings do not cross other wirings.

Printed wiring board artwork that encloses the X0 and X1 pins with ground should result in stable operation.

#### Power-on Sequence for A/D Converter Power Supply Analog Input

- Before turning on power to the A/D converter power supply pin (AV<sub>CC</sub>) and analog input pins (AN0 to AN15), be sure power to the digital power supply pin (V<sub>CC</sub>) has already been turned on.
- When turning off the power, turn off the power to the digital power supply pin (V<sub>CC</sub>) after turning off the power to the A/D converter and analog inputs.
- When a pin that is used for analog input is also used as an input port, prevent the analog input voltage from exceeding AV<sub>CC</sub>. (The analog power and digital power can be simultaneously turned on or off with no problem.)

#### Treating Pins When the A/D Converter Is Not Used

When the A/D converter is not used, connect AV<sub>CC</sub> and V<sub>CC</sub>, and AV<sub>SS</sub> and V<sub>SS</sub>.

#### ■ Output of High Dielectric Output Pin (Circuit Type C or D)

When a high dielectric output pin (circuit type C or D) is used as an ordinary output port, the value obtained by pulling down the  $V_{KK}$  pin voltage is output in "L" level output mode. In this case, the  $V_{KK}$  pin level voltage is applied to the external circuit. Add a diode clamp circuit as shown in the figure below.



#### Note on during Operation of PLL Clock Mode

In the case of the PLL clock is selected as the machine clock, if an oscillator is off or if the clock input is stopped, the microcontroller may be continued to operation by the free running frequency of the internal PLL self oscillator circuit.

This operation is warranted.

# 1.9 Clock Supply Map

Figure 1.9-1 "Clock Supply Map" shows a clock supply map of the MB90M405 series.

#### Clock Supply Map



Figure 1.9-1 Clock Supply Map

HCLK : Oscillation clock frequency

MCLK : Main clock frequency

PCLK : PLL clock frequency

# 1.10 Low Power Consumption Mode

This section provides an overview of low-power mode. The MB90M405 series uses the operation modes listed in the table below, and functions and clocks stop differently depending on the mode. For more information, see CHAPTER 4 "CLOCKS."

#### Relationships between operation Modes and Power

| Operation mode | Main clock | PLL clock | CPU       | Built-in resources        | Timing clock |
|----------------|------------|-----------|-----------|---------------------------|--------------|
| PLL Run        | Operating  | Operating | Operating | Operating                 | Operating    |
| Main Run       | Operating  | Stopped   | Operating | Operating                 | Operating    |
| PLL Sleep      | Operating  | Operating | Stopped   | Operating <sup>(*1)</sup> | Operating    |
| Main Sleep     | Operating  | Stopped   | Stopped   | Operating <sup>(*1)</sup> | Operating    |
| Pseudo Clock   | Operating  | Stopped   | Stopped   | Stopped                   | Operating    |
| Stop           | Stopped    | Stopped   | Stopped   | Stopped                   | Stopped      |

Table 1.10-1 Relationships between Operation Modes and Power

In the above table, the operation modes are arranged in descending order of power consumption In PLL Run mode, operation is performed based on PCLK obtained by multiplying the source oscillation by 1 to 4. In Main Run mode, operation is performed based on MCLK obtained by dividing the source clock by 2. \*1: In Sleep mode, since the CPU has stopped, access to the built-in resources from the CPU is disabled.

## CHAPTER 2 CPU

# This chapter describes the CPU and the memory space provided by the MB90M405 series.

- 2.1 "CPU"
- 2.2 "Memory Space"
- 2.3 "Memory Maps"
- 2.4 "Addressing"
- 2.5 "Memory Location of Multibyte Data"
- 2.6 "Registers"
- 2.7 "Dedicated Registers"
- 2.8 "General-Purpose Registers"
- 2.9 "Prefix Codes"

### 2.1 CPU

The  $F^2MC-16LX$  CPU core is a 16-bit CPU designed for use in applications, such as welfare and mobile equipment, which require high-speed real-time processing. The instruction set of the  $F^2MC-16LX$  was designed for controllers so that it can perform various types of control at high speeds and efficiencies.

The F<sup>2</sup>MC-16LX CPU core processes 32-bit data using a built-in 32-bit accumulator. Memory space, which can be extended to up to 16M bytes, can be accessed in either linear or bank access mode. The instruction set inherits the AT architecture of the F<sup>2</sup>MC-8L and has additional instructions for supporting the C language. In addition, it has an extended addressing mode, enhanced multiply/divide instructions, and improved bit manipulation instructions. The features of the F<sup>2</sup>MC-16XL CPU are shown below:

#### CPU

- Minimum instruction execution time: 59.5 ns (source oscillation at 4.2 MHz and clock multiplication by 4)
- O Maximum memory address space: 16M bytes. Can be accessed in linear or bank mode.

#### O Instruction set optimum for controller applications

- Many data types (bit, byte, word, and long word)
- As many as 23 addressing modes
- · Enhanced high-precision arithmetic operation by a 32-bit accumulator
- Enhanced signed multiply/divide instructions and RETI instruction function

#### O Interrupt function

Eight programmable priority levels

#### **O** Automatic transfer function independent to CPU

Extended intelligent I/O service using up to 16 channels

- Instruction set supporting high-level language (C) and multi-tasking
   System stack pointer, instruction set symmetry, and barrel shift instructions
- O Increased execution speed: 4-byte instruction queue

### 2.2 Memory Space

All I/O, programs, and data are located in the 16M-byte memory space of the F<sup>2</sup>MC-16LX. The RAM space is used for extended intelligent I/O service (EI<sup>2</sup>OS) descriptors, general-purpose registers, and vector tables.

#### Memory Space

All I/O, programs, and data are located in the 16M-byte memory space of the F<sup>2</sup>MC-16LX CPU. The CPU is able to access each built-in peripheral function (resource) through a memory space address indicated by the 24-bit address bus.





\*1 The size of internal ROM differs for each model.

\*2 The area accessible by the image differs for each model.

\*3 The size of internal RAM differs for each model.

\*4 There is no access in single-chip mode.

#### ROM Area

#### $\bigcirc$ Vector table area (address: "FFFC00<sub>H</sub> to FFFFF<sub>H</sub>")

- This area is used as a vector table for vector call instructions, interrupt vectors, and reset vectors.
- This area is allocated at the highest addresses of the ROM area. The start address of the corresponding processing routine is stored in each vector table address.

#### O Program area (address: Up to "FFFBFF<sub>H</sub>")

- ROM is built in as an internal program area.
- The size of the internal ROM differs for each model.

#### RAM Area

#### O Data area (address: From "000100<sub>H</sub>")

- The static RAM is built in as an internal data area.
- The size of internal RAM differs for each model.

#### O General-purpose register area (address: " $000180_{H}$ to $00037F_{H}$ ")

- Auxiliary registers used for 8-bit, 16-bit, and 32-bit arithmetic operations and transfer are allocated in this area.
- When this area is not used as a general purpose register, it can be used as ordinary RAM.
- When this area is used as a general-purpose register, general-purpose register addressing enables high-speed access within a few instruction cycles.

#### ○ Extended intelligent I/O service (El<sup>2</sup>OS) descriptor area (address: "000100<sub>H</sub> to 00017F<sub>H</sub>")

- This area retains the transfer modes, I/O addresses, transfer count, and buffer addresses of the Extended Intelligent I/O Service (EI<sup>2</sup>OS).
- If the Extended Intelligent I/O Service (EI<sup>2</sup>OS) is not used, this area can be used as ordinary RAM.

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

The interrupt control registers (ICR00 to ICR15) correspond to the built-in peripheral functions that have an interrupt function. These registers set interrupt levels and control the extended intelligent I/O service (El<sup>2</sup>OS).

#### $\odot\,$ Peripheral function control register area (address: "000020\_H to 0000AF\_H")

This register controls the built-in peripheral functions (resources).

#### $\odot\,$ I/O port control register area (address: $\,"000000_{H}$ to $00001F_{H}")$

This register controls the I/O port.

### 2.3 Memory Maps

This section shows the memory map for each model of MB90M405 series.

#### Memory Maps



#### Figure 2.3-1 Memory Maps

| Model            | Address #1               | Address #2          | Address #3          |  |  |
|------------------|--------------------------|---------------------|---------------------|--|--|
| MB90M407/M407A   | FE8000 <sub>H</sub>      | 004000 <sub>H</sub> | 001100 <sub>H</sub> |  |  |
| MB90M408/M408A   | FE0000 <sub>H</sub>      | 004000 <sub>H</sub> | 001100 <sub>H</sub> |  |  |
| MB90MF408/MF408A | FE0000 <sub>H</sub>      | 004000 <sub>H</sub> | 001100 <sub>H</sub> |  |  |
| MB90MV405        | F80000 <sub>H</sub> (*1) | 004000 <sub>H</sub> | 001100 <sub>Н</sub> |  |  |

\*1: V products have no built-in ROM. This area should be understood as the ROM decode area of the tool.

#### **Reference:**

The ROM mirroring function allows the small model of the C compiler to be used.

The low-order 16-bit address of FF bank becomes the same as the low-order 16-bit address of 00 bank. However, not all the data in the ROM area can be seen as a mirror image in 00 bank because the ROM area of FF bank exceeds 48K bytes.

To use the small model of the C compiler, store the data table in "FF4000<sub>H</sub> to FFFFF<sub>H</sub>" to show the data table as a mirror image in "004000<sub>H</sub> to  $00FFFF_H$ ". Thus, the data table in the ROM area can be referenced without the "far" specification declared in the pointer.

#### Note:

- If the ROM mirroring function register is set, the data in the upper side of FF bank ("FF4000<sub>H</sub> to FFFFFF<sub>H</sub>") can be seen as a mirror image in the upper side of 00 bank ("004000<sub>H</sub> to 00FFFF<sub>H</sub>").
- For information on setting the ROM mirroring function, see Chapter 22 "ROM MIRRORING FUNCTION SELECTION MODULE".

### 2.4 Addressing

Addresses can be generated using linear addressing and bank addressing. In linear addressing, the 16M-byte space is directly specified using a continuous 24-bit address.

In bank addressing, the 16M-byte space is divided into 256 64K-byte banks. The upper 8 bits of the address are specified by a bank register and the lower 16 bits of the address are directly specified by an instruction.

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

Linear Addressing and Bank Addressing





### 2.4.1 Address Specification by Linear Addressing

The linear addressing has two types of address specified:

- Specify 24-bit address directly in the instruction as operand
- Specify 24-bit address in a 32-bit general-purpose registers, using the lower 24 bits
- Linear Addressing by 24-Bit Operand Specification

Figure 2.4-2 Example of Direct Specification of a 24-bit Physical Address in Linear Addressing



Addressing by Indirect Specification with a 32-Bit Register

Figure 2.4-3 Example of Indirect Specification with a 32-bit General-Purpose Register in Linear Addressing



RL1: 32-bit (long-word) general-purpose register

### 2.4.2 Address Specification by Bank Addressing

In address specification by bank addressing, the 16M-byte space is divided into 256 64K-byte banks. The upper 8 bits of the address are specified by a bank register and the lower 16 bits of the address are directly specified by an instruction. The five types of bank registers classified by function are as follows:

- 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

| Bank register name                       | Access space          | Main function                                                                                                                                                                                               | Initial value<br>after a reset |
|------------------------------------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|
| Program bank register<br>(PCB)           | Program (PC) space    | Instruction codes, vector tables, and immediate-value data are stored.                                                                                                                                      | FF <sub>H</sub>                |
| Data bank register<br>(DTB)              | Data (DT) space       | Read/write data is stored. Internal or external peripheral control registers and data registers are accessed.                                                                                               | 00 <sub>H</sub>                |
| User stack bank<br>register (USB)        | Stack (SP) space      | This area is used for stack accesses such as when PUSH/POP instructions                                                                                                                                     | 00 <sub>H</sub>                |
| System stack bank<br>register (SSB) (*1) |                       | and interrupt registers are saved.<br>The SSB is used when the stack flag in<br>the condition register (CCR:S) is 1. The<br>USB is used when the stack flag in the<br>condition register (CCR:S) is 0. (*1) | 00 <sub>H</sub>                |
| Additional bank register<br>(ADB)        | Additional (AD) space | Data that overflows from the data (DT) space is stored.                                                                                                                                                     | 00 <sub>H</sub>                |

| Table 2 4-1 | Access Space and Main Function of Each Bank Register |
|-------------|------------------------------------------------------|
|             | Access opace and main runction of Lach Dank Register |

\*1: The SSB is always used as an interrupt stack.

See Section 2.7.9 "Bank Registers (PCB, DTB, USB, SSB, ADB)" for details.



#### Figure 2.4-4 Sample Bank Addressing

#### Bank Addressing and Default Space

To improve instruction coding efficiency, each instruction has a defined default space for each addressing method, as shown in Table 2.4-2 "Addressing and Default Spaces". To use a space other than the default space, specify a prefix code for a bank before the instruction. This enables the bank space that corresponds to the specified prefix code to be accessed.See Section 2.9 "Prefix Codes" for details about prefix codes.

| Table 2.4-2 | Addressing and Defa | ult Spaces |
|-------------|---------------------|------------|
|-------------|---------------------|------------|

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

### 2.5 Memory Location of Multibyte Data

Multibyte data is written to memory sequentially from the lower address. If multibyte data is 32-bit data, the lower 16 bits are transferred followed by the upper 16 bits. If a reset signal is input immediately after the low-order data is written, the high-order data may not be written.

#### Storage of Multibyte Data in RAM

The lower 8 bits of the data is located at address n, and subsequent data is located at address n + 1, address n + 2, address n + 3, and so on, in this sequence.



#### Figure 2.5-1 Storage of Multibyte Data in RAM

#### Storage of Multibyte Operand





#### Storage of Multibyte Data in a Stack



Figure 2.5-3 Storage of Multibyte Data in a Stack

#### Multibyte Data Access

Multibyte data is generally accessed within a bank. For an instruction that accesses multibyte data, the address "FFFF<sub>H</sub>" is followed by " $0000_{\text{H}}$ " in the same bank.

Figure 2.5-4 Multibyte Data Access on a Bank Boundary



### 2.6 Registers

F<sup>2</sup>MC-16LX registers are classified into internal dedicated CPU registers and built-in RAM general-purpose registers.

#### Dedicated Registers and General-Purpose Registers

he dedicated registers are built-in hardware components of the CPU. Consequently, their use is limited by the CPU architecture.

General-purpose registers are allocated together with RAM in the CPU address space. General-purpose registers are like dedicated registers in that they can be accessed without address specifications, but are like regular memory in that their use can be defined by the user.



Figure 2.6-1 Dedicated Registers and General-Purpose Registers

### 2.7 Dedicated Registers

The following 11 registers are dedicated registers in the CPU.

- Accumulator (A)
- User stack pointer (USP)
- System stack pointer (SSP)
- Processor status (PS)
- Program counter (PC)
- Direct page register (DPR)
- Program bank register (PCB)
- Data bank register (DTB)
- User stack bank register (USB)
- System stack bank register (SSB)
- Additional data bank register (ADB)

#### ■ Configuration of Dedicated Registers

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

| AH   | AL            | : Accumulator (A)<br>Two 16-bit registers used for the storage of arithmetic operation results.<br>The two registers can be combined as a contiguous 32-bit register.           |
|------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | USP           | : User stack pointer (USP)<br>16-bit stack pointer that indicates the user stack address                                                                                        |
|      | SSP           | : System stack pointer (SSP)<br>16-bit stack pointer that indicates the system stack address                                                                                    |
|      | PS            | <ul> <li>Processor status (PS)</li> <li>16-bit status register that indicates the system status</li> </ul>                                                                      |
|      | PC            | : Program counter (PC)<br>16-bit count register that indicates the current instruction storage location                                                                         |
|      | DPR           | <ul> <li>Direct page register (DPR)</li> <li>8-bit page register that specifies bits 8 to 15 of the operand address<br/>when the short direct addressing is executed</li> </ul> |
|      | PCB           | : Program bank register (PCB)<br>8-bit bank register that indicates the program space                                                                                           |
|      | DTB           | : Data bank register (DTB)<br>8-bit bank register that indicates the data space                                                                                                 |
|      | USB           | : User stack bank register (USB)<br>8-bit bank register that indicates the user stack space                                                                                     |
|      | SSB           | : System stack bank register (SSB)<br>8-bit bank register that indicates the system stack space                                                                                 |
|      | ADB<br>8 bits | <ul> <li>Additional data bank register (ADB)</li> <li>8-bit bank register that indicates the additional space</li> </ul>                                                        |
| 20   | < 16 bits →   |                                                                                                                                                                                 |
| < 32 | bits 🔶        |                                                                                                                                                                                 |

| Dedicated register                  | Initial 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 in reset vector (contents of FFFDC <sub>H</sub> ,<br>FFFFDD <sub>H</sub> )                                          |  |  |  |  |  |  |  |  |  |
| Direct page register (DPR)          | 01 <sub>H</sub>                                                                                                           |  |  |  |  |  |  |  |  |  |
| Program bank register (PCB)         | Value in reset vector (contents of FFFDE <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)    | 00 <sub>H</sub>                                                                                                           |  |  |  |  |  |  |  |  |  |
| Additional data bank register (ADB) | 00 <sub>H</sub>                                                                                                           |  |  |  |  |  |  |  |  |  |

Table 2.7-1 Initial Values of the Dedicated Registers

#### Note:

Shown above are the initial values for use in a device, not for use in an ICE (such as an emulator).

### 2.7.1 Accumulator (A)

The accumulator (A) consists of two 16-bit arithmetic operation registers (AH and AL). The accumulator is used to temporarily store the results of an arithmetic operation and data.

The accumulator (A) can be used as a 32-bit, 16-bit, or 8-bit register. Arithmetic operations can be performed between memory and other registers or between the higher 16-bit arithmetic operation register (AH) and the lower 6-bit arithmetic operation register (AL). The A register has a data retention function: When data not longer than a word is transferred to the AL register, data stored in the AL register before the transfer is transferred to the AH register. (Data is not retained for some instructions.)

#### Accumulator (A)

#### O Data transfer to the accumulator

The accumulator (A) can handle 32-bit (long word), 16-bit (word), and 8-bit (byte) data. The four-bit data transfer instruction (MOVN) is exceptionally provided but the data is processed in the same way as that for 8-bit data.

- For 32-bit data processing, the AH and AL registers are used in combination.
- For 16-bit and 8-bit data, the AL register is used while the AH register retains data in the AL register.
- Data not longer than a byte, when transferred to the AL register, becomes 16 bits long through sign or zero extension and is stored in the AL register. Data stored in the AL register can be handled as 16-bit or 8-bit data.

Figure 2.7-3 "Example of AL-AH Transfer in the Accumulator (A) (8-bit Immediate Value, Zero Extension)" to Figure 2.7-6 "Example of AL-AH Transfer in the Accumulator (A) (16 bits, Register Indirect)" show specific examples of transfer.



#### Figure 2.7-2 Data Transfer to the Accumulator

\*1 Becomes "000H" or "FFFH" for a 4-bit transfer instruction.

#### O Accumulator byte-processing arithmetic operation

When a byte-processing arithmetic operation instruction is executed for the AL register, the upper 8 bits of the AL register before the arithmetic operation is executed are ignored. The upper 8 bits of the arithmetic operation results are all zeros.

#### O Initial value of the accumulator

The initial value after a reset is undefined.

#### Figure 2.7-3 Example of AL-AH Transfer in the Accumulator (A) (8-bit Immediate Value, Zero Extension)





#### Figure 2.7-4 Example of AL-AH Transfer in the Accumulator (A) (8-bit Immediate Value, Sign Extension)

#### Figure 2.7-5 Example of 32-bit Data Transfer to the Accumulator (A) (Register Indirect)

(Instruction that performs a long-word-length read using the result of the RW1 contents + an 8-bit offset as the address and stores the read value in the A register)



MOVL A,@RW1+6

#### Figure 2.7-6 Example of AL-AH Transfer in the Accumulator (A) (16 bits, Register Indirect)



- LSB : Least Significant Bit
- DTB : Data bank register

### 2.7.2 Stack Pointers (USP, SSP)

There are two types of stack pointers: a user stack pointer (USP) and a system stack pointer (SSP). Each stack pointer is a register that indicates the memory address of the location of the destination for saved data or a return address when PUSH instructions, POP instructions, and subroutines are executed. The upper 8 bits of the stack address are specified by the user stack bank register (USB) or system stack bank register (SSB).

When the S flag of the condition code register (CCR) is 0, the USP and USB registers are valid. When the S flag is 1, the SSP and SSB registers are valid.

#### Stack Selection

The  $F^2MC-16LX$  uses two types of stack: a system stack and a user stack.

The stack address is determined, as shown in Table 2.7-2 "Stack Address Specification", by the S flag in the processor status (PS:CCR).

| Table 2.7-2 | Stack | Address | Specification |
|-------------|-------|---------|---------------|
|-------------|-------|---------|---------------|

| S flag | Stack address                    |                            |  |  |  |  |  |  |  |  |  |
|--------|----------------------------------|----------------------------|--|--|--|--|--|--|--|--|--|
| Shay   | Upper 8 bits                     | Lower 16 bits              |  |  |  |  |  |  |  |  |  |
| 0      | User stack bank register (USB)   | User stack pointer (USP)   |  |  |  |  |  |  |  |  |  |
| 1 (*1) | System stack bank register (SSB) | System stack pointer (SSP) |  |  |  |  |  |  |  |  |  |

\*1: Initial value

Since a reset initializes the S flag to "1", the system stack is used by default. When an interrupt is received, the stack flag (CCR:S) is set to "1" and the system stack pointer will be used. The user stack is used for all types of stack operations except those for interrupt routines. Unless the stack space is divided, the system stack should be used.

#### 2.7 Dedicated Registers



#### Figure 2.7-7 Stack Operation Instruction and Stack Pointer

X : Undefined

MSB: Most Significant Bit

LSB : Least Significant Bit

#### Note:

- To set a stack address in the stack pointer, use an even-numbered address. If an oddnumbered address is used, a word is accessed in two separate operations, reducing access efficiency.
- The initial values for the USP and SSP registers are undefined.
- Allocate the system stack area, user stack area, and data area so that they do not overlap.

#### System Stack Pointer (SSP)

To use the system stack pointer (SSP), set the S flag in the condition code register (CCR) to "1". If the S flag is set to "1", the upper 8 bits of the address to be used for the stack operation are indicated by the system stack bank register (SSB).

For more information on the condition code register (CCR), see Section 2.7.4 "Condition Code Register (PS: CCR)". For more information on the system stack bank register (SSB), see Section 2.7.9 "Bank Registers (PCB, DTB, USB, SSB, ADB)".

#### User Stack Pointer (USP)

To use the user stack pointer (USP), set the S flag in the condition code register (CCR) to "0". If the S flag is set to "0", the upper 8 bits of the address to be used for the stack operation are indicated by the user stack bank register (USB).

For more information on the condition code register (CCR), see Section 2.7.4 "Condition Code Register (PS: CCR)". For more information on the system stack bank register (SSB), see Section 2.7.9 "Bank Registers (PCB, DTB, USB, SSB, ADB)".

### 2.7.3 Processor Status (PS)

The processor status register (PS) contains CPU control bits and bits that indicate the CPU status. The PS register consists of the following three registers:

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

#### Processor Status (PS) Configuration

The processor status register (PS) contains CPU control bits and bits that indicate the CPU status.

#### Figure 2.7-8 Processor Status (PS) Configuration

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

#### O Condition Code Register (CCR)

This register consists of flags that are set to "1" or reset to "0" in accordance with instruction execution results or interrupts.

For more information on the flags, see Section 2.7.4 "Condition Code Register (PS: CCR)".

#### O Register Bank Pointer (RP)

This pointer points to the first address of the memory block (register bank) used as the generalpurpose register in the RAM area.

There are 32 banks for general-purpose registers. Set values  $"00_{H}$  to  $1F_{H}"$  in the RP to specify a bank.

For the setting method and more information on this pointer, see Section 2.7.5 "Register Bank Pointer (PS: RP)".

#### O Interrupt Level Mask Register (ILM)

This register indicates the level of an interrupt currently accepted by the CPU. The value is compared with that of the interrupt level setting bits (ICR: IL0 to IL2) in the interrupt control register (ICR00 to ICR15) set so that an interrupt request corresponds to each peripheral function (resource).

For the setting method and more information on this register, see Section 2.7.6 "Interrupt Level Mask Register (PS: ILM)".

### 2.7.4 Condition Code Register (PS: CCR)

The condition code register (CCR) is an 8-bit register that consists of the following bits:

- Bits that indicate the result of an arithmetic operation and the contents of transfer data
- · Bits that control the acceptance of an interrupt request

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

Refer to the programming manual for details about the status of the condition code register (CCR) during instruction execution.



#### X:Not used

- : Undefined

#### **O** Interrupt enable flag (I)

Interrupts are enabled when the I flag is set to "1", or disabled when the I flag is reset to "0", in response to any interrupt request other than software interrupts. The I flag is reset to "0" by an external or software reset.

#### • Stack flag (S)

This flag indicates the pointer used for a stack operation. The user stack pointer (USP) is valid if the S flag is reset to "0". The system stack pointer (SSP) is valid if the S flag is set to "1". The S flag is set to "1" when an interrupt is accepted or when an external or software reset is asserted.

For more information on the stack pointers, see Section 2.7.2 "Stack Pointers (USP, SSP)"

#### • Sticky bit flag (T)

The T flag is set to "1" if the data shifted out of by the carry contains "1" during execution of a logical or arithmetic right shift instruction. Otherwise, the T flag is reset to "0". The T flag is also reset to "0" if the shift amount is zero.

#### O Negative flag (N)

The N flag is set to "1" if the most significant bit (MSB) of the general-purpose registers (RL0 to RL3) that store the operation result is "1". Otherwise, the N flag is reset to "0".

For more information on general-purpose registers, see Section 2.8 "General-Purpose Registers".

#### O Zero flag (Z)

The Z flag is set to "1" if the general-purpose registers (RL0 to RL3) that store the operation result are " $0000_{\text{H}}$ ". Otherwise, the Z flag is reset to "0".

#### O Overflow flag (V)

The V flag is set to "1" if an overflow occurs in a signed numeric value. Otherwise, the V flag is reset to "0".

#### ○ Carry flag (C)

The C flag is set to "1" if a carry from the most significant bit or a borrow to the least significant bit occurs during an arithmetic operation. Otherwise, the C flag is reset to "0".

### 2.7.5 Register Bank Pointer (PS: RP)

The register bank pointer (RP) is a five-bit register that points to the first address of the general-purpose register bank currently used.

#### Register Bank Pointer (RP)

#### Figure 2.7-10 Configuration of the Register Bank Pointer (RP)

|     | ILM  |      |      |    |    | RP CCR |    |    |   |   |   |   |   |   |   |   |                    |
|-----|------|------|------|----|----|--------|----|----|---|---|---|---|---|---|---|---|--------------------|
| Bit | 15   | 14   | 13   | 12 | 11 | 10     | 9  | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | RP initial value   |
| PS  | ILM2 | ILM1 | ILM0 | B4 | B3 | B2     | B1 | B0 | _ | Ι | S | Т | Ν | Z | V | С | 00000 <sub>B</sub> |

#### ■ General-Purpose Register Area and Register Bank Pointer

The register bank pointer (RP) points to the relationship between the general-purpose register of the  $F^2MC-16LX$  and the address in internal RAM. The relationship between the contents of the RP register and the address follows the conversion rules shown in Figure 2.7-11 "Conversion Rules for Physical Address of General-Purpose Register Area".

#### Figure 2.7-11 Conversion Rules for Physical Address of General-Purpose Register Area

Conversion formula  $[000180_H + (RP) \times 10_H]$ 



- The register bank pointer (RP) can assume values from 00<sub>H</sub> to 1F<sub>H</sub>. The first address of a register bank can be set to a value from 000180<sub>H</sub> to 00037F<sub>H</sub>.
- Although an assembler instruction can use an 8-bit immediate value transfer instruction for transfer to the register bank pointer (RP). However, only the lower 5 bits of the data are valid.
- A reset initializes the register bank pointer (RP) to 00000<sub>B</sub>.

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

The interrupt level mask register (ILM) is a 3-bit register that indicates the level of the interrupt currently accepted by the CPU.

#### Interrupt Level Mask Register (ILM)

See CHAPTER 6 "INTERRUPTS" for details about interrupts.

#### Figure 2.7-12 Configuration of the Interrupt Level Mask Register (ILM)

|     | ILMRP |      |      |    |    |    |    |    |   |   |   |   |   |   |   |   |                   |
|-----|-------|------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|-------------------|
| Bit | 15    | 14   | 13   | 12 | 11 | 10 | 9  | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | ILM initial value |
| PS  | ILM2  | ILM1 | ILM0 | B4 | B3 | B2 | B1 | B0 | - | I | S | Т | Ν | Ζ | V | С | 000в              |

The interrupt level mask register (ILM) indicates the level of the interrupt currently accepted by the CPU.

A level of the interrupt currently accepted by the CPU can be set in the ILM register. The CPU does not accept any interrupt with an interrupt level lower than that set in the ILM register.

- A reset sets the highest interrupt level in the ILM register, causing no interrupt to be accepted.
- Although an assembler instruction can use an 8-bit immediate value transfer instruction for transfer to the interrupt level mask register (ILM). However, only the lower 3 bits of the data are valid.

| ILM2 | ILM1 | ILM0 | Interrupt<br>level | Interrupt level priority      |
|------|------|------|--------------------|-------------------------------|
| 0    | 0    | 0    | 0                  |                               |
| 0    | 0    | 1    | 1                  | Highest (interrupts disabled) |
| 0    | 1    | 0    | 2                  | <b>≜</b>                      |
| 0    | 1    | 1    | 3                  |                               |
| 1    | 0    | 0    | 4                  |                               |
| 1    | 0    | 1    | 5                  |                               |
| 1    | 1    | 0    | 6                  | ↓<br>↓                        |
| 1    | 1    | 1    | 7                  | Lowest                        |

Table 2.7-3 Interrupt Level Mask Register (ILM) and Interrupt Level Priority

### 2.7.7 Program Counter (PC)

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

#### Program Counter (PC)

The program bank register (PCB) specifies the upper 8 bits, and the program counter (PC) specifies the lower 16 bits, of the address of the next instruction to be executed by the CPU. The address of the next instruction to be executed is as shown in Figure 2.7-13 "Program Counter (PC)". The contents of the PC are updated by conditional branch instructions, subroutine call instructions, interrupts, and resets. The PC can also be used as a base pointer for reading operands.

For more information on the PCB, see Section 2.7.9 "Bank Registers (PCB, DTB, USB, SSB, ADB)".





#### Note:

The PC and PCB cannot be rewritten directly by a program (instructions such as MOVPC and  $\#0FF_{H}$ ).

### 2.7.8 Direct Page Register (DPR)

The direct page register (DPR) is an 8-bit register that specifies bits 8 to 15 (addr8 to addr15) of the operand address when a short direct addressing instruction is executed. A reset initializes the DPR to "01<sub>H</sub>".

#### Direct Page Register (DPR)



Figure 2.7-14 Physical Address Generation by the Direct Page Register (DPR)

MSB : Most Significant Bit LSB : Least Significant Bit

#### Figure 2.7-15 Example of Direct Page Register (DPR) Setting and Data Access



48

### 2.7.9 Bank Registers (PCB, DTB, USB, SSB, ADB)

Bank registers specify the highest 8-bit address by bank addressing. The five bank registers are as follows:

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

The PCB, DTB, USB, SSB, and ADB registers indicate the individual memory banks where the program space, data space, user stack space, system stack space, and additional space are located.

#### ■ Bank Registers (PCB, DTB, USB, SSB, ADB)

#### • Program bank register (PCB)

The PCB is a bank register that specifies the program (PC) space. The PCB is rewritten whenever a JMPP, CALLP, RETP, or RETI instruction causes a branch anywhere within the 16M-byte space, when an software interrupt instruction is executed, when a hardware interrupt occurs, or when an exception occurs.

#### • Data bank register (DTB)

The DTB is a bank register that specifies the data (DT) space.

#### O User stack bank register (USB), system stack bank register (SSB)

The USB and SSB are bank registers that specify the stack (SP) space. Either the USB or SSB is used depending on the value of the S flag in the processor status register (PS:CCR). For more information, see Section 2.7.2 "Stack Pointer (USP, SSP)".

#### • Additional bank register (ADB)

The ADB is a bank register that specifies the additional (AD) space.

#### **O** Bank settings and data access

All bank registers are 8 bits in length. A reset initializes the PCB to " $FF_H$ " and the DTB, USB, SSB, and ADB to " $00_H$ ". The PCB can be read but cannot be written to. Bank registers other than the PCB can be read and written to.

#### Note:

The MB90M405 series supports up to the memory space contained in the device.

See Section 2.4.2 "Address Specification by Bank Addressing" for the operation of each register.

### 2.8 General-Purpose Registers

The general-purpose registers are a memory block allocated in RAM at  $000180_{\rm H}$  to  $00037F_{\rm H}$  as register banks, each of which consists of eight 16-bit segments.

The general-purpose registers can be used as general-purpose 8-bit registers (byte registers R0 to R7), 16-bit registers (word registers RW0 to RW7), or 32-bit registers (long-word registers RL0 to RL7).

General-purpose registers can access RAM with a short instruction at high speed. Since general-purpose registers are blocked into register banks, protection of register contents and division into function units can readily be performed. When a generalpurpose register is used as a long-word register, it can be used as a linear pointer that directly accesses the entire space.

#### Configuration of a General-Purpose Register

General-purpose registers exist in RAM at " $000180_{\text{H}}$ " to " $00037F_{\text{H}}$ " and are configured as 32 banks. The register bank pointer (RP) specifies the bank. The RP determines the first address of each bank as shown in the following equation. 16 bits multiplied by 8 are defined as one register bank.

First address of general-purpose register =  $000180_{H} + RP \times 10_{H}$ 

For more information on the PR, see Section 2.7.5 "Register Bank Pointer (PS: RP)".





#### Note:

The register bank pointer (RP) is initialized to  $00_{H}$  after a reset.

#### Register Bank

Register banks can be used as general-purpose registers (byte registers R0 to R7, word registers RW0 to RW7, and long word registers RL0 to RL3) for various arithmetic operations and pointers. Long word registers can be used also as linear pointers that directly access all the memory space.

A reset does not initialize the contents of the register bank as with RAM but the status before reset is retained. A power-on reset, however, makes the contents undefined.

| Register name | Function                                                                                                                                            |  |  |  |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| R0 to R7      | Used as an operand in various instructions<br><b>Note:</b><br>R0 is also used as a barrel shift counter and an instruction<br>normalization counter |  |  |  |
| RW0 to RW7    | Used as a pointer<br>Used as an operand in various instructions<br><b>Note:</b><br>RW0 is used also as a string instruction counter                 |  |  |  |
| RL0 to RL3    | Used as a long pointer<br>Used as an operand in various instructions                                                                                |  |  |  |

Table 2.8-1 Typical Functions of General-Purpose Registers

### 2.9 Prefix Codes

Prefix codes are placed before an instruction to partially change the operation of the instruction. The three types of prefix codes are as follows:

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

#### Prefix Codes

#### O Bank select prefix (PCB, DTB, ADB, SPB)

A bank select prefix is placed before an instruction to select the memory space to be accessed by the instruction regardless of the addressing method.

For more information, see Section 2.9.1 "Bank Select Prefix (PCB, DTB, ADB, SPB)".

#### • Common register bank prefix (CMR)

The common register bank prefix is placed before an instruction that accesses a register bank to change the register accessed by the instruction to the common bank (register bank selected when RP = 0) at 000180<sub>H</sub> to 00018F<sub>H</sub> regardless of the current register bank pointer (RP) value.

For more information, see Section 2.9.2 "Common Register Bank Prefix (CMR)".

#### **O** Flag change suppression prefix (NCC)

The flag change suppression prefix code is placed before an instruction to suppress a flag change accompanying the execution of the instruction.

For more information, see Section 2.9.3 "Flag Change Suppression Prefix (NCC)".

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

Memory space used for data access is determined for each addressing method. However, placing a bank select prefix before an instruction selects the memory space to be accessed by the instruction regardless of the addressing method.

#### ■ Bank Select Prefixes (PCB, DTB, ADB, SPB)

| Table 2.9-1 | Bank Select | Prefix Codes |
|-------------|-------------|--------------|
|-------------|-------------|--------------|

| Bank select prefix | Selected space                                                                                                                        |  |  |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------|--|--|
| РСВ                | Program space                                                                                                                         |  |  |
| DTB                | Data space                                                                                                                            |  |  |
| ADB                | Additional space                                                                                                                      |  |  |
| SPB                | When the value of the S flag in the condition code register (CCR) is 0 and the user stack space is 1, the system stack space is used. |  |  |

If a bank select prefix is used, some instructions perform an unexpected operation.

 Table 2.9-2
 Instructions Not Affected by Bank Select Prefix Codes

| Instruction type                | Instruction                                              |                                                                              |                                                                                              | Effect of bank select prefix                                          |                                                                                                                                                                                                            |
|---------------------------------|----------------------------------------------------------|------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| String instruction              | MOVSMOVSWSCEQSCWEQFILSFILSW                              |                                                                              | The bank register specified by the operand is used irrespective of whether a prefix is used. |                                                                       |                                                                                                                                                                                                            |
| Stack operation<br>instruction  | PUSHW                                                    |                                                                              | POPW                                                                                         |                                                                       | When the S flag is 0, the user<br>stack bank (USB) is used whether<br>or not there is a prefix. When the<br>S flag is 1, the system stack bank<br>(SSB) is used regardless of<br>whether a prefix is used. |
| I/O access<br>instruction       | MOV<br>MOVW<br>MOV<br>MOV<br>MOVB<br>SETB<br>BBC<br>WBTC | A,io<br>A,io<br>io, A<br>io,#imm8<br>A,io:bp<br>io:bp<br>io:bp, rel<br>io,bp | MOVX<br>MOVW<br>MOVB<br>CLRB<br>BBS<br>WBTS                                                  | A,io<br>io, A<br>io,#imm16<br>io:bp,A<br>io:bp<br>io:bp, rel<br>io:bp | The I/O space (000000 <sub>H</sub> to<br>0000FF <sub>H</sub> ) is accessed whether or<br>not there is a prefix.                                                                                            |
| Interrupt return<br>instruction | RETI                                                     |                                                                              |                                                                                              |                                                                       | The system stack bank (SSB) is used whether or not a prefix is used.                                                                                                                                       |

| Instruction type                                        | Instruction | Explanation                                                         |  |
|---------------------------------------------------------|-------------|---------------------------------------------------------------------|--|
| Flag change<br>instructionANDCCR, #imm8<br>ORCCR, #imm8 |             | The effect of the prefix extends to the next instruction.           |  |
| ILM setting MOVILM, #imm8 instruction                   |             | The effect of the prefix extends to the next instruction.           |  |
| PS return POPWPS instruction                            |             | Do not place a bank select prefix before the PS return instruction. |  |

Table 2.9-3 Instructions Whose Use Requires Caution When Bank Select Prefix

### 2.9.2 Common Register Bank Prefix (CMR)

Placing the common register bank prefix (CMR) before an instruction that accesses a register bank changes the register accessed by it to the common bank at "000180<sub>H</sub>" to "00018F<sub>H</sub>" (register bank selected when RP = "00<sub>H</sub>") regardless of the current register bank pointer (RP) value.

#### ■ Common Register Bank Prefix (CMR)

To facilitate data exchange between multiple tasks, the F<sup>2</sup>MC-16LX provides a common bank that can be commonly used by these tasks. The common bank is located at addresses " $000180_{\text{H}}$ " to " $00018F_{\text{H}}$ ".

However, be careful when you use this prefix with the instructions listed in Table 2.9-4 "Instructions Whose Use Requires Caution When the Common Register Bank Prefix (CMR) Is Used ".

Table 2.9-4 Instructions Whose Use Requires Caution When the Common Register Bank Prefix (CMR) Is Used

| Instruction type           | Instruction |           |              | Explanation                                                   |
|----------------------------|-------------|-----------|--------------|---------------------------------------------------------------|
|                            | MOVSM       | OVSW      |              |                                                               |
| String instruction         | SCEQ        | SCWEQ     |              | Do not place the CMR prefix before the<br>string instruction. |
|                            | FILS        |           | FILSW        | 9                                                             |
| Flag change<br>instruction | AND         | CCR,#imm8 | OR CCR,#imm8 | The effect of the prefix extends to the next instruction.     |
| PS return<br>instruction   | POPW        | PS        |              | The effect of the prefix extends to the next instruction.     |
| ILM setting<br>instruction | MOV         | ILM,#imm8 |              | The effect of the prefix extends to the next instruction.     |

### 2.9.3 Flag Change Suppression Prefix (NCC)

The flag change suppression prefix (NCC) code is set before an instruction to suppress a flag change accompanying the execution of the instruction.

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

Use the flag change suppression prefix (NCC) to suppress unnecessary flag changes. Changes in the T, N, Z, V, and C flags can be suppressed.

Be careful when you use this prefix with the instructions listed in Table 2.9-5 "Instructions Whose Use Requires Caution When the Flag Change Suppression Prefix (NCC) Is Used ".

For more information on the T, N, Z, V, and C flags, see Section 2.7.4 "Condition Code Register (PS: CCR)".

# Table 2.9-5 Instructions Whose Use Requires Caution When the Flag Change Suppression Prefix (NCC) Is Used Is Used

| Instruction type                                         | Instruction                      |                         | Explanation                                                                                                                                                                                 |
|----------------------------------------------------------|----------------------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| String instruction                                       | MOVS<br>SCEQ<br>FILS             | MOVSW<br>SCWEQ<br>FILSW | Do not place the NCC prefix before the string instruction.                                                                                                                                  |
| Flag change<br>instruction                               | AND CCR, #imm8<br>OR CCR, #imm8  |                         | The condition code register (CCR)<br>changes as defined in the instruction<br>specification whether or not a prefix is<br>used.<br>The effect of prefix extends to the next<br>instruction. |
| PS return instruction                                    | POPW PS                          |                         | The condition code register (CCR)<br>changes as defined in the instruction<br>specification whether or not a prefix is<br>used.<br>The effect of prefix extends to the next<br>instruction. |
| ILM setting instruction                                  | MOV ILM, #imm8                   |                         | The effect of prefix extends to the next instruction.                                                                                                                                       |
| Interrupt instruction<br>Interrupt return<br>instruction | INT #vct8<br>INT adder16<br>RETI | INT9<br>INTP addr24     | The condition code register (CCR)<br>changes as defined in the instruction<br>specification whether or not a prefix is<br>used.                                                             |
| Context switch instruction                               | JCTX @A                          |                         | The condition code register (CCR)<br>changes as defined in the instruction<br>specification whether or not a prefix is<br>used.                                                             |

# 2.9.4 Restrictions on Prefix Codes

The following restrictions are imposed on the use of prefix codes:

- Interrupt requests are not accepted during the execution of prefix codes and interrupt suppression instructions.
- If a prefix code is placed before an interrupt instruction, the effect of the prefix code is delayed.
- If consecutively placed prefix codes conflict, the last prefix code is valid.
- Prefix Codes and Interrupt Suppression Instructions

|                                                          | Prefix codes                           |                          | Interrupt suppression instructions (instructions that delay the effect of prefix codes) |  |  |  |  |
|----------------------------------------------------------|----------------------------------------|--------------------------|-----------------------------------------------------------------------------------------|--|--|--|--|
| Instructions that<br>do not accept<br>interrupt requests | 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                                            |  |  |  |  |

#### Table 2.9-6 Prefix Codes and Interrupt Suppression Instructions

#### ○ Interrupt Suppression

As shown in Figure 2.9-1 "Interrupt Suppression", an interrupt request generated during the execution of prefix codes and interrupt instructions is not accepted. The interrupt is not processed until the first instruction that is not governed by a prefix code or that is not an interrupt suppression instruction is executed.





#### O Delay of the effect of prefix codes

If a prefix code is placed before an interrupt/hold suppression instruction as shown in Figure 2.9-2 "Interrupt Suppression Instructions and Prefix Codes", the prefix code takes effect on the first instruction executed after the interrupt/hold suppression instruction.

#### Figure 2.9-2 Interrupt Suppression Instructions and Prefix Codes



#### Consecutive Prefix Codes

When consecutive conflicting prefix codes (PCB, ADB, DTB, and SPB) are specified, the last prefix code is valid.





### This chapter describes resets for the MB90M405 series.

- 3.1 "Resets"
- 3.2 "Reset Causes and Oscillation Stabilization Wait Time"
- 3.3 "External Reset Pin"
- 3.4 "Reset Operation"
- 3.5 "Reset Cause Bits"
- 3.6 "Status of Pins in a Reset"

### 3.1 Resets

If a reset cause is generated, the CPU stops the current execution process and waits for the reset to be cleared. When the reset is cleared, the CPU begins processing at the address indicated by the reset vector.

There are four causes of a reset:

- Power-on reset (at power-on)
- Watchdog timer overflow (during the use of a watchdog timer)
- External reset input via the RST pin
- Setting "0" in the internal reset signal generation bit (RST) of the low power consumption mode control register (software reset)
- Reset Causes

#### Table 3.1-1 Reset Causes

| Type of reset                            | Cause                                                                                                                                  | Machine clock                       | Watchdog<br>timer | Oscillation<br>stabilization wait |  |
|------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|-------------------|-----------------------------------|--|
| External pin                             | "L" level input to RST pin                                                                                                             | Main clock<br>frequency (MCLK)      | Stop              | No                                |  |
| Software                                 | e "0" written to the internal<br>reset signal generation bit<br>(RST) of the low power<br>consumption mode control<br>register (LPMCR) |                                     | Stop              | No                                |  |
| Watchdog timer   Watchdog timer overflow |                                                                                                                                        | Main clock<br>frequency (MCLK) Stop |                   | No                                |  |
| Power-on                                 | Power-on                                                                                                                               | Main clock<br>frequency (MCLK)      | Stop              | Yes                               |  |

MCLK: Main clock frequency (oscillation clock frequency divided by 2: 2/HCLK)

#### O External reset

An external reset is generated if the external reset terminal ( $\overline{RST}$  terminal) is set to the "L" level. The "L" level must be input at least for 16 machine cycles (16/ $\phi$ ). While the machine clock is used, no oscillation stabilization wait time is placed even if a reset occurs due to the "L" level input to the external reset pin.

#### **Reference:**

If the external reset pin is set to the "L" level while an instruction is being executed (while a transfer instruction such as MOV is being executed), the external reset input becomes valid after the completion of processing by the instruction being executed.

For a string-processing instruction (such as MOVS), however, the reset input may become valid before the transfer resulting from the specified counter value is completed.

If the external reset pin is set to the "L" level, the port pin enters the reset status regardless of the instruction execution cycle (if set to the "L" level, the operation is asynchronous).

#### **O** Software reset

A software reset is a reset for three machine cycles  $(3/\phi)$  generated by writing "0" to the internal reset signal generation bit (RST) of the low power consumption mode control register (LPMCR). The oscillation stabilization wait time is not required for software resets.

#### **O** Watchdog timer reset

A watchdog timer reset is generated unless "0" is written to the watchdog timer control bit (WTE) of the watchdog timer control register (WDTC) within the time specified in the interval time setting bits (WT1, WT0) of the WDTC after the watchdog timer is activated.

#### O Power-on reset

A power-on reset is generated when the power is turned on.

The oscillation stabilization wait time is fixed at 2<sup>17</sup>/HCLK (about 31.25 ms if the source oscillation is 4.194 MHz). A reset occurs after the oscillation stabilization wait time has elapsed.

#### Information: Definition of clocks

HCLK: Oscillation clock frequency (Clock supplied from the oscillation pin)

MCLK: Main clock frequency (Clock obtained by dividing the source oscillation by two)

φ: Machine clock (CPU operating clock)

1/4: Machine cycle (CPU operating clock cycle)

See Section 4.1 "Clocks" for details about clocks.

# 3.2 Reset Causes and Oscillation Stabilization Wait Time

The F<sup>2</sup>MC-16LX has four reset causes. The oscillation stabilization wait time for a reset depends on the reset cause.

Reset Causes and Oscillation Stabilization Wait Time

| Reset cause                 | Oscillation stabilization wait time<br>The corresponding time interval for an oscillation clock frequency of<br>4 MHz is given in parentheses. |  |  |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Power-on reset              | 2 <sup>17</sup> /HCLK (about 31.25 ms)                                                                                                         |  |  |
| Watchdog timer              | None. (The WS1 and WS0 bits are initialized to "11 <sub>B</sub> ".)                                                                            |  |  |
| External reset from RST pin | None. (The WS1 and WS0 bits are initialized to "11 <sub>B</sub> ".)                                                                            |  |  |
| Software reset              | None. (The WS1 and WS0 bits are initialized to "11 <sub>B</sub> ".)                                                                            |  |  |

#### Table 3.2-1 Reset Causes and Oscillation Stabilization Wait Time

HCLK: Oscillation clock frequency (MHz)

# Table 3.2-2 Oscillation Stabilization Wait Time Depending on Settings of Clock Selection Register (CKSCR)

| WS1 | WS0 | Oscillation stabilization wait time<br>The corresponding time interval for an oscillation clock frequency<br>of 4.194 MHz is given in parentheses. |  |  |  |
|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0   | 0   | 2 <sup>10</sup> /HCLK (about 244 μs)                                                                                                               |  |  |  |
| 0   | 1   | 2 <sup>13</sup> /HCLK (about 1.95 ms)                                                                                                              |  |  |  |
| 1   | 0   | 2 <sup>15</sup> /HCLK (about 7.81 ms)                                                                                                              |  |  |  |
| 1   | 1   | 2 <sup>17</sup> /HCLK (about 31.25 ms)                                                                                                             |  |  |  |

HCLK: Oscillation clock frequency (MHz)

#### Note:

Oscillation clock oscillators generally require an oscillation stabilization wait time from the start of oscillation until they stabilize at their natural frequency. Be sure to set a proper oscillation stabilization wait time for the oscillator to be used.

#### Oscillation Stabilization Wait Reset Status

For a power-on reset or an external reset in stop mode, the reset operation occurs after the oscillation stabilization wait time generated by the timebase timer elapses. Unless the external reset input is released, the reset operation occurs after the external reset is released.

### 3.3 External Reset Pin

An internal reset occurs if an "L" level signal is input to the external reset pin ( $\overline{RST}$  pin). In the MB90M405 series, a reset occurs in synchronization with the CPU operating clock. However, resets of external pins (I/O ports) occur asynchronously.

- Block Diagrams of the External Reset Pin
  - O Block diagram of components related to internal resets



Figure 3.3-1 Block Diagram of Components Related to Internal Resets

#### Note:

The machine clock is required to initialize the internal circuit. When a reset signal is input, the clock must be supplied from the oscillation pin.

#### O Block diagram of components related to internal resets for external pins (I/O ports)





## 3.4 Reset Operation

When a reset is cleared, the mode data and the reset vector stored in the internal or external memory are fetched. The mode data register determines the CPU operating mode. The reset vector determines the execution start address used after a reset sequence ends.

Overview of Reset Operation



Figure 3.4-1 Reset Operation Flow

#### Mode Pins

Setting the mode pins (MD0 to MD2) specifies how to fetch the mode data and the reset vector. Fetching the mode data and the reset vector is performed in the reset sequence. See Section 7.2 "Mode Pins (MD2 to MD0)" for details about mode pins.

#### Mode Data Fetch

When a reset is cleared, the CPU transfers mode data to the mode data register. After the mode data is transferred, the reset vector is transferred to the program counter (PC) and the program counter bank register (PCB).

The mode data register can determine the bus mode and the bus width. The reset vector can determine the program start address.

For more information, see CHAPTER 7 "SETTING A MODE".

Figure 3.4-2 Transfer of Reset Vector and Mode Data



#### O Mode data register (address: FFFDF<sub>H</sub>)

The mode data register setting can be changed while a reset sequence is executed. The mode data register setting is valid after a reset vector is fetched. No new contents can be written to the mode data register even if an instruction is used to specify mode data at "FFFFDF<sub>H</sub>".

For more information, see Section 7.3 "Mode Data Register".

#### $\bigcirc$ Reset vector (address: "FFFFDC<sub>H</sub>" to "FFFFDE<sub>H</sub>")

The reset vector determines the program start address used after a reset is cleared. A program is executed from the address specified in the reset vector.

#### 3.5 **Reset Cause Bits**

#### Read the watchdog timer control register (WDTC) to identify a reset cause.

#### Reset Cause Bits

Read the reset cause flag bits PONR, WRST, ERST, and SRST of the watchdog timer control register (WDTC) to identify a reset cause. If a reset cause needs to be identified after a reset is cleared, read the reset cause flag bits PONR, WRST, ERST, and SRST of the watchdog timer control register (WDTC).

The PONR, WRST, ERST, and SRST bits are cleared to "0" if the watchdog timer control register (WDTC) is read.



Figure 3.5-1 Block Diagram of Reset Cause Bits

S : Set

R : Reset

Q : Output F/F : Flip Flop

#### ■ Correspondence between Reset Cause FLAG Bits and Reset Causes

#### Figure 3.5-2 Configuration of Reset Cause Bits (Watchdog Timer Control Register)

#### Watchdog timer control register (WDTC)



| Reset cause                        | PONR | WRST | ERST | SRST |
|------------------------------------|------|------|------|------|
| Power-on reset                     | 1    | Х    | Х    | Х    |
| Watchdog timer overflow            | *    | 1    | *    | *    |
| External reset request via RST pin | *    | *    | 1    | *    |
| Software reset request (LPMCR:RST) | *    | *    | *    | 1    |

\*: Previous state retained

X: Undefined

#### Notes about Reset Cause Bits

#### O Multiple reset causes generated at the same time

When multiple reset causes are detected, the corresponding reset cause bits of the watchdog timer control register (WDTC) are set to "1". For example, if an external reset and a watchdog timer reset occur at the same time, the reset cause flag bits (ERST, WRST) of the watchdog timer control register (WDTC) are set to "1".

#### O Power-on reset

If a power-on reset occurs, the PONR bit of the watchdog timer control register (WDTC) is set to "1" and the WRST, ERST, and SRST bits are undefined.

If the PONR bit is set to "1", the contents of the WRST, ERST, and SRST bits should be ignored.

#### • Clearing the reset cause bits

The PONR, WRST, ERST, and SRST bits are cleared to "0" if the watchdog timer control register (WDTC) is read. In other words, these reset cause flag bits are not cleared to "0" unless the watchdog timer control register (WDTC) is read even if a reset occurs.

#### Note:

The value of the WDTC register cannot be assured if the power is turned on under conditions where a power-on reset does not occur.

### 3.6 Status of Pins in a Reset

#### This section describes the status of pins when a reset occurs.

#### Status of Pins during a Reset

The status of pins during a reset is determined by the settings of the mode pins (MD2 to  $MD0 = 011_B$ ).

#### **O** When internal vector mode is specified

All the I/O pins are set to high impedance output, and the mode data is read from the internal ROM.

#### Status of Pins after Mode Data is Read

The status of pins after mode data is read is determined by the mode data (M1 and M0 =  $00_B$ ).

#### $\odot$ When single-chip mode is specified (M1 and M0 = 00<sub>B</sub>)

All the I/O pins become high impedance output, and the mode data is read from the internal ROM.

#### Note:

Specify an external pin level that disables external circuits.

**CHAPTER 3 RESETS** 

# CHAPTER 4 CLOCKS

This chapter describes the clocks used by MB90M405 series.

- 4.1 "Clocks"
- 4.2 "Block Diagram of the Clock Generation Block"
- 4.3 "Clock Selection Register (CKSCR)"
- 4.4 "Clock Mode"
- 4.5 "Oscillation Stabilization Wait Time"
- 4.6 "Connection of an Oscillation or an External Clock to the Microcontroller"

## 4.1 Clocks

The clock generation block controls the operating clock of the CPU and peripheral functions (resources). The following four clocks are available:

- Oscillation clock
- Main clock
- PLL clock
- Machine clock

#### Clocks

The clock generation block contains the oscillation circuit and the PLL clock multiplier circuit. The clock generation block controls the oscillation stabilization wait time and PLL clock multiplication as well as controls the operation of switching the clock with a clock selector.

#### • Oscillation clock frequency (HCLK)

The oscillation clock is generated either from an oscillator connected to the X0 and X1 pins or by input of an external clock.

#### • Main clock (MCLK)

The main clock, which is the oscillation clock divided by 2, supplies the clock input to the timebase timer and the clock selector.

#### O PLL clock (PCLK)

The PLL clock is obtained by multiplying the oscillation clock in the internal PLL clock multiplier circuit. Four different clocks (multiplied by 1 through 4) can be generated.

#### O Machine clock(φ)

The machine clock is the operating clock of the CPU and peripheral functions (resources). One machine clock cycle is called a machine cycle. Either the main clock or a PLL clock can be selected.

#### **Reference:**

PLL oscillation, which may be from 3 to 16.8 MHz, varies depending on the operating voltage and the frequency multiplier.

For more information, see the "data sheet".

#### Note:

The maximum operating frequency of the CPU and the peripheral function circuits is 16.8 MHz. If a frequency multiplier is specified that results in a frequency higher than the maximum operating frequency, devices will not operate normally.

For example, if an oscillation clock of 16.8 MHz is generated, a multiplier of 1 or division by 2 can be specified.

### 4.2 Block Diagram of the Clock Generation Block

The clock generation block consists of the following five blocks:

- System clock generation circuit
- PLL multiplier circuitS
- Clock selector
- Clock selection register (CKSCR)
- oscillation stabilization wait time selector

#### Block Diagram of the Clock Generation Block



#### Figure 4.2-1 Block Diagram of the Clock Generation Block

#### **Reference:**

Figure 4.2-1 "Block Diagram of the Clock Generation Block" includes the standby control circuit and the timebase timer circuit.

#### **O** System clock generation circuit

The system clock generation circuit generates an oscillation clock from an oscillator connected to the X0 and X1 pins or by input of an external clock.

#### **Reference:**

Figure 4.2-1 "Block Diagram of the Clock Generation Block" includes the standby control circuit and the timebase timer circuit.

#### **O PLL multiplier circuit**

The PLL multiplier circuit multiplies the oscillation clock and supplies the resultant clock to the clock selector.

#### O Clock selector

The clock selector selects the clock to be supplied to the CPU and peripheral clock control circuits from among the main clock and the PLL clock.

#### ○ Clock selection register (CKSCR)

The clock selection register selects the machine clock and determines the oscillation stabilization wait time and the PLL clock multiplier, etc.

#### O oscillation stabilization wait time selector

The oscillation stabilization wait time selector selects the oscillation stabilization wait time of the oscillation clock when the stop mode is cleared. One of the four time-base timer outputs is selected to determine the oscillation stabilization wait time.

# 4.3 Clock Selection Register (CKSCR)

The clock selection register (CKSCR) switches the machine clock and sets the oscillation stabilization wait time and the PLL clock multiplier, etc.

#### ■ Configuration of the Clock Selection Register (CKSCR)



#### Figure 4.3-1 Configuration of the Clock Selection Register (CKSCR)

HCLK : Oscillation clock frequency

- R/W : Read/write
- R : Read only
- : Undefined bit
  - : Initial value

#### **Reference:**

A reset initializes the machine clock selection bit to the main clock setting.

| Bit name         |                                                                       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|------------------|-----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| bit 15<br>bit 11 | RESV:<br>Reserved bit                                                 | Note:<br>Always set "0".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
| bit 14           | MCM:<br>Machine clock<br>indication bit                               | <ul> <li>This bit indicates whether the main clock or a PLL clock has been selected as the machine clock.</li> <li>When this bit is set to "0", a PLL clock has been selected.</li> <li>When this bit is set to "1", the main clock has been selected.</li> <li>If the machine clock selection bit (MCS) is set to "0" and MCM is set to "1", the PLL clock oscillation stabilization wait time is in effect.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
| bit 13<br>bit 12 | WS1, WS0:<br>oscillation<br>stabilization wait<br>time selection bits | <ul> <li>These bits select the oscillation stabilization wait time for the oscillation clock after the stop mode has been cleared due to an external interrupt.</li> <li>A reset cause initializes these bits to "11<sub>B</sub>".</li> <li>Specify an oscillation stabilization wait time appropriate for the oscillator used.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| bit 10           | MCS:<br>Machine clock<br>selection bit                                | <ul> <li>This bit specifies whether the main clock or a PLL clock is selected as the machine clock.</li> <li>When this bit is set to "0", a PLL clock is selected.</li> <li>When this bit is set to "1", the main clock is selected.</li> <li>If this bit has been set to "1" and is reset to "0", the oscillation stabilization wait time for the PLL clock starts. As a result, the time-base timer counter and the interrupt request flag bit (TBOF) of the time-base timer counter control register (TBTC) are cleared to "0".</li> <li>For PLL clocks, the oscillation stabilization wait time is fixed to 2<sup>14</sup>/HCLK. The oscillation stabilization wait time is about 3.9 ms if the oscillation clock frequency is 4.194 MHz.)</li> <li>When the main clock has been selected, the oscillation clock divided by 2 is used as the machine clock. The machine clock frequency is 2 MHz if the oscillation clock frequency is 4 MHz.</li> <li>A reset initializes this bit to 1.</li> <li>Note:</li> <li>The MCS bit set to "1" can be reset to "0" while the interrupt request enable bit (TBIE) of the time-base timer counter control register (ILM) are set to disable timer-base timer interrupt requests.</li> </ul> |  |  |  |  |
| bit 9<br>bit 8   | CS1, CS0:<br>Multiplier<br>selection bits                             | <ul> <li>These bits select a PLL clock multiplier.</li> <li>One of the four multipliers can be selected.</li> <li>A reset initializes these bits to "00<sub>B</sub>".</li> <li>Note: <ul> <li>These bits cannot be set while the machine clock selection bit (MCS) or the machine clock indication bit (MCM) is set to "0". Set these bits only after setting the MCS bit to "1".</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |

### Table 4.3-1 Function Description of Each Bit of the Clock Selection Register (CKSCR)

HCLK: Oscillation clock frequency

### 4.4 Clock Mode

#### Two clock modes are provided: main clock mode and PLL clock mode.

#### ■ Main Clock Mode and PLL Clock Mode

#### • Main clock mode

In main clock mode, the main clock is used as the operating clock of the CPU and peripheral resources while the PLL clocks are disabled.

#### **O PLL clock mode**

In PLL clock mode, a PLL clock is used as the machine clock of the CPU and peripheral functions (resources). Specify a PLL clock multiplier in the multiplier selection bits (CS1 and CS0) of the clock selection register (CKSCR).

#### Clock Mode Transition

Setting the machine clock selection bit (MCS) of the clock selection register (CKSCR) causes switching between main clock mode and PLL clock mode.

#### **O** Switching from main clock mode to PLL clock mode

When the MCS bit of the CKSCR that is set to "1" is reset to "0", switching from the main clock to a PLL clock occurs after the PLL clock oscillation stabilization wait time  $(2^{14}/HCLK)$  has elapsed.

#### O Switching from PLL clock mode to main clock mode

When the MCS bit of the CKSCR that is set to "0" is reset to "1", switching from a PLL clock to the main clock occurs when the edges of the PLL clock and the main clock coincide (after 1 to 8 PLL clocks).

#### Note:

Before setting the peripheral functions (resources) after the machine clock switching, make sure that the machine clock has been switched by referring to the MCM bit of the CKSCR.

#### Selection of a PLL Clock Multiplier

Set the multiplier selection bits (CS1 and CS0) of the CKSCR to  $"00_B"$  and  $"11_B"$  to set one of the four PLL clock multipliers (1 through 4).

#### Machine Clock

Either the main clock or a PLL clock is used as the machine clock. The machine clock is an operating clock of the CPU and peripheral functions (resources). Set either the main clock or a PLL clock in the MCS bit of the CKSCR.



Figure 4.4-1 Status Change Diagram for Machine Clock Selection

(1) The MCS bit is cleared.

(2) The PLL clock oscillation stabilization wait ends with CS1 and CS0 =  $00_B$ .

(3) The PLL clock oscillation stabilization wait ends with CS1 and CS0 =  $01_B$ .

(4) The PLL clock oscillation stabilization wait ends with CS1 and CS0 =  $10_B$ .

(5) The PLL clock oscillation stabilization wait ends with CS1 and CS0 =  $11_B$ .

(6) The MCS bit is set (including hardware standby and watchdog timer resets).

(7) PLL clock and main clock frequency synchronization timing

MCS : Machine clock set bit of CKSCR

MCM : Machine clock indication bit of CKSCR

CS1, CS0 : Multiplier set bits of CKSCR

#### Note:

The initial value for the machine clock setting is main clock (CKSCR:MCS = 1).

## 4.5 Oscillation Stabilization Wait Time

Whenever the power is turned on, or whenever stop mode is cleared, oscillation begins following a state in which there was no oscillation. Accordingly, an oscillation stabilization wait time is required. Also, whenever the switching from the main clock to a PLL clock occurs, an oscillation stabilization wait time is required after the oscillation of the PLL clock starts.

#### Oscillation Stabilization Wait Time

Specify an oscillation stabilization wait time appropriate for the oscillator used because the oscillation stabilizes in different lengths of time depending on the oscillator type. Specify an appropriate oscillation stabilization wait time in the oscillation stabilization wait time selection bits (WS1 and WS0) of the clock selection register (CKSCR).

When switching from the main clock to a PLL clock occurs, the CPU operates on the main clock during an oscillation stabilization wait time and starts to operate on a PLL clock.

The timebase timer counts the specified oscillation stabilization wait time.



#### Figure 4.5-1 Operation When Oscillation Starts

# 4.6 Connection of an Oscillator or an External Clock to the Microcontroller

The MB90M405 series contains a system clock generation circuit. An oscillator can be connected to the X0 and X1 pins.

Alternatively, pulses from an external clock may be input.

Connection of an Oscillator or an External Clock to the Microcontroller

#### O Example of connecting a crystal or ceramic oscillator to the microcontroller

Connect a crystal or ceramic oscillator as shown in the example in Figure 4.6-1 "Example of Connecting a Crystal or Ceramic Oscillator to the Microcontroller".

#### Figure 4.6-1 Example of Connecting a Crystal or Ceramic Oscillator to the Microcontroller



#### O Example of connecting an external clock to the microcontroller

As shown in Figure 4.6-2 "Example of Connecting an External Clock to the Microcontroller", connect an external clock to pin X0. Pin X1 must be open.

#### Figure 4.6-2 Example of Connecting an External Clock to the Microcontroller



# CHAPTER 5 LOW POWER CONSUMPTION MODE

### This chapter describes the low power consumption mode of MB90M405 series.

- 5.1 "Low Power Consumption Mode"
- 5.2 "Block Diagram of the Low Power Consumption Control Circuit"
- 5.3 "Low Power Consumption Mode Control Register (LPMCR)"
- 5.4 "CPU Intermittent Operation Mode"
- 5.5 "Standby Mode"
- 5.6 "Status Change Diagram"
- 5.7 "Pin Status in Standby Mode and during Reset"
- 5.8 "Usage Notes on Low Power Consumption Mode"

# 5.1 Low Power Consumption Mode

The MB90M405 series has the following low power consumption modes, one of which can be selected depending on the operating clock setting and the clock operation control.

- CPU intermittent operation mode (PLL clock intermittent operation mode and main clock intermittent operation mode)
- Standby mode (sleep mode, timebase timer mode)

All modes other than PLL clock mode are low power consumption modes.

■ CPU Operating Modes and Current Consumption



#### Figure 5.1-1 CPU Operating Modes and Current Consumption

Note:

This figure is only an indication of the degree of power consumption for each mode. Actual current consumption values may not agree with those in the figure.

#### Clock Mode

#### O PLL clock mode

The CPU and peripheral functions (resources) operate on a PLL clock.

#### O Main clock mode

The CPU and peripheral functions (resources) operate on the main clock. In the main clock mode, the PLL multiplier circuit is disabled.

See Section 4.4 "Clock Mode", for details about clock mode.

#### CPU Intermittent Operation Mode

The CPU operates intermittently while the machine clock is supplied to the peripheral functions (resources).

#### Standby Mode

#### O PLL sleep mode

The CPU operating clock is stopped. Other components continue to operate on a PLL clock.

#### O Main sleep mode

The CPU operating clock is stopped. Other components continue to operate on the main clock.

#### **O** Timebase timer mode

All the components but the oscillation clock and the timebase timer are stopped.

#### O Stop mode

The oscillation clock is stopped. All the functions are stopped.

#### Note:

In stop mode, data can be retained at the minimum power consumption because the oscillation clock has stopped.

## 5.2 Block Diagram of the Low Power Consumption Control Circuit

The low power consumption control circuit consists of the following circuits and register:

- CPU intermittent operation selector
- Standby clock control circuit
- CPU clock control circuit
- Peripheral clock control circuit
- Pin high-impedance control circuit
- Internal reset generation circuit
- Low power consumption mode control register (LPMCR)
- Block Diagram of the Low Power Consumption Control Circuit



Figure 5.2-1 Block Diagram of the Low Power Consumption Control Circuit

#### O CPU intermittent operation selector

This selector selects the number of clock pulses during which the CPU is halted in CPU intermittent operation mode.

#### **O** Standby control circuit

This circuit controls the CPU clock control circuit, the peripheral clock control circuit, and the pin high-impedance control circuit to switch to, or release low power consumption mode.

#### **O CPU clock control circuit**

This circuit control the clocks supplied to the CPU.

#### O Peripheral clock control circuit

This circuit control the clocks supplied to the peripheral functions (resources).

#### **O** Pin high-impedance control circuit

A setting of this circuit to timebase timer mode or stop mode causes the I/O pins to enter a high impedance state. For those I/O pins configured to accept the connection of a pull-up resistor, this circuit disconnects the pull-up resistor in stop mode.

#### **O** Internal reset generation circuit

If the RST bit of the low power consumption mode control register (LPMCR:RST) is set to "0" by software, this circuit generates a three-cycle reset signal to the internal circuit.

#### O Low power consumption mode control register (LPMCR)

This register selects either switching to or release of low power consumption mode and the number of clock pulses during which the CPU is halted in CPU intermittent operation mode.

# 5.3 Low Power Consumption Mode Control Register (LPMCR)

The low power consumption mode control register (LPMCR) selects the switching to, or release of low power consumption mode and the number of clock pulses during which the CPU is halted in CPU intermittent operation mode.

#### ■ Low Power Consumption Mode Control Register (LPMCR)

Figure 5.3-1 Configuration of the Low Power Consumption Mode Control Register (LPMCR)



| Bit name       |                                                                                      | Function                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|----------------|--------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| bit 7          | STP:<br>Stop bit                                                                     | <ul> <li>This bit selects the stop mode.</li> <li>When this bit is set to "1", the microcontroller enters stop mode.</li> <li>When this bit is set to "0", there is no effect on operation.</li> <li>An external reset or the output of a hardware interrupt resets this bit to "0".</li> <li>The read value of this bit is "0".</li> </ul>                              |  |  |  |  |
| bit 6          | SLP:<br>Sleep bit                                                                    | <ul> <li>This bit selects sleep mode.</li> <li>When this bit is set to "1", the microcontroller enters sleep mode.</li> <li>When this bit is set to "0", there is no effect on operation.</li> <li>An external reset or the output of a hardware interrupt resets this bit to "0".</li> <li>The read value of this bit is "0".</li> </ul>                                |  |  |  |  |
| bit 5          | SPL:<br>Pin state setting<br>bit valid in<br>timebase timer<br>mode or stop<br>mode) | <ul> <li>This bit selects a pin state in timebase timer mode or stop mode.</li> <li>When this bit is set to "0", an I/O pin has a retained level.</li> <li>When this bit is set to "1", an I/O pin has high impedance.</li> <li>An external reset resets this bit to "0".</li> </ul>                                                                                     |  |  |  |  |
| bit 4          | RST:<br>Internal reset<br>signal generation<br>bit                                   | <ul> <li>This bit selects an internal reset.</li> <li>When this bit is set to "0", an internal reset signal of three machine cycles is generated.</li> <li>When this bit is set to "1", there is no effect on operation.</li> <li>The read value of this bit is "1".</li> </ul>                                                                                          |  |  |  |  |
| bit 3          | TMD:<br>Timebase timer<br>mode bit                                                   | <ul> <li>This bit selects the switching to timebase timer mode.</li> <li>When this bit is set to "0", the microcontroller enters timebase timer mode.</li> <li>When this bit is set to "1", there is no effect on operation.</li> <li>An external reset or a hardware interrupt return sets this bit to "1".</li> <li>The read value of this bit is "1".</li> </ul>      |  |  |  |  |
| bit 2<br>bit 1 | CG1, CG0:<br>CPU halt clock<br>pulses selection<br>bits                              | <ul> <li>These bits set the number of CPU halt clock pulses in CPU intermittent operation mode.</li> <li>The clock supplied to the CPU is stopped for the specified number of clock cycles every time after an instruction is executed.</li> <li>These bits select one of the four clock pulses.</li> <li>A reset initializes these bits to "00<sub>B</sub>".</li> </ul> |  |  |  |  |
| bit 0          | RESV:<br>Reserved bit                                                                | This bit must be set to "0".                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |

# Table 5.3-1 Function Description of Each Bit of the Low Power Consumption Mode Control Register (LPMCR)

#### ■ Access to the Low Power Consumption Mode Control Register

Use one of the instructions listed in Table 5.3-2 "Instructions to Be Used for Switching to Low Power Consumption Mode" to set low power consumption mode control register. The operation is not assured if any instruction other than that listed in Table 5.3-2 "Instructions to Be Used for Switching to Low Power Consumption Mode" is used to enter low power consumption mode. Any instruction may be used provided it is not an instruction that controls switching to low power consumption mode control register.

When using word access to set the low power consumption mode control register, use an evennumbered address. A malfunction may occur if an odd-numbered address is used to enter low power consumption mode.

| MOV io, #imm8      | MOV dir, #imm8   | MOV eam, #imm8   | MOV eam, Ri   |
|--------------------|------------------|------------------|---------------|
| MOV io, A          | MOV dir, A       | MOV addr, A      | MOV eam, A    |
| MOV @RLi+disp8, A  | MOVP addr24, A   |                  |               |
| MOVW io, #imm16    | MOVW dir, #imm16 | MOVW eam, #imm16 | MOVW eam, RWi |
| MOVW io, A         | MOVW dir, A      | MOVW addr16,     | MOVW eam, A   |
| MOVW @RLi+disp8, A | MOVPW addr24, A  |                  |               |

Table 5.3-2 Instructions to Be Used for Switching to Low Power Consumption Mode

#### ■ Priority of STP, SLP and TMD bits

If stop mode (LPMCR: STP), sleep mode (LPMCR: SLP), and timebase timer mode (LPMCR: TMD) are simultaneously specified, the microcontroller enters the following order of priority:

stop mode, timebase timer mode, or sleep mode

### 5.4 CPU Intermittent Operation Mode

In CPU intermittent operation mode, the CPU operates intermittently while the peripheral functions (resources) operate on the machine clock.

#### CPU Intermittent Operation Mode

In CPU intermittent operation mode, the machine clock to be supplied to the CPU is halted for a certain period every time after an instruction is executed, so that the activation of an internal bus cycle is delayed. Reducing the CPU speed while supplying a fast peripheral clock to the peripheral function circuits allows processing with low power consumption.

- Use the CG1 and CG0 bits of the low power consumption mode control register (LPMCR) to specify the number of cycles during which the clock supplied to the CPU is halted.
- For external bus operation, use the same clock as that for the peripheral functions.
- You can calculate the instruction execution time required when CPU intermittent operation mode is used as follows: Multiply the instruction execution count required to access registers, built-in memory, built-in peripheral functions (resources), and external buses by the halt cycle count, and add this correction value to the regular execution time.



#### Figure 5.4-1 Clock Pulses during CPU Intermittent Operation

# 5.5 Standby Mode

Standby mode includes the sleep mode (PLL sleep mode and main sleep mode), timebase timer mode, and stop mode.

#### Operating Status during Standby Mode

| Sta                            | ndby mode                           | Condition<br>for switch | Oscil-<br>lation | Clock               | CPU       | Timebase<br>timer<br>Watchdog<br>timer | Peripheral | Pin    | Release<br>event        |
|--------------------------------|-------------------------------------|-------------------------|------------------|---------------------|-----------|----------------------------------------|------------|--------|-------------------------|
| Sleep                          | PLL sleep<br>mode                   | MCS = 0<br>SLP = 1      | Active           | Active<br>In-active | In-active | Active                                 | Active     | Active | External<br>reset<br>or |
| mode                           | Main sleep<br>mode                  | MCS = 1<br>SLP = 1      |                  |                     |           |                                        |            |        |                         |
| Time-<br>base<br>timer<br>mode | Timebase<br>timer mode<br>(SPL = 0) | TMD = 0                 |                  |                     | In-active |                                        |            | Hold   |                         |
|                                | Timebase<br>timer mode<br>(SPL = 1) | TMD = 0                 |                  |                     |           |                                        |            | Hi-z   | hardware<br>interrupt   |
| Stop<br>mode                   | Stop mode<br>(SPL = 0)              | STP = 1                 |                  |                     |           | Inactive                               | Inactive   | Hold   |                         |
|                                | Stop mode<br>(SPL = 1)              | STP = 1                 |                  |                     |           |                                        |            | Hi-z   |                         |

Table 5.5-1 Operation Statuses in Standby Mode

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

SLP: Sleep bit of low power consumption mode control register (LPMCR)

STP: Timebase timer or stop bit of low power consumption mode control register (LPMCR)

TMD: Timebase timer mode bit of low power consumption mode control register (LPMCR)

MCS: Machine clock selection bit of clock set register (CKSCR)

Hi-z: High-impedance

### 5.5.1 Sleep Mode

In sleep mode, the CPU operating clock is halted while components other than the CPU continue to operate. When switching to sleep mode is specified, the microcontroller enters PLL sleep mode if PLL clock mode has been specified or the main sleep mode if the main clock mode has been specified.

#### Switching to Sleep Mode

Set the sleep mode bit (SLP) of the low power consumption mode control register (LPMCR) to "1", the timebase timer mode bit (TMD) to "1", and the stop mode bit (STP) to "0" to enter sleep mode. When switching to sleep mode is specified, the microcontroller enters PLL sleep mode if the machine clock setting bit (MCS) of the clock selection register (CKSCR) is set to "0". Alternatively, the microcontroller enters main sleep mode if the MCS is set to "1".

#### Note:

If you make the stop mode bit (STP), sleep mode bit (SLP), and timebase timer mode bit (TMD) effective at the same time, the stop mode bit (STP) has precedence. If you make the sleep mode bit (SLP) and timebase timer mode bit (TMD) effective at the same time, the timebase timer mode bit (TMD) has precedence. The order of priority is as follows:

Stop mode > Timebase timer mode > Sleep mode

#### O Data retention function

In sleep mode, the contents of both the dedicated registers and internal RAM are retained.

For more information on dedicated registers, see Section 2.7 "Dedicated Registers".

#### O Operation during output of an interrupt request

While an interrupt request is output, the microcontroller does not enter sleep mode but executes the next instruction even if the sleep mode bit (SLP) of the low power consumption mode control register (LPMCR) is set to "1".

#### O Pin state

In sleep mode, the pin state existing just before sleep mode is entered is retained.

#### Release of Sleep Mode

An external reset or the output of a hardware interrupt releases sleep mode.

#### O Release by a reset

For more information, see Section 3.4 "Reset Operation".

#### **O** Release by a hardware interrupt

An interrupt request with an interrupt level higher than 7 (Interrupt control register ICR: IL2, IL1,  $IL0 = "000_B"$  to "110<sub>B</sub>") is required to cause a hardware interrupt to release sleep mode.



A peripheral function issues an interrupt to set the enable flag.



#### Note:

To handle an interrupt, the microcontroller normally starts with interrupt processing after executing the instruction following the instruction that specifies sleep mode. However, the microcontroller may start interrupt processing before executing the next instruction if a sleep mode request and an external bus hold request are accepted at the same time.

### 5.5.2 Timebase Timer Mode

In timebase timer mode, all of the operations other than the source oscillation and the timebase timer are stopped.

#### Switching to Timebase Timer Mode

If the timebase timer mode bit (TMD) of the low power consumption mode control register (LPMCR) is set to "0", the microcontroller enters timebase timer mode.

#### **O** Data retention function

In timebase timer mode, the contents of both the dedicated registers and internal RAM are retained.

For more information on dedicated registers, see Section 2.7 "Dedicated Registers".

#### O Operation during output of an interrupt request

While an interrupt request is output, the microcontroller does not enter timebase timer mode even if the timebase timer mode bit (TMD) of the low power consumption mode control register (LPMCR) is set to "0".

#### **O** Status of pins

The I/O pins in timebase timer mode can be set to retain a previous level or have high impedance in the pin status setting bit (SPL) of the low power consumption mode control register (LPMCR).

#### Release of Timebase Timer Mode

Timebase timer mode is released by an external reset, timebase timer interrupt, or hardware interrupt resulting from input of an external interrupt.

#### **O** Release by a reset

For more information, see Section 3.4 "Reset Operation".

#### O Release by a hardware interrupt

An interrupt request with an interrupt level higher than 7 (IL2, IL1 and IL0 of the interrupt control register (ICR) are  $000_B$  to  $110_B$ ) is required to release timebase timer mode with a hardware interrupt.

Note:

When interrupt processing is executed, the microcontroller normally enters interrupt processing after executing the instruction after the instruction that specifies timebase timer mode.

### 5.5.3 Stop Mode

In stop mode, the source oscillation is stopped. Since all the functions are stopped, data can be retained while minimum power is consumed.

#### Switching to Stop Mode

If the stop mode bit (STP) of the low power consumption mode control register (LPMCR) is set to "1", the microcontroller enters stop mode.

#### **O** Data retention function

In stop mode, the contents of both the dedicated registers and RAM are retained.

For more information on dedicated registers, see Section 2.7 "Dedicated Registers".

#### O Operation during acceptance or execution of an interrupt request

While an interrupt request is being accepted or executed, the microcontroller does not enter stop mode even though the stop mode bit (STP) of the low power consumption mode control register (LPMCR) is set to "1".

#### O Status of pins

The I/O pins in stop mode can be set to retain a previous level or have high impedance in the pin status setting bit (SPL) of the low power consumption mode control register (LPMCR).

#### Release of Stop Mode

Stop mode is released by an external reset or hardware interrupt resulting from input of an external interrupt.

#### O Release by a reset

For more information, see Section 3.4 "Reset Operation".

#### O Release by a hardware interrupt

An interrupt request with an interrupt level higher than 7 (IL2, IL1 and IL0 of the interrupt control register (ICR) are  $000_B$  to  $110_B$ ) is required to release stop mode with an external interrupt.

#### Note:

To handle an interrupt, the microcontroller enters interrupt processing in ordinary cases after executing the instruction following the instruction that specifies stop mode. However, the microcontroller may enter interrupt processing before executing the next instruction if a request to enter stop mode and an external bus hold request are received at the same time.



Figure 5.5-2 Release of Stop Mode (External Reset)

### 5.6 Status Change Diagram

Figure 5.6-1 "Status Change Diagram" shows the CPU operation modes of the MB90M405 series and a state transition diagram.

#### Status Change Diagram



Figure 5.6-1 Status Change Diagram

#### ■ Operating States in Low Power Consumption Mode

| Low power<br>consumption<br>mode | Entry condition    | Oscillation     | Machine<br>clock | CPU             | Peripheral | Pin      | Release<br>method  |
|----------------------------------|--------------------|-----------------|------------------|-----------------|------------|----------|--------------------|
| Main sleep                       | MCS="1"<br>SLP="1" | Running Running |                  | Stopped         | Running    | Running  | Reset<br>interrupt |
| PLL sleep                        | MCS="0"<br>SLP="1" | Running         | Running          | Stopped Running |            | Running  | Reset<br>interrupt |
| Timebase<br>timer<br>(SPL="0")   | TMD="0"            | Running         | Stopped          | Stopped         | Stopped    | Retained | Reset<br>interrupt |
| Timebase<br>timer<br>(SPL="1")   | TMD="0"            | Running         | Stopped          | Stopped         | Stopped    | Hi-z     | Reset<br>interrupt |
| Stop<br>(SPL="0")                | MCS="1"<br>STP="1" | Stopped         | Stopped          | Stopped         | Stopped    | Retained | Reset<br>interrupt |
| Stop<br>(SPL="1")                | MCS="1"<br>STP="1" | Stopped         | Stopped          | Stopped         | Stopped    | Hi-z     | Reset<br>interrupt |

 Table 5.6-1 Operating States in Low Power Consumption Mode

### 5.7 Pin Status in Standby Mode and during Reset

Table 5.7-1 "State of Pins in Single-Chip Mode" shows the status of pins in standby mode and during a reset.

#### Software Pull-Up Resistor

For I/O pins configured in software to accept the connection of a pull-up resistor, set the port to an output setting that disconnects the pull-up resistor.

#### ■ Status of Pins in Single-Chip Mode

| Table 5.7-1 | State of Pins | in Single-Chip Mode |
|-------------|---------------|---------------------|
|-------------|---------------|---------------------|

| Pin name                                             | Sleen mede                             | Stop m                                 | Reset                               |                  |
|------------------------------------------------------|----------------------------------------|----------------------------------------|-------------------------------------|------------------|
| Sleep mode                                           |                                        | SPL=0                                  | SPL=1                               |                  |
| P82 to P87<br>P90 to P91<br>PA0 to PA7<br>PB0 to PB5 | The preceding status is retained. (*2) | The preceding status is retained. (*2) | Input shut off (*3)<br>/output Hi-z | Output Hi-z (*4) |
| P80, P81<br>PB6, PB7                                 |                                        | Input enabled (*1)                     |                                     |                  |

\*1: "Input enabled" means that the input function is enabled. However, the input function is enabled only if an external interrupt is enabled. These pins, when used as output ports, conform to the setting of the pin status setting bit (SPL) of the low power consumption mode control register (LPMCR).

- \*2: "The preceding status is retained" means that the output status of the pin immediately before switching to standby mode is retained (\*5). However, note that the input is disabled (\*6) if the pin was in the input status.
- \*3: "Input shut off" means that the input to the pin is inhibited.
- \*4: "Output Hi-Z" means that the pin-driving transistor is disabled and that the pin is made to have high impedance.
- \*5: "the output status is retained as is" means that the output value of a peripheral function (resource) or a port is retained.
- \*6: "the input is disabled" means that a value input to the pin cannot be accepted internally because an internal circuit is not running.

### 5.8 Usage Notes on Low Power Consumption Mode

Note the following items when using low power consumption mode:

- Switching to standby mode and interrupts
- Release of standby mode by an interrupt
- · Release of stop mode by an external interrupt
- Oscillation stabilization wait time

#### Switching to Standby Mode and Interrupts

While an interrupt request is output, the microcontroller does not enter standby mode even if the stop mode bit (STP) of the low power consumption mode control register (LPMCR) is set to "1", the sleep mode bit (SLP) is set to "1", or the timebase timer mode bit (TMD) is set to "0".

#### Release of Standby Mode by an Interrupt

Standby mode is released if an interrupt request with an interrupt level higher than 7 (Interrupt control register ICR: IL2, IL1, IL0 =  $"000_B"$  to  $"110_B"$ ) is output in sleep mode, timebase timer mode, or stop mode.

If the interrupt level setting bit (ICR: IL2, IL1, IL0) corresponding to an interrupt request has a priority higher than the interrupt level mask register (ILM) and the interrupt enable flag of the condition code register is enabled (CCR:I = 1), the interrupt is accepted and the interrupt processing routine is executed. Unless the interrupt is accepted, the processing starts again from the next instruction to the one that set standby mode.

#### Note:

Interrupt disable setting is required before the setting of standby mode unless an interrupt processing routine is executed immediately after standby mode is released.

#### Release of Stop Mode by an External interrupt

To release stop mode by an external interrupt, set the DTP/interrupt enable register (ENIR) and the request level setting register (ELVR) before the microcontroller enters stop mode.

Select one of the "H" level, "L" level, rising edge, and falling edge as an input cause.

#### Oscillation Stabilization Wait Time

#### **O** Source clock oscillation stabilization wait time

An oscillation stabilization wait time is required after stop mode is released because the source oscillation has been halted in stop mode. The oscillation stabilization wait time can be set in the oscillation stabilization wait time setting bits (WS1, WS0) of the clock selection register (CKSCR). On a return due to a reset, the registers are set to the initial value. The clock cycle is therefore fixed to 2<sup>17</sup>/HCLK.

#### O PLL clock oscillation stabilization wait time

A PLL clock oscillation stabilization wait time is required after the operating clock is changed from the main clock to the PLL clock because the PLL clock is halted while the CPU operates on the main clock. While waiting for PLL clock oscillation stabilization, the CPU operates on the main clock.

The PLL clock oscillation stabilization wait time is fixed at 2<sup>14</sup>/HCLK (HCLK: clock oscillation frequency).

### CHAPTER 6 INTERRUPTS

# This chapter explains the interrupts and extended intelligent I/O service (EI<sup>2</sup>OS) in the MB90M405 series.

- 6.1 "Interrupts"
- 6.2 "Interrupt Causes and Interrupt Vectors"
- 6.3 "Interrupt Control Registers and Peripheral Functions"
- 6.4 "Hardware Interrupts"
- 6.5 "Software Interrupts"
- 6.6 "Interrupt of Extended Intelligent I/O Service (EI<sup>2</sup>OS)"
- 6.7 "Exception Processing Interrupt"
- 6.8 "Stack Operations for Interrupt Processing"
- 6.9 "Sample Programs for Interrupt Processing"

### 6.1 Interrupts

The MB90M405 series has the following interrupt functions and exception processing function:

- Hardware interrupts
- Software interrupts
- Interrupts from extended intelligent I/O service (El<sup>2</sup>OS)
- Exception processing

#### Interrupt Types and Functions

#### O Hardware interrupt

A hardware interrupt transfers control to an interrupt processing program in response to an interrupt request from a peripheral function (resource). For more information, see Section 6.4 "Hardware Interrupts".

#### **O** Software interrupt

A software interrupt transfers control to an interrupt processing program if a software interrupt instruction (INT instruction) is executed on a program. For more information, see Section 6.5 "Software Interrupts".

#### O Interrupt from extended intelligent I/O service (El<sup>2</sup>OS)

The extended intelligent I/O service (EI<sup>2</sup>OS) can transfer data between a register contained in a peripheral function (resource) and internal memory if settings are made in the interrupt control registers (ICR00 to ICR15) and the extended intelligent I/O service descriptor (ISD).

When the data transfers have been terminated, the interrupt processing program is executed. For more information, see Section 6.6 "Interrupt of Extended Intelligent I/O Service (El<sup>2</sup>OS)".

#### **O** Exception processing

Exception processing is performed if an undefined instruction code is executed.

If exception processing is performed, the register value currently processed is saved to the system stack and the processing branches to the exception processing routine. For more information, see Section 6.7 "Exception Processing Interrupt".

#### Interrupt Operation



Figure 6.1-1 Overall Flow of Interrupt Operation

\*1 When a string type instruction is being executed, the interrupt is evaluated in each step.

#### 6.2 **Interrupt Causes and Interrupt Vectors**

The MB90M405 series have functions for handling 256 types of interrupt cause. The 256 interrupt vector tables are allocated to the memory at the highest addresses. Software interrupts can use 256 interrupt instructions (INT0 to INT255). Note that INT8 is shared with a reset vector interrupt and that INT10 is shared with exception processing. INT11 to INT42 are shared with an interrupt from a peripheral function (resource).

#### Interrupt Vectors

Interrupt vector tables referenced during interrupt processing are allocated to the highest addresses in the memory area ( $FFFC00_{H}$  to  $FFFFE_{H}$ ). Interrupt vectors share the same area

with El<sup>2</sup>OS, exception processing, hardware, and software interrupts.

Table 6.2-1 "Interrupt Vectors" shows the assignment of software interrupt instructions, interrupt numbers, and interrupt vectors.

| Software<br>interrupt<br>instruction | Vector<br>address L | Vector<br>address M | Vector<br>address H | Mode data           | Interrupt<br>No. | Hardware interrupt                    |
|--------------------------------------|---------------------|---------------------|---------------------|---------------------|------------------|---------------------------------------|
| INT0                                 | FFFFFC <sub>H</sub> | FFFFFD <sub>H</sub> | FFFFFE <sub>H</sub> | Not used            | #0               | None                                  |
| :                                    | :                   | :                   | :                   | :                   | :                | :                                     |
| INT7                                 | FFFFE0 <sub>H</sub> | FFFFE1 <sub>H</sub> | FFFFE2 <sub>H</sub> | Not used            | #7               | None                                  |
| INT8                                 | FFFFDC <sub>H</sub> | FFFFDD <sub>H</sub> | FFFFDE <sub>H</sub> | FFFFDF <sub>H</sub> | #8               | (RESET Vector)                        |
| INT9                                 | FFFFD8 <sub>H</sub> | FFFFD9 <sub>H</sub> | FFFFDA <sub>H</sub> | Not used            | #9               | None                                  |
| INT10                                | FFFFD4 <sub>H</sub> | FFFFD5 <sub>H</sub> | FFFFD6 <sub>H</sub> | Not used            | #10              | <exception processing=""></exception> |
| INT11                                | FFFFD0 <sub>H</sub> | FFFFD1 <sub>H</sub> | FFFFD2 <sub>H</sub> | Not used            | #11              | Hardware interrupt #0                 |
| INT12                                | FFFFCC <sub>H</sub> | FFFFCD <sub>H</sub> | FFFFCE <sub>H</sub> | Not used            | #12              | Hardware interrupt #1                 |
| INT13                                | FFFFC8 <sub>H</sub> | FFFFC9 <sub>H</sub> | FFFFCA <sub>H</sub> | Not used            | #13              | Hardware interrupt #2                 |
| INT14                                | FFFFC4 <sub>H</sub> | FFFFC5 <sub>H</sub> | FFFFC6 <sub>H</sub> | Not used            | #14              | Hardware interrupt #3                 |
| :                                    | :                   | :                   | :                   | :                   | :                | :                                     |
| INT254                               | FFFC04 <sub>H</sub> | FFFC05 <sub>H</sub> | FFFC06 <sub>H</sub> | Not used            | #254             | None                                  |
| INT255                               | FFFC00 <sub>H</sub> | FFFC01 <sub>H</sub> | FFFC02 <sub>H</sub> | Not used            | #255             | None                                  |

#### Table 6.2-1 Interrupt Vectors

#### Note:

Interrupt vectors not defined during software design should be set at the exception processing address.

#### ■ Interrupt Causes and Interrupt Vectors/Interrupt Control Registers

|                                     | EI <sup>2</sup> OS | Ir                     | nterrupt        | vector              | Interrupt o               | Priority            |          |
|-------------------------------------|--------------------|------------------------|-----------------|---------------------|---------------------------|---------------------|----------|
| Interrupt cause                     | support            | <sup>t</sup> Number *1 |                 | Address             | ICR                       | Address             | Priority |
| Reset                               | Х                  | #08                    | 08 <sub>H</sub> | FFFFDC <sub>H</sub> | -                         | -                   |          |
| INT9 instruction                    | Х                  | #09                    | 09 <sub>H</sub> | FFFFD8 <sub>H</sub> | -                         | -                   | High     |
| Exception processing                | Х                  | #10                    | 0A <sub>H</sub> | FFFFD4 <sub>H</sub> | -                         | -                   | 1        |
| DTP/external interrupt channel 0    | 0                  | #11                    | 0B <sub>H</sub> | FFFFD0 <sub>H</sub> | ICR00                     | 0000B0 <sub>H</sub> |          |
| DTP/external interrupt channel 1    | 0                  | #13                    | 0D <sub>H</sub> | FFFFC8 <sub>H</sub> | ICR01                     | 0000B1 <sub>H</sub> |          |
| Serial I/O channel 2                | Δ                  | #15                    | 0F <sub>H</sub> | FFFFC0 <sub>H</sub> | ICR02                     | 000082              |          |
| DTP/external interrupt channels 2/3 | 0                  | #16                    | 10 <sub>H</sub> | FFFFBC <sub>H</sub> | ICRUZ                     | 0000B2 <sub>H</sub> |          |
| Serial I/O channel 3                | Δ                  | #17                    | 11 <sub>H</sub> | FFFFB8 <sub>H</sub> | ICR03                     | 000082              |          |
| 16-bit free-running timer           | Δ                  | #18                    | 12 <sub>H</sub> | FFFFB4 <sub>H</sub> | ICRUS                     | 0000B3 <sub>H</sub> |          |
| Reserved                            | -                  | #20                    | -               | FFFFAC <sub>H</sub> | ICR04                     | 0000B4 <sub>H</sub> |          |
| 16-bit reload timer channel 2       | Δ                  | #21                    | 15 <sub>H</sub> | FFFFA8 <sub>H</sub> | ICR05                     | 0000B5 <sub>H</sub> |          |
| 16-bit reload timer channel 0       | Δ                  | #23                    | 17 <sub>H</sub> | FFFFA0 <sub>H</sub> | ICR06                     | 0000B6 <sub>H</sub> |          |
| 16-bit reload timer channel 1       | Δ                  | #24                    | 18 <sub>H</sub> | FFFF9C <sub>H</sub> | ICRU0                     |                     |          |
| Input capture channel 0             | Δ                  | #25                    | 19 <sub>H</sub> | FFFF98 <sub>H</sub> | ICR07                     | 000007              |          |
| Input capture channel 1             | Δ                  | #26                    | 1A <sub>H</sub> | FFFF94 <sub>H</sub> |                           | 0000B7 <sub>H</sub> |          |
| Reserved                            | -                  | #27                    | -               | FFFF90 <sub>H</sub> | ICR08 0000B8 <sub>H</sub> |                     |          |
| Output compare match                | Х                  | #29                    | 1D <sub>H</sub> | FFFF88 <sub>H</sub> | ICR09 0000B9 <sub>H</sub> |                     |          |
| Reserved                            | -                  | #31                    | -               | FFFF80 <sub>H</sub> | ICR10                     | 0000BA <sub>H</sub> |          |
| Timebase timer                      | Х                  | #33                    | 21 <sub>H</sub> | FFFF78 <sub>H</sub> | 10044                     | 000000              |          |
| Reserved                            | -                  | #34                    | -               | FFFF74 <sub>H</sub> | ICR11                     | 0000BB <sub>H</sub> |          |
| UART0 receive end                   | 0                  | #35                    | 23 <sub>H</sub> | FFFF70 <sub>H</sub> | 10040                     | 000000              |          |
| UART0 send end                      | Δ                  | #36                    | 24 <sub>H</sub> | FFFF6C <sub>H</sub> | ICR12                     | 0000BC <sub>H</sub> |          |
| End of A/D conversion               | 0                  | #37                    | 25 <sub>H</sub> | FFFF68 <sub>H</sub> | 10540                     | 000000              |          |
| I <sup>2</sup> C interface          |                    | #38                    | 26 <sub>H</sub> | FFFF64 <sub>H</sub> | ICR13                     | 0000BD <sub>H</sub> |          |
| UART1 receive end                   | 0                  | #39                    | 27 <sub>H</sub> | FFFF60 <sub>H</sub> |                           | 0000055             |          |
| UART1 send end                      |                    | #40                    | 28 <sub>H</sub> | FFFF5C <sub>H</sub> | ICR14                     | 0000BE <sub>H</sub> | ↓        |
| Flash memory status                 | Х                  | #41                    | 29 <sub>H</sub> | FFFF58 <sub>H</sub> |                           | 0000055             | Low      |
| Delayed interrupt generator module  | Х                  | #42                    | 2A <sub>H</sub> | FFFF54 <sub>H</sub> | ICR15                     | 0000BF <sub>H</sub> |          |

O: Can be used.

X: Cannot be used.

 $\odot$  : Usable if used with the El<sup>2</sup>OS stop function.

 $\Delta$  : Usable when an interrupt cause that shares the ICR is not used.

\*1: If multiple interrupts of the same level are output simultaneously, an interrupt cause with a smaller interrupt vector number takes precedence.

### 6.3 Interrupt Control Registers and Peripheral Functions

The interrupt control registers ICR00 to ICR15 correspond to all peripheral functions that have the interrupt function. These registers control interrupts and the extended intelligent I/O service (El<sup>2</sup>OS).

#### Interrupt Control Registers

#### Table 6.3-1 Interrupt Control Registers

| Address                                           | Register                                          | Abbreviation | Corresponding peripheral function (Resource)                |
|---------------------------------------------------|---------------------------------------------------|--------------|-------------------------------------------------------------|
| 0000B0 <sub>H</sub>                               | Interrupt control register 00                     | ICR00        | DTP/external interrupt channel 0                            |
| 0000B1 <sub>H</sub>                               | 0000B1 <sub>H</sub> Interrupt control register 01 |              | DTP/external interrupt channel 1                            |
| 0000B2 <sub>H</sub> Interrupt control register 02 |                                                   | ICR02        | Serial I/O channel 2<br>DTP/external interrupt channels 2/3 |
| 0000B3 <sub>H</sub>                               | 0000B3 <sub>H</sub> Interrupt control register 03 |              | Serial I/O channel 3<br>16-bit free-running timer           |
| 0000B4 <sub>H</sub>                               | Interrupt control register 04                     | ICR04        | Reserved                                                    |
| 0000B5 <sub>H</sub>                               | Interrupt control register 05                     | ICR05        | 16-bit reload timer channel 2                               |
| 0000B6 <sub>H</sub>                               | Interrupt control register 06                     | ICR06        | 16-bit reload timer channels 0/1                            |
| 0000B7 <sub>H</sub>                               | Interrupt control register 07                     | ICR07        | Input capture channels 0/1                                  |
| 0000B8 <sub>H</sub>                               | Interrupt control register 08                     | ICR08        | Reserved                                                    |
| 0000B9 <sub>H</sub>                               | Interrupt control register 09                     | ICR09        | Output compare                                              |
| 0000BA <sub>H</sub>                               | Interrupt control register 10                     | ICR10        | Reserved                                                    |
| 0000BB <sub>H</sub>                               | Interrupt control register 11                     | ICR11        | Timebase timer                                              |
| 0000BC <sub>H</sub>                               | Interrupt control register 12                     | ICR12        | UART0 receive end<br>UART0 send end                         |
| 0000BD <sub>H</sub>                               | Interrupt control register 13                     | ICR13        | A/D converter<br>I <sup>2</sup> C bus interface             |
| 0000BE <sub>H</sub>                               | Interrupt control register 14                     | ICR14        | UART1 receive end<br>UART1 send end                         |
| 0000BF <sub>H</sub>                               | Interrupt control register 15                     | ICR15        | Flash memory status<br>Delayed interrupt generator module   |

The following four settings can be made in an interrupt control register (ICR).

- Set the interrupt level of the corresponding peripheral function (resource).
- Set an interrupt of the peripheral function (resource) either as an interrupt or as the extended intelligent I/O service.
- Set the descriptor address of the extended intelligent I/O service (El<sup>2</sup>OS).

• Display the status of the extended intelligent I/O service (EI<sup>2</sup>OS)

Interrupt control registers (ICRs) have different functions during the writing and reading of data.

#### Note:

When interrupt control registers (ICRs) are set, a read-modify-write instruction of SETB and CLRB cannot be used to access it.

### 6.3.1 Interrupt Control Registers (ICR00 to ICR15)

Interrupt control registers can determine the interrupt processing or the extended intelligent I/O service processing when an interrupt request is output. Interrupt control registers (ICRs) have different bit functions during the writing and reading of data.

Interrupt Control Registers (ICR00 to ICR15)



Figure 6.3-1 Interrupt Control Registers (ICR00 to ICR15) during Writing

#### Bit 7 5 4 3 2 1 0 Initial value 6 ICR00 to ICR15 S1 S0 ISE IL2 IL1 IL0 \_ ХХ000111в R R R/W R/W R/W R/W --L L IL2 IL0 Interrupt level setting bit IL1 0 0 0 Interrupt level 0 (highest) 0 0 1 0 1 0 0 1 1 0 1 0 1 0 1 1 1 0 1 1 1 Interrupt level 7 (no interrupt) ISE El<sup>2</sup>OS enable bit 0 Activates the interrupt sequence when an interrupt occurs Activates EI2OS when an interrupt occurs 1 S1 S0 EI<sup>2</sup>OS status 0 0 EI<sup>2</sup>OS operation in progress or EI<sup>2</sup>OS not activated 0 1 Stopped status due to count termination 1 0 Reserved 1 1 Stopped status due to a request from the peripheral function

Figure 6.3-2 Interrupt Control Registers (ICR00 to ICR15) during Reading

Reading

| R/W | : Read/write    |
|-----|-----------------|
| R   | : Read only     |
| -   | : Undefined bit |
| Х   | : Undefined     |
|     | : Initial value |

### 6.3.2 Interrupt Control Register Functions

The interrupt control registers (ICR00 to ICR15) can specify the following settings:

- Interrupt level setting
- Extended intelligent I/O service (EI<sup>2</sup>OS) enable setting
- Extended intelligent I/O service (EI<sup>2</sup>OS) descriptor address setting
- Extended intelligent I/O service (El<sup>2</sup>OS) operation status display

#### ■ Configuration of Interrupt Control Registers (ICR)

#### Figure 6.3-3 Configuration of Interrupt Control Registers (ICR)

Writing to interrupt control register (ICR)

| 10000                | Bit     | 7       | 6      | 5       | 4    | 3   | 2   | 1   | 0   | Initial value |
|----------------------|---------|---------|--------|---------|------|-----|-----|-----|-----|---------------|
| ICR00<br>to<br>ICR15 |         | ICS3    | ICS2   | ICS1    | ICS0 | ISE | IL2 | IL1 | IL0 | 00000111в     |
| Reading of in        | terrupt | control | regist | er (ICF | २)   |     |     |     |     | -             |
| -                    | Bit     | 7       | 6      | 5       | 4    | 3   | 2   | 1   | 0   | Initial value |
| ICR00<br>to<br>ICR15 |         | _       |        | S1      | S0   | ISE | IL2 | IL1 | IL0 | ХХ000111в     |
|                      |         |         |        |         |      |     |     |     |     | -             |

- : Undefined bit

#### **Reference:**

Set the El<sup>2</sup>OS descriptor address setting bits (ICS3 to ICS0) to start the extended intelligent I/O service (El<sup>2</sup>OS). Set the El<sup>2</sup>OS enable bit (ISE) to "1" to activate it. Alternatively, set the ISE to "0" to refrain from activating it. If El<sup>2</sup>OS is not activated, the ICS3 to ICS0 bits need not be set.

#### O Interrupt level setting bits (IL2 to IL0)

These bits can set the interrupt level of the corresponding peripheral function (resource). A reset initializes these bits to level 7 (no interrupts). (No interrupts can be generated at level 7.)

 Table 6.3-2
 Correspondence between the Interrupt Level Setting Bits and Interrupt Levels

| IL2 | IL1 | IL0 | Interrupt level           |  |  |
|-----|-----|-----|---------------------------|--|--|
| 0   | 0   | 0   |                           |  |  |
| 0   | 0   | 1   | 0 (highest priority)<br>▲ |  |  |
| 0   | 1   | 0   |                           |  |  |
| 0   | 1   | 1   |                           |  |  |
| 1   | 0   | 0   |                           |  |  |
| 1   | 0   | 1   | ↓                         |  |  |
| 1   | 1   | 0   | 6 (lowest priority)       |  |  |
| 1   | 1   | 1   | 7 (no interrupts)         |  |  |

#### • Extended intelligent I/O service (El<sup>2</sup>OS) enable bit (ISE)

When an interrupt request is output,  $EI^2OS$  is started if the  $EI^2OS$  enable bit (ISE) is set to "1". Alternatively, an interrupt sequence is started if the  $EI^2OS$  enable bit (ISE) is set to "0". When  $EI^2OS$  processing is completed, the ISE bit is reset to "0". If a peripheral function (resource) has no  $EI^2OS$  function, set the ISE bit to "0" using software. A reset initializes the ISE bit to "0".

#### O Extended intelligent I/O service (El<sup>2</sup>OS) channel setting bits (ICS3 to ICS1)

The El<sup>2</sup>OS descriptor address setting bits (ICS3 to ICS1) are valid when a descriptor is set. Set the El<sup>2</sup>OS descriptor address in these bits. Set values in the El<sup>2</sup>OS descriptor address setting bits to set the El<sup>2</sup>OS descriptor address. A reset initializes the ICS3 to ICS0 bits to  $0000_{B}$ .

| ICS3 | ICS2 | ICS1 | ICS0 | Selected channel | 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> |
| 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 6.3-3 Correspondence between El<sup>2</sup>OS Channel Setting Bits and Descriptor Addresses

### • Extended intelligent I/O service (El<sup>2</sup>OS) status bits (S1 and S0)

The El<sup>2</sup>OS status bits (S1 and S0) are valid during reading. Read the S1 and S0 bits while  $El^2OS$  is activated to determine whether  $El^2OS$  is running or terminated. A reset initializes the S1 and S0 bits to "00<sub>B</sub>".

| S1 | S0 | El <sup>2</sup> OS status                                                    |
|----|----|------------------------------------------------------------------------------|
| 0  | 0  | EI <sup>2</sup> OS operation in progress or EI <sup>2</sup> OS not activated |
| 0  | 1  | Stopped status due to count termination                                      |
| 1  | 0  | Reserved                                                                     |
| 1  | 1  | Stopped status due to a request from the peripheral function (resource)      |

Table 6.3-4 Relationship between El<sup>2</sup>OS Status Bits and the El<sup>2</sup>OS Status

### 6.4 Hardware Interrupts

A hardware interrupt operates as follows: an interrupt request that is output by a peripheral function (resource) temporarily interrupts a program being executed by the CPU and transfers control to a user-defined interrupt processing program. The extended intelligent I/O service (EI<sup>2</sup>OS) is also handled as a hardware interrupt.

#### Hardware Interrupts

#### **O** Hardware interrupt function

The hardware interrupt function determines whether an interrupt can be accepted. To do so, it compares the interrupt level of an interrupt request that is output by a peripheral function (resource) with the interrupt level mask register (PS: ILM) while referring to the contents of the I flag (PS: I).

If a hardware interrupt is accepted, the contents of the direct page register (DPR), accumulator (A), program counter (PC), processor status register (PS), and bank registers (ADB, DTB, and PCB) are saved to the system stack. An interrupt level stored in the ICR register is then stored in the interrupt level mask register (ILM). Finally, the processing branches to the interrupt vector and the interrupt processing program is executed.

#### **O** Multiple interrupts

A hardware interrupt can be activated while the interrupt processing program is being executed.

#### ○ Extended intelligent I/O service (El<sup>2</sup>OS)

 $EI^2OS$  is a data transfer function between memory and I/O registers. When the transfer of data to the extended intelligent I/O service descriptor is completed, a hardware interrupt is activated.  $EI^2OS$  cannot be activated in duplicate. While  $EI^2OS$  is being processed, no interrupt request or  $EI^2OS$  request is accepted. When the processing of  $EI^2OS$  is completed, interrupt request or  $EI^2OS$  request is accepted.

#### **O** External interrupt

An external interrupt is accepted as a hardware interrupt if a circuit that can output an interrupt request from an external terminal (DTP/external interrupt circuit) detects an interrupt request.

#### O Interrupt vector

Interrupt vector tables referenced during interrupt processing are allocated to memory at  $\text{FFFC00}_{\text{H}}$  to  $\text{FFFFF}_{\text{H}}$ .

#### **Reference:**

See Section 6.2 "Interrupt causes and Interrupt Vectors", for more information about the allocation of interrupt numbers and interrupt vectors.

#### Hardware Interrupt Structure

The mechanisms shown in Table 6.4-1 "Mechanisms Used for Hardware Interrupts" are used for hardware interrupts. These mechanisms must be configured in a user program before hardware interrupts can be used.

| Table 6.4-1 Mechanisms Used for Hardware Interrupts |
|-----------------------------------------------------|
|-----------------------------------------------------|

|                                                         | Mechanism                                                                                                        | Function                                                         |  |
|---------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|--|
| Peripheral function (resource)                          | Interrupt enable bit, interrupt<br>request bitControls interrupt requests from a peripher<br>function (resource) |                                                                  |  |
| Interrupt controller                                    | Interrupt control register (ICR) Sets the interrupt level and controls El <sup>2</sup> OS                        |                                                                  |  |
| CPU                                                     | Interrupt enable flag (I)                                                                                        | Identifies the interrupt enable status                           |  |
|                                                         | Interrupt level mask register<br>(ILM)                                                                           | Compares the request interrupt level and current interrupt level |  |
|                                                         | Microcode                                                                                                        | Executes the interrupt processing routine                        |  |
| FFFC00 <sub>H</sub> to<br>FFFFFF <sub>H</sub> in memory | Interrupt vector table                                                                                           | Stores the branch destination address for interrupt processing   |  |

#### ■ Hardware Interrupt Disable

Acceptance of a hardware interrupt request is disabled under the following conditions:

## • Hardware interrupt acceptance disable during writing to the peripheral function (resource) control register

No hardware interrupt request is accepted while data is written to the peripheral function (resource) control register.

#### Figure 6.4-1 Hardware Interrupt Request While Writing to the Peripheral Function Control Register Area

Instruction that writes to the peripheral function control register area



#### **O** Hardware interrupt acceptance disable by interrupt suppression instructions

The hardware interrupt suppression instructions listed in Table 6.4-2 "Hardware Interrupt Suppression Instruction" ignore interrupt requests without detecting whether a hardware interrupt request exists.

If a hardware interrupt request is output while a hardware interrupt suppression instruction is being executed, the interrupt is accepted and processed after completion of the hardware interrupt suppression instruction and the subsequent execution of an instruction other than the hardware interrupt suppression instruction.

|                                                                       | Prefix code                            |                          | rupts/hold suppression instructions ns that delay the effect of the prefix code) |
|-----------------------------------------------------------------------|----------------------------------------|--------------------------|----------------------------------------------------------------------------------|
| Instructions that<br>do not accept<br>interrupts and<br>hold requests | 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                                     |

#### Table 6.4-2 Hardware Interrupt Suppression Instruction

#### O Hardware interrupt acceptance disable during execution of a software interrupt

When a software interrupt is activated, the I flag is cleared to 0. In this state, other interrupt requests cannot be accepted.

### 6.4.1 Operation of Hardware Interrupts

This section explains hardware interrupt operation from generation of a interrupt request to the completion of interrupt processing.

#### Hardware Interrupt Activation

#### O Peripheral function (resource) operation (generation of an interrupt request)

A peripheral function (resource) that has a hardware interrupt request function has an "interrupt request flag bit" and an "interrupt enable flag" in the corresponding peripheral function (resource) control registers. The interrupt request flag bit indicates the presence of an interrupt request. The interrupt enable flag determines whether a CPU interrupt request is enabled or disabled. When an interrupt cause defined in a peripheral function is detected, an interrupt request is output to an interrupt controller as long as the interrupt request flag bit is set to "1" and the interrupt enable bit is set to enable an interrupt request to the CPU.

#### O Interrupt controller operation (interrupt request control)

The interrupt controller compares the interrupt levels (ILs) to accept the request having the highest level. If multiple interrupts of the same level are output simultaneously, an interrupt request with the smallest number takes precedence (see Table 6.2-1 "Interrupt Vectors").

#### • CPU operation (interrupt request acceptance and interrupt processing)

The CPU compares the received interrupt level (ICR: IL2 to IL0) and the interrupt level mask register (ILM). If IL2 to IL0 are greater than ILM and interrupts are enabled (PS: CCR: I = "1"), the CPU terminates the instruction being executed and performs the interrupt processing. If the  $EI^2OS$  enable bit (ISE) of the interrupt control register (ICR) is set to "0", the CPU performs the interrupt processing. If the ISE is set to "1", the CPU starts  $EI^2OS$  and then performs the interrupt processing.

Interrupt processing saves the contents of the dedicated registers (12 bytes including A, DPR, ADB, DTB, PCB, PC, and PS) on the system stack (the system stack space indicated by the SSB and SSP).

The CPU then loads data into the interrupt vector program counters (PCB and PC), updates the ILM, and sets the stack flag (S) (sets CCR: S = 1 and activates the system stack).

#### Returning from a Hardware Interrupt

If an interrupt processing program writes "0" to the interrupt request flag bit of a peripheral function (resource) that output an interrupt cause and the RETI instruction is executed, data saved on the system stack is restored to the dedicated registers and the program processing that was executed before branching due to an interrupt is resumed.

#### Hardware Interrupt Operation



Figure 6.4-2 Hardware Interrupt Operation

- IL : Interrupt level setting bit in the interrupt control register (ICR)
- PS : Processor status
- I : Interrupt enable flag
- ILM : Interrupt level mask register

IR : Instruction register

- 1. An interrupt cause is output within the peripheral functions (resources).
- 2. If the interrupt enable bit in the peripheral functions (resources) is set to enable interrupts, interrupt requests are output from the peripheral functions (resources) to the interrupt controller.
- 3. The interrupt controller that receives interrupt requests from the peripheral functions (resources) checks the priorities of interrupt requests simultaneously received and transfers the interrupt level (IL) of an interrupt request with the highest priority to the CPU.
- 4. The CPU compares the interrupt level (IL) requested by the interrupt controller with the interrupt level mask register (ILM).
- 5. If the comparison indicates a higher priority than the current interrupt processing level, the CPU checks the contents of the I flag in the condition code register (CCR).
- If, in the check, the I flag in the CCR is found to be set to Enabled (CCR: I = "1"), the CPU waits until the execution of an instruction being executed is terminated. When it is terminated, the CPU sets the requested level (IL2 to IL0) in the ILM.
- 7. The values in the dedicated registers are saved to the system stack. The processing branches to the interrupt processing routine.
- 8. If a program in the interrupt processing routine sets the interrupt request flag bit of a peripheral function (resource) to "0" and the RETI instruction is executed, data saved on the system stack is restored to the dedicated registers and the interrupt processing is terminated.

### 6.4.2 Processing for Interrupt Operation

When a peripheral function (resource) outputs an interrupt request and the CPU accepts it, the interrupt processing is performed after the instruction currently being executed is terminated. If the El<sup>2</sup>OS enable bit (ISE) of the interrupt control register (ICR) is set to "0", the CPU performs the interrupt processing. If the ISE is set to "1", the CPU activates the extended intelligent I/O service (El<sup>2</sup>OS). If a software interrupt is output by the INT instruction, the instruction currently being executed is suspended, the interrupt processing routine is performed, and hardware interrupts are disabled.

#### Processing for Interrupt Operation



Figure 6.4-3 Flow of Interrupt Processing

- \*1 When a string type instruction is being executed, the interrupt is evaluated in each step.
- : Interrupt enable flag of the condition code register (CCR) S
- IF : Interrupt request flag of the peripheral function
- IE : Interrupt enable flag of the peripheral function
- ILM : Interrupt level mask register (in the PS)
- ISE : EI2OS enable flag of the interrupt control register (ICR)
- IL : Interrupt level setting bit of the interrupt control register (ICR)
  - : Stack flag of the condition code register (CCR)
- PCB : Program bank register
- PC : Program counter:

### 6.4.3 **Procedure for Using Hardware Interrupts**

Before hardware interrupts can be used, the system stack area, peripheral function (resource), and interrupt control register (ICR) must be set.

#### Procedure for Using Hardware Interrupts



#### Figure 6.4-4 Procedure for Using Hardware Interrupts

- 1. Set the system stack area.
- 2. Set the operation of a peripheral function (resource).
- 3. Set the interrupt control register (ICR).
- 4. Set the interrupt enable bit of the peripheral function (resource) to enable the output of interrupt requests.
- 5. Set the interrupt level mask register (ILM) and interrupt enable flag (I) to interrupt acceptable.
- 6. If an interrupt request of the peripheral function (resource) is detected, a hardware interrupt request is output.
- 7. The interrupt processing hardware saves the dedicated register values to the system stack. The processing then branches to the interrupt processing program.

- 8. The interrupt processing program processes the peripheral function (resource) in response to the generated interrupt.
- 9. Clear the peripheral function (resource) interrupt request.
- 10.Execute the interrupt return instruction (RETI instruction), and return to the program before branching.

### 6.4.4 Multiple Interrupts

Multiple hardware interrupts can be implemented in response to multiple interrupt requests from peripheral functions (resources). However, multiple extended intelligent I/O services cannot be activated.

#### Multiple Interrupts

#### **O** Operation of multiple interrupts

If an interrupt request with an interrupt level that is higher than the one being executed is output, the current interrupt processing is suspended and the higher-priority interrupt request is executed. When the processing of the higher-priority interrupt ends, the previous interrupt processing resumes.

If, during execution of interrupt processing, an interrupt request with a level equal to or lower than the current interrupt processing is output, the new interrupt request is suspended until the current interrupt processing ends, unless the I flag of the condition code register (ICR) or the interrupt level mask register (ILM) is changed. When the current interrupt processing ends, the suspended interrupt request is executed.

Other multiple interrupts to be activated during an interrupt can be temporarily disabled by setting the I flag in the condition code register (CCR) in the interrupt processing routine to interrupts not allowed (CCR: I = 0) or the interrupt level mask register (ILM) to interrupts not allowed (ILM =  $000_B$ ).

#### Note:

- 0 to 7 can be set as the interrupt level. If level 7 is set, the CPU does not accept interrupt requests.
- The extended intelligent I/O service (EI<sup>2</sup>OS) cannot be used for the activation of multiple interrupts. During processing of the extended intelligent I/O service (EI<sup>2</sup>OS), all other interrupt requests and extended intelligent I/O service requests are held.

#### **O** Example of multiple interrupts

This example of multiple interrupt processing assumes that a timer interrupt is given a priority that is higher than an A/D converter interrupt. In this example, the A/D converter interrupt level is set to 2, and the timer interrupt level is set to 1. If a timer interrupt is generated during processing of the A/D converter interrupt, the processing shown in Figure 6.4-5 "Example of Multiple Interrupt" is performed.



#### Figure 6.4-5 Example of Multiple Interrupt

- At the start of A/D converter interrupt processing, the value in the interrupt level mask register (ILM) indicates the A/D converter interrupt level (ICR:IL2 to IL0) (2 in this example). If an interrupt request with level 1 or 0 is generated, the interrupt processing for level 1 or 0 takes precedence.
- When the interrupt processing ends and the return instruction (RETI) is executed, the values
  of the dedicated registers (A, DPR, ADB, DTB, PCB, PC, and PS) saved to the stack are
  restored and the interrupt mask register (ILM) is set back to the value that it had before the
  interruption.

### 6.4.5 Hardware Interrupt Processing Time

The time for completion of the currently executed instruction and the interrupt handling time apply from the output of a hardware interrupt request until the interrupt processing routine is executed.

#### Hardware Interrupt Processing Time

The interrupt request sampling wait time and the interrupt handling time (time required to prepare for interrupt processing) are required from the output of a hardware interrupt request until the interrupt processing routine is executed.



#### Figure 6.4-6 Interrupt Processing Time

The final instruction cycle samples the interrupt request here.

\* : One machine cycle corresponds to one machine clock (  $\phi$  ).

#### O Interrupt request sampling wait time

The interrupt request sampling wait time refers to the time required from the output of an interrupt request by a peripheral function (resource) until the instruction being executed terminates. The CPU checks through sampling whether an interrupt request is output in the final cycle of an instruction being executed. The interrupt request sampling wait time is required because no interrupt request can be recognized while an instruction is being executed.

#### **Reference:**

The maximum interrupt request sampling wait time applies when an interrupt request is output immediately after execution of the POPW RW0, ... RW7 instruction (45 machine cycles) with the longest execution cycle is started.

#### O Interrupt handling time (♦ machine cycle)

After accepting an interrupt request, the CPU saves the values of dedicated registers to the system stack and fetches the interrupt vector. The interrupt handling time is therefore required. Obtain the interrupt handling time by using the following equations:

When an interrupt starts to be processed:  $\phi = 24 + 6 \times Z$  machine cycles When control is returned from an interrupt:  $\phi = 11 + 6 \times Z$  machine cycles (RETI instruction)

The interrupt handling time varies depending on the address of the stack pointer.

| Address pointed to by the stack pointer | Interpolation value (Z) |
|-----------------------------------------|-------------------------|
| External 8-bit                          | +4                      |
| External even-numbered address          | +1                      |
| External odd-numbered address           | +4                      |
| Internal even-numbered address          | 0                       |
| Internal odd-numbered address           | +2                      |

#### **Reference:**

One machine cycle equals one clock cycle of the machine clock ( $\phi$ ).

### 6.5 Software Interrupts

When the software interrupt instruction is executed, control is transferred from the main program to the interrupt processing program. Hardware interrupts are disabled while the software interrupt instruction is being executed.

#### Software Interrupt Activation

#### **O** Software interrupt activation

The INT instruction is used to activate a software interrupt. A software interrupt does not have an interrupt request flag bit or enable flag like that of a hardware interrupt. Thus, an interrupt request is output whenever the INT instruction is executed.

#### **O** Hardware interrupt suppression

Since the INT instruction does not have interrupt levels, the interrupt level mask register (ILM) is not updated. During the execution of the INT instruction, the I flag of the condition code register (CCR) is set to 0, and hardware interrupts are masked.

To enable hardware interrupts during software interrupt processing, set the I flag of the condition code register (CCR) to "1" in the software interrupt processing routine.

#### **O** Software interrupt operation

When the CPU fetches the INT instruction, the software interrupt processing microcode is activated. This microcode saves the internal CPU registers on the system stack, masks hardware interrupts (CCR: I = 0), and branches to the corresponding interrupt vector.

#### **Reference:**

See Section 6.2 "Interrupt Causes and Interrupt Vectors", in CHAPTER 6 "INTERRUPTS" for more information about the allocation of interrupt numbers and interrupt vectors.

#### Returning from a Software Interrupt

In the interrupt processing program, when the interrupt return instruction (RETI instruction) is executed, the data saved to the system stack is restored to the dedicated registers and the processing that was being executed before branching for the interrupt is resumed.

#### Software Interrupt Operation

Figure 6.5-1 Software Interrupt Operation



- PS : Processor status
- I : Interrupt enable flag
- S : Stack flag
- IR : Instruction register
- 1. A software interrupt instruction is (INT instruction) executed.
- 2. The values of the dedicated registers are saved to the system stack. Hardware interrupts are masked. The processing branches to the interrupt vector.
- 3. The RETI instruction in the user interrupt processing routine terminates the interrupt processing.

#### Note:

When the program bank register (PCB) is "FF<sub>H</sub>", the vector area of the CALLV instruction overlaps the INT #vct8 instruction table. When you create software, watch for duplicated addresses of the CALLV and INT #vct8 instructions.

### 6.6 Interrupt of Extended Intelligent I/O Service (El<sup>2</sup>OS)

The extended intelligent I/O service (El<sup>2</sup>OS) automatically transfers data between a peripheral function (resource) and memory. When the data transfer terminates, a hardware interrupt is generated.

#### ■ Extended Intelligent I/O Service (El<sup>2</sup>OS)

The extended intelligent I/O service ( $EI^2OS$ ) is a type of hardware interrupt.  $EI^2OS$  transfers data between a peripheral function (resource) and memory. The user should create program to activate and terminate  $EI^2OS$  but need not create a data transfer program.

#### O Advantages of extended intelligent I/O service (El<sup>2</sup>OS)

Compared to data transfer performed by the interrupt processing routine, El<sup>2</sup>OS has the following advantages.

- Coding a transfer program is not necessary, reducing program size.
- Since transfer can be activated due to an interrupt cause of a peripheral function (resource), there is no need of polling for a data transfer cause.
- Incrementing of a transfer address can be selected.
- Incrementing or no update can be selected for the I/O register address.

#### O Extended intelligent I/O service (El<sup>2</sup>OS) termination interrupt

The processing branches to the interrupt processing routine when data transfer by EI<sup>2</sup>OS terminates.

An interrupt processing program can determine the EI<sup>2</sup>OS termination cause by checking the EI<sup>2</sup>OS status bits (S1 and S0) of the interrupt control register (ICR).

#### **Reference:**

Interrupt numbers and interrupt vectors are permanently set for each peripheral. See Section 6.2 "Interrupt Causes and Interrupt Vectors", in CHAPTER 6 "INTERRUPTS" for more information.

#### ○ Interrupt control register (ICR)

This register, which is located in the interrupt controller, activates El<sup>2</sup>OS, specifies the El<sup>2</sup>OS channel, and displays the El<sup>2</sup>OS termination status.

#### • Extended intelligent I/O service (El<sup>2</sup>OS) descriptor (ISD)

This descriptor, which is located in RAM at  $000100_H$  to  $00017F_H$ , is an eight-byte data that retains the transfer mode, resource address, transfer count, and buffer address. The descriptor handles 16 channels. The channel is specified by the interrupt control register (ICR).

#### Note:

When the extended intelligent I/O service ( $EI^2OS$ ) is operating, execution of the CPU program stops.

#### Operation of the Extended Intelligent I/O Service (El<sup>2</sup>OS)

Figure 6.6-1 Extended Intelligent I/O Service (El<sup>2</sup>OS) Operation



- ISD : EI2OS OS descriptor I/OA: I/O address pointer
- BAP: Buffer address pointer
- ICS : EI<sup>2</sup>OS channel setting bit in the interrupt control register (ICR)
- DCT: Data counter
- 1. A peripheral function (resource) outputs an interrupt request.
- 2. The interrupt controller selects the EI<sup>2</sup>OS descriptor in accordance with the setting in the interrupt control register (ICR).
- 3. The transfer source and transfer destination are read from the descriptor.
- 4. Transfer is performed between resource and memory.
- 5. After data transfer is completed, the interrupt request flag bit of the peripheral function (resource) is cleared to "0".

## 6.6.1 Extended Intelligent I/O Service (El<sup>2</sup>OS) Descriptor (ISD)

The extended intelligent I/O service (EI<sup>2</sup>OS) descriptor (ISD) resides in internal RAM at  $000100_{\rm H}$  to  $00017F_{\rm H}$ . The ISD consists of 8 bytes x 16 channels.

■ Configuration of the Extended Intelligent I/O Service (El<sup>2</sup>OS) Descriptor (ISD)

The ISD consists of 8 bytes x 16 channels.



Figure 6.6-2 Configuration of El<sup>2</sup>OS Descriptor (ISD)

MSB : Most significant bit

LSB : Least significant bit

### **CHAPTER 6 INTERRUPTS**

| Channel | Descriptor 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      | 000158 <sub>H</sub> |
| 12      | 000160 <sub>H</sub> |
| 13      | 000168 <sub>H</sub> |
| 14      | 000170 <sub>H</sub> |
| 15      | 000178 <sub>H</sub> |

### Table 6.6-1 El<sup>2</sup>OS descriptor area

# 6.6.2 Registers of the Extended Intelligent I/O Service (El<sup>2</sup>OS) Descriptor (ISD)

The extended intelligent I/O service (El<sup>2</sup>OS) descriptor (ISD) consists of the following registers, which account for a total of eight bytes:

- Data counter (DCT: 2 bytes)
- I/O register address pointer (I/OA: 2 bytes)
- El<sup>2</sup>OS status register (ISCS: 1 byte)
- Buffer address pointer (BAP: 3 bytes)

The initial values of these registers are undefined.

### ■ Data Counter (DCT)

The DCT is a 16-bit register in which a transfer data byte count can be set. Every time one byte of data is transferred, the counter is decremented by one.  $EI^2OS$  terminates when the data counter reaches "0000<sub>H</sub>".

### Figure 6.6-3 Configuration of DCT



R/W: Read-write X : Undefined

■ I/O Register Address Pointer (IOA)

The IOA is a 16-bit register that indicates the lower address (A15 to A0) of the I/O register used to transfer data to and from the buffer. The upper address (A23 to A16) is  $00_{\text{H}}$ . Any I/O from  $0000_{\text{H}}$  to FFFF<sub>H</sub> can be specified by address.



|     |     |     |     | I/C | DAH |     |     |     |     |     |     | I/C | DAL |     |     |     |                                         |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----------------------------------------|
| Bit | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8 \ | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0 \ | Initial value                           |
| IOA | A15 | A14 | A13 | A12 | A11 | A10 | A09 | A08 | A07 | A06 | A05 | A04 | A03 | A02 | A01 | A00 | XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX |
|     | R/W |                                         |

R/W: Read-write

### Extended Intelligent I/O Service (El<sup>2</sup>OS) Status Register (ISCS)

The ISCS is an 8-bit register. The ISCS indicates the update/fixed for the buffer address pointer and I/O register address pointer, transfer data format (byte or word), and transfer direction.



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

R/W : Read-write

X : Undefined

- \*1 : Only the lower 16 bits of the buffer address pointer change. The buffer address pointer can only be incremented.
- \*2 : The address pointer can only be incremented.

### Buffer Address Pointer (BAP)

The buffer address pointer (BAP) is a 24-bit register in which a memory address of the data transfer source can be set in the El<sup>2</sup>OS operation. Data can be transferred between a 16M-byte memory address and a peripheral function (resource) address because a BAP exists in every channel of El<sup>2</sup>OS. If the BAP update/fixed selection bit (BF) of the El<sup>2</sup>OS status register (ISCS) is set to "0", only the lower 16 bits (BAPM and BAPL) are incremented and the upper 8 bits (BAPH) are not incremented.

### Figure 6.6-6 Configuration of Buffer Address Pointer (BAP)



R/W : Read-write

X : Undefined

#### Note:

- The maximum transfer count that can be specified by the data counter (DCT) is 65,536 (64 K bytes).
- The area that can be specified by the I/O address pointer (IOA) extends from  $000000_{\rm H}$  to  $00FFFF_{\rm H}$ .
- The area that can be specified with the buffer address pointer (BAP) extends from 000000<sub>H</sub> to FFFFF<sub>H</sub>.

## 6.6.3 Operation of the Extended Intelligent I/O Service (El<sup>2</sup>OS)

The CPU uses  $EI^2OS$  to transfer data if a peripheral function (resource) outputs an interrupt request while the corresponding interrupt control register (ICR) is set to enable the activation of  $EI^2OS$ . When the  $EI^2OS$  processing terminates, the hardware interrupt processing is performed.

### Operation Flow of the Extended Intelligent I/O Service (El<sup>2</sup>OS)

Figure 6.6-7 Flow of Extended Intelligent I/O Service (El<sup>2</sup>OS) Operation



# 6.6.4 Procedure for Using the Extended Intelligent I/O Service (El<sup>2</sup>OS)

Before the extended intelligent I/O service (EI<sup>2</sup>OS) can be used, the system stack area, extended intelligent I/O service (EI<sup>2</sup>OS) descriptor, peripheral function (resource), and interrupt control register (ICR) must be set.

Procedure for Using the Extended Intelligent I/O Service (El<sup>2</sup>OS)





ISE : El<sup>2</sup>OS enable bit in the interrupt control register (ICR)

S1, S0 : El<sup>2</sup>OS status of the interrupt control register (ICR)

# 6.6.5 Processing Time of the Extended Intelligent I/O Service (EI<sup>2</sup>OS)

The time required to process the extended intelligent I/O service (El<sup>2</sup>OS) varies with the settings for the El<sup>2</sup>OS descriptor (ISD):

- Setting in the El<sup>2</sup>OS status register (ISCS)
- Address pointed to by the I/O register address pointer (I/OA)
- Address pointed to by the buffer address pointer (BAP)
- External data bus length for external access
- Transfer data length

Because the hardware interrupt is activated when data transfer by El<sup>2</sup>OS terminates, the interrupt handling time is added.

### ■ Processing Time (one transfer time) of the Extended Intelligent I/O Service (El<sup>2</sup>OS)

### O When data transfer continues

The EI<sup>2</sup>OS processing time for data transfer continuation is shown in Table 6.6-2 "Extended Intelligent I/O Service Execution Time" based on the EI<sup>2</sup>OS status register (ISCS) setting.

| Table 6.6-2 Extended | Intelligent I/O Service Execution Time |
|----------------------|----------------------------------------|
|----------------------|----------------------------------------|

| EI <sup>2</sup> OS termination control bit (SE | termination | es due to<br>request from<br>ipherall | Ignores termination<br>request from the<br>peripheral |       |        |
|------------------------------------------------|-------------|---------------------------------------|-------------------------------------------------------|-------|--------|
| I/OA update/fixed selection bit (If            | -) setting  | Fixed                                 | Update                                                | Fixed | Update |
| BAP address update/fixed selection             | Fixed       | 32                                    | 34                                                    | 33    | 35     |
| bit (BF) setting                               | Update      | 34                                    | 36                                                    | 35    | 37     |

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

As shown in Table 6.3-3 "Correspondence between the EI<sup>2</sup>OS Channel Selection Bits and Descriptor Addresses", interpolation is necessary depending on the El<sup>2</sup>OS execution condition.

| I/O register address pointer |          |        | Internal | access | Externa | access |
|------------------------------|----------|--------|----------|--------|---------|--------|
|                              |          |        | B/Even   | Odd    | B/Even  | 8/Odd  |
| Buffer                       | Internal | B/Even | 0        | +2     | +1      | +4     |
| address<br>pointer           | access   | Odd    | +2       | +4     | +3      | +6     |
|                              | External | B/Even | +1       | +3     | +2      | +5     |
|                              | access   | 8/Odd  | +4       | +6     | +5      | +8     |

 Table 6.6-3 Data Transfer Interpolation Value for El<sup>2</sup>OS Execution Time

B: Byte data transfer

8: External bus using the 8-bit word transfer Even: Even-numbered address word transfer

Odd: Odd-numbered address word transfer

### O When the data counter (DCT) count terminates (final data transfer)

Interrupt handling time is added because the hardware interrupt is activated when data transfer by EI<sup>2</sup>OS terminates. The EI<sup>2</sup>OS processing time when counting terminates is calculated by using the equation below. Z in this equation is a correction value for the interrupt handling time.



The interrupt handling time is different for each address pointed to by the stack pointer.

 Table 6.6-4 Interpolation Value (Z) for the Interrupt Handling Time

| Address pointed to by the stack pointer | Interpolation value (Z) |  |  |  |  |
|-----------------------------------------|-------------------------|--|--|--|--|
| External 8-bit                          | +4                      |  |  |  |  |
| External even-numbered address          | +1                      |  |  |  |  |
| External odd-numbered address           | +4                      |  |  |  |  |
| Internal even-numbered address          | 0                       |  |  |  |  |
| Internal odd-numbered address           | +2                      |  |  |  |  |

### **O** For termination by a termination request from the peripheral function (resource)

When data transfer by  $EI^2OS$  is terminated before completion due to a termination request from the peripheral function (resource) (ICR: S1, S0 = 11<sub>B</sub>), the data transfer is not performed and a hardware interrupt is activated. The  $EI^2OS$  processing time is calculated with the following formula. Z in the formula indicates the interpolation value for the interrupt handling time (Table 6.6-4 "Interpolation Value (Z) for the Interrupt Handling Time").

 $EI^{2}OS$  processing time for termination before completion = 36 + 6 x Z) machine cycles

One machine cycle corresponds to one clock cycle of the machine clock ( $\phi$ ).

### 6.7 Exception Processing Interrupt

In the MB90M405 series, exception processing occurs if an undefined instruction is executed. Exception processing is basically the same as an interrupt. When an exception occurs between instructions, program processing is interrupted and the processing branches to the exception processing routine.

Exception processing, occurring due to an unexpected operation, can be used to execute an undefined instruction and detect a CPU runaway status during debugging.

### Exception Processing

### **O** Exception processing operation

In the MB90M405 series, the processing branches to the exception processing routine if an instruction undefined in the instruction map is executed.

The following processing is executed before exception processing branches to the interrupt routine:

- The A, DPR, ADB, DTB, PCB, PC, and PS registers are saved to the system stack.
- The I flag of the condition code register (CCR) is cleared to 0, and hardware interrupts are masked.
- The S flag of the condition code register (CCR) is set to 1, and the system stack is activated

The program counter (PC) value saved to the stack is the exact address where the undefined instruction is stored. For 2-byte or longer instruction codes, the code identified as undefined is stored at this address. When the exception factor type must be determined within the exception processing routine, use this PC value.

### **O** Return from exception processing

If the RETI instruction is used to return control from exception processing, a branch to the exception processing routine occurs again because the PC is pointing to an undefined instruction. Use a software reset or input the "L" level from the RST pin (an external reset).

### 6.8 Stack Operations for Interrupt Processing

Once an interrupt is accepted, the contents of the dedicated registers are saved to the system stack before a branch to interrupt processing. Execute the interrupt return instruction after the interrupt processing terminates to restore the values saved on the system stack to the dedicated registers.

### Stack Operations at the Start of Interrupt Processing

Once an interrupt is accepted, the CPU saves the contents of the current dedicated registers to the system stack in the order given below:

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

### Figure 6.8-1 Stack Operations at the Start of Interrupt Processing



### Stack Operations on Return from Interrupt Processing

When the interrupt return instruction (RETI) is executed at the termination of interrupt processing, the PS, PC, PCB, DTB, ADB, DPR, and A values are returned from the stack in reverse order from the order they were placed on the stack. The dedicated registers are restored to the status they had immediately before the start of interrupt processing.

#### **O** Stack area allocation

The stack area is used for saving and restoring the program counter (PC) when the subroutine call instruction (CALL) and vector call instruction (CALLV) are executed in addition to interrupt processing. The stack area is used for temporary saving and restoring of registers by the PUSHW and POPW instructions.

The stack area is allocated together with the data area in RAM.



### Figure 6.8-2 Stack Area

- \*1 The internal ROM is different for each model.
- \*2 The internal RAM is different for each model.

#### Note:

- Generally set an even-numbered address in the stack pointers (SSP and USP). If an oddnumbered address is set, one extra cycle is required to save data to, and restore data from the stack.
- Allocate the system stack area, user stack area, and data area so that they do not overlap.

#### **O** System stack and user stack

The system stack area is used for interrupt processing. When an interrupt is output, the user area being used is switched to the system stack. Use only the system stack unless the stack space needs to be divided in particular.

## 6.9 Sample Programs for Interrupt Processing

This section contains sample programs for interrupt processing.

### ■ Sample Programs for Interrupt Processing

### **O** Processing specifications

The following is a sample program for an interrupt that uses external interrupt 0 (INT0).

### O Sample coding

```
EQU000011H;Port 1 direction registerEQU000028H;DTP/interrupt permission registerEQU000029H;DTP/interrupt cause registerEQU00002AH;Request level setting registerEQU0000B0H;Interrupt control register 00
DDR1
ENIR
EIRR
ELVR
ICR00 EOU 0000B0H
STACK SSEG
                            ;Stack
       RW 100
STACK_T RW
              1
      ENDS
STACK
;----- Main program -----
CODE
        CSEG
START:
        MOV
              RP,#0
                              General-purpose registers use the first bank.
       MOV ILM, #07H
                              ;Sets ILM in PS to level 7.
             A, #!STACK_T
        MOV
                              ;Sets system stack.
        MOV
             SSB, A
       MOVW A, #STACK_T
MOVW SP, A
                              ;Sets stack pointer, then
                              ;Sets SSP because S flag = 1.
             DDR1, #0000000B ;Sets P10/INTO pin to input.
        MOV
             CCR, #040H;Sets I flag of CCR in PS, enables interrupts.I:ICR00, #00H;Sets interrupt level to 0 (highest priority).
        OR
        MOV
        MOV
             I:ELVR, #00000001B ;Requests that INTO be made level H.
              I:EIRR, #00H ;Clears INTO interrupt cause.
        MOV
             I:ENIR, #01H
                              ;Enables INTO input.
        MOV
LOOP:
        NOP
                               ;Dummy loop
        NOP
        NOP
        NOP
       BRA
            LOOP
                              ;Unconditional jump
-----Interrupt program ------
ED_INT1:
        MOV
              I:EIRR, #00H ;Acceptance of new INTO not allowed
        NOP
        NOP
        NOP
        NOP
        NOP
        NOP
       RETI
                            ;Return from interrupt
       ENDS
CODE
;-----Vector setting------
VECT CSEG ABS=0FFH
        ORG
              OFFDH
                           ;Sets vector for interrupt #11 (OBH).
        DSL
              ED_INT1
        ORG
             OFFDCH
                           ;Sets reset vector.
        DSL
             START
              00H
                           ;Sets single-chip mode.
        DB
VECT
        ENDS
        END START
```

### ■ Processing Specifications of Sample Program for Extended Intelligent I/O Service (El<sup>2</sup>OS)

### **O** Processing Specifications

- This program detects the H level signal input to the INT0 pin and activates the extended intelligent I/O service (EI<sup>2</sup>OS).
- When the H level is input to the INT0 pin, El<sup>2</sup>OS is activated. Data is transferred from port 0 to the memory at the 3000<sub>H</sub> address.
- The number of transfer data bytes is 100 bytes. After 100 bytes are transferred, an interrupt is generated because El<sup>2</sup>OS transfer has terminated.

### **O** Sample coding

| DDR1    | EQU  | 000011H ; P      | Port 1-direction register                                                                  |
|---------|------|------------------|--------------------------------------------------------------------------------------------|
| ENIR    | EQU  |                  | TP/interrupt permission register                                                           |
| EIRR    | EQU  |                  | TP/interrupt cause register                                                                |
| ELVR    | EQU  |                  | equest level setting register                                                              |
| ICR00   | EQU  |                  | interrupt control register 00                                                              |
| BAPL    | EQU  |                  | ower buffer address pointer                                                                |
| BAPM    | EQU  |                  | liddle buffer address pointer                                                              |
| BAPH    | EQU  |                  | pper buffer address pointer                                                                |
| ISCS    | EQU  |                  | H <sup>2</sup> OS status                                                                   |
| I/OAL   | EQU  |                  | ower I/O address pointer                                                                   |
| I/OAH   | EQU  |                  | pper I/O address pointer                                                                   |
| DCTL    | EQU  |                  | ow-order data counter                                                                      |
| DCTH    | EOU  | 000107н ;н       | ligh-order data counter                                                                    |
| ER0     | EQU  | EIRR:0 ;D        | Definition of external interrupt request flag bit                                          |
| STACK   | SSEG |                  | tack                                                                                       |
|         | RW   | 100              |                                                                                            |
| STACK_T | RW   | 1                |                                                                                            |
| STACK   | ENDS |                  |                                                                                            |
| ;       |      | Main program     | n                                                                                          |
| CODE    | CSEG |                  |                                                                                            |
| START:  |      |                  |                                                                                            |
|         | AND  | CCR, #0BFH       | ;Clears the I flag of the CCR in the PS and                                                |
|         |      |                  | ;prohibits interrupts.                                                                     |
|         | MOV  | 1                | ;Sets the register bank pointer.                                                           |
|         |      | A, #!STACK_T     | ;Sets the system stack.                                                                    |
|         | MOV  | SSB, A           |                                                                                            |
|         | MOVW | A, #STACK_T      | ;Sets the stack pointer, then                                                              |
|         | MOVW | SP, A            | ;Sets SSP because the S flag = 1.                                                          |
|         | MOV  |                  | 3 ;Sets the P10/INTO pin to input.                                                         |
|         | MOV  | BAPL, #00H       | ;Sets the buffer address (003000H).                                                        |
|         | MOV  | BAPM, #30H       |                                                                                            |
|         | MOV  | BAPH, #00H       |                                                                                            |
|         | MOV  | ISCS, #00010001B | ;No I/O address update, byte transfer, buffer<br>;address updated, I/O -> buffer transfer, |
|         |      |                  | iterminated by the peripheral function.                                                    |
|         | MOV  | IOAL, #00H       | Sets the transfer source address                                                           |
|         |      | ,                | ;(port 0:000000H).                                                                         |
|         | MOV  | IOAH, #00H       | •                                                                                          |
|         | MOV  | DCTL, #64H       | ;Sets the number of transfer bytes (100 bytes).                                            |
|         | MOV  | DCTH, #00H       | · · · · · ·                                                                                |
|         |      | •                |                                                                                            |

MOV I:ICR00,#00001000B ;EI<sup>2</sup>OS channel 0, EI<sup>2</sup>OS enable, interrupt level 0 ;(highest priority) MOV I:ELVR, #00000001B ;Requests that INTO be made H level. MOV I:EIRR, #00H ;Clears the INTO interrupt cause. MOV I:ENIR, #01H ;Enables INTO interrupts. MOV ILM, #07H ;Sets the ILM in the PS to level 7. ;Sets the I flag of the CCR in the PS and OR CCR, #040H ;enables interrupts. : LOOP BRA LOOP ;Infinite loop ;-----Interrupt program-----WARI CLRB ERO ;Clears interrupt/DTP request flag. : User processing ;Checks EI<sup>2</sup>OS termination factor, ;processes data in buffer, sets EI<sup>2</sup>OS again. : RETI CODE ENDS ;-----Vector processing-----VECT CSEG ABS=0FFH ORG 0FFD0H ;Sets vector for interrupt #11 (OBH). DSL WARI ORG 0FFDCH ;Sets reset vector. DSL START DB 00H ;Sets single-chip mode. ENDS VECT END START

### **CHAPTER 6 INTERRUPTS**

# CHAPTER 7 SETTING A MODE

This chapter describes the operating modes and the memory access modes of the MB90M405 series.

- 7.1 "Setting a Mode"
- 7.2 "Mode Pins (MD2 to MD0)"
- 7.3 "Mode Data"

### 7.1 Setting a Mode

Set the mode pin level used after a reset and the mode data in the mode register to determine the operating mode.

### Mode Setting



#### Operating Modes

An operating mode can be specified by the mode pins (MD2 to MD0) and the bus mode setting bits (M1 and M0) of the mode data registers. The microcontroller performs an ordinary start of operation and writes to FLASH memory in the specified operating mode.

#### Note:

Set single-chip mode for the MB90M405 series.

To set single-chip mode, set the MD2 to MD0 pins to " $011_B$ " and the M1 and M0 bits of the mode data register to " $00_B$ ", respectively.

#### Bus Mode

The bus mode varies depending on whether the memory into which the reset vector should be read is internal or external. Set the MD2 to MD0 pins and the M1 and M0 bits of the mode data register to specify a bus mode. Set the MD2 to MD0 pins to determine a bus mode in which a reset vector and mode data should be read. Additionally, set the M1 and M0 bits of the mode data register to specify a bus mode.

#### **Reference:**

The term RUN mode refers to the current mode in which the CPU operates. RUN modes include main clock mode, in which the CPU operates based on the main clock; PLL clock mode, in which the CPU operates based on the PLL clock; and low power consumption mode. For more information, see Chapter 5 "Low Power Consumption Mode".

#### Note:

For the MB90M405 series, specify single-chip mode.

To specify single-chip mode, set the MD2 to MD0 pins to  $011_B$  and the bus mode setting bits (M1 and M0) of the mode data register to  $00_B$ .

### 7.2 Mode Pins (MD2 to MD0)

Three external pins, MD2 to MD0, are supported as the mode pins. These are used to specify how the reset vector and mode data are fetched.

### ■ Mode Pins (MD2 to MD0)

Use the mode pins to specify whether a reset vector should be read from external or internal memory. Use the mode data register to specify the external data bus width if a reset vector should be read from external memory.

For a built-in flash memory type, use the mode pins to specify the flash memory write mode in which a program should be written to the built-in flash memory.

Table 7.2-1 Mode Pin Settings

| MD2 | MD2 | MD0 | Mode name                       | Reset vector<br>access area | External data<br>bus width                | Remarks                                                                              |  |  |  |  |  |
|-----|-----|-----|---------------------------------|-----------------------------|-------------------------------------------|--------------------------------------------------------------------------------------|--|--|--|--|--|
| 0   | 0   | 0   |                                 |                             |                                           |                                                                                      |  |  |  |  |  |
| 0   | 0   | 1   |                                 | Setting not                 | t allowed                                 |                                                                                      |  |  |  |  |  |
| 0   | 1   | 0   |                                 |                             |                                           |                                                                                      |  |  |  |  |  |
| 0   | 1   | 1   | Internal vector<br>mode         | Internal memory             | Specified in the<br>mode data<br>register | The reset sequence<br>and subsequent<br>sequences are<br>controlled by mode<br>data. |  |  |  |  |  |
| 1   | 0   | 0   |                                 | Setting not                 | t allowed                                 |                                                                                      |  |  |  |  |  |
| 1   | 0   | 1   |                                 |                             |                                           |                                                                                      |  |  |  |  |  |
| 1   | 1   | 0   | Flash serial write<br>mode (*1) | -                           | -                                         | -                                                                                    |  |  |  |  |  |
| 1   | 1   | 1   | Flash memory<br>mode            | -                           | -                                         | -                                                                                    |  |  |  |  |  |

MD2 to MD0: Connect the pins to  $V_{SS}$  for 0 and to  $V_{CC}$  for 1.

\*1: The flash memory serial write cannot be executed just by setting the mode terminal. The settings for other pins must be made as well. For more information, see "Example of a Serial Write Connection".

### Note:

For the MB90M405 series, specify single-chip mode.

To specify single-chip mode, set the MD2 to MD0 pins to  $011_B$  and the bus mode setting bits (M1 and M0) of the mode data register to  $00_B$ .

### 7.3 Mode Data

The mode data register is at memory location  $FFFDF_{H_{,}}$  and is used to specify the operation after a reset sequence.

### Mode Data

The mode data at address "FFFDF<sub>H</sub>" can be fetched to the mode data register while a reset sequence is being executed. The contents of the mode data register can be changed while a reset sequence is being executed. They cannot be changed using an instruction. The mode data setting takes effect after a reset sequence.





### Bus Mode Setting Bits

The bus mode setting bits specify operating mode after a reset sequence.

| Table 7.3-1 | Bus Mode Setting | g Bits and Functions |
|-------------|------------------|----------------------|
|-------------|------------------|----------------------|

| M1 | MO | Function              | Remarks                  |
|----|----|-----------------------|--------------------------|
| 0  | 0  | Single-chip mode      | Described in this manual |
| 0  | 1  |                       |                          |
| 1  | 0  | (Setting not allowed) | -                        |
| 1  | 1  |                       |                          |



Figure 7.3-2 Memory Map in Single-Chip Mode

Note: "#x for each model" is an address that depends on the model. For more information, see the memory map.

### Relationship between Mode Pins and Mode Data

| Table 7.3-2 Relationship between Access Areas and Physical Addresses in Single-chip |  |
|-------------------------------------------------------------------------------------|--|
| Mode                                                                                |  |

| Mode             | MD2 | MD1 | MD0 | M1 | MO |
|------------------|-----|-----|-----|----|----|
| Single-chip mode | 0   | 1   | 1   | 0  | 0  |

Note:

For the MB90M405 series, specify single-chip mode.

To specify single-chip mode, set the MD2 to MD0 pins to  $011_B$  and the bus mode setting bits (M1 and M0) of the mode data register to  $00_B$ .

### CHAPTER 7 SETTING A MODE

# CHAPTER 8 I/O PORTS

This chapter describes the functions and operations of the MB90M405 series I/O ports.

- 8.1 "Overview of I/O Ports"
- 8.2 "I/O Port Registers"
- 8.3 "Port 8"
- 8.4 "Port 9"
- 8.5 "Port A"
- 8.6 "Port B"
- 8.7 "Sample I/O Port Program"

### 8.1 Overview of I/O Ports

A maximum of 26 I/O ports (parallel I/O ports) are available. These ports can also be used as resource I/O pins (I/O pins of peripheral functions).

### ■ I/O Port Function

I/O ports include port direction registers (DDR) and port data registers (PDR). Each bit in the DDR specifies input or output for a port pin. The PDR specifies the output data for a port pin. If the DDR sets an I/O port pin to input, the level value of the port pin is made ready by reading the PDR. If the DDR sets an I/O port pin to output, the value of the PDR is output to the port pin. The following lists the resources that are also used to function as I/O ports:

- Port 8: Used as an I/O port and also as resource pins (external interrupt input pin, ICU, and UART)
- Port 9: Used as an I/O port and also as resource pins (I<sup>2</sup>C and serial I/O ch3)
- Port A: Used as an I/O port and also as resource pins (A/D converter and timing clock output)
- Port B: Used as an I/O port and also as resource pins (A/D converter, serial I/O ch2, external interrupt input pin, and reload timer ch0)

| I/O<br>port | Pin                                  | Input form           | Output<br>form    | Function |      |       |      |      |      |      |      |      |
|-------------|--------------------------------------|----------------------|-------------------|----------|------|-------|------|------|------|------|------|------|
|             |                                      |                      |                   | I/O port | P87  | P86   | P85  | P84  | P83  | P82  | P81  | P80  |
| Port 8      | Port 8 P80 to P87                    |                      | CMOS              | Resource | SO1  | SC1   | SI1  | SO0  | SC0  | SIO  | IC1  | IC0  |
|             |                                      |                      |                   | Resource | 001  | 301   | 51   | 300  | 500  | 310  | INT1 | INT0 |
|             |                                      | CMOS<br>(hysteresis) |                   | I/O port | -    | -     | -    | -    | -    | -    | P91  | P90  |
| Port 9      | Port 9 P90/SDA/SO3<br>to P91/SCL/SC3 |                      | Nch open<br>drain | Resource | -    | -     | -    | -    | -    | -    | SCL  | SDA  |
|             |                                      |                      |                   |          |      |       |      |      |      |      | SC3  | SO3  |
|             |                                      |                      |                   | I/O port | PA7  | PA6   | PA5  | PA4  | PA3  | PA2  | PA1  | PA0  |
| Port A      | PA0/AN0/TMCK<br>to PA7/AN7           |                      |                   | Resource | AN7  | AN6   | AN5  | AN4  | AN3  | AN2  | AN1  | AN0  |
|             |                                      |                      |                   | Resource |      |       |      |      |      |      |      | TMCK |
|             |                                      |                      | CMOS              | I/O port | PB7  | PB6   | PB5  | PB4  | PB3  | PB2  | PB1  | PB0  |
| Port B      | PB0/AN8 to                           |                      |                   |          | AN15 | AN14  | AN13 | AN12 | AN11 | AN10 | AN9  | AN8  |
| TOILD       | PB7/AN15/INT3                        |                      |                   | Resource | INT3 | INT2  | SO2  | SC2  | SI2  | _    |      | _    |
|             |                                      |                      |                   |          |      | 11112 | то   | TIN  | 512  |      | _    | _    |

Table 8.1-1 Functions of Each Port

### Note:

Ports A and B are also used as analog input pins. When using them as I/O ports, set port A and port B direction registers (DDRA and DDRB), the data registers (PDRA and PDRB), and analog input enable registers 0 and 1 (ADER0 and ADER1) to  $00_{\text{H}}$ . A reset initializes analog input enable registers 0 and 1 (ADER0 and ADER1) to  $FF_{\text{H}}$ .

### ■ Operation of an I/O Port Also Used for Resources When DDR Is Set to Port Output

| Resource operation<br>enable/disable setting    | Resource operation enabled      | Resource operation disabled    |
|-------------------------------------------------|---------------------------------|--------------------------------|
| Pin status of a port also<br>used for resources | Dependent on resource operation | Output of value set in the PDR |

# Figure 8.1-1 Pin Status of a Port Also Used for Resources When Resource Operation is Enabled or Disabled

### 8.2 I/O Port Registers

This section lists the registers related to I/O port settings.

### ■ I/O Port Registers

### Table 8.2-1 Port Registers

| Register                               | Read/Write | Address             | Initial value         |
|----------------------------------------|------------|---------------------|-----------------------|
| Port 8 data register (PDR8)            | R/W        | 000008 <sub>H</sub> | XXXXXXXX <sub>B</sub> |
| Port 9 data register (PDR9)            | R/W        | 000009 <sub>H</sub> | XXXXXXXXB             |
| Port A data register (PDRA)            | R/W        | 00000A <sub>H</sub> | XXXXXXXX <sub>B</sub> |
| Port B data register (PDRB)            | R/W        | 00000B <sub>H</sub> | XXXXXXXX <sub>B</sub> |
| Port 8 direction register (DDR8)       | R/W        | 000018 <sub>H</sub> | 00000000 <sub>B</sub> |
| Port 9 direction register (DDR9)       | R/W        | 000019 <sub>H</sub> | XXXXXX00 <sub>B</sub> |
| Port A direction register (DDRA)       | R/W        | 00001A <sub>H</sub> | 00000000 <sub>B</sub> |
| Port B direction register (DDRB)       | R/W        | 00001B <sub>H</sub> | 00000000 <sub>B</sub> |
| Analog input enable register 0 (ADER0) | R/W        | 00001E <sub>H</sub> | 11111111 <sub>B</sub> |
| Analog input enable register 1 (ADER1) | R/W        | 00001F <sub>H</sub> | 11111111 <sub>B</sub> |

R/W: Read/write enabled X: Undefined

-: Unused

### Notes:

- If an RMW instruction is executed for a port data register (PDR) in port input mode, the pin level is read when a READ instruction is executed. Note that the bit value used for the same type of input port other than the one subject to bit operations may be changed.
- If an RMW instruction is executed for a port data register (PDR) that is also used for resources in resource operation mode, the pin level is read for a pin that operates as a resource pin when a READ instruction is executed. Note that the bit value used for the same type of input port other than the one subject to bit operations may be changed.

### Table 8.2-2 What Is Read by READ after RMW Instruction Executed for a PDR

|                                           | Resource operation<br>enabled | Resource operation<br>disabled |
|-------------------------------------------|-------------------------------|--------------------------------|
| Port input mode (DDR = 00 <sub>H</sub> )  | Pin level                     | Pin level                      |
| Port output mode (DDR = FF <sub>H</sub> ) | Pin level                     | PDR value                      |

| Resource operation<br>enable/disable setting    | Resource operation enabled      | Resource operation disabled                                                                              |
|-------------------------------------------------|---------------------------------|----------------------------------------------------------------------------------------------------------|
| Pin status of a port<br>also used for resources | Dependent on resource operation | Input mode (DDR = 00 <sub>H</sub> ) : Hi-z<br>Output mode (DDR = FF <sub>H</sub> ) : A changed PDR value |
| RMW instruction<br>execution timing for PDRA    | Execution of RM                 | is output.                                                                                               |

| PDRA value | Previous data | $\lambda$ Changes depending on the pin level when an RMW instruction is executed |
|------------|---------------|----------------------------------------------------------------------------------|
|------------|---------------|----------------------------------------------------------------------------------|

### 8.3 Port 8

Port 8 is an I/O port. This section describes the configuration and registers of Port 8 and provides a block diagram of the pins.

### Port 8 Configuration

Port 8 consists of the following:

- I/O port pins/resource I/O pins (P80, IC0, INT0 to P87, and SO1)
- Port 8 data register (PDR8)
- Port 8 direction register (DDR8)

### Port 8 Pins

### Table 8.3-1 Port 8 Pins

| Port   | Pin              | Port | Port function |      | Resource function                 | I/O for | Circuit |      |
|--------|------------------|------|---------------|------|-----------------------------------|---------|---------|------|
| name   | name             | FOIL | Iunction      |      |                                   | Input   | Output  | type |
|        | P80/IC0/<br>INT0 | P80  |               | IC0  | Trigger input for input capture 0 |         |         |      |
|        |                  |      |               | INT0 | External interrupt 0              |         | смоз    | E    |
|        | P81/IC1/<br>INT1 | P81  |               | IC1  | Trigger input for input capture 1 |         |         |      |
|        |                  |      | 1/0           | INT1 | External interrupt 1              | CMOS    |         |      |
| Port 8 | P82/SI0          | P82  | I/O<br>port   | SI0  | Serial data input 0               |         |         |      |
|        | P83/SC0          | P83  |               | SC0  | Serial clock I/O 0                |         |         |      |
|        | P84/SO0          | P84  |               | SO0  | Serial data output 0              |         |         |      |
|        | P85/SI1          | P85  |               | SI1  | Serial data input 1               |         |         |      |
|        | P86/SC1          | P86  | P86           |      | Serial clock I/O 1                |         |         |      |
|        | P87/SO1          | P87  |               | SO1  | Serial data output 1              |         |         |      |

### Note:

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



Figure 8.3-1 Block Diagram of the Port 8 Pins

### Port 8 Registers

The Port 8 registers are the Port 8 data register (PDR8) and the Port 8 direction register (DDR8). The bits of each register correspond to the Port 8 pins on a one-to-one basis.

Table 8.3-2 Port 8 Pins and Corresponding Register Bits

| Port name |                   | Register bits and corresponding port pins |      |      |      |      |      |      |      |  |  |
|-----------|-------------------|-------------------------------------------|------|------|------|------|------|------|------|--|--|
| Port 9    | PDR8, DDR8        | bit7                                      | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |  |  |
| Port 8    | Corresponding pin | P87                                       | P86  | P85  | P84  | P83  | P82  | P81  | P80  |  |  |

### 8.3.1 Port 8 Registers (PDR8 and DDR8)

### This section describes the Port 8 registers.

### ■ Functions of the Port 8 Registers

### • Port 8 data register (PDR8)

The PDR8 register specifies the output value for each Port 8 pin.

### • Port 8 direction register (DDR8)

The DDR8 register specifies the I/O direction for each Port 8 pin.

A pin functions as an output port when the bit corresponding to the pin is set to 1. A pin functions as an input port when the bit corresponding to the pin is set to 0.

 Table 8.3-3
 Functions of the Port 8 Registers

| Register                             | Bit                            | Read                            | mode                                                | Write                                        | mode                                        | Address             | Initial value                          |  |
|--------------------------------------|--------------------------------|---------------------------------|-----------------------------------------------------|----------------------------------------------|---------------------------------------------|---------------------|----------------------------------------|--|
| name                                 | value                          | Input port                      | Output port                                         | Input port                                   | Output port                                 | Audress             |                                        |  |
| Port 8<br>data<br>register<br>(PDR8) | 0 The pin is at the "L" level. |                                 | The<br>corresponding<br>bit of PDR8 is<br>set to 0. | The<br>corresponding<br>bit of PDR8 is<br>0. | The "L" level is output from the pin.       | 000008 <sub>H</sub> | XXXXXXXX                               |  |
|                                      | 1                              | The pin is at the "H" level.    | The<br>corresponding<br>bit of PDR8 is<br>set to 1. | The<br>corresponding<br>bit of PDR8 is<br>1. | The "H" level<br>is output from<br>the pin. | 000008H             | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |  |
| Port 8<br>direction                  | 0                              |                                 |                                                     | The pin functio port.                        | ns as an input                              | 000018 <sub>H</sub> | 00000000 <sub>B</sub>                  |  |
| register<br>(DDR8)                   | 1                              | The correspon<br>PDR8 is set to | •                                                   | The pin functio port.                        | ns as an output                             | 0000 10H            | 0000000 <sub>B</sub>                   |  |

X: Undefined

### 8.3.2 Operation of Port 8

### This section describes the operation of Port 8.

### Operation of Port 8

### O When Port 8 is set as an output port in the Port 8 direction register (DDR8)

- The value stored in the Port 8 data register (PDR8) is output to the Port 8 pins.
- When the Port 8 data register (PDR8) is read, the value stored in PDR8 is output.

#### O When Port 8 is set as an input port in the Port 8 direction register (DDR8)

- The Port 8 pins have high impedance.
- When a value is set in the Port 8 data register (PDR8), the value is retained but is not output to the pin.
- When the PDR8 register is read, the pin input level (0 for "L" or 1 for "H") is output.

#### Note:

If a read-modify-write instruction (such as the bit set instruction) is used to access the PDR8 register, none of the bits specified for output in the DDR8 register are affected. For a bit specified for input in the DDR8 register, however, the pin input level is written to the PDR8 register. Therefore, to change a bit specified for input to output, first write an output value to the PDR8 register and then specify the DDR8 register as an output port.

#### • Port operation after a reset

- When the CPU is reset, the DDR8 and RDR8 registers are initialized to 00<sub>H</sub> and the Port 8
  pins have high impedance.
- The PDR8 register is not initialized when the CPU is reset. To use the PDR8 as an output
  port, first write an output value to the PDR8 register and then specify the DDR8 register as
  an output port.

### O Port operation in stop or time-base timer mode

When the port switches to stop mode or time-base timer mode while the pin status setting bit (SPL) of the low-power mode control register (LPMCR) is set to 1, the pins have high impedance regardless of the value in the Port 8 direction register (DDR8). Note that the input buffer is forcibly blocked off to prevent leakage due to an open circuit.

### Table 8.3-4 States of the Port 8 Pins

| Pin name   | Normal operation                     | Sleep mode                           | Stop mode or time-<br>base timer mode<br>(SPL = 0) | Stop mode or<br>time-base timer<br>mode (SPL = 1,<br>RDR = 0)                                        | Stop mode or<br>time-base timer<br>mode (SPL = 1,<br>RDR = 1)                                              |  |  |  |
|------------|--------------------------------------|--------------------------------------|----------------------------------------------------|------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|--|--|--|
| P80 to P87 | I/O port                             | I/O port                             | I/O port                                           |                                                                                                      |                                                                                                            |  |  |  |
| IC0        | Trigger input for<br>input capture 0 |                                      |                                                    |                                                                                                      |                                                                                                            |  |  |  |
| IC1        | Trigger input for<br>input capture 1 | Trigger input for<br>input capture 1 | Trigger input for<br>input capture 1               |                                                                                                      |                                                                                                            |  |  |  |
| SI0        | Serial data input 0                  | Serial data input 0                  | Serial data input 0                                | Input blocking:                                                                                      | Input blocking:<br>Held at the "H"                                                                         |  |  |  |
| SC0        | Serial clock I/O 0                   | Serial clock I/O 0                   | Serial clock I/O 0                                 | Output at Hi-z                                                                                       | level                                                                                                      |  |  |  |
| SO0        | Serial data output 0                 | Serial data output 0                 | Serial data output 0                               |                                                                                                      |                                                                                                            |  |  |  |
| SI1        | Serial data input 1                  | Serial data input 1                  | Serial data input 1                                |                                                                                                      |                                                                                                            |  |  |  |
| SC1        | Serial clock I/O 1                   | Serial clock I/O 1                   | Serial clock I/O 1                                 |                                                                                                      |                                                                                                            |  |  |  |
| SO1        | Serial data output 1                 | Serial data output 1                 | Serial data output 1                               |                                                                                                      |                                                                                                            |  |  |  |
| INTO, INT1 | External interrupt request 0, 1      | External interrupt request 0, 1      | External interrupt<br>request 0, 1                 | Input blocking:<br>Output held<br>(Input is enabled<br>when an external<br>interrupt is<br>enabled.) | Input blocking:<br>Output at Hi-z<br>(Input is<br>enabled when<br>an external<br>interrupt is<br>enabled.) |  |  |  |

SPL: Pin status specification bit of the low-power mode control register (LPMCR:SPL) Hi-z: High impedance

### 8.4 Port 9

Port 9 is an I/O port that can also be used for resource I/O. Each of the port pins can be switched between a resource and an I/O port according to the value of the corresponding bit. This section describes the configuration and registers of Port 9 and provides a block diagram of the pins. The focus is on I/O ports.

### Port 9 Configuration

Port 9 consists of the following:

- I/O port pins/resource I/O pins (P90, SDA, SO3 to P91, SCL, and SC3)
- Port 9 data register (PDR9)
- Port 9 direction register (DDR9)

### Port 9 Pins

The I/O pins of Port 9 also function as resource I/O pins. The I/O pins cannot be used as an I/O port when they are being used as resource I/O pins.

Table 8.4-1 Port 9 Pins

| Port   | Pin Port function |        |         | Reso    | ource function                  | I/O for      | Circuit       |      |  |
|--------|-------------------|--------|---------|---------|---------------------------------|--------------|---------------|------|--|
| name   | name              | 1 0111 | unction | Nest    |                                 | Input        | Output        | type |  |
| Duri   | P90               | P90    | I/O     | SDA/SO3 | 120                             | CMOS         | Nch           | 0    |  |
| Port 9 | P91               | P91    | port    | SCL/SC3 | I <sup>2</sup> C and serial I/O | (hysteresis) | open<br>drain | G    |  |

Note:

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

### Block Diagram of the Port 9 Pins



Figure 8.4-1 Block Diagram of the Port 9 Pins

### Port 9 Registers

The Port 9 registers are the Port 9 data register (PDR9) and the Port 9 direction register (DDR9). The bits of each register correspond to the Port 9 pins on a one-to-one basis.

Table 8.4-2 Port 9 Pins and Corresponding Register Bits

| Port name |                   | Register bits and corresponding port pins |       |       |       |       |       |      |      |  |
|-----------|-------------------|-------------------------------------------|-------|-------|-------|-------|-------|------|------|--|
| Port 0    | PDR9, DDR9        | bit15                                     | bit14 | bit13 | bit12 | bit11 | bit10 | bit9 | bit8 |  |
| Port 9    | Corresponding pin | -                                         | -     | -     | -     | -     | -     | P91  | P90  |  |

### 8.4.1 Port 9 Registers (PDR9 and DDR9)

### This section describes the Port 9 registers.

### ■ Functions of the Port 9 Registers

### • Port 9 data register (PDR9)

The PDR9 register specifies the output value for each Port 9 pin.

### • Port 9 direction register (DDR9)

The DDR9 register specifies the I/O direction for each Port 9 pin. A pin functions as an output port when the bit corresponding to the pin is set to 1. A pin functions as an input port when the bit corresponding to the pin is set to 0.

| Register                                  | Bit   | Read                                       | mode                                                | Write                                        | mode                                                                                   | Address             | Initial value         |  |
|-------------------------------------------|-------|--------------------------------------------|-----------------------------------------------------|----------------------------------------------|----------------------------------------------------------------------------------------|---------------------|-----------------------|--|
| name                                      | value | Input port                                 | Output port                                         | Input port                                   | Output port                                                                            | Audress             |                       |  |
| Port 9                                    | 0     | The pin is at the "L" level.               | The<br>corresponding<br>bit of PDR9 is<br>set to 0. | The<br>corresponding<br>bit of PDR9 is<br>0. | The "L" level is<br>output from<br>the pin.                                            |                     |                       |  |
| data<br>register<br>(PDR9)                | 1     | The pin is at the "H" level.               | The<br>corresponding<br>bit of PDR9 is<br>set to 1. | The<br>corresponding<br>bit of PDR9 is<br>1. | Because of<br>Nch open<br>drain, pull-up<br>is required to<br>output the "H"<br>level. | 000009 <sub>H</sub> | XXXXXXXXB             |  |
| Port 9<br>direction<br>register<br>(DDR9) | 0     | The corresponding bit of DDR9 is set to 0. |                                                     | Functions as a                               | n input port.                                                                          | 000010 0000000      |                       |  |
|                                           | 1     | The correspond<br>DDR9 is set to           | •                                                   | Functions as a                               | n output port.                                                                         | 000019 <sub>H</sub> | 00000000 <sub>B</sub> |  |

Table 8.4-3 Functions of the Port 9 Registers

X: Undefined

### 8.4.2 Operation of Port 9

### This section describes the operation of Port 9.

### Operation of Port 9

### • When Port 9 is set as an output port in the Port 9 direction register (DDR9)

- The value stored in the Port 9 data register (PDR9) is output to the Port 9 pins.
- When Port 9 data register (PDR9) is read, the value stored in the PDR9 is output.

### • When Port 9 is set as an input port in the Port 9 direction register (DDR9)

- The Port 9 pins have high impedance.
- When a value is set in the Port 9 data register (PDR9), the value is retained but is not output to the pin.
- When the PDR9 register is read, the pin input level (0 for "L" or 1 for "H") is output.

#### Note:

If a read-modify-write instruction (such as the bit set instruction) is used to access the PDR9 register, none of the bits specified for output in the DDR9 register are affected. For a bit specified for input in the DDR9 register, however, the pin input level is written to the PDR9 register. Therefore, to change a bit specified for input to output, first write an output value to the PDR9 register and then specify the DDR9 register as an output port.

### O Port operation after a reset

- When the CPU is reset, the DDR9 register is initialized to 00H and the Port 9 pins have high impedance.
- The PDR9 register is not initialized when the CPU is reset. To use the Port 9 as an output port, first write an output value to the PDR9 register and then specify the DDR9 register as an output port.

### **O** Port operation in stop or time-base timer mode

When the port switches to stop mode or time-base timer mode while the pin status setting bit (SPL) of the low-power mode control register (LPMCR) is set to 1, the pins have high impedance regardless of the value in the Port 9 direction register (DDR9). Note that the input buffer is forcibly blocked off to prevent leakage due to an open circuit.

| Pin name | Normal operation                | Sleep mode                      | Stop mode or<br>time-base timer<br>mode<br>(SPL = 0) | Stop mode or<br>time-base timer<br>mode<br>(SPL = 1) |  |
|----------|---------------------------------|---------------------------------|------------------------------------------------------|------------------------------------------------------|--|
| P90, P91 | I/O port                        | I/O port                        |                                                      | Input blocking:                                      |  |
| SDA/SO3  | I <sup>2</sup> C and serial I/O | I <sup>2</sup> C and serial I/O | Input blocking:<br>Output at Hi-z                    | Held at the "H"                                      |  |
| SCL/SC3  | T C and senari/O                | T C and senari/O                | nd serial I/O                                        |                                                      |  |

### Table 8.4-4 States of the Port 9 Pins

SPL: Pin status specification bit of the low-power mode control register (LPMCR:SPL) Hi-z: High impedance

### 8.5 Port A

Port A is an I/O port that can also be used for A/D converter analog input. Each of the port pins can be switched between analog input and an I/O port according to the value of the corresponding bit. This section describes the configuration and registers of Port A and provides a block diagram of the pins. The focus is on I/O ports.

### Port A Configuration

Port A consists of the following:

- I/O port pins and A/D converter analog input pins (PA0, AN0, TMCK to PA7, and AN7)
- Port A data register (PDRA)
- Port A direction register (DDRA)
- Analog input enable register 0 (ADER0)

### Port A Pins

The I/O pins of Port A are also used for A/D converter analog input. The I/O pins cannot be used as an I/O port when they are being used for A/D converter analog input. Conversely, the I/O pins cannot be used for A/D converter analog input when they are being used as an I/O port.

| Port   | Pin          | Port function |             | P                        | esource function | I/O for              | Circuit |      |
|--------|--------------|---------------|-------------|--------------------------|------------------|----------------------|---------|------|
| name   | name name    |               |             |                          |                  | Input                | Output  | type |
|        | PA0/         | DAG           |             | AN0                      | Analog input 0   |                      |         |      |
|        | AN0/<br>TMCK | PA0           |             | TMCK Timing clock output |                  |                      |         |      |
|        | PA1/AN1 PA   | PA1           |             | AN1                      | Analog input 1   | CMOS<br>(hysteresis) | CMOS    | F    |
|        | PA2/AN2      | PA2           | I/O<br>port | AN2                      | Analog input 2   |                      |         |      |
| Port A | PA3/AN3      | PA3           |             | AN3                      | Analog input 3   |                      |         |      |
|        | PA4/AN4      | PA4           |             | AN4                      | Analog input 4   |                      |         |      |
|        | PA5/AN5      | PA5           |             | AN5                      | Analog input 5   | -                    |         |      |
|        | PA6/AN6      | PA6           |             | AN6                      | Analog input 6   |                      |         |      |
|        | PA7/AN7      | PA7           |             | AN7                      | Analog input 7   |                      |         |      |

### Table 8.5-1 Port A Pins

Note:

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



### Figure 8.5-1 Block Diagram of the Port A Pins

#### Note:

To use a port pin as an input port, set the corresponding bit of the Port A direction register (DDRA) to 0 and the corresponding bit of analog input enable register 0 (ADER0) to 0.

To use a port pin as an analog input pin, set the corresponding bit of the Port A direction register (DDRA) to 0 and the corresponding bit of analog input enable register 0 (ADER0) to 1.

### Port A Registers

The Port A registers are the Port A data register (PDRA), the Port A direction register (DDRA), and analog input enable register 0 (ADER0). The bits of each register correspond to the Port A pins on a one-to-one basis.

| Port name | R                 | Register bits and corresponding port pins |      |      |      |      |      |      |      |  |
|-----------|-------------------|-------------------------------------------|------|------|------|------|------|------|------|--|
| Port A    | PDRA, DDRA, ADER0 | bit7                                      | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |  |
| FUILA     | Corresponding pin | PA7                                       | PA6  | PA5  | PA4  | PA3  | PA2  | PA1  | PA0  |  |

### 8.5.1 Port A Registers (PDRA, DDRA and ADER0)

### This section describes the Port A registers.

### Functions of the Port A Registers

### ○ Port A data register (PDRA)

The PDRA register specifies the output value for each Port A pin.

### • Port A direction register (DDRA)

The DDRA register specifies the I/O direction for each Port A pin.

A pin functions as an output port when the bit corresponding to the pin is set to 1. A pin functions as an input port when the bit corresponding to the pin is set to 0.

### O Analog input enable register 0 (ADER0)

Each bit of the ADER0 register can be set as an I/O port or as analog input to the A/D converter. A pin is used for analog input when the bit corresponding to the port (pin) is set to 1, and is used as an I/O port when the bit is set to 0.

#### Note:

If a signal at an intermediate level is input when a pin is set as an I/O port, input leakage current flows. To use a pin for analog input, therefore, be sure to set the corresponding bit of the ADER0 register for analog input to the A/D converter.

### **Reference:**

When reset, the DDRA register is initialized to  $00_H$ , the ADER0 register is initialized to FF<sub>H</sub>, and the A/D converter is set to analog input.

| Register                                           | Bit   | Read                             | mode                                                | Write                                               | mode                                        | Address                                   | Initial value         |  |
|----------------------------------------------------|-------|----------------------------------|-----------------------------------------------------|-----------------------------------------------------|---------------------------------------------|-------------------------------------------|-----------------------|--|
| name                                               | value | Input port                       | Output port                                         | Input port                                          | Output port                                 | Auuress                                   |                       |  |
| Port A<br>data                                     | 0     | The pin is at the "L" level.     | The<br>corresponding<br>bit of PDRA is<br>set to 0. | The<br>corresponding<br>bit of PDRA is<br>0.        | The "L" level is<br>output from<br>the pin. | 00000                                     |                       |  |
| register<br>(PDRA)                                 | 1     | The pin is at the "H" level.     | The<br>corresponding<br>bit of PDRA is<br>1.        | The<br>corresponding<br>bit of PDRA is<br>set to 1. | The "H" level<br>is output from<br>the pin. | 00000A <sub>H</sub>                       | XXXXXXXX <sub>B</sub> |  |
| Port A direction                                   | 0     | The correspond<br>PDRA is set to | •                                                   | The pin functio port.                               | ns as an input                              | 00001A <sub>H</sub> 00000000 <sub>B</sub> |                       |  |
| register<br>(DDRA)                                 | 1     | The correspone<br>PDRA is set to | -                                                   | The pin functio port.                               | ns as an output                             | 0000 IAH                                  | 0000000B              |  |
| Analog<br>input<br>enable<br>register 0<br>(ADER0) | 0     | The correspond<br>ADER0 is set t |                                                     | I/O port                                            |                                             | 000045                                    |                       |  |
|                                                    | 1     | The correspond<br>ADER0 is set t | •                                                   | A/D converter a to 7                                | analog input 0 00001E <sub>H</sub>          |                                           | 11111111 <sub>B</sub> |  |

Table 8.5-3 Functions of the Port A Registers

X: Undefined

### 8.5.2 Operation of Port A

### This section describes the operation of Port A.

### Operation of Port A

- When Port A is set as an output port in the Port A direction register (DDRA) and analog input enable register 0 (ADER0)
  - The value stored in the Port A data register (PDRA) is output to the Port A pin.
  - When Port A data register (PDRA) is read, the value stored in PDRA is output.

### When Port A is set as an input port in the Port A direction register (DDRA) and analog input enable register 0 (ADER0)

- The Port A pins have high impedance.
- When a value is set in the Port A data register (PDRA), the value is retained but is not output to the pin.
- When the PDRA register is read, the pin input level (0 for "L" or 1 for "H") is output.
- If a read-modify-write instruction (such as the bit set instruction) is used to access the PDRA register, none of the bits specified for output in the DDRA register are affected. For a bit specified for input in the DDRA register, however, the pin input level is written to the PDRA register. Therefore, to change a bit specified for input to output, first write an output value to the PDRA register and then specify the DDRA register as an output port.

### • When Port A is set for analog input to the A/D converter

To use a port pin for analog input to the A/D converter, set the bit of analog input enable register 0 (ADER0) corresponding to the analog input pin to 1. When the corresponding PDRA bit is read while a pin is set for A/D converter analog input, 0 is read.

### O Port operation after a reset

When the CPU is reset, the DDRA register is initialized to  $00_H$  and the ADER0 register is initialized to FF<sub>H</sub> so that it can be used for analog input to the A/D converter. To use Port A as an I/O port, set the ADER0 register to  $00_H$  to set the port to port I/O mode.

### **O** Port operation in stop or time-base timer mode

When the port switches to stop mode or time-base timer mode while the pin status setting bit (SPL) of the low-power mode control register (LPMCR) is set to 1, the pins have high impedance regardless of the value in the Port A direction register (DDRA). Note that the input buffer is forcibly blocked off to prevent leakage due to an open circuit.

| Pin name      | Normal operation                           | Sleen mode                                 |                 | Stop mode or<br>time-base timer<br>mode<br>(SPL = 1) |  |
|---------------|--------------------------------------------|--------------------------------------------|-----------------|------------------------------------------------------|--|
| PA0 to<br>PA7 | I/O port                                   | I/O port                                   | Input blocking: | Input blocking:                                      |  |
| AN0 to<br>AN7 | Analog input of<br>A/D converter 0<br>to 7 | Analog input of<br>A/D converter 0<br>to 7 | Out held        | Output at Hi-z                                       |  |

Table 8.5-4 States of the Port A pins

SPL: Pin status specification bit of low-power mode control register (LPMCR:SPL) Hi-z: High impedance

### 8.6 Port B

Port B is an I/O port that can also be used for A/D converter analog input, a serial interface, and external interrupt input. Each of the port pins can be switched between analog input and an I/O port according to the value of the corresponding bit. This section describes the configuration and registers of Port B and provides a block diagram of the pins. The focus is on I/O ports.

### Port B Configuration

Port B consists of the following:

- I/O port pins, A/D converter analog input pins, and resource input pins (PB0, AN8 to PB7, AN15, and INT3)
- Port B data register (PDRB)
- Port B direction register (DDRB)
- Analog input enable register 1 (ADER1)

### Port B Pins

The I/O pins of Port B are also used for A/D converter analog input and resource I/O. The I/O pins cannot be used as an I/O port when they are being used for A/D converter analog input or resource I/O. Conversely, the I/O pins cannot be used for A/D converter analog input or resource I/O when they are being used as an I/O port.

| Port   | Pin name | Port f                   | unction     | D    | esource function      | I/O for              | Circuit |      |  |
|--------|----------|--------------------------|-------------|------|-----------------------|----------------------|---------|------|--|
| name   | name     |                          | unction     |      |                       | Input                | Output  | type |  |
|        | PB0/AN8  | PB0                      |             | AN8  | Analog input 8        |                      |         |      |  |
|        | PB1/AN9  | PB1                      |             | AN9  | Analog input 9        |                      |         |      |  |
|        | PB2/AN10 | PB2                      |             | AN10 | Analog input 10       |                      |         |      |  |
|        | PB3/     | 3/<br>/PB3               | 002         |      | AN11                  | Analog input 11      |         |      |  |
|        | AN11/SI2 | грэ                      |             | SI2  | Serial data input 2   | CMOS<br>(hysteresis) | CMOS    | F    |  |
| Port B | PB4/     |                          | I/O<br>port | AN12 | Analog input 12       |                      |         |      |  |
|        | AN12/    | PB4                      |             | SC2  | Serial clock output 2 |                      |         |      |  |
|        | SC2/TIN  |                          |             | TIN  | Reload timer input 1  |                      |         |      |  |
|        | PB5/     |                          |             | AN13 | Analog input 13       |                      |         |      |  |
|        | AN13/    | PB5                      |             | SO2  | Serial data output 2  |                      |         |      |  |
|        | SO2/TO   | TO Reload timer output 1 |             |      |                       |                      |         |      |  |

### Table 8.6-1 Port B Pins

| Port   | Pin name                            | ame Port function |      | D     | esource function     | I/O for              | Circuit |   |
|--------|-------------------------------------|-------------------|------|-------|----------------------|----------------------|---------|---|
| name   | ame Pin name Port function Resource |                   |      | Input | Output               | type                 |         |   |
|        | PB6/                                |                   |      | AN14  | Analog input 14      |                      |         |   |
| Port B | AN14/<br>INT2                       | PB6               | I/O  | INT2  | External interrupt 2 | CMOS<br>(hysteresis) | CMOS    | F |
| FUILD  | PB7/                                | 007               | port | AN15  | Analog input 15      |                      |         |   |
|        | AN15/<br>INT3                       | PB7               |      | INT3  | External interrupt 3 |                      |         |   |

Table 8.6-1 Port B Pins (Continued)

Note:

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

### Block Diagram of the Port B Pins



### Figure 8.6-1 Block Diagram of the Port B Pins

#### Note:

To use a port pin as an input port, set the corresponding bit of the Port B direction register (DDRB) to 0 and the corresponding bit of analog input enable register 1 (ADER1) to 0.

To use a port pin as an analog input pin, set the corresponding bit of the Port B direction register (DDRB) to 0 and the corresponding bit of analog input enable register 1 (ADER1) to 1.

### Port B Registers

The Port B registers are the Port B data register (PDRB), Port B direction register (DDRB), and analog input enable register 1 (ADER1). The bits of each register correspond to the Port B pins on a one-to-one basis.

| Port name | Register bits and corresponding port pins |       |       |       |       |       |       |      |      |
|-----------|-------------------------------------------|-------|-------|-------|-------|-------|-------|------|------|
| Port B    | PDRB, DDRB, DER1                          | bit15 | bit14 | bit13 | bit12 | bit11 | bit10 | bit9 | bit8 |
|           | Corresponding pin                         | PB7   | PB6   | PB5   | PB4   | PB3   | PB2   | PB1  | PB0  |

### 8.6.1 Port B Registers (PDRB, DDRB and ADER1)

### This section describes the Port B registers.

### Functions of the Port B Registers

### • Port B data register (PDRB)

The PDRB register specifies the output value for each Port B pin.

### • Port B direction register (DDRB)

The DDRB register specifies the I/O direction for each Port B pin.

A pin functions as an output port when the bit corresponding to the pin is set to 1. A pin functions as an input port when the bit corresponding to the pin is set to 0.

### • O Analog input enable register 0 (ADER1)

Each bit of the ADER1 register can be set as an I/O port or as analog input to the A/D converter. A pin is used for analog input when the bit corresponding to the port (pin) is set to 1, and is used as an I/O port when the bit is set to 0.

#### Note:

If a signal at an intermediate level is input when a pin is set as an I/O port, input leakage current flows. To use a pin for analog input, therefore, be sure to set the corresponding bit of the ADER1 register for analog input to the A/D converter.

### **Reference:**

When reset, the DDRB register is initialized to  $00_H$ , the ADER1 register is initialized to FF<sub>H</sub>, and the A/D converter is set to analog input.

| Register                                           | Bit   | Read                              | mode                                                | Write                                        | mode                                        | Address             | Initial value         |  |
|----------------------------------------------------|-------|-----------------------------------|-----------------------------------------------------|----------------------------------------------|---------------------------------------------|---------------------|-----------------------|--|
| name                                               | value | Input port                        | Output port                                         | Input port                                   | Output port                                 | Auuress             |                       |  |
| Port B<br>data                                     | 0     | The pin is at the "L" level.      | The<br>corresponding<br>bit of PDRB is<br>set to 0. | The<br>corresponding<br>bit of PDRB is<br>0. | The "L" level is<br>output from<br>the pin. | 00000B.             | ~~~~~~                |  |
| register<br>(PDRB)                                 | 1     | The pin is at the "H" level.      | The<br>corresponding<br>bit of PDRB is<br>set to 1. | The<br>corresponding<br>bit of PDRB is<br>1. | The "H" level<br>is output from<br>the pin. | 00000B <sub>H</sub> | XXXXXXXX <sub>B</sub> |  |
| Port B<br>direction                                | 0     | The correspond<br>DDRB is set to  | •                                                   | The pin functio port.                        | ns as an input                              | 00001B <sub>H</sub> | 00000000 <sub>B</sub> |  |
| register<br>(DDRB)                                 | 1     | The correspone<br>DDRB is set to  | •                                                   | The pin functio port.                        | ns as an output                             |                     |                       |  |
| Analog<br>input<br>enable<br>register 1<br>(ADER1) | 0     | The correspond<br>ADER1 is set to |                                                     | I/O port                                     |                                             | 000045              |                       |  |
|                                                    | 1     | The correspond<br>ADER1 is set to |                                                     | A/D converter a                              | analog input                                | 00001F <sub>H</sub> | 11111111 <sub>B</sub> |  |

X: Undefined

### 8.6.2 Operation of Port B

### This section describes the operation of Port B.

### Operation of Port B

- When Port B is set as an output port for the Port B direction register (DDRB) and analog input enable register 1 (ADER1)
  - The value stored in the Port B data register (PDRB) is output to the Port B pin.
  - When Port B data register (PDRB) is read, the value stored in PDRB is output.
- When Port B is set as an input port in the Port B direction register (DDRB) and analog input enable register 1 (ADER1)
  - The Port B pins have high impedance.
  - When a value is set in the Port B data register (PDRB), the value is retained but is not output to the pin.
  - When the PDRB register is read, the pin input level (0 for "L" or 1 for "H") is output.

### Note:

If a read-modify-write instruction (such as the bit set instruction) is used to access the PDRB register, none of the bits specified for output in the DDRB register are affected. For a bit specified for input in the DDRB register, however, the pin input level is written to the PDRB register. Therefore, to change a bit specified for input to output, first write an output value to the PDRB register and then specify the DDRB register as an output port.

### O When Port B is set for analog input to the A/D converter

To use a port pin for analog input to the A/D converter, set the bit of analog input enable register 1 (ADER1) corresponding to the analog input pin to 1. When the corresponding PDRB bit is read while a pin is set for A/D converter analog input, 0 is read.

### O Port operation after a reset

When the CPU is reset, the DDRB register is initialized to  $00_H$  and the ADER1 register is initialized to FF<sub>H</sub> so that it can be used for analog input to the A/D converter. To use Port B as an I/O port, set the ADER1 register to  $00_H$  to set the port to port I/O mode.

### **O** Port operation in stop or time-base timer mode

When the port switches to stop mode or time-base timer mode while the pin status setting bit (SPL) of the low-power mode control register (LPMCR) is set to 1, the pins have high impedance regardless of the value in the Port B direction register (DDRB). Note that the input buffer is forcibly blocked off to prevent leakage due to an open circuit.

| Pin name       | Normal operation                             | Sleep mode                                   | Stop mode or<br>time-base timer<br>mode<br>(SPL = 0)                                                 | Stop mode or<br>time-base<br>timer mode<br>(SPL = 1)                                                       |
|----------------|----------------------------------------------|----------------------------------------------|------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|
| PB0 to<br>PB7  | I/O port                                     | I/O port                                     |                                                                                                      |                                                                                                            |
| AN8 to<br>AN15 | Analog input of A/<br>D converter 8 to<br>15 | Analog input of A/<br>D converter 8 to<br>15 |                                                                                                      |                                                                                                            |
| SI2            | Serial data input 2                          | Serial data input 2                          |                                                                                                      |                                                                                                            |
| SC2            | Serial clock I/O 2                           | Serial clock I/O 2                           | IInput blocking:<br>Output held                                                                      | Input blocking:<br>Output at Hi-z                                                                          |
| SO2            | Serial data output<br>2                      | Serial data output<br>2                      |                                                                                                      | ·                                                                                                          |
| TIN            | Reload timer input<br>1                      | Reload timer input<br>1                      |                                                                                                      |                                                                                                            |
| то             | Reload timer<br>output 1                     | Reload timer<br>output 1                     |                                                                                                      |                                                                                                            |
| INT2, INT3     | External interrupt request 2, 3              | External interrupt request 2, 3              | Input blocking:<br>Output held<br>(Input is enabled<br>when an external<br>interrupt is<br>enabled.) | Input blocking:<br>Output at Hi-z<br>(Input is<br>enabled when<br>an external<br>interrupt is<br>enabled.) |

Table 8.6-4 States of the Port B Pins

SPL: Pin status specification bit of low-power mode control register (LPMCR:SPL) Hi-z: High impedance

### 8.7 Sample I/O Port Program

This section provides a sample program that uses I/O ports.

### Sample I/O Port Program

### **O** Processing specifications

- Ports 8 and A are used to turn on all segments of a seven-segment (eight-segment if the decimal point is included) LED.
- Pin PA0 corresponds to the anode common pin of the LED, and pins P80 to P87 correspond to the segment pins.



### **O** Coding example

| PDR8<br>PDRA<br>DDR8 | EQU<br>EQU<br>EQU | 000008H<br>00000AH<br>000018H |                                              |
|----------------------|-------------------|-------------------------------|----------------------------------------------|
|                      | EQU               | 00001AH                       |                                              |
| ;                    | Main p            | program                       |                                              |
| CODE                 |                   | CSEG                          |                                              |
| START:               |                   |                               |                                              |
|                      |                   |                               | ; Already initialized                        |
|                      | MOV               | I:PDRA, #00000000B            | ; Sets PAO to the "L" level<br>; (#xxxxxx0B) |
|                      | MOV               | I:DDRA, #111111118            | ; Sets all port-A bits to output mode.       |
|                      | MOV               | I:PDR8, #11111111B            | ; Sets all port-8 bits to 1.                 |
|                      | MOV               | I:DDR8, #11111111B            | ; Sets all port-8 bits to output mode.       |
| CODE                 |                   | ENDS                          |                                              |
| ;                    |                   |                               |                                              |
|                      | END               | START                         |                                              |

## CHAPTER 9 SERIAL I/O

# This chapter describes the functions and operations of the serial I/O unit of the MB90M405 series.

- 9.1 "Overview of the Serial I/O Unit"
- 9.2 "Registers of the Serial I/O Unit"
- 9.3 "Serial I/O Prescaler (CDCR)"
- 9.4 "Operations of the Serial I/O Unit"

### 9.1 Overview of the Serial I/O Unit

The serial I/O unit is a serial I/O interface that can transfer data in an 8-bit/2-channel configuration in clock synchronous mode. Moreover, selection between LSB-first and MSB-first transfer for data transfer is possible.

### Overview of Serial I/O Unit

The two types of serial I/O operating modes are as follows:

### O Internal shift clock mode:

Transfers data in synchronization with the internal clock (communication prescaler).

### O External shift clock mode:

Transfers data in synchronization with the clock input from an external pin (SC). In this mode, general-purpose ports that share the external pin (SC) can perform transfer operations using CPU instructions (based on the timing of execution of the port reversal instruction).

### Block Diagram of the Serial I/O Unit





### 9.2 Registers of the Serial I/O Unit

The operations of the serial I/O unit can be specified using the following registers:

- Serial mode control status register (SMCR), higher
- Serial mode control status register (SMCR), lower
- Serial shift data register (SDR)

Registers of the Serial I/O Unit

Figure 9.2-1 Registers of the Serial I/O Unit

bit 15 ...... bit 8 bit 7 ..... bit 0

Serial mode control status register (SMCR)

Serial data register (SDR)

#### 9.2.1 Serial Mode Control Status Register (SMCR)

Serial Mode Control Status Register, Higher (SMCR)

The serial mode control status register (SMCR) controls the operating mode for serial I/O transfer.

#### Figure 9.2-2 Serial Mode Control Status Register, Higher (SMCR) Bit 9 15 14 13 12 11 10 8 Initial value BUSY SMD2SMD1SMD0 SIE SIR STOP STRT 0000010в R/W R/W R/W R/W R R/W R/W R/W STRT Start bit 0 Stop of serial transfer 1 Start of serial transfer STOP Stop bit 0 Normal operation 1 Stop of transfer BUSY Transfer status bit Stopped or serial data register R/W wait 0 Serial transfer 1 Serial I/O interrupt request flag bit SIR Read Write 0 No interrupt request exists. Clears an interrupt request. 1 An interrupt request exists. Does not affect operation. SIE Serial I/O interrupt request enable bit 0 Disables interrupt requests. 1 Enables interrupt requests. Serial shift clock mode setting bit MD2 SMD1 SMD0 $\phi = 16 \text{MHz}(\text{div} = 8) | \phi = 8 \text{MHz}(\text{div} = 4)$ $\phi = 4MHz(div = 4)$ 0 1 MHz 500 KMHz 0 0 1 MHz 0 0 1 500 KMHz 500 KMHz 250 KMHz 0 125 KMHz 1 0 125 KMHz 62.5 KMHz 0 1 1 62.5 KMHz 62.5 KMHz 31.25 KMHz 1 0 0 31.25 KMHz 31.25 KMHz 15.625 KMHz 1 0 1 External shift clock mode 0 1 1 Reserved 1 1 1 Reserved R/W : Read/write enabled R : Read only

φ : Machine clock frequency

: Initial value

| No.                  | Bit name                                                     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------|--------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit15<br>to<br>bit13 | SMD2, SMD1, SMD0:<br>Serial shift clock mode<br>setting bits | <ul> <li>Selects a serial shift clock mode.</li> <li>The settings of the serial shift clock mode setting bits (SMD2, SMD1 and SMD0) and Communication Prescaler Control Register (CDCR0/CDCR1) determine the transfer speed of the shift clock.</li> <li>A reset initializes these bits to 000B.</li> <li>Writing to these bits during transfer is prohibited (Do not write these bits).</li> <li>One of five internal shift clocks or an external shift clock can be specified. Do not set SMD2 to SMD0 to 110B or 111B because these settings are reserved.</li> <li>When SCOE is set to "0" for clock selection, shift operations for each instruction.</li> </ul>                                                                          |
| bit12                | SIE:<br>Serial I/O interrupt<br>request enable bit           | <ul> <li>This bit enables serial I/O interrupt requests.</li> <li>When this bit is set to "1", setting the serial I/O interrupt request flag bit (SIR) to "1" outputs an interrupt request.</li> <li>A reset initializes this bit to "0".</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| bit11                | SIR:<br>Serial I/O interrupt<br>request flag bit             | <ul> <li>This is a flag bit for an interrupt request to the serial I/O.</li> <li>This bit is set to "1" when serial data transfer ends.</li> <li>While the serial I/O interrupt request enable bit (SIE) is "1", set this bit to "1" to output an interrupt request to the CPU.</li> <li>When the MODE bit is "0", set this bit to "0" to clear the interrupt request.</li> <li>When the MODE bit is "1", reading or writing the SDR register clears the interrupt flag bit to "0".</li> <li>Regardless of the value of the MODE bit, a reset or setting of the STOP bit to "1" clears the interrupt flag bit to "0".</li> <li>Setting this bit to "0" clears the interrupt flag bit to "0".</li> <li>The read value is always "1".</li> </ul> |
| bit10                | BUSY:<br>Transfer status bit                                 | <ul> <li>This bit is "1" while a serial transfer is being executed.</li> <li>A reset initializes this bit to "0".</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| bit9                 | STOP:<br>Stop bit                                            | <ul> <li>This bit forcibly stops serial transfer.</li> <li>Setting this bit to "1" puts serial transfer into the stopped state with STOP set to "1".</li> <li>A reset initializes this bit to "1".</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| bit8                 | STRT:<br>Start bit                                           | <ul> <li>This bit starts serial transfer.</li> <li>Setting this bit to "1" in the stopped state starts transfer.</li> <li>Setting this bit to "1" during serial transfer or in the serial shift register R/W wait state causes the written value to be ignored.</li> <li>Setting this bit to "0" does not affect operation.</li> <li>The read value is always "0".</li> </ul>                                                                                                                                                                                                                                                                                                                                                                  |

### Serial Mode Control Status Register Lower (SMCR)



Figure 9.2-3 Serial Mode Control Status Register Lower (SMCR)

R/W : Read/write enabled

: Initial value

| No.             | Bit name                                  | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit7 to<br>bit4 | -:<br>Undefined bit                       | <ul><li>The read value is undefined.</li><li>Setting this bit does not affect the transfer operation.</li></ul>                                                                                                                                                                                                                                                                                                                                                                       |
| bit3            | MODE:<br>Serial mode selection<br>bit     | <ul> <li>Use this bit to select the condition for resuming operation from the stopped state.</li> <li>If this bit is "0", starting is performed by setting STRT to "1".</li> <li>If this bit is "1", reading or writing the serial data register (SDR) starts the transfer operation.</li> <li>Rewriting this bit during transfer is prohibited.</li> <li>A reset initializes this bit to "0".</li> <li>Set this bit to "1" to start the extended intelligent I/O service.</li> </ul> |
| bit2            | BDS:<br>Bit direction selection<br>bit    | <ul> <li>This bit selects the serial data transfer direction.</li> <li>If this bit is "0", data is transferred starting with the least significant bit (LSB first).</li> <li>If this bit is "1", data is transferred starting with the most significant bit (MSB first).</li> <li>Set the BDS bit before writing data to the SDR register.</li> </ul>                                                                                                                                 |
| bit1            | SOE:<br>Serial output enable<br>bit       | <ul> <li>This bit controls the output of the serial I/O output external pins (SO2 and SO3).</li> <li>If this bit is "0", the pin serves as the I/O port pin.</li> <li>If this bit is "1", the pin serves as the serial data output pin.</li> <li>A reset initializes this bit to "0".</li> </ul>                                                                                                                                                                                      |
| bit0            | SCOE:<br>Shift clock output<br>enable bit | <ul> <li>This bit controls the output of the shift clock I/O external pins (SC2 and SC3).</li> <li>If this bit is "0", the pin serves as the I/O port pin.</li> <li>If this bit is "1", the pin serves as the serial data output pin.</li> <li>Set this bit to "0" to perform transfer for each instruction in external shift clock mode.</li> <li>A reset initializes this bit to "0".</li> </ul>                                                                                    |

### Table 9.2-2 Functional Description of Lower Bits in Serial Mode Control Status Register (SMCR)

### 9.2.2 Serial Shift Data Register (SDR)

The serial shift data register (SDR) retains serial I/O transfer data. Writing to and reading the SDR is prohibited during transfer.

### ■ Serial Shift Data Register (SDR)

| Bit | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   | Initial value |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|---------------|
|     | D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  | XXXXXXXXB     |
|     | R/W |               |

Figure 9.2-4 Serial Shift Data Register (SDR)

### 9.3 Communication Prescaler Control Register (CDCR0/ CDCR1)

The Communication Prescaler Control Register (CDCR0/CDCR1) provides a serial I/O shift clock.

The operation clock for serial I/O operation can be obtained by dividing the output of the machine clock. The serial I/O unit is designed to obtain a fixed baud rate for each of the machine clocks in the system. The Communication Prescaler Control Register (CDCR0/CDCR1) controls division of the machine clock.

### ■ Communication Prescaler Control Register (CDCR0/CDCR1)

| Bit | 15  | 14  | 13  | 12  | 11       | 10   | 9    | 8    | Initial value         |
|-----|-----|-----|-----|-----|----------|------|------|------|-----------------------|
|     | MD  | -   | -   | -   | Reserved | DIV2 | DIV1 | DIV0 | 0XXX0000 <sub>B</sub> |
|     | R/W | R/W | R/W | R/W | R/W      | R/W  | R/W  | R/W  |                       |

 
 Table 9.3-1
 Functional Description of Bits in Communication Prescaler Control Register (CDCR0/ CDCR1)

| No.                     | Bit name                                                  | Function                                                                                                                                                                                                                                      |
|-------------------------|-----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit15                   | MD:<br>Communication<br>prescaler operation<br>enable bit | <ul> <li>Use this bit to enable operation of the communication prescaler.</li> <li>If this bit is set to "1", the communication prescaler is enabled.</li> <li>If this bit is set to "0", the communication prescaler is disabled.</li> </ul> |
| bit14<br>bit13<br>bit12 | -:<br>Undefined bit                                       | <ul><li>The read value is undefined.</li><li>The value of this bit does not affect operation.</li></ul>                                                                                                                                       |
| bit11                   | Reserved:<br>Reserved bit                                 | Be sure to set this bit to "0".                                                                                                                                                                                                               |
| bit10<br>bit9<br>bit8   | DIV2 to DIV0:<br>Division ratio setting<br>bit            | <ul> <li>Use this bit to set the division ratio of the machine clock.</li> <li>For information on the setting values, see Table 9.3-2 "Communication Prescaler."</li> </ul>                                                                   |

| MD | DIV2 | DIV1 | DIV0 | div     |
|----|------|------|------|---------|
| 0  | -    | -    | -    | Stopped |
| 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 9.3-2 Machine Clock Division Ratio

div: Machine clock division ratio

### Note:

If the division ratio has been changed, wait one cycle of the divide-by-two machine clock for clock stabilization before performing transfer.

The CDCR0 is a prescaler for the serial I/O channel 2 (also serve as the UART channel 0). The CDCR1 is a prescaler for the serial I/O channel 3 (also serve as the UART channel 1).

### 9.4 Operation of the Serial I/O Unit

The serial I/O unit consists of the serial mode control status register (SMCR) and the shift data register (SDR). The serial I/O unit is used to input and output 8-bit serial data.

### Operation of the Serial I/O Unit

The following explains how serial data is input and output. The contents of the shift data register are output to the serial output pin (SO pin) in bit serial mode in synchronization with a falling edge of the serial shift clock (external or internal clock). Data is input from the serial input pin (SI pin) in bit serial mode in synchronization with a rising edge of the clock. The shift direction (transfer from the MSB or LSB) can be selected using the bit direction bit (BDS) in the serial mode control status register lower (SMCR).

When transfer ends, the serial I/O unit enters the stopped state or data register R/W wait state according to the setting of the serial mode selection bit (MODE) in the serial mode control status register lower (SMCR). To enter the transfer state from the various states, do the following:

- To return from the stopped state, set the stop bit (STOP) to "0" and the start bit (STRT) to "0" (The settings for STOP and STRT can be made simultaneously).
- To return from the serial data register (SDR) wait state, read or write the data register.

### 9.4.1 Shift Clock

The shift clock operates in two modes: internal shift clock mode and external shift clock mode. A mode can be specified in the serial mode control status register (SMCR). Switch the mode while the serial I/O unit is stopped. Check for the stopped state by reading the transfer status bit (BUSY).

#### Internal Shift Clock Mode

In internal shift clock mode, the shift clock with a 50% duty cycle can be supplied for synchronous timing output from the SC pin. One-bit data is transferred for each clock. Calculate the transfer rate as follows:

transfer-rate (s) =  $\frac{\text{div} \times A}{\text{machine-clock-frequency (Hz)}}$ 

A, the divide factor specified in the serial shift clock mode setting bits (SMD0 to SMD2), is 2, 4, 16, or 32.

#### External Shift Clock Mode

In external shift clock mode, one-bit data is transferred for each clock in synchronization with the external shift clock that is input from the SC pin. A transfer rate up to 1/5 machine cycles is available. For example, a transfer rate up to 2 MHz is available when one machine cycle is 0.1  $\mu$ s.

Data can also be transferred for each instruction. Transfer data for each instruction as follows:

- Select the external shift clock mode and set the shift clock output enable bit (SCOE) in the serial mode control status register (SMCR) to "0".
- 2. Then, set the direction register for one of the ports that share the ISC pin to "1" to set the port to output mode.

After making the above settings, set the port data register (PDR) to "1" and then "0". The port value that is output to the SC pin is then fetched as the external clock and data is transferred. Start the shift clock at the "H" level.

#### Note:

Writing to the serial mode control register (SMCR) and the serial shift data register (SDR) is prohibited during serial I/O operation.

### 9.4.2 Operating States of the Serial I/O Unit

The serial I/O unit operates in the following four states:

- STOP state
- Stopped state
- R/W wait state of the SDR register
- Transfer state

### STOP State

When a reset occurs or the stop bit (STOP) in the serial mode control status register (SMCR) is set to "1", the shift counter is initialized and SIR is set to "0". Have the serial I/O unit return from the STOP state by setting STOP to "0" and STRT to "1" (the settings for these bits can be made simultaneously). No transfer operation occurs when the stop bit (STOP) is set to "1" and the start bit (STRT) is set to "1" because STOP has a higher priority than STRT.

### Stopped State

While the serial mode selection bit (MODE) is set to "0", BUSY is set to "0" and SIR is set to "1" in the serial mode control status register (SMCR) at the end of transfer. After that, the counter is initialized and the serial I/O enters the stopped state. Set STRT to "1" to have the serial I/O unit return from the stopped state and resume transfer.

### R/W Wait State of the Serial Data Register

While the serial mode selection bit (MODE) is set to "1", BUSY is set to "0" and SIR is set to "1" in the serial mode control status register (SMCR) at the end of serial transfer. After that, the serial I/O unit enters the SDR register R/W wait state. If the setting in the interrupt enable register is Enabled, this block outputs an interrupt signal.

To have the serial I/O unit return from the R/W wait state and resume transfer, read or write the SDR register to set BUSY to "1".

### Transfer State

While BUSY is set to "1", the serial I/O unit is transferring serial data. Depending on the setting of the serial mode selection bit (MODE), the serial I/O enters either the stopped or the R/W wait state.



### Figure 9.4-1 State Transition Diagram of Serial I/O Operation





- When MODE is set to "1", transfer is completed according to the shift clock counter. Then, SIR is set to "1" and the serial I/O enters the read/write wait state. When the serial I/O interrupt enable bit (SIE) is set to "1", an interrupt signal is generated. However, no interrupt signal is generated if SIE is inactive or transfer is interrupted by setting of the stop bit (STOP) to "1".
- 2. When the serial shift data register (SDR) is read or written, the interrupt request is cleared and serial transfer is resumed.

### 9.4.3 Start/Stop Timing of Shift Operation

To start the shift operation, set the stop bit (STOP) to "0" and the start bit (STRT) to "1" in the serial mode control status register (SMCR). The shift operation stops if STOP is set to "1" or when transfer terminates.

- Stop by setting STOP to "1": The shift operation stops while SIR remains at "0" regardless of the value the serial mode selection bit (MODE) is set to.
- Stop at the end of transfer: The shift operation stops after SIR is set to "1" regardless of the value the serial mode selection bit (MODE) is set to.

The transfer status bit (BUSY) is set to "1" in serial transfer state or "0" in stopped or R/W wait state regardless of the value the serial mode selection bit (MODE) is set to. To check the transfer state, read the BUSY bit.

### ■ Start/Stop Timing of Shift Operation

O Internal shift clock mode (LSB first)



### Figure 9.4-3 Timing of Shift Operation (Internal Clock)





O When shift operation is performed in accordance with instructions in external shift clock mode (LSB first)

## Figure 9.4-5 Timing of Shift Operation (When a Shift Operation Is Performed in Accordance with Instructions in External Shift Clock Mode)



### O Stop by setting STOP to "1" (LSB first, internal clock mode)

### Figure 9.4-6 Stop Timing When the Stop Bit (STOP) Is Set to "1"



Note: DO7 to DO0 represent output data.

### Serial Data I/O Timings

During serial data transfer, data is output from the serial output pin (SO) on a falling edge of the shift clock and data is input from the serial input pin (SI) on a rising or falling edge (determined beforehand).

Figure 9.4-7 Timing of Serial Data I/O Shift

| - 102   |                                                                                                 |
|---------|-------------------------------------------------------------------------------------------------|
| SC0,SC1 |                                                                                                 |
| 000,001 | SI input                                                                                        |
| SI0,SI1 |                                                                                                 |
|         | SO output                                                                                       |
| SO0,SO1 | $\land$ DO0 $\land$ DO1 $\land$ DO2 $\land$ DO3 $\land$ DO4 $\land$ DO5 $\land$ DO6 $\land$ DO7 |
|         |                                                                                                 |
| O MSB f | irst (when the BDS bit is "1")                                                                  |
| SC0,SC1 |                                                                                                 |
| ,       | SI input                                                                                        |
| SI0,SI1 | $\land$ DI7 $\land$ DI6 $\land$ DI5 $\land$ DI4 $\land$ DI3 $\land$ DI2 $\land$ DI1 $\land$ DI0 |
|         | SO output                                                                                       |
| SO0,SO1 | $\land$ DO7 $\land$ DO6 $\land$ DO5 $\land$ DO4 $\land$ DO3 $\land$ DO2 $\land$ DO1 $\land$ DO0 |
|         |                                                                                                 |

O LSB first (when the BDS bit is "0")

### 9.4.4 Interrupt Function of the Serial I/O Unit

The serial I/O unit can output interrupt requests to the CPU. If, at the end of data transfer, the serial I/O interrupt request flag bit (SIR), which is an interrupt flag, is set to "1" and the serial I/O interrupt enable bit (SIE) in the serial mode control status register (SMCR) is set to "1", the serial I/O outputs an interrupt request to the CPU.

### ■ Interrupt Function of the Serial I/O Unit



CHAPTER 9 SERIAL I/O

## CHAPTER 10 TIMEBASE TIMER

# This chapter describes the functions and operation of the timebase timer of the MB90M405 series.

- 10.1 "Overview of the Timebase Timer"
- 10.2 "Configuration of the Timebase Timer"
- 10.3 "Timebase Timer Control Register (TBTC)"
- 10.4 "Timebase Timer Interrupts"
- 10.5 "Operation of the Timebase Timer"
- 10.6 "Usage Notes on the Timebase Timer"

### **10.1** Overview of the Timebase Timer

The timebase timer is an 18-bit free-running counter that counts up in synchronization with the main clock. The timer has two functions: An interval timer function that can select one of four intervals and a function for supplying clocks to the oscillation stabilization interval timer and the watchdog timer.

### ■ Interval Timer Function

The interval timer function repeatedly generates an interrupt request at a given interval.

- An interrupt request is generated when the interval timer bit for the timebase counter overflows.
- The interval timer bit (interval) can be selected from four types.

### Table 10.1-1 Intervals for the Timebase Timer

| Main clock cycle | Interval cycle                            |
|------------------|-------------------------------------------|
|                  | 2 <sup>12</sup> /HCLK (Approx. 0.97 ms)   |
| 2/HCLK (0.5 µs)  | 2 <sup>14</sup> /HCLK (Approx. 3.90 ms)   |
| 2/HOLK (0.5 µS)  | 2 <sup>16</sup> /HCLK (Approx. 15.62 ms)  |
|                  | 2 <sup>19</sup> /HCLK (Approx. 125.00 ms) |

HCLK: Oscillation clock frequency

Values in parentheses are for a 4.194 MHz oscillation clock.

### Clock Supply Function

The clock supply function supplies clocks to the oscillation settling time timer and to some peripheral functions.

Table 10.1-2 Clock Cycle Time Supplied from the Timebase Timer

| Clock destination        | Clock cycle time                          | Remarks                                        |
|--------------------------|-------------------------------------------|------------------------------------------------|
| Oscillation setting time | 2 <sup>13</sup> /HCLK (Approx. 1.95 ms)   | Oscillation settling time for ceramic vibrator |
|                          | 2 <sup>15</sup> /HCLK (Approx. 7.81 ms)   | Oscillation settling time for crystal vibrator |
|                          | 2 <sup>18</sup> /HCLK (Approx. 62.50 ms)  |                                                |
| Watchdog timer           | 2 <sup>12</sup> /HCLK (Approx. 0.97 ms)   | Count-up clock for watchdog timer              |
|                          | 2 <sup>14</sup> /HCLK (Approx. 3.90 ms)   |                                                |
|                          | 2 <sup>16</sup> /HCLK (Approx. 15.62 ms)  |                                                |
|                          | 2 <sup>19</sup> /HCLK (Approx. 125.00 ms) |                                                |

HCLK: Oscillation clock frequency

Values in parentheses occurs during operation of the 4.194 MHz oscillation clock.

### Reference:

The oscillation settling time is the yardstick because the oscillation cycle time is unstable as soon as oscillation starts.

### **10.2** Configuration of the Timebase Timer

The timebase timer consists of the following four blocks:

- Timebase timer counter
- Counter clear circuit •
- Interval timer selector
- Timebase timer control register (TBTC) •

Block Diagram of the Timebase Timer



### Figure 10.2-1 Block Diagram of the Timebase Timer

OF : Overflow

\*1 Switching of the machine clock from the oscillation clock to the PLL clock

\*2 Interrupt number

### O Timebase timer counter

An 18-bit up counter that uses the main clock as the count clock

### O Counter clear circuit

Clears the timebase timer counter by setting the timebase timer initialization bit (TBR) of the timebase timer control register (TBTC) to "0", performing a power-on reset, sending the CPU into stop mode (LPMCR: STP = "1"), and changing the machine clock from the main clock to the PLL clock (CKSCR: MCS =  $"1" \rightarrow "0"$ ).

### O Interval timer selector

Selects one of four outputs of the timebase timer counter. An overflow of the selected bit becomes an interrupt cause.

### **O** Timebase timer control register (TBTC)

Selects the interval, clears the timebase timer counter, controls an interrupt request, and checks the status.

### **10.3 Timebase Timer Control Register (TBTC)**

The timebase timer control register (TBTC) selects the interval, clears the timebase timer counter, controls an interrupt request, and checks the status.

### ■ Timebase Timer Control Register (TBTC)

| Bit | 15   | 14 | 13 | 12   | 11   | 10                | 9                                   | 8       | 3                  | Initial value         |                                     |  |  |
|-----|------|----|----|------|------|-------------------|-------------------------------------|---------|--------------------|-----------------------|-------------------------------------|--|--|
|     | RESV | _  |    | TBIE | TBOF | TBR               | твс                                 | 1 TB    | C0                 | 1XX00100 <sub>B</sub> |                                     |  |  |
|     | R/W  | -  | -  | R/W  | R/W  |                   | R/V                                 | V R     | /W                 |                       |                                     |  |  |
|     |      |    |    |      |      | └→F               | TBC1 T                              | ГВС0    |                    | Interval              | selection bit                       |  |  |
|     |      |    |    |      |      |                   | 0                                   | 0       | 2 <sup>12</sup> /⊦ | ICLK (Approx. 0       | .97 ms)                             |  |  |
|     |      |    |    |      |      |                   | 0                                   | 1       | 2 <sup>14</sup> /⊦ | ICLK (Approx. 3       | .90 ms)                             |  |  |
|     |      |    |    |      |      |                   | 1                                   |         |                    | ICLK (Approx. 1       | ,                                   |  |  |
|     |      |    |    |      |      | L                 | 1                                   |         |                    | ICLK (Approx. 1       | ,                                   |  |  |
|     |      |    |    |      |      | V                 | alues                               | in par  | enthe              | eses are for a 4.     | 194 MHz oscillation clock.          |  |  |
|     |      |    |    |      |      | <b>→</b>          | TBR                                 |         | -                  | Timebase timer        | initialization bit                  |  |  |
|     |      |    |    |      |      |                   | 0                                   | Clearir | ng of              | the timebase tim      | er counter and an interrupt request |  |  |
|     |      |    |    |      |      |                   | 1                                   | No eff  | ect o              | n operation           |                                     |  |  |
|     |      |    |    |      |      | г                 |                                     |         |                    |                       |                                     |  |  |
|     |      |    |    |      |      | <b></b>           | TBOF                                |         |                    | Interrupt req         |                                     |  |  |
|     |      |    |    |      |      | - L               |                                     |         |                    | reading               | During writing                      |  |  |
|     |      |    |    |      |      |                   |                                     |         |                    | t request made        | Clearing of an interrupt request    |  |  |
|     |      |    |    |      |      | L                 | 1  I                                | nterru  | pt re              | quest made            | No effect on operation              |  |  |
|     |      |    |    |      |      |                   |                                     |         |                    |                       |                                     |  |  |
|     |      |    |    |      |      |                   | • TBIE Interrupt request enable bit |         |                    |                       |                                     |  |  |
|     |      |    |    |      |      |                   | 0 Interrupt request output disabled |         |                    |                       |                                     |  |  |
|     |      |    |    |      |      | L                 | 1 Interrupt request output enabled  |         |                    |                       |                                     |  |  |
|     |      |    |    |      |      | RESV Reserved bit |                                     |         |                    |                       |                                     |  |  |
|     |      |    |    |      |      | ľ                 | Be su                               | ure to  | write              | 1 to this bit.        |                                     |  |  |

Figure 10.3-1 Timebase Timer Control Register (TBTC)

| R/W  | : | Read/write                  |
|------|---|-----------------------------|
| W    | : | Write only                  |
| Х    | : | Undefined                   |
| -    | : | Not used                    |
|      | : | Initial value               |
| HCLK | : | Oscillation clock frequency |
|      |   |                             |

|                | Bit name                                     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit15          | RESV:<br>Reserved bit                        | Be sure to write 1 to this bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| bit14<br>bit13 | Not used                                     | <ul><li>When read, the value is undefined.</li><li>Writing has no effect on operation.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| bit12          | TBIE:<br>Interrupt request<br>enable bit     | <ul> <li>This bit enables interrupt requests.</li> <li>When this bit and the interrupt request flag bit (TBOF) are 1, an interrupt request is output.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| bit11          | TBOF:<br>Interrupt request flag<br>bit       | <ul> <li>TBOF is a flag bit for an interrupt request.</li> <li>This bit is set to "1" when the interval timer bit selected for the timebase timer counter overflows.</li> <li>When the interrupt request enable bit (TBIE) is set to "1", an interrupt request is output.</li> <li>Set this bit to "0" to clear an interrupt request.</li> <li>When this bit is set to "1", there is no effect on operation.</li> <li>Note:</li> <li>To set this bit to "0", set the interrupt request enable bit (TBIE) or the interrupt level mask register (ILM) of the processor status (PS) to Disabled.</li> <li>This bit is cleared to "0" when a transition to stop mode occurs, the timebase timer is cleared due to the timebase timer initialization bit (TBR), or a reset occurs.</li> </ul> |
| bit10          | TBR:<br>Timebase timer<br>initialization bit | <ul> <li>Used to clear the timebase timer counter.</li> <li>When this bit is set to "0", the timebase timer counter is cleared to 00000<sub>H</sub> and the interrupt request flag bit (TBOF) is cleared to "0".</li> <li>Writing 1 does not affect operation.</li> <li>[Reference]<br/>The read value is always 1.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| bit9<br>bit8   | TBC1, TBC0:<br>Interval selection bit        | <ul> <li>Used to select an interval timer cycle.</li> <li>The bit for the interval timer of the timebase timer counter is specified.</li> <li>Four types of interval can be selected.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

Table 10.3-1 Function Description of Each Bit in the Timebase Timer Control Register (TBTC)

### **10.4 Timebase Timer Interrupts**

The timebase timer can output an interrupt request when an overflow of the interval counter selected with the interval time setting bit occurs (interval timer function).

### ■ Timebase Timer Interrupts

The interrupt request flag bit (TBOF) of the timebase timer control register (TBTC) is set to "1" when the timebase timer counter counts up on the main clock and an overflow of the specified interval timer occurs. If the TBOF bit is set to "1" while the interrupt request enable bit is set to Enabled (TBTC:TBIE="1"), an interrupt request (interrupt number #34) is output to the CPU and the interrupt processing routine is executed. In the interrupt processing routine, set the TBOF bit to "0" to clear the interrupt request. When the specified interval timer bit overflows, the TBOF bit is set to "1" regardless of the value in the TBIE bit.

### **Reference:**

• The timebase timer cannot use the extended intelligent I/O service (EI<sup>2</sup>OS).

### ■ Timebase Timer Interrupts and El<sup>2</sup>OS

### Table 10.4-1 Timebase Interrupts and El<sup>2</sup>OS

| Interrupt number       | Interrupt level | Vect                | EI <sup>2</sup> OS  |                     |                     |       |
|------------------------|-----------------|---------------------|---------------------|---------------------|---------------------|-------|
| interrupt number       | Register name   | Address             | Lower               | Upper               | Bank                | EI-03 |
| #33 (21 <sub>H</sub> ) | ICR11           | 0000BB <sub>H</sub> | FFFF78 <sub>H</sub> | FFFF79 <sub>H</sub> | FFFF7A <sub>H</sub> | х     |

x: Not available

### 10.5 Operation of the Timebase Timer

This section describes the operation of the interval timer function, the oscillation stabilization interval timer function, and the clock supply function.

### Operation of the Interval Timer Function (Timebase Timer)

The interval timer function generates an interrupt request for each interval

The stabilization in Figure 10.5-1 "Stabilization of the Timebase Timer" is required to all the timer to operate as an interval timer.



Figure 10.5-1 Setting of the Timebase Timer

- The timebase timer continues counting up as long as the clock oscillates.
- The interval may become longer than the time set because of timebase timer clearing.

### Oscillation Stabilization Wait Time Timer Function

The timebase timer is also used as the oscillation time timer for oscillation and the PLL clocks.

| Operation                                                                     | Counter clear | TBOF clear | Oscillation Stabilization Wait Time                                                  |
|-------------------------------------------------------------------------------|---------------|------------|--------------------------------------------------------------------------------------|
| TBTC: Writing of 0 to TBR                                                     | 0             | 0          | -                                                                                    |
| Power-on reset                                                                | 0             | 0          | Oscillation clock oscillation stabilization wait                                     |
| Watchdog reset                                                                | 0             | 0          | time                                                                                 |
| Releasing of stop mode                                                        | 0             | 0          | Oscillation clock oscillation stabilization wait time (at return to main clock mode) |
| Transition from oscillation<br>clock mode to PLL clock<br>mode (MCS = 1 to 0) | 0             | 0          | PLL clock oscillation stabilization wait time                                        |
| Releasing of timebase timer mode                                              | х             | Х          | PLL clock oscillation stabilization wait time (at return to PLL clock mode)          |
| Releasing of sleep mode                                                       | Х             | Х          | -                                                                                    |

| Table 10.5-1 T | Timebase Timer | <b>Counter Clearin</b> | g and Oscillation | Stabilization | Wait Time |
|----------------|----------------|------------------------|-------------------|---------------|-----------|
|----------------|----------------|------------------------|-------------------|---------------|-----------|

O: Available

X: Not available

### ■ Clock Supply Function

The timebase timer supplies clocks to the watchdog timer. Clearing of the timebase counter affects operation of the watchdog timer. For more information, see Section 10.6 "Usage Notes on the Timebase Timer".

#### Timebase Timer Operation Statuses

Figure 10.5-2 "Timebase Timer Operations" shows the following operation statuses.

- When a power-on reset occurs
- When the CPU enters sleep mode while the interval timer function is operating
- When the CPU enters stop mode •
- When the timebase timer counter clear request is issued ٠

When the CPU enters stop mode, the timebase timer counter is cleared and the timebase timer counter stops. To release stop mode, use the timebase timer counter to count the oscillation stabilization interval.



Figure 10.5-2 Timebase Timer Operations

If the interval time setting bits of the timebase timer control register (TBC: TBC, TBC0) is set to "11<sub>B</sub>" (2<sup>19</sup>/HCLK)

: Oscillation stabilization interval HCLK : Oscillation clock frequency

### **10.6 Usage Notes on the Timebase Timer**

This section provides notes on how clearing of an interrupt request or clearing of the timebase timer counter affects the functions.

### Timebase Timer Usage Notes

### **O** Clearing interrupt requests

Clear the interrupt request flag bit (TBOF) of the timebase timer control register (TBTC) to "0" while the interrupt request enable bit (TBIE) or the interrupt level mask register (ILM) of the processor status (PS) is set to disabled.

### • Functions affected by clearing of the timebase timer counter

- Interval timer function (interval interrupt)
- When the watchdog timer is being used
- Clock output circuit

### O Use of the timebase timer as the oscillation settling time timer

In stop mode in which the operating clock stops, the timebase timer counter is cleared and stopped. When the timebase timer counter is cleared, the clock supplied from it starts to be supplied again from the initial state. As a result, the H level may be shortened or the L level may be prolonged by half a cycle at the maximum. Although the clock for the watchdog timer also starts to be supplied again from the initial state, the watchdog timer operates in normal cycles because the watchdog timer counter is cleared at the same time.

### O Notes on peripheral functions to which clocks are supplied from the timebase timer

At power-on or in stop mode, the source oscillation is stopped. Thus, the timebase timer counter places the oscillation stabilization interval for the operating clock using the clock supplied from the oscillator. Depending on the oscillator type, an appropriate oscillation stabilization interval must be specified.

For more information, see Section 4.5 "Oscillation Stabilization Wait Time".

## CHAPTER 11 WATCHDOG TIMER

# This chapter describes the functions and operations of the watchdog timer of the MB90M405 series.

- 11.1 "Overview of the Watchdog Timer"
- 11.2 "Configuration of the Watchdog Timer"
- 11.3 "Watchdog Timer Control Register (WDTC)"
- 11.4 "Operation of the Watchdog Timer"
- 11.5 "Usage Notes on the Watchdog Timer"

### 11.1 Overview of the Watchdog Timer

The watchdog timer is a 2-bit counter that uses the output of the timebase timer as the count clock. After the watchdog timer is activated, the CPU is reset within a specified interval unless the watchdog timer is cleared.

### Watchdog Timer Function

The watchdog timer is provided to detect whether a program is running out of control. The watchdog timer, once activated, must continue to be cleared within every specified interval. If the program results in an endless loop and the watchdog timer is not cleared within the minimum time shown in Table 11.1-1 "Intervals for the Watchdog Timer" a watchdog reset is issued to the CPU, sending it into the reset status. Specify the watchdog timer interval in the interval setting bits (WT1, WT0) of the watchdog timer control register (WDTC).

Table 11.1-1 Intervals for the Watchdog Timer

| WT1  | WT0 | Interval          |                   |                               |  |  |  |
|------|-----|-------------------|-------------------|-------------------------------|--|--|--|
| **** |     | Minimum (*1)      | Maximum (*1)      | Oscillation clock cycle count |  |  |  |
| 0    | 0   | Approx. 3.58 ms   | Approx. 4.61 ms   | $2^{14} \pm 2^{11}$ cycle     |  |  |  |
| 0    | 1   | Approx. 14.33 ms  | Approx. 18.3 ms   | $2^{16}\pm2^{13}\text{cycle}$ |  |  |  |
| 1    | 0   | Approx. 57.23 ms  | Approx. 73.73 ms  | $2^{18}\pm2^{15}$ cycle       |  |  |  |
| 1    | 1   | Approx. 458.75 ms | Approx. 589.82 ms | $2^{21} \pm 2^{18}$ cycle     |  |  |  |

\*1: Value during operation of the 4.19 MHz oscillation clock

For more information on a watchdog timer interval, see Section 11.4 "Operation of the Watchdog Timer".

### **Reference:**

The watchdog timer, after being activated, can be stopped using a power-on reset or a reset from the watchdog timer. The watchdog timer can be cleared with an external reset, an internal reset, writing to the watchdog control bit (WTE) of the watchdog timer control register (WDTC), or transition to sleep or stop mode. However, the watchdog function is enabled and not stopped.

### Note:

The watchdog counter consists of a 2-bit counter that uses the carry signals of the timebase timer as count clocks. Since the watchdog timer uses a carry signal of the timebase timer, the watchdog reset interval time may become longer than the specified time if the timebase timer is cleared.

### 11.2 Configuration of the Watchdog Timer

The watchdog timer consists of the following blocks:

- Count clock selector
- Watchdog timer (2-bit counter)
- Watchdog reset generator
- Counter clear control circuit
- Watchdog timer control register (WDTC)

Block Diagram of the Watchdog Timer



- : Undefined bit

### O Count clock selector

Used to select one of the four timebase timer output clocks as the count clock of the watchdog timer. Setting the count clock of the watchdog timer determines a watchdog reset interval.

### O Watchdog counter (2-bit counter)

The watchdog timer is a 2-bit timer that counts the clock specified by the count clock selector.

### O Watchdog reset generator

Used to generate the reset signal by an overflow of the watchdog counter.

### O Counter clear circuit

Used to clear the watchdog counter and to control the operation or stopping of the counter.

### • Watchdog timer control register (WDTC)

Used to set the interval, activate and clear the watchdog timer, and hold the reset generation cause.

### 11.3 Watchdog Timer Control Register (WDTC)

The watchdog timer control register (WDTC) is used to set an interval time, start the watchdog timer, clear a setting, and indicate a reset generation cause.



### Watchdog Timer Control Register (WDTC)

- Undefined bit
- : Initial value

Retains the previous status.

HCLK : Oscillation clock frequency

|                              | Bit name                                       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------------------------|------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit7<br>bit5<br>bit4<br>bit3 | PONR, WRST,<br>ERST, SRST:<br>Reset cause bits | <ul> <li>Read-only bits for indicating the reset cause. If more than one reset cause occurs, the bit for each reset cause occurring is set to 1.</li> <li>These bits are all cleared to 0 after the watchdog timer control register (WDTC) is read.</li> <li>A power-on reset sets the reset cause flag bit PONR to "1" and sets the reset cause flag bits WRST, ERST, and SRST to an undefined value.</li> <li>If the PONR bit is set to "1", the contents of the WRST, ERST, and SRST bits should be ignored.</li> </ul> |
| bit6                         | -:<br>Undefined bit                            | <ul><li>The value of this bit is not defined if it is read.</li><li>The set value does not affect the operation.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                 |
| bit2                         | WTE:<br>Watchdog timer<br>control bit          | <ul> <li>The watchdog timer is activated when this bit is set to "0" in the first write operation after a power-on reset or a reset from the watchdog timer.</li> <li>The watchdog timer is cleared when this bit is set to "0" in write operations after the first after a power-on reset or a reset from the watchdog timer.</li> <li>Writing 1 does not affect operation.</li> </ul>                                                                                                                                    |
| bit1<br>bit0                 | WT1, WT0:<br>Interval selection bit            | <ul> <li>Used to select the watchdog timer interval.</li> <li>Data in these bits is valid when the watchdog timer is activated. Data can be written to this bit and the watchdog control bit (WTE) at the same time. Data written to these bits after the watchdog timer is activated is invalid.</li> <li>These bits are write-only.</li> </ul>                                                                                                                                                                           |

### Table 11.3-1 Function Description of Each Bit of the Watchdog Timer Control Register (WDTC)

### 11.4 Operation of the Watchdog Timer

The watchdog timer generates a watchdog reset by an overflow of the watchdog counter.

### Watchdog Timer Operation





Used
 Set 0.

#### **O** Activating the watchdog timer

- To activate the watchdog timer, set the watchdog control bit (WTE) of the watchdog timer control register (WDTC) to "0" for the first time after a reset from the watchdog timer is generated after a power-on reset. The interval can be set in the interval setting bits (WT1, WT0) of the watchdog timer control register (WDTC).
- The watchdog timer, after being activated, can be stopped using a power-on reset or a reset from the watchdog timer. The watchdog timer cannot be stopped by an external reset, a software reset, writing to the watchdog control bit (WTE) of the watchdog timer control register (WDTC), or transition to sleep or timebase timer mode.

### **O** Clearing the watchdog timer

- To clear the watchdog timer, set the watchdog control bit (WTE) of the watchdog timer control register (WDTC) to "0".
- The watchdog timer can be cleared also by input of an external reset or an internal reset or transition to sleep mode.
- Transition to timebase timer mode clears and stops the watchdog timer.

### **O** Intervals for the watchdog timer

Figure 11.4-2 "Clear Timing and Watchdog Timer Intervals" shows the relationship between the clear timing of the watchdog timer and intervals.

### O Checking a reset cause

A reset cause can be determined by checking the PONR, WRST, ERST, and SRST bits of the watchdog timer control register (WDTC) after a reset.

### Figure 11.4-2 Clear Timing and Watchdog Timer Intervals

[WDG timer block diagram]



[Minimum interval] When the WTE bit is cleared immediately before the count clock rises:



[Maximum interval] When the WTE bit is cleared immediately after the count clock rises:



### 11.5 Usage Notes on the Watchdog Timer

### Notes on using the watchdog timer are given below.

### ■ Usage Notes on the Watchdog Timer

#### **O** Stopping the watchdog timer

Once the watchdog timer is activated, it cannot stop until a power-on or watchdog reset occurs.

#### O Interval setting

The interval setting becomes valid when the watchdog timer is activated. The interval setting is ignored unless the watchdog timer is activated.

#### O Interval time

The interval time of the watchdog timer may become longer than the specified value when the timebase timer is cleared because a carry signal of the timebase timer is used as the count clock.

### **O** Notes on program creation

If the watchdog timer is repetitiously cleared in a program, the processing time of the program including the interrupt processing must be equal to or less than the minimum interval.

### **O** Watchdog timer operation in timebase timer mode

In timebase timer mode, the watchdog timer is cleared and stopped. The watchdog timer is restarted when the CPU returns from timebase timer mode to main clock mode or PLL clock mode.

**CHAPTER 11 WATCHDOG TIMER** 

## CHAPTER 12 16-BIT RELOAD TIMER

# This chapter describes the functions and operations of the 16-bit reload timer of the MB90M405 series.

- 12.1 "Overview of the 16-Bit Reload Timer"
- 12.2 "Configuration of the 16-Bit Reload Timer"
- 12.3 "16-Bit Reload Timer Pins"
- 12.4 "16-Bit Reload Timer Registers"
- 12.5 "16-Bit Reload Timer Interrupts"
- 12.6 "Operation of the 16-Bit Reload Timer"
- 12.7 "Usage Notes on the 16-Bit Reload Timer"

### 12.1 Overview of the 16-Bit Reload Timer

The MB90M405 series has three 16-bit reload timer channels. The following clock modes and the following counter operation modes can be specified.

Clock modes

- Internal clock mode: The timer counts down in synchronization with the internal clock.
- Event count mode: The timer counts down in synchronization with the external input pulse.

**Counter operation modes** 

- Reload mode: The timer repeats counting by reloading the count setting value.
- One-shot mode: The timer stops counting when an underflow occurs.

■ 16-bit reload timer operating modes

| Clock mode            | Counter operation | Operation of 16-bit reload timer                            |
|-----------------------|-------------------|-------------------------------------------------------------|
| Internal clock mode   | Reload mode       | Software trigger operation                                  |
|                       | One-shot mode     | External trigger operation<br>External gate input operation |
| Event count mode      | Reload mode       | Software trigger operation                                  |
| (external clock mode) | One-shot mode     |                                                             |

 Table 12.1-1
 16-Bit Reload Timer Operating Modes

### Internal Clock Mode

The 16-bit reload timer is in internal clock mode if the count clock setting bits (CSL1, CSL0) of the timer control status register (TMCSR) are set to  $"00_B"$ ,  $"01_B"$ , or  $"10_B"$ .

For internal clock mode, select one of the following three operations:

### O Software trigger operation

Counting starts when the software trigger bit (TRG) is set to "1" while the count enable bit (CNTE) of the TMCSR register is set to "1".

### O External trigger operation

Counting starts when a valid edge (rising, falling, or both edges) of trigger input specified in the operation mode setting bits (MOD2, MOD1, and MOD0) is input to the TIN pins while the CNTE bit of the TMCSR register is set to "1".

### O External gate input operation

Counting continues while a valid level of gate input ("L" or "H") specified in the operation mode setting bits (MOD2, MOD1, and MOD0) is input to the TIN pins while the CNTE bit of the TMCSR register is set to "1".

### Event Count Mode (External Clock Mode)

The 16-bit reload timer is in event count mode (external clock) if the count clock setting bits (CSL1, CSL0) of the timer control status register (TMCSR) are set to " $11_B$ ". Counting starts when a valid edge (rising, falling, or both edges) of trigger input specified in the operation mode setting bits (MOD2, MOD1, and MOD0) is input to the TIN pins while the CNTE bit is set to "1". The 16-bit reload timer can also be used as an interval timer if external clock is input periodically.

### Counter Operation

### O Reload mode

Counting starts when an underflow of the 16-bit down counter (change from " $0000_{H}$ " to "FFFF<sub>H</sub>") loads the values of the 16-bit reload register (TMRLR) into the 16-bit down counter. Since the 16-bit reload timer causes an interrupt request to occur for an underflow condition, it can be used as an interval timer. Every time an underflow occurs, a reversed toggle waveform can be output from the T0 pin.

### Table 12.1-2 Intervals for the 16-Bit Reload Timer

| Count clock    | Count clock period                 | Interval             |
|----------------|------------------------------------|----------------------|
| Internal clock | 2 <sup>1</sup> /φ (0.125 μs)       | 0.125 μs to 8.192 ms |
|                | 2 <sup>3</sup> /φ (0.5 μs)         | 0.5 μs to 32.768 ms  |
|                | 2 <sup>5</sup> /φ (2.0 μs)         | 2.0 μs to 131.1 ms   |
| External clock | $2^{3/\phi}$ or more (0.5 $\mu$ s) | 0.5 μs or more       |

Values in parentheses are for a 16 MHz machine clock.

### O Single-shot mode

An underflow of the 16-bit down counter (change from "0000<sub>H</sub>" to "FFFF<sub>H</sub>") stops counting.

### **Reference:**

- 16-bit reload timer 0 can be used to create the baud rate of UART.
- 16-bit reload timer 1 can be used to provide a start trigger of the A/D converter.

### **CHAPTER 12 16-BIT RELOAD TIMER**

### ■ 16-Bit Reload Timer Interrupts and El<sup>2</sup>OS

An underflow of the 16-bit down counter (change from  $"0000_{H}"$  to "FFFF<sub>H</sub>") outputs an interrupt request.

Table 12.1-3 16-Bit Reload Timer Interrupts and El<sup>2</sup>OS

| Channel               | -                      |                  | t control<br>ster   | Vect                | El <sup>2</sup> OS  |                     |       |
|-----------------------|------------------------|------------------|---------------------|---------------------|---------------------|---------------------|-------|
| Chainei               | number                 | Register<br>name | Address             | Lower               | Upper               | Bank                | EI-05 |
| 16-bit reload timer 0 | #23 (17 <sub>H</sub> ) | ICR06 000        | 0000B6 <sub>H</sub> | FFFFA0 <sub>H</sub> | FFFFA1 <sub>H</sub> | FFFFA2 <sub>H</sub> |       |
| 16-bit reload timer 1 | #24 (18 <sub>H</sub> ) |                  | ооорон              | FFFF9C <sub>H</sub> | FFFF9D <sub>H</sub> | FFFF9E <sub>H</sub> | Δ     |
| 16-bit reload timer 2 | #21 (15 <sub>H</sub> ) | ICR05            | 0000B5 <sub>H</sub> | FFFFA8 <sub>H</sub> | FFFFA9 <sub>H</sub> | FFFFAA <sub>H</sub> |       |

 $\triangle$  : Usable when an interrupt cause that shares the ICR is not used.

### 12.2 Configuration of the 16-Bit Reload Timer

Each of the 16-bit reload timers 0 to 2 consists of the following blocks:

- Count clock generation circuit
- Reload control circuit
- Output control circuit
- Operation control circuit
- 16-bit timer register (TMR)
- 16-bit reload register (TMRLR)
- Timer control status register (TMCSR)
- Block Diagram of the 16-Bit Reload Timer



\*2 Channel 1

### O Count clock generation circuit

This circuit generates the count clock for the 16-bit reload timer from the machine clock or external input clock.

### O Reload control circuit

This circuit controls starting of the 16-bit down counter and, if an underflow (change from  $0000_H$  to FFFF<sub>H</sub>) is detected, the load operation for loading a value into the 16-bit down counter.

### O Output control circuit

This circuit controls the inversion of the TO pin output through an underflow of the 16-bit down counter (change from " $0000_{H}$ " to "FFFF<sub>H</sub>") and enabling and disabling of TO pin output.

### O Operation control circuit

This circuit controls activation and stop of the 16-bit down counter.

### ○ 16-bit timer register (TMR)

This register is a 16-bit down counter. The current counter value is read from this register during a read operation.

### ○ 16-bit reload register (TMRLR)

This register stores a value to be loaded to the 16-bit down counter. The setting value of this register is loaded to the 16-bit down counter, which then starts counting down.

### O Timer control status register (TMCSR)

This register selects the operation mode of the 16-bit reload timer, the count clock, and the operating conditions, enables and disables counting, controls interrupts, and checks the statuses of interrupt requests.

### 12.3 16-Bit Reload Timer Pins

This section describes the pins of the 16-bit reload timer and provides a pin block diagram.

### ■ 16-Bit Reload Timer Pins

The pins of the 16-bit reload timer are shared with the general-purpose ports.

Table 12.3-1 16-Bit Reload Timer Pins

| Pin name | Pin function                         | I/O format               | Pull-up<br>option | Standby<br>control | Settings required for<br>pins                        |
|----------|--------------------------------------|--------------------------|-------------------|--------------------|------------------------------------------------------|
| PB4/TIN0 | Port B input-output/<br>timer input  | CMOS output/             | Not               |                    | Setting for the input port<br>(DDRB: bit12=0)        |
| PB5/TO0  | Port B input-output/<br>timer output | CMOS hysteresis<br>input | available         | Available          | Setting for timer output<br>enable<br>(TMCR0:OUTE=1) |

### Block Diagram of the 16-Bit Reload Timer Pins





### 12.4 16-Bit Reload Timer Registers

The 16-bit reload timer registers are as follows.

### ■ 16-Bit Reload Timer Registers

### Figure 12.4-1 16-Bit Reload Timer Registers

bit 15 ····· bit 8 bit 7 ···· bit 0 Timer control status register (TMCSR)

16-bit timer register/16-bit reload register (TMR/TMRLR) (\*1)

\*1 This register functions as a 16-bit timer register (TMR) during reading, and functions as a 16-bit reload register (TMRLR) during writing.

### 12.4.1 Timer Control Status Register, Higher (TMCSR)

The timer control status register (TMCSR) is used to select the operating mode and the count clock of the 16-bit reload timer.

- Figure 12.4-2 Timer Control Status Register, Higher (TMCSR) Bit 13 12 11 10 9 8 7 Initial value 15 14 ХХХХ00000в \_\_\_\_ CSL1 CSL0 MOD2 MOD1 MOD0 \_\_\_\_ \_\_\_\_ R/W R/W R/W R/W R/W \_ -Operating mode selection bit (in the internal clock mode) MOD2 MOD1 MOD0 Input terminal function Valid edge, level 0 0 0 Trigger inhibit -0 1 Rising edge 0 0 1 0 Trigger input Falling edge 1 1 Both edges 0 "L" level 1 Х 0 Gate input 1 Х 1 "H" level Operating mode selection bit MOD2 MOD1 MOD0 (in the event count mode) Input terminal function Valid edge Х 0 0 \_ -Х 0 1 Rising edge Х 1 0 Trigger input Falling edge Х 1 Both edges 1 Count clock selection bit CSL1 CSL0 Function Count clock 0 0 2<sup>1</sup>/ \$\phi\$ (0.125 \mus) 0 1 Internal clock mode 2<sup>3</sup>/ φ (0.5 μs) 0 2<sup>5</sup>/ φ (2.0 μs) 1 1 1 External event input Event count mode
- Timer Control Status Register, Higher (TMCSR)

### R/W : Read/write

- : Undefined bit
- X : Indefinite : Initial value
- : Machine clock, the value in the parentheses () indicates the value when the machine clock is operated at 16MHz.

CSL1, CSL0:

٠

bit12

bit11

| (TMCSR) |                         |                           |                                                                                                                                   |  |  |  |  |  |  |  |
|---------|-------------------------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
|         |                         | Bit name                  | Function                                                                                                                          |  |  |  |  |  |  |  |
|         | bit15<br>bit14<br>bit13 | Not used<br>Undefined bit | <ul><li>When these bits are read, their values are undefined.</li><li>Writing to these bits has no effect on operation.</li></ul> |  |  |  |  |  |  |  |

These bits select the count clock of the 16-bit reload timer.

# Table 12.4-1 Function Description of Each Bit of the Higher of the Timer Control Status Register

| bit10                | Count clock selection bits                            | <ul> <li>When these bits are set to "00<sub>B</sub>", "01<sub>B</sub>", and "10<sub>B</sub>", internal clock mode is selected.</li> <li>When these bits are set to 11<sub>B</sub>, event count mode is set.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |  |
|----------------------|-------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| bit9<br>bit8<br>bit7 | MOD2, MOD1, MOD0:<br>Operating mode<br>selection bits | <ul> <li>When these bits are set to 11<sub>B</sub>, event count mode is set.</li> <li>These bits select operation mode.</li> <li>In internal clock mode: <ul> <li>The MOD2 bit is used to select input pin functions.</li> </ul> </li> <li>When the MOD2 bit is set to "0", the input pin is used as a trigger input pin. Whenever a valid edge is input, the value in the 16-bit reload register (TMRLR) is loaded into the counter and counting starts. The MOD1 and MOD0 bits select the type of valid edge.</li> <li>When the MOD2 bit is set to "1", the input pin becomes a gate. Counting continues as long as a valid level specified in the MOD0 bit is input.</li> <li>The value specified in the MOD1 bit has no effect on operation.</li> <li>In event count mode: <ul> <li>In event count mode, the input pin becomes a trigger input pin. Counting starts when a valid edge specified in the MOD1 and MOD0 bits is input.</li> </ul> </li> </ul> |  |  |  |  |  |  |  |  |  |

### 12.4.2 Timer Control Status Register, Lower (TMCSR)

The timer control status register (TMCSR) is used to set the operating conditions of the 16-bit reload timer, enable and disable counting, control interrupts, and check the status of interrupt requests.

■ Timer Control Status Register, Lower (TMCSR)





R/W : Read/write

: Initial value

\* : See Section 12.4.1, "Timer Control Status Register, Higher (TMCSR)," for MOD0 (bit 7)

| Table 12.4-2         Function Description of Each Bit of the Lower of the Timer Control StatusRegister |
|--------------------------------------------------------------------------------------------------------|
| (TMCSR)                                                                                                |

|      | Bit name                                           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |
|------|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| bit6 | OUTE:<br>Timer output<br>enable bit                | <ul> <li>This bit enables or disables output to the timer output pin.</li> <li>When this bit is set to "0", the pin serves as an I/O port. When this bit is set to "1", the pin serves as a timer output pin.</li> </ul>                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |
| bit5 | OUTL:<br>Pin output level<br>setting bit           | <ul> <li>This bit selects the output level of the timer output pin.</li> <li>The timer output pin outputs a toggle waveform in reload mode or a square wave indicating that counting is in progress in one-shot mode.</li> <li>Opposite output levels are output from the pin depending on whether this bit is set to "0" or "1".</li> </ul>                                                                                                                                                      |  |  |  |  |  |  |  |  |
| bit4 | RELD:<br>Reload selection bit                      | <ul> <li>This bit enables reloading.</li> <li>When this bit is set to "1", the timer is in reload mode. When an underflow of the 16-bit down counter occurs, the value stored in the 16-bit reload register is loaded into the 16-bit down counter and counting continues.</li> <li>When this bit is set to "0", the timer is in one-shot mode. When an underflow of the 16-bit down counter occurs, counting stops.</li> </ul>                                                                   |  |  |  |  |  |  |  |  |
| bit3 | INTE:<br>Underflow interrupt<br>request enable bit | <ul> <li>This bit enables interrupt requests.</li> <li>When this bit and the interrupt request flag (UF) bit are 1, the timer outputs an interrupt request.</li> </ul>                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |
| bit2 | UF:<br>Underflow interrupt<br>request flag bit     | <ul> <li>This is a flag bit for an interrupt request.</li> <li>This bit is set to "1" when an underflow of the 16-bit down counter occurs.</li> <li>An interrupt request is output when this bit is set to "1" while the underflow interrupt request enable bit (INTE) is set to "1".</li> <li>Setting this bit to "0" clears an interrupt request.</li> <li>Setting this bit to "1" has no effect on operation.</li> <li>This bit is also cleared when El<sup>2</sup>OS is activated.</li> </ul> |  |  |  |  |  |  |  |  |
| bit1 | CNTE:<br>Count enable bit                          | <ul> <li>This bit enables or disables counting.</li> <li>When this bit is set to "1", the counter is placed in trigger standby mode.<br/>Counting starts when the software trigger bit (TRG) is set to "1" or a valid<br/>edge (rising, falling, or both edges) of trigger input specified in the operation<br/>mode setting bits (MOD2, MOD1, and MOD0) is input to the TIN pins.</li> <li>When this bit is set to "0", counting stops.</li> </ul>                                               |  |  |  |  |  |  |  |  |
| bit0 | TRG:<br>Software trigger bit                       | <ul> <li>This bit starts the interval timer function or counter function with software.</li> <li>When this bit is set to "1" while the count enable bit (CNTE) is set to "1", the value stored in the 16-bit reload register is loaded into the 16-bit down counter and counting starts.</li> <li>When this bit is set to "0", there is no effect on operation.</li> <li>The read value is "0".</li> </ul>                                                                                        |  |  |  |  |  |  |  |  |

### 12.4.3 16-bit Timer Register (TMR)

The 16-bit timer register (TMR) is always able to read the count value from the 16-bit down counter.

### ■ 16-bi t Timer Register (TMR)



Figure 12.4-4 16-Bit Timer Register (TMR)

R: Read only X: Undefined

The 16-bit timer register is a 16-bit down counter.

When the software trigger bit (TRG) is set to "1" while the count enable bit (CNTE) of the timer control status register (TMCSR) is set to "1" or a valid edge (rising, falling, or both edges) of trigger input specified in the operation mode setting bits (MOD2, MOD1, and MOD0) is input to the TIN pins, the values stored in the 16-bit reload register (TMRLR) are loaded into the 16-bit down counter and counting starts. This register holds the value of the 16-bit timer register (TMR) while counting is stopped (TMCSR: CNTE = "0").

### Notes:

- Be sure to use a word transfer instruction (MOVW A, 003A<sub>H</sub>) to read data from the 16-bit timer register (TMR).
- Although 16-bit timer register (TMR) is read-only and the 16-bit reload register (TMRLR) is write-only, they are placed at the same address. Thus, writing a value to the 16-bit timer register has no effect on this register because the value is written to the 16-bit reload register.

### 12.4.4 16-bit Reload Register (TMRLR)

The 16-bit reload register (TMRLR) sets a reload value in the 16-bit down counter. The value written to this register is loaded into the down counter, and the value is counted down.

### 16-Bit Reload Register (TMRLR)



Figure 12.4-5 16-Bit Reload Register (TMRLR)

When a value is written to the 16-bit reload register (TMRLR), counting must be stopped (TMCSR:CNTE="0") regardless of the operating mode of the 16-bit reload register. While the count enable bit (CNTE) of the timer control status register (TMCSR) is set to "1", a value stored in the 16-bit reload register is loaded into the 16-bit down counter and countdown starts in one of two cases: the software trigger bit (TRG) is set to "1" or a valid edge (rising, falling, or both edges) of the trigger input specified in the operation mode setting bits (MOD2, MOD1, and MOD0) is input to the TIN pins.

In reload mode, when an underflow of the 16-bit down counter occurs (change from " $0000_{\text{H}}$ " to "FFFF<sub>H</sub>"), a value stored in the 16-bit reload register (TMRLR) is loaded into the 16-bit down counter and countdown continues. In one-shot mode, when an underflow of the 16-bit down counter occurs, the 16-bit down counter stops at the value "FFFF<sub>H</sub>".

### Notes:

- Counting must be stopped (TMCSR: CNTE = "0") when a value is written to the 16-bit reload register (TMRLR).
- Use a word transfer instruction (MOVW 003A<sub>H</sub>, A) to write a value to the 16-bit reload register (TMRLR).
- Although the 16-bit reload register (TMRLR) is write-only and the 16-bit timer register (TMR) is read-only, they are placed at the same address. Since different values are written to, and read from these registers, none of the INC/DEC and other instructions that result in read-modify-write (RMW) operations can be used.

### 12.5 16-Bit Reload Timer Interrupts

The 16-bit reload timer outputs an interrupt request when an underflow of the 16-bit down counter occurs. The 16-bit reload timer also supports the extended intelligent I/ O service (El<sup>2</sup>OS).

### ■ 16-Bit Reload Timer Interrupts

|                              | 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 cause              | Underflow of the 16-bit down counter (TMR0) | Underflow of the 16-bit down counter (TMR1) |  |  |  |  |  |

 Table 12.5-1
 Interrupt Control Bits and Interrupt Causes of the 16-Bit Reload Timer

In the 16-bit reload timer, the underflow interrupt request flag bit (UF) of the timer control status register (TMCSR) is set to "1" when an underflow of the 16-bit down counter occurs (change from " $0000_{\text{H}}$ " to "FFFF<sub>H</sub>"). If, at this time, the underflow interrupt request enable bit is set to Enabled (TMSCR: INTE = "1"), an interrupt request is output.

### ■ 16-Bit Reload Timer Interrupts and El<sup>2</sup>OS

### Table 12.5-2 16-Bit Reload Timer Interrupts and El<sup>2</sup>OS

| Channel               | Interrupt              | Interrup<br>regi | t control<br>ster   | Vect                | EI <sup>2</sup> OS  |                     |       |
|-----------------------|------------------------|------------------|---------------------|---------------------|---------------------|---------------------|-------|
| Chainei               | number                 | Register<br>name | Address             | Lower               | Upper               | Bank                | EI-03 |
| 16-bit reload timer 0 | #23 (17 <sub>H</sub> ) | ICR06            | 0000В6 <sub>Н</sub> | FFFFA0 <sub>H</sub> | FFFFA1 <sub>H</sub> | FFFFA2 <sub>H</sub> |       |
| 16-bit reload timer 1 | #24 (18 <sub>H</sub> ) |                  | 0000B0H             | FFFF9C <sub>H</sub> | FFFF9D <sub>H</sub> | FFFF9E <sub>H</sub> | Δ     |
| 16-bit reload timer 2 | #21 (15 <sub>H</sub> ) | ICR05            | 0000B5 <sub>H</sub> | FFFFA8 <sub>H</sub> | FFFFA9 <sub>H</sub> | FFFFAA <sub>H</sub> |       |

 $\triangle$  : Usable when an interrupt cause that shares the ICR is not used.

### ■ El<sup>2</sup>OS Function of the 16-Bit Reload Timer

The 16-bit reload timer allows the use of the extended intelligent I/O service (EI<sup>2</sup>OS) when an underflow of the 16-bit down counter occurs (change from " $0000_{H}$ " to "FFFF<sub>H</sub>").

### 12.6 Operation of the 16-Bit Reload Timer

This section describes the 16-bit reload timer settings and counter operating status.

### 16-Bit Reload Timer Settings

### O Internal clock mode setting

The setting shown in Figure 12.6-1 "Internal Clock Mode Setting" is required to operate this timer as an interval timer.

| Figure 12.6-1 Internal Clock Mode Setting                 |     |    |    |    |    |      |      |      |      |      |      |      |      |      |    |      |     |
|-----------------------------------------------------------|-----|----|----|----|----|------|------|------|------|------|------|------|------|------|----|------|-----|
|                                                           | Bit | 15 | 14 | 13 | 12 | 11   | 10   | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2  | 1    | 0   |
| TMCSR                                                     |     |    | _  | _  |    | CSL1 | CSL0 | MOD2 | MOD1 | MOD0 | OUTE | OUTL | RELD | INTE | UF | CNTE | TRG |
| / ⊚ ⊘ ⊘ ⊘ ⊘ ⊘ 0 0 0 0 0 0 0 0 0 0 0 0 0 0                 |     |    |    |    |    |      |      |      |      | 1    | 0    |      |      |      |    |      |     |
| TMRL Set the initial value (reload value) of the counter. |     |    |    |    |    |      |      |      |      |      |      |      |      |      |    |      |     |
| ⊚: Used                                                   |     |    |    |    |    |      |      |      |      |      |      |      |      |      |    |      |     |

1 : Set 1.

#### O Event counter mode setting

he setting shown in Figure 12.6-2 "Event Counter Mode Setting" is required to operate this timer as an event counter.

#### Figure 12.6-2 Event Counter Mode Setting



#### Counter Operating Status

The 16-bit down counter status is determined by the count enable bit (CNTE) values of the timer control status register (TMCSR) and the internal trigger wait signal value (WAIT). Figure 12.6-3 "Counter Status Transition" shows the relationship between the count enable bit (CNTE) values and the internal trigger wait signal (WAIT) values in the stop status (STOP status), trigger wait status (WAIT status), and running status (RUN status)



Figure 12.6-3 Counter Status Transition

- WAIT : Wait signal (internal signal)
- TRG : Software trigger bit of timer control status register (TMCSR)
- CNTE : Count enable bit of timer control status register (TMCSR)
- UF : Underflow interrupt request flag bit of timer control status register (TMCSR)
- RELD : Reload selection bit of timer control status register (TMCSR)

### 12.6.1 Internal Clock Mode (Reload Mode)

The 16-bit reload timer count downs the 16-bit down counter in synchronization with the internal count clock and outputs an interrupt request when an underflow occurs (change from " $0000_{\text{H}}$ " to "FFFF<sub>H</sub>"). It can also output a toggle waveform from the timer output pin.

#### Operation in Internal Clock Mode (Reload Mode)

While the count enable bit (CNTE) of the timer control status register (TMCSR) is set to "1", a value stored in the 16-bit reload register (TMRLR) is loaded into the 16-bit down counter, and then countdown starts in one of the following cases: the software trigger bit (TRG) is set to "1", or a valid edge (rising, falling, or both edges) of the trigger input specified in the operation mode setting bits (MOD2, MOD1, and MOD0) is input to the TIN pins. When the CNTE bit and the software trigger bit are set to "1" simultaneously, countdown starts as soon as counting is enabled.

When an underflow of the 16-bit down counter occurs (change from " $0000_{H}$ " to "FFFF<sub>H</sub>"), a value stored in the 16-bit reload register (TMRLR) is loaded into the 16-bit down counter and countdown continues. An interrupt request is output to the CPU when an underflow of the 16-bit down counter occurs while the underflow interrupt request flag bit (UF) of the timer control status register (TMCSR) is "1" and the underflow interrupt request enable bit (INTE) is "1".

The timer can also output from the TO pin a toggle waveform, which is inverted for each underflow.

#### • Software trigger operation

Counting starts when the software trigger bit (TRG) is set to "1" while the count enable bit (CNTE) of the timer control status register (TMCSR) is set to "1".

| Count clock      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Counter          | X1 X0000;XX1 X0000;X1 X |
| Data load signal | Reload data Reload data Reload data Reload data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| UF bit           | NNNNNN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| CNTE bit         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| TRG bit          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| TO pin           | → <sub>T*</sub> : ←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

#### Figure 12.6-4 Count Operation in Reload Mode (Software Trigger Operation)

T: Machine cycle (one cycle of the machine clock)

\* It takes 1T time from trigger input to loading of the reload data.

#### **O** External trigger operation

Counting starts when a valid edge (rising, falling, or both edges) of trigger input specified in the operation mode setting bits (MOD2, MOD1, and MOD0) is input to the TIN pins while the count enable bit (CNTE) of the timer control status register (TMCSR) is set to "1".



#### Figure 12.6-5 Count Operation in Reload Mode (External Trigger Operation)

T: Machine cycle (one cycle of the machine clock)

\* It takes 2T to 2.5T time from external trigger input to loading of the reload data.

#### Note:

Specify  $2/\phi$  ( $\phi$ : machine clock frequency) or more for the width of a trigger pulse to be input to the TIN pin.

#### **O** Gate input operation

Counting starts when the software trigger bit (TRG) is set to "1" while the count enable bit (CNTE) of the timer control status register (TMCSR) is set to "1".

Counting continues while a valid level of gate input ("L" or "H") specified in the operation mode setting bits (MOD2, MOD1, and MOD0) is input to the TIN pin.

#### Figure 12.6-6 Count Operation in Reload Mode (Software Trigger, Gate Input Operation)

| Count clock      |                                                                                                                                   |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Counter          | X         Reload data         X         -1         X         -1         X         00000         X         -1         X         -1 |
| Data load signal |                                                                                                                                   |
| UF bit           | Γ                                                                                                                                 |
| CNTE bit         |                                                                                                                                   |
| TRG bit          |                                                                                                                                   |
| TIN pin          | → <sup>*</sup> <sup>*</sup>                                                                                                       |
| TO pin           |                                                                                                                                   |

T: Machine cycle (one cycle of the machine clock)

\* It takes 1T time from trigger input to loading of the reload data.

#### Note:

Specify  $2/\phi$  ( $\phi$  : machine clock frequency) or more for the width of a gate input pulse to be input to the TIN pin.

### 12.6.2 Internal Clock Mode (Single-shot Mode)

The 16-bit reload timer count downs the 16-bit down counter in synchronization with the internal count clock and outputs an interrupt request when an underflow occurs (change from " $0000_{\text{H}}$ " to "FFFF<sub>H</sub>"). It can also output a square waveform from the T0 pin.

#### Internal Clock Mode (Single-Shot Mode)

When the software trigger bit (TRG) is set to "1" while the count enable bit (CNTE) of the timer control status register (TMCSR) is set to "1" or a valid edge (rising, falling, or both edges) of trigger input specified in the operation mode setting bits (MOD2, MOD1, and MOD0) is input to the TIN pins, a value stored in the 16-bit reload register (TMRLR) is loaded into the 16-bit down counter and countdown starts. When both the CNTE bit and the software trigger bit (TMCSR: TRG) are set to "1", countdown starts as soon as counting is enabled.

When an underflow of the 16-bit down counter occurs (change from " $0000_{H}$ " to "FFFF<sub>H</sub>"), the 16-bit down counter stops counting at the value "FFFF<sub>H</sub>".

An interrupt request is output when an underflow of the 16-bit down counter occurs while the underflow interrupt request flag bit (UF) of the timer control status register (TMCSR) is set to "1" and the underflow interrupt request enable bit (INTE) is set to "1".

The timer can also output from the TO pin a rectangular waveform indicating that counting is in progress.

#### • Software trigger operation

Counting starts when the software trigger bit (TRG) is set to "1" while the count enable bit (CNTE) of the timer control status register (TMCSR) is set to "1".



#### Figure 12.6-7 Count Operation in Single-Shot Mode (Software Trigger Operation)

T: Machine cycle (one cycle of the machine clock)

\* It takes 1T time from trigger input to loading of the reload data.

#### **O** External trigger input operation

Counting starts when a valid edge (rising, falling, or both edges) of trigger input specified in the operation mode setting bits (MOD2, MOD1, and MOD0) is input to the TIN pins while the count enable bit (CNTE) of the timer control status register (TMCSR) is set to "1".





T: Machine cycle (one cycle of the machine clock)

\* It takes 2T to 2.5T time from external trigger input to loading of the reload data.

#### Note:

Specify 2/\u00f3 or more for the width of the trigger pulse input to the TIN pin.

#### O External Gate input operation

Counting starts when the software trigger bit (TRG) is set to "1" while the count enable bit (CNTE) of the timer control status register (TMCSR) is set to "1".

Counting continues while a valid level of gate input ("L" or "H") specified in the operation mode setting bits (MOD2, MOD1, and MOD0) is input to the TIN pin.

#### Figure 12.6-9 Count Operation in Single-Shot Mode (Software Trigger Gate Input Operation)



T: Machine cycle (one cycle of the machine clock)

\* It takes 1T time from trigger input to loading of the reload data.

#### Note:

Specify  $2/\phi$  ( $\phi$  : machine clock frequency) or more for the width of a gate input pulse to be input to the TIN pin.

### 12.6.3 Event Count Mode

The 16-bit reload timer count downs the 16-bit down counter every time it detects a valid edge of pulse input to the TIN pin and outputs an interrupt request when an underflow occurs (change from " $0000_{H}$ " to "FFFF<sub>H</sub>"). It can also output a toggle or square waveform from the T0 pin.

#### Event Count Mode

When the software trigger bit (TRG) is set to "1" while the count enable bit (CNTE) of the timer control status register (TMCSR) is set to "1", a value stored in the 16-bit reload register (TMRLR) is loaded into the 16-bit down counter and countdown occurs every time a valid edge (rising, falling, or both edges) of pulse input to the TIN pin (external count clock) is detected. When both the CNTE bit and the software trigger bit (TRG) are set to "1", countdown starts as soon as counting is enabled.

#### O Operation in reload mode

When an underflow of the 16-bit down counter occurs (change from " $0000_{\text{H}}$ " to "FFFF<sub>H</sub>"), a value stored in the 16-bit reload register (TMRLR) is loaded into the 16-bit down counter and countdown continues.

An interrupt request is output to the CPU when an underflow of the 16-bit down counter (change from  $0000_H$  to FFFF<sub>H</sub>) occurs while the underflow interrupt request flag bit (UF) of the timer control status register (TMCSR) is set to "1" and the underflow interrupt request enable bit (INTE) is set to "1".

The timer can also output from the TO pin a toggle waveform, which is inverted for each underflow.



Figure 12.6-10 Count Operation in Reload Mode (Event Count Mode)

T: Machine cycle (one cycle of the machine clock)

\* It takes 1T time from trigger input to loading of the reload data.

#### Note:

Specify  $2^2/\phi$  or more for the H and L widths of the pulse input to the TIN pin.

#### **O** Operation in single-shot mode

When an underflow of the 16-bit down counter occurs (change from  $"0000_{\text{H}}"$  to "FFFF<sub>H</sub>"), the 16-bit down counter stops counting at the value "FFFF<sub>H</sub>".

An interrupt request is output to the CPU when an underflow of the 16-bit down counter (change from  $0000_H$  to FFFF<sub>H</sub>) occurs while the underflow interrupt request flag bit (UF) of the timer control status register (TMCSR) is "1" and the underflow interrupt request enable bit (INTE) is "1".

The timer can also output from the TO pin a rectangular waveform indicating that count.

Figure 12.6-11 Counter Operation in Single-Shot Mode (Event Count Mode)



T: Machine cycle (one cycle of the machine clock)

\* It takes 1T time from trigger input to loading of the reload data.

#### Note:

Specify  $2^2/\phi$  or more for the H and L widths of the pluse input to the TIN pin.

### 12.7 Usage Notes on the 16-Bit Reload Timer

#### Notes on using the 16-bit reload timer are given below.

#### ■ Usage Notes on the 16-Bit Reload Timer

#### O Notes on using a program for setting

- Write a value to the 16-bit reload register (TMRLR) when counting stops (TMCSR: CNTE = 0). Also, a value can be read from the 16-bit timer register (TMR) even during counting, but always be sure to use a word transfer instruction (MOVW A, dir, etc.).
- Counting must be stopped (TMCSR: CNTE = "0") when the count clock setting bits (CSL1 and CSL0) of the timer control register (TMCSR) are changed.

#### **O** Notes about interrupts

- When the UF bit of the timer control status register (TMCSR) is set to 1 and an interrupt request is enabled (TMCSR: INTE = 1), control cannot be returned from interrupt processing. Always clear the UF bit.
- The 16-bit reload timer shares the interrupt control register with the 8/16-bit PPG timers. Therefore, if multiple interrupts of the same level are output, the interrupt with a smaller interrupt vector number has precedence.

## CHAPTER 13 16-BIT I/O TIMER

# This chapter describes the functions and operations of the 16-bit I/O timer of the MB90M405 series.

- 13.1 "Overview of the 16-Bit I/O Timer"
- 13.2 "16-Bit I/O Timer Block Diagram"
- 13.3 "16-Bit I/O Timer Registers"
- 13.4 "16-Bit Free-Running Timer Operations"
- 13.5 "16-Bit Output Compare Operations"
- 13.6 "16-Bit Input Capture Operations"

### 13.1 Overview of the 16-Bit I/O Timer

## The 16-bit I/O timer, which is based on a 16-bit free-running timer, can output two independent waveforms and measure an input pulse width and an external clock cycle.

#### ■ 16-bit Free-Running Timer (One Channel)

The 16-bit free-running timer consists of a 16-bit up counter (timer data register [TCDT]), timer control status register (TCCS), and prescaler.

The counter output value of the 16-bit free-running timer is used as the basic time (base timer) for output compare and input capture.

#### O Counter operation clock (one of four types)

Internal clock types:  $\phi/4$ ,  $\phi/16$ ,  $\phi/32$ ,  $\phi/64$ 

φ: Machine clock frequency

#### O Interrupt

An interrupt is issued to the CPU when a counter overflow occurs or the counter value matches the value of compare register 0.

#### O Initialization

The counter value is initialized to  $0000_{\text{H}}$  when a reset occurs, the software reset bit is cleared to "0", or the value of compare register 0 matches the count value of the free-running timer.

#### Output Compare (One Channel)

The output compare module consists of a 16-bit compare register and a control register. When the value of the 16-bit free-running timer matches the compare register value, an interrupt is issued to the CPU.

#### Input Capture (Two Channels)

The input capture module consists of a capture register and a control register, each of which corresponds to two independent external input pins. The capture register stores the value of the 16-bit free-running timer. It can also issue an interrupt to the CPU when an edge of the signal input from an external pin is detected.

- The edge to be detected (rising, falling, or both edges) of an external input signal can be selected.
- Two input capture modules can operate independently.
- An interrupt can be issued upon detection of a valid edge of an external input signal.

An input capture interrupt can be used to start the extended intelligent I/O service.

### 13.2 16-Bit I/O Timer Block Diagram

Figure 13.2-1 "16-Bit I/O Timer Block Diagram" shows a block diagram of the 16-bit I/O timer.

#### ■ 16-Bit I/O Timer Block Diagram



Figure 13.2-1 16-Bit I/O Timer Block Diagram

### 13.3 16-Bit I/O Timer Registers

The 16-bit I/O timer has the following six types of registers:

- Timer counter data register (TCDT)
- Timer counter control status register (TCCS)
- Output compare register (OCCP0)
- Output compare control status register (OCS0)
- Input capture data register (IPC0 and IPC1)
- Input capture control status register (ICS01)

#### ■ 16-Bit I/O Timer Registers

#### Figure 13.3-1 16-Bit I/O Timer Registers

| bit15 ····· bit8                         | bit7 bit0                                     |
|------------------------------------------|-----------------------------------------------|
| Timer counter data register upper (TCDT) | Timer counter data register lower (TCDT)      |
|                                          | Timer counter control status register (TCCS)  |
| Output compare register upper (OCCP)     | Output compare register lower (OCCP)          |
|                                          | Output compare control status register (OCS0) |
| Input capture data register upper (IPC)  | Input capture data register lower (IPC)       |
|                                          | Input capture control status register (ICS01) |

### 13.3.1 16-Bit Free-Running Timer Registers (TCDT and TCCS)

The 16-bit free-running timer has the following registers:

- Timer counter data register (TCDT)
- Timer counter control status register (TCCS)

Timer Counter Data Register (TCDT)

The count value of the 16-bit free-running timer can be read from the timer counter data register (TCDT). A reset clears the counter value to  $0000_B$ . You can set the timer value via the timer counter data register. The setting must be made in stop state (STOP="1").

The 16-bit free-running timer is initialized by any of the following events:

- Reset
- Initialization due to the clear bit (CLR) of the control status register
- Initialization due to a match between compare register 0 for output compare and the timer counter value (mode setting is required)

| Bit | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | Initial value         |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----------------------|
|     | T15 | T14 | T13 | T12 | T11 | T10 | T09 | T08 | 00000000 <sub>B</sub> |
|     | R/W |                       |
|     |     |     |     |     |     |     |     |     |                       |
|     | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   | Initial value         |
|     | T07 | T06 | T05 | T04 | Т03 | T02 | T01 | тоо | 00000000 <sub>в</sub> |
|     | R/W |                       |

Figure 13.3-2 Timer Counter Data Register (TCDT)

R/W : Read/write enabled

#### Note:

The timer counter data register (TCDT) requires word access.

#### Timer Counter Control Status Register (TCCS)

Bit



Figure 13.3-3 Timer Counter Control Status Register (TCCS)

R/W : Read/write enabled

φ

: Initial value

: Machine clock frequency

#### Bit name Function Reserved: bit 7 ٠ Be sure to set this bit to "0". Reserved bit This bit is a flag bit for an interrupt request. ٠ This bit is set to "1" if the counter value of the 16-bit free-running timer IVF: overflows. Free-running timer • An interrupt is output if this bit is set to "1" while the free-running timer bit 6 interrupt enable bit (IVFE) is "1". interrupt request flag An interrupt request is cleared if this bit is set to "0". bit • Setting this bit to "1" does not effect operation. • • Read-modify-write instructions return "1" for this bit. IVFE: This bit enables interrupt requests. Free-running timer bit 5 An interrupt is output if the free-running timer interrupt request flag bit • interrupt request (IVF) is set to "1" while this bit is "1". enable bit ٠ This bit stops the 16-bit free-running timer counter. If this bit is set to "0", the 16-bit free-running timer counter runs. STOP: If this bit is set to "1", the 16-bit free-running timer counter stops. • bit 4 Count stop bit Note: When the 16-bit free-running timer counter stops, the output compare operation also stops. • This bit sets the initialization condition of the 16-bit free-running timer counter value. ٠ If this bit is set to "0", a reset or setting the clear bit (CLR="1") initializes the counter value to 0000<sub>H</sub>. MODE: If this bit is set to "1", a reset, setting the clear bit (CLR="1"), or a match • Free-running timer bit 3 initialization condition between the 16-bit free-running timer counter value and the compare clear register (CPCLR) value initializes the counter value to 0000<sub>H</sub>. setting bit Note: The counter value is cleared at the next counting operation after the ٠ detection of an initialization condition as specified in the MODE bit. • The CLR bit clears the counter value to 0000<sub>H</sub> while the 16-bit freerunning timer counter is running. • If this bit is set to "0", operation is not affected. • If this bit is set to "1", the counter value is cleared to 0000<sub>H</sub>. CLR: bit 2 The read value of this bit is always "0". • Clear bit Note: To clear the counter value to 0000<sub>H</sub> while the 16-bit free-running timer ٠ counter is stopped (STOP="1"), set the timer data register (TCDT) to 0000н. CLK1 and CLK0: These bits select the count clock of the 16-bit free-running timer. bit 1 Count clock selection Set these bits while output compare and input capture are stopped, since bit 0 bits the count clock changes as soon as these bits are set.

#### Table 13.3-1 Functions of the Timer Counter Control Status Register (TCCS) Bits

### 13.3.2 Output Compare Registers (OCCP0 and OCS0)

The output compare unit uses the following registers:

- Output compare register (OCCP0)
- Output compare control status register (OCS0)

#### Output Compare Register (OCCP0)

The output compare register (OCCP0) is a 16-bit register whose value is compared with the 16bit free-running timer. Because the initial value of this register is undefined, set an initial value before enabling timer operation. When the output compare register value matches the 16-bit free-running timer value, a compare signal that sets the output compare interrupt request flag bit to "1" is generated.

 Figure 13.3-4
 Output Compare Register (OCCP0)

 15
 14
 13
 12
 11
 10
 9
 8
 Initial val

| Bit | 15       | 14       | 13       | 12       | 11       | 10       | 9        | 8        | Initial value                          |
|-----|----------|----------|----------|----------|----------|----------|----------|----------|----------------------------------------|
|     | C15      | C14      | C13      | C12      | C11      | C10      | C09      | C08      | XXXXXXXXB                              |
|     | R/W      |                                        |
|     |          |          |          |          |          |          |          |          |                                        |
|     | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        | Initial value                          |
|     | 7<br>C07 | 6<br>C06 | 5<br>C05 | 4<br>C04 | 3<br>C03 | 2<br>C02 | 1<br>C01 | 0<br>C00 | Initial value<br>XXXXXXXX <sub>B</sub> |

R/W : Read/write enabled

X : Undefined

#### Note:

The output compare register (OCCP0) requires word access.

#### Output Compare Control Status Register (OCS0)



#### Figure 13.3-5 Output Compare Control Status Register (OCS0)

R/W : Read/write enabled

X : Undefined - : Undefined bit

: Initial value

253

|                | Bit name                                                   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 7          | -:<br>Undefined bit                                        | <ul><li>The value read from this bit is undefined.</li><li>Setting this bit to a new value does not affect operation.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                        |
| bit 6          | IOP0:<br>Output compare<br>interrupt request flag<br>bit   | <ul> <li>This bit is a flag bit for interrupt requests.</li> <li>This bit is set to "1" if the compare register (OCCP) value matches the value of the 16-bit free-running timer counter.</li> <li>An interrupt is output to the CPU if this bit is set to "1" while the output compare interrupt enable bit (IOE0) is "1".</li> <li>An interrupt request is cleared if this bit is set to "0".</li> <li>Setting this bit to "1" does not affect operation.</li> <li>Read-modify-write instructions return "1" for this bit.</li> </ul> |
| bit 5          | -:<br>Undefined bit                                        | <ul><li>The value read from this bit is undefined.</li><li>Setting this bit to a new value does not affect operation.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                        |
| bit 4          | IOE0:<br>Output compare<br>interrupt request<br>enable bit | <ul> <li>This bit enables interrupt requests.</li> <li>An interrupt request is output to the CPU if the output compare interrupt request flag bit (IOP0) is set to "1" while this bit is "1".</li> </ul>                                                                                                                                                                                                                                                                                                                               |
| bit 3<br>bit 2 | -:<br>Undefined bit                                        | <ul><li>The value read from this bit is undefined.</li><li>Setting this bit to a new value does not affect operation.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                        |
| bit 1<br>bit 0 | CST1, CST0:<br>Compare operation<br>enable bit             | <ul> <li>This bit enables a compare operation between the output compare register (OCCP0) value and the 16-bit free-running timer counter value.</li> <li>Set the output compare register (OCCP0) value before enabling the compare operation.</li> <li>If this bit is set to "1", the compare operation is enabled.</li> </ul>                                                                                                                                                                                                        |

#### Note:

Since output compare is synchronized with the 16-bit free-running timer clock, the compare operation stops when the 16-bit free-running timer stops (TCCS:STOP="1").

### 13.3.3 Input Capture Registers (IPC0/IPC1 and ICSSS0)

The input capture unit has the following registers:

- Input capture data registers (IPC0/IPC1)
- Input capture control status register (ICS01)

#### ■ Input Capture Data Registers (IPC0/IPC1)

The input capture data registers (IPC0/IPC1) retain the value of the 16-bit free-running timer when a valid edge of the corresponding external pin input waveform is detected.

Figure 13.3-6 Input Capture Data Registers (IPC0/IPC1)



R: Read only

X : Undefined

#### Note:

The input capture data registers (IPC0/IPC1) require word access. Writing to these registers is disabled.

#### Input Capture Control Status Register (ICS01)



Figure 13.3-7 Input Capture Control Status Register (ICS01)

R/W : Read/write enabled

]: Initial value

#### Note:

The input capture data register (ICS01) requires byte access.

| Table 13.3-3 Functions of the Input Capture Control Status Register (ICS01) Bits |
|----------------------------------------------------------------------------------|
|----------------------------------------------------------------------------------|

|                      | Bit name                                                            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------------|---------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 7<br>bit 6       | ICP1, ICP0:<br>Input capture interrupt<br>request flag bit          | <ul> <li>This bit is a flag bit for interrupt requests.</li> <li>This bit is set to "1" if a valid edge of an external input pin is detected.</li> <li>An interrupt request is output if this bit is set to "1" while the input capture interrupt enable bits (ICE1 and ICE0) are "1".</li> <li>An interrupt request is cleared if this bit is set to "0".</li> <li>Setting this bit to "1" does not affect operation.</li> <li>Read-modify-write instructions return "1" for this bit.</li> </ul> |
| bit 5<br>bit 4       | ICE1, ICE0:<br>Input capture interrupt<br>request enable bit        | <ul> <li>This bit enables interrupt requests.</li> <li>An interrupt request is output if the input capture interrupt request flag bits (ICP1, ICP0) are set to "1" while this bit is "1".</li> </ul>                                                                                                                                                                                                                                                                                               |
| bit 3<br>to<br>bit 0 | EG11, EG10, EG01,<br>EG00:<br>Valid edge polarity<br>selection bits | <ul> <li>These bits select the polarity of a valid edge of the input waveform and enable or disable the input capture operation.</li> <li>The input capture operation is enabled if these bits are set to 01<sub>B</sub> to 11<sub>B</sub>. The polarity of a valid edge of the input waveform can be selected as rising edge, falling edge, or both edges.</li> <li>If these bits are set to 00<sub>B</sub>, input capture operation and edge detection are disabled.</li> </ul>                  |

### 13.4 16-Bit Free-Running Timer Operations

The 16-bit free-running timer starts counting from the counter value  $0000_B$  after a reset is released. The counter value is used as the reference time for16-bit output compare and 16-bit input capture.

#### ■ 16-Bit Free-Running Timer Operations

A counter value is cleared in the following cases:

- The counter value overflows.
- The counter value matches the value of output compare register 0. (A mode must be set.)
- The clear bit (CLR) of the timer counter control status register (TCCS) is set to "1".
- The timer counter data register (TCDC) is set to 0000<sub>B</sub> during a stop.
- A reset occurs.

An interrupt can be output to the CPU if the free-running timer overflows or if the counter is cleared when the free-running timer value matches the value of compare register 0 (A mode must be set for the compare match interrupt).



#### Figure 13.4-1 Counter Cleared by an Overflow





#### ■ 16-bit Free-Running Timer Count Timing

The 16-bit free-running timer counts up based on the specified internal clock.

|                        | Figure 13.4-3 Count Timing of th                                                                                              | e Free-Running Ti  | mer                 |   |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------|--------------------|---------------------|---|
| φ                      |                                                                                                                               |                    |                     |   |
| Count clock —          |                                                                                                                               |                    |                     |   |
|                        | Ν                                                                                                                             |                    | N + 1               |   |
| reset o                | unter can be cleared using a reset, sol<br>r software clears the counter immedia<br>r in synchronization with the count timin | tely. A match with |                     |   |
| Figure 13.4-4          | Clear Timing of the Free-Running T                                                                                            | imer (Match with   | Compare Register 0) |   |
| ф                      |                                                                                                                               | ·                  |                     | _ |
| Compare register value | Ν                                                                                                                             |                    |                     | _ |
| Compare match          |                                                                                                                               | [                  |                     | _ |
| Counter value          | N X                                                                                                                           | 000                | 00                  | _ |

### 13.5 16-Bit Output Compare Operations

A 16-bit output compare compares the specified compare register value with the value of the 16-bit free-running timer. If a match occurs, the interrupt request flag bit is set to "1".

#### 16-bit Output Compare Operations

Output compare outputs an interrupt when the free-running timer value matches the specified compare register value and a compare match signal is generated.



Figure 13.5-1 Compare Operation When Compare Register Rewritten

### 13.6 16-Bit Input Capture Operations

The 16-bit input capture can capture the 16-bit free-running timer value in the capture register for outputting an interrupt when the specified valid edge is detected.

#### ■ 16-bit Input Capture Operations



#### Figure 13.6-1 Example of Input Capture Timing

Capture0 = Rising edge Capture1 = Falling edge Capture example = Both edges (example)

#### ■ Input Capture Input Timing



## CHAPTER 14 UART

This chapter describes the functions and operations of the MB90M405 series UART.

- 14.1 "Overview of UART"
- 14.2 "Configuration of UART"
- 14.3 "UART Pins"
- 14.4 "UART Registers"
- 14.5 "UART Interrupts"
- 14.6 "UART Baud Rates"
- 14.7 "Operation of UART"
- 14.8 "Notes on Using UART"

### 14.1 Overview of UART

UART is a general-purpose serial data communication interface for performing synchronous or asynchronous (start-stop synchronization) communication with external devices. The UART has a bidirectional communication function (normal mode), additionally the master-slave communication function (multiprocessor mode) is only available for the master system.

#### UART Functions

#### **O UART Functions**

UART is a general-purpose serial data communication interface for transmitting serial data to and receiving data from another CPU and peripheral devices. It has the functions listed in Table 14.1-1 "UART Functions".

#### Table 14.1-1 UART Functions

|                                                                       | Function                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Data buffer                                                           | Full-duplex, double buffering                                                                                                                                                                                                                                                                                                                                               |
| Transfer mode                                                         | <ul><li>Clock synchronous (using start and stop bits)</li><li>Clock asynchronous (start-stop synchronization)</li></ul>                                                                                                                                                                                                                                                     |
| Baud rate                                                             | <ul> <li>Up to 2MHz (when the machine clock is operated at 16MHz)</li> <li>A dedicated baud rate generator is provided.</li> <li>Baud rate by an external clock (clock input through the SCK pins)</li> <li>Internal clock (internal clocks supplied from 16-bit reload timer 0 can be used.)</li> <li>The baud rate can be selected from a total of eight types</li> </ul> |
| Data length                                                           | <ul><li>7 bits (in asynchronous normal mode only)</li><li>8 bits</li></ul>                                                                                                                                                                                                                                                                                                  |
| Signal mode                                                           | Non-return to zero (NRZ)                                                                                                                                                                                                                                                                                                                                                    |
| Reception error<br>detection                                          | <ul> <li>Framing error</li> <li>Overrun error</li> <li>Parity error (cannot be detected in multiprocessor mode.)</li> </ul>                                                                                                                                                                                                                                                 |
| Interrupt request                                                     | <ul> <li>Reception interrupt (reception completion and reception error detection)</li> <li>Transmission interrupt (transmission completion)</li> <li>Extended intelligent I/O service (EI<sup>2</sup>0S) is available for both transmission and reception interrupts.</li> </ul>                                                                                            |
| Master-slave<br>communication<br>function<br>(multiprocessor<br>mode) | One-to-n communication (one master to n slaves) can be performed. (This function is supported only for the master system.)                                                                                                                                                                                                                                                  |

#### Note:

During clock synchronous transfer, start and stop bits are not added so only data is transferred in UART.

#### Table 14.1-2 UART Operation Mode

| Operation mode |                | Data I                  | ength                  | Synchronization | Stop bit                    |  |
|----------------|----------------|-------------------------|------------------------|-----------------|-----------------------------|--|
|                |                | When parity is disabled | When parity is enabled | on mode         | length                      |  |
| 0              | Normal mode    | 7 or 8 bits             |                        | Asynchronous    | 1 or 2 bits <sup>(*2)</sup> |  |
| 1              | Multiprocessor | 8+1 <sup>(*1)</sup>     | -                      | Asynchronous    |                             |  |
| 2              | Normal mode    | 8                       | -                      | Synchronous     | None                        |  |

-: Setting not possible

\*1: "+1" indicates the address/data selection bit (A/D) for communication control.

\*2: During reception, only one stop bit can be detected.

#### ■ UART Interrupt and El<sup>2</sup>OS

Table 14.1-3 UART Interrupt and El<sup>2</sup>OS

| Interrupt cause              | Interrupt<br>number   | Interrupt control<br>register |                     | Vector table address |                     |                     | El <sup>2</sup> OS |
|------------------------------|-----------------------|-------------------------------|---------------------|----------------------|---------------------|---------------------|--------------------|
|                              |                       | Register<br>name              | Address             | Lower                | Upper               | Bank                | EI 05              |
| UART0 reception<br>interrupt | #35(23 <sub>H</sub> ) | ICR12                         | 0000BC <sub>H</sub> | FFFF70 <sub>H</sub>  | FFFF71 <sub>H</sub> | FFFF72 <sub>H</sub> | Ø                  |
| UART0 transmission interrupt | #36(24 <sub>H</sub> ) |                               |                     | FFFF6C <sub>H</sub>  | FFFF6D <sub>H</sub> | FFFF6E <sub>H</sub> | Δ                  |
| UART1 reception<br>interrupt | #39(27 <sub>H</sub> ) | ICR14                         | 0000BE <sub>H</sub> | FFFF60 <sub>H</sub>  | FFFF61 <sub>H</sub> | FFFF62 <sub>H</sub> | Ø                  |
| UART1 transmission interrupt | #40(28 <sub>H</sub> ) | 101314                        |                     | FFFF5C <sub>H</sub>  | FFFF5D <sub>H</sub> | FFFF5E <sub>H</sub> | Δ                  |

◎ : Provided with a function that detects a UART reception error and stops EI<sup>2</sup>OS

△: Usable when ICR12 and ICR14 or interrupt causes that share an interrupt vector are not used

### 14.2 Configuration of UART

UART consists of the following 11 blocks:

- Clock Selector
- Reception Control Circuit
- Transmission Control Circuit
- Reception Status Detection Circuit
- Reception Shift Register
- Transmission Shift Register
- Mode Control Register (SMR0/1)
- Control Register (SCR0/1)
- Status Register (SSR0/1)
- Input Data Register (SIDR0/1)
- Output Data Register (SODR0/1)

Block Diagram of UART



#### Figure 14.2-1 Block Diagram of UART

#### **O** Clock Selector

The clock selector selects the sending/receiving clock from the dedicated baud rate generator, external input clock (clock input through the SCK0/SCK1 pins), and internal clock (clock supplied from the 16-bit reload timer).

#### **O** Reception Control Circuit

The reception control circuit consists of a received bit counter, start bit detection circuit, and received parity counter. The received bit counter counts receive data bits. When reception of one data item for the specified data length is complete, the received bit counter generates a reception interrupt request. The start bit detection circuit detects start bits from the serial input signal. When the circuit detects a start bit, it writes data in the SIDR0/1 register by shifting at the specified transfer rate. The received parity counter calculates the parity of the receive data.

#### **O** Transmission Control Circuit

The transmission control circuit consists of a transmission bit counter, transmission start circuit, and transmission parity counter. The transmission bit counter counts transmission data bits. When transmission of one data item of the specified data length is complete, the transmission bit counter generates a transmission interrupt request. The transmission start circuit starts transmission when send data is written to the output data register (SODR0/SODR1). The transmission parity counter generates the parity bits for data when transmitting data with parity.

#### • Reception Shift Register

The reception shift register fetches receive data input from the SIN0/1 pin, shifting the data bit by bit. When reception is complete, the reception shift register transfers receive data to the SIDR0/1 register.

#### O Transmission Shift Register

The transmission shift register transfers data written to the SODR0/1 register to itself and outputs the data to the SOT0/1 pin, shifting the data bit by bit.

#### • Mode Control Register (SMR0/1)

The mode register performs the operations of the operation mode setting, baud rate clock setting, serial clock I/O control, and output enable setting of serial data to pins.

#### ○ Control Register (SCR0/1)

The control register performs the operations of the parity presence/absence setting, parity setting, stop bit length/data length settings, frame data format setting in operation mode 1, clearing of received error flag bits, and enable/disable setting of send/receive operations.

#### • Status Register (SSR0/1)

The status register performs the operations of status check for transmission/reception and errors, transfer direction setting of serial data, and enable/disable setting of send/receive interrupt requests.

#### O Input Data Register (SIDR0/1)

This register retains receive data.

#### O Output Data Register (SODR0/1)

This register sets transmission data. Data written to this register is converted to serial data and output.

### 14.3 UART Pins

### This section describes the UART pins and provides a pin block diagram.

#### UART Pins

The UART pins also serve as I/O ports.

#### Table 14.3-1 UART Pins

| Pin name | Pin function                             | I/O format                                  | Pull-up | Standby control | Setting required to use pin                                  |
|----------|------------------------------------------|---------------------------------------------|---------|-----------------|--------------------------------------------------------------|
| SI0      | Port I/O or serial<br>data input         |                                             | Nothing | Provided        | Set as an input port<br>(DDR8: bit2 = 0)                     |
| SO0      | Port I/O or serial data output           | CMOS output<br>and CMOS<br>hysteresis input |         |                 | Set to serial data output enable<br>mode (SMR0: SOE = 1)     |
| SC0      | Port I/O or serial<br>clock input/output |                                             |         |                 | Set as an input port<br>(DDR8: bit3 = 0)                     |
|          |                                          |                                             |         |                 | Set to serial clock output<br>enable mode<br>(SMR0:SCKE = 1) |
| SI1      | Port I/O or serial data input            |                                             |         |                 | Set as an input port<br>(DDR8: bit5 = 0)                     |
| SO1      | Port I/O or serial data output           |                                             |         |                 | Set to serial data output enable<br>mode (SMR1: SOE = 1)     |
| SC1      | Port I/O or serial<br>clock input/output |                                             |         |                 | Set as an input port<br>(DDR8: bit6 = 0)                     |
|          |                                          |                                             |         |                 | Set to serial clock output<br>enable mode<br>(SMR1:SCKE = 1) |

#### Block Diagram of UART Pins



Figure 14.3-1 Block Diagram of UART Pins

### 14.4 UART Registers

The following figure shows the UART registers.

#### ■ UART Registers

### Figure 14.4-1 UART Registers

bit15 ····· bit8 bit7 ···· bit0

| Control register (SCR)                          | Mode control register (SMR)            |  |  |  |
|-------------------------------------------------|----------------------------------------|--|--|--|
| Status register (SSR)                           | Input/output data register (SIDR/SODR) |  |  |  |
| Communication prescaler control register (CDCR) |                                        |  |  |  |

### 14.4.1 Control Register (SCR0/SCR1)

The control register (SCR0/SCR1) is a register for performing the operations of the parity presence/absence setting, parity setting, stop bit length/data length settings, frame data format setting in operation mode 1, clearing of received error flag bits, and enable/disable setting of send/receive operations.

### Control Register (SCR0/SCR1)



Figure 14.4-2 Control Register (SCR0/SCR1)

| Table 14.4-1 | Functions of Bits for Co | ntrol Register (SCR0/SCR1) |
|--------------|--------------------------|----------------------------|
|--------------|--------------------------|----------------------------|

|       | Bit name                                 | Function                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
|-------|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| bit15 | PEN: Parity<br>enable bit                | This bit selects whether to add a parity bit during transmission in serial data input-output mode or to detect it during reception. Note: No parity can be used in operation modes 1 and 2. Therefore, fix this bit to 0.                                                                                                                                                                                                    |  |  |  |  |
| bit14 | P: Parity selection bit                  | This bit specifies the odd parity/even parity.<br><b>Note:</b><br>Valid only when parity presence (PEN="1") is selected.                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| bit13 | SBL: Stop bit<br>length selection<br>bit | This bit selects the length of the stop bits or the frame end mark of send data in asynchronous transfer mode.<br><b>Note:</b><br>During reception, only the first bit of the stop bits is detected.                                                                                                                                                                                                                         |  |  |  |  |
| bit12 | CL: Data length selection bit            | <ul> <li>This bit specifies the length of send and receive data.</li> <li>Note:</li> <li>Seven bits can be selected in operation mode 0 (asynchronous) only.</li> <li>Be sure to select eight bits (CL=1) in operation mode 1 (multiprocessor mode) and operation mode 2 (synchronous).</li> </ul>                                                                                                                           |  |  |  |  |
| bit11 | A/D: Address/<br>data selection bit      | <ul> <li>Specify the data format of a frame to be sent or received in multiprocessor mode (mode 1).</li> <li>Select usual data when this bit is 0, and select address data when the bit is 1.</li> </ul>                                                                                                                                                                                                                     |  |  |  |  |
| bit10 | REC: Reception<br>error flag clear bit   | <ul> <li>This bit clears the FRE, ORE, and PE flags of the status register (SSR0/1).</li> <li>Write 0 to this bit to clear the FRE, ORE, and PE flag. Writing 1 to this bit has no effect on the others.</li> <li>Note: <ul> <li>If UART is active and a reception interrupt is enabled, clear the REC bit only when the FRE, DRE, or PE flag indicates 1.</li> </ul> </li> </ul>                                            |  |  |  |  |
| bit9  | RXE: Reception<br>enable bit             | <ul> <li>This bit controls UART reception.</li> <li>When this bit is 0, reception is disabled. When it is 1, reception is enabled.</li> <li>Note:         <ul> <li>If reception operation is disabled during reception, reception of data currently being received is finished and the received data is stored in the input data register (SIDR0/SIDR1), and then the reception operation is stopped.</li> </ul> </li> </ul> |  |  |  |  |

#### **CHAPTER 14 UART**

| Bit name |                                    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|----------|------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| bit8     | TXE:<br>Transmission<br>enable bit | <ul> <li>This bit controls UART transmission.</li> <li>When this bit is 0, transmission is disabled. When the bit is 1, transmission is enabled.</li> <li>Note:         <ul> <li>When transmission operation is disabled during transmission, wait until there is no data in the send data buffers (SODR0/1) before stopping the transmission operation.</li> <li>If transmission operation is disabled during transmission, transmission operation is disabled during transmission, transmission operation is disabled during transmission, transmission operation is stopped after all data in the output data register (SODR0/SODR1) is sent out. When setting "0", write data to the output data register (SODR0/SODR1) and then wait for at least 1/16 period of the baud rate for the clock asynchronous transfer mode and the same period as the baud rate for the clock synchronous transfer mode.</li> </ul> </li> </ul> |  |  |

### Table 14.4-1 Functions of Bits for Control Register (SCR0/SCR1) (Continued)

## 14.4.2 Mode Register (SMR0/SMR1)

The mode register (SMR0/SMR1) is a register for performing the operations of the operation mode setting, baud rate clock setting, serial clock I/O control, and output enable setting of serial data to pins.

■ Mode Control Register (SMR0/SMR1)



275

|                      | Bit name                                         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|----------------------|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| bit7<br>bit6         | MD1 and MD0:<br>Operation mode<br>selection bits | These bits select an operation mode.<br><b>Note:</b><br>Operation mode 1 (multiprocessor mode) can be used only from the master<br>system during master-slave communication. UART cannot be used from the<br>slave system because it has no address/data detection function during<br>reception.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| bit5<br>bit4<br>bit3 | CS2 to CS0:<br>Clock selection bits              | <ul> <li>This bit selects a baud rate clock source. When the dedicated baud rate generator is selected, the baud rate is determined at the same time.</li> <li>When the dedicated baud rate generator is selected, eight baud rates can be selected: 6 types for the dedicated baud rate generator selected, 1 type for the internal timer selected, and 1 type for the external clock selected.</li> <li>Clock input can be selected from external clocks (SCK0/SCK1 pin input), the internal clock (16-bit reload timer0), and the dedicated baud rate generator.</li> </ul>                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| bit2                 | -:<br>Undefined bit                              | <ul><li>When this bit is read, the value is undefined.</li><li>The value set to this bit does not affect operation.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| bit1                 | SCKE:<br>Serial clock output<br>enable bit       | <ul> <li>This bit controls the serial clock input-output ports.</li> <li>When this bit is 0, the SC pins operate as input-output ports or serial clock input pins. When this bit is 1, the pins operate as serial clock output pins.</li> <li>Note: <ul> <li>To use the SC pins as serial clock input (SCKE="0") pins, set them as input pins. Also, select an external clock (SMR0/SMR1: CS2 to CS0="111<sub>B</sub>") using the clock setting bits.</li> <li>To use the SC pins as serial clock output (SCKE="1"), select the dedicated baud rate generator (SMR0/SMR1:CS2 to CS0=000<sub>B</sub> to 101<sub>B</sub>) or internal clock (SMR0/SMR1:CS2 to CS0=110<sub>B</sub>).</li> </ul> </li> <li>Reference: <ul> <li>When the SCK0/1 pin is assigned to serial clock output (SCKE=1), it functions as the serial clock output pin regardless of the status of the input-output ports.</li> </ul> </li> </ul> |  |  |  |
| bit0                 | SOE:<br>Serial data output<br>enable bit         | <ul> <li>This bit enables the output of serial data.</li> <li>When this bit "0", the SO pins operate as an I/O port.</li> <li>When this bit is "1", the SO pins operate as a serial data output pin.</li> <li>Reference:<br/>When the serial data output (SOE="1") is selected, the pins operate as a serial data output pin regardless of the state of the I/O port.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |

## 14.4.3 Status Register (SSR0/SSR1)

The status register (SSR0/SSR1) is a register for performing the operations of status check for transmission/reception and errors, transfer direction setting of serial data, and enable/disable setting of send/receive interrupts.

■ Status Register (SSR0/SSR1)



: Initial value

| Table 14.4-3 | Functions of Bits for Status Register (SSR0/SSR1) |
|--------------|---------------------------------------------------|
|--------------|---------------------------------------------------|

| No.   | Bit name                                    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|---------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit15 | PE:<br>Parity error flag bit                | <ul> <li>This bit is set to "1" when a parity error occurs during reception.</li> <li>This bit is cleared to "0" when "0" is written to the reception error flag clear bit (REC) of the control register (SCR0/SCR1).</li> <li>When this bit is set to "1" while the reception interrupt request enable bit (RIE) is 1, a reception interrupt request is output.</li> <li>When this bit is set to "1", data in the input data register (SIDR0/SIDR1) will be invalid.</li> </ul>                                                                                           |
| bit14 | ORE:<br>Overrun error flag bit              | <ul> <li>This bit is set to "1" when an overrun error occurs during reception.</li> <li>This bit is cleared to "0" when "0" is written to the reception error flag clear bit (REC) of the control register (SCR0/SCR1).</li> <li>When this bit is set to "1" while the reception interrupt request enable bit (RIE) is 1, a reception interrupt request is output.</li> <li>When this bit is set to "1", data in the input data register (SIDR0/SIDR1) will be invalid.</li> </ul>                                                                                         |
| bit13 | FRE:<br>Framing error flag bit              | <ul> <li>This bit is set to "1" when a framing error occurs during reception.</li> <li>This bit is cleared to "0" when "0" is written to the reception error flag clear bit (REC) of the control register (SCR0/SCR1).</li> <li>When this bit is set to "1" while the reception interrupt request enable bit (RIE) is 1, a reception interrupt request is output.</li> <li>When this bit is set to "1", data in the input data register (SIDR0/SIDR1) will be invalid.</li> </ul>                                                                                          |
| bit12 | RDRF:<br>Receive data full flag<br>bit      | <ul> <li>This bit indicates the status of the input data register (SIDR0/SIDR1).</li> <li>This bit is set to "1" when the receive data is stored in the input data register (SIDR0/SIDR1).</li> <li>This bit is cleared to "0" when the input data register (SIDR0/SIDR1) is read.</li> <li>When the reception interrupt request enable bit (RIE) is set to 1 while this bit is "1", a reception interrupt request is output.</li> </ul>                                                                                                                                   |
| bit11 | TDRE: Transmission<br>data empty flag bit   | <ul> <li>This bit indicates the status of the output data register (SODR0/SODR1).</li> <li>This bit is cleared to "0" when transmission data is written to the output data register (SODR0/SODR1).</li> <li>This bit is set to "1" when data is sent after loading it into the transmission shift register.</li> <li>When the transmission interrupt request enable bit (TIE) is set to 1 while this bit is "1", a transmission interrupt request is output.</li> <li>Note:     "1" is set in the initial state.</li> </ul>                                                |
| bit10 | BDS:<br>Transfer direction<br>selection bit | <ul> <li>This bit specifies the transfer direction of serial data.</li> <li>When this bit is set to "0", transfer starts with the lowest-order bit (LSB first).</li> <li>When this bit is set to "1", transfer starts with the highest-order bit (MSB first).</li> <li>Note: The upper bits and lower bits of data are exchanged during reading from or writing to the serial data register. Written data therefore becomes invalid if the bit direction selection bit (BDS) is rewritten after the data was written to the output data register (SODR0/SODR1).</li> </ul> |

| No.  | Bit name                                             | Function                                                                                                                                                                                                                                                                                |
|------|------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit9 | RIE:<br>Reception interrupt<br>request enable bit    | <ul> <li>This bit enables a reception interrupt request.</li> <li>When the reception data full flag enable bit (RDRF) is set to "1" or one of the reception error flag bits (PE, ORE, and FRE) is set to "1" while this bit is "1", a reception interrupt request is output.</li> </ul> |
| bit8 | TIE:<br>Transmission interrupt<br>request enable bit | <ul> <li>This bit enables a transmission interrupt request.</li> <li>When the transmission data empty flag bit (TDRE) is set to "1" while this bit is "1", a transmission interrupt request is output.</li> </ul>                                                                       |

Table 14.4-3 Functions of Bits for Status Register (SSR0/SSR1) (Continued)

# 14.4.4 Input Data Register (SIDR0/SIDR1) and Output Data Register (SODR0/SODR1)

The input data register (SIDR0/SIDR1) is a serial data reception register. The output data register (SODR0/SODR1) is a serial data transmission register.

#### Input Data Register (SIDR0/SIDR1)

7 3 2 0 Bit 6 5 4 1 Initial value D7 D6 D5 D4 D3 D2 D1 D0 XXXXXXXX<sub>B</sub> R R R R R R R R

Figure 14.4-5 Input Data Register (SIDR0/SIDR1)

- R : Read only
- X : Indefinite

The input data register (SIDR0/SIDR1) is a register to store receive data. The serial data signal transmitted to the SI0/SI1 pin is converted in the shift register and then stored in the input data register (SIDR0/SIDR1). When the data length is 7 bits long in operation mode 0, bit7 (D7) becomes invalid. When receive data is stored in this register, the reception data full flag bit (RDRF) of the status register (SSR0/SSR1) is set to "1". If the reception interrupt request output is enabled (SSR0/SSR1: RIE="1"), a reception interrupt is output.

Read the input data register (SIDR0/SIDR1) when the reception data full flag bit (RDRF) of the status register (SSR0/SSR1) is set to "1". The reception data full flag bit (RDRF) is cleared to "0" when the input data register (SIDR0/SIDR1) is read. When a reception error occurs (one of SSR0/SSR1: PE, ORE, FRE is "1"), data in the input data register (SIDR0/SIDR1) becomes invalid.

#### Output Data Register (SODR0/SODR1)

| Bit | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  | Initial value |
|-----|----|----|----|----|----|----|----|----|---------------|
|     | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | XXXXXXXXB     |
|     | W  | W  | W  | W  | W  | W  | W  | W  |               |

#### Figure 14.4-6 Output Data Register (SODR0/SODR1)

W : Write only

X : Indefinite

When data to be transmitted is written to the output data register (SODR0/SODR1), if transmission is enabled, the send data is transferred to the transmission shift register, converted into serial data, and then transmitted from the serial data output pin (SO0/SO1 pin). When the data length is 7 bits long in operation mode 0, bit7 (D7) becomes invalid.

When the transmission data is written to the output data register, the transmission data empty flag bit (TDRE) of the status register (SSR0/SSR1) is cleared to "0". When transfer to the transmission shift register is completed, the status register is set to "1". If the transmission data empty flag bit (TDRE) is "1", the next send data can be written. When the transmission data empty flag bit (TDRE) is set to "1" while the transmission interrupt request output is enabled (SSR0/SSR1: TIE="1"), a transmission data after the transmission data empty flag bit (TDRE) is set to "1".

#### Note:

The output data register (SODR0/SODR1) is a write-only register and the input data register (SIDR0/SIDR1) is a read-only register. These registers are located at the same address, and so the read value is different from the write value. Therefore, instructions that perform a read-modify-write (RMW) operation such as the INC/DEC instruction cannot be used.

## 14.4.5 Communication Prescaler Control Register (CDCR0/ CDCR1)

The communication prescaler control register (CDCR0/CDCR1) is a register that controls the division of machine clocks.

#### Communication Prescaler Control Register (CDCR0/CDCR1)

The operation clocks of UART can be obtained by dividing machine clocks. UART is designed to obtain certain baud rates for various machine cycles. Output from the communication prescaler is used for the operation clocks of serial I/O.



R/W : Read/write

- : Undefined bit

Table 14.4-4 Functions of Bits for Communication Prescaler Control Register (CDCR0/CDCR1)

| No.                     | Bit name                                                  | Function                                                                                                                                                                                                     |
|-------------------------|-----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit15                   | MD:<br>Communication<br>prescaler operation<br>enable bit | <ul> <li>This bit enables a communication prescaler operation.</li> <li>If this bit is "1", the communication prescaler operates.</li> <li>If this bit is "0", the communication prescaler stops.</li> </ul> |
| bit14<br>bit13<br>bit12 | -:<br>Undefined bit                                       | <ul><li>When these bits are read, values are undefined.</li><li>Values set to these bits do not affect operation.</li></ul>                                                                                  |
| bit11                   | RESV:<br>Reservation bit                                  | Always set "0".                                                                                                                                                                                              |
| bit10<br>bit9<br>bit8   | DIV2 to DIV0:<br>Frequency division<br>ratio setting bit  | <ul> <li>These bits are used to set the frequency division ratio of the machine clock.</li> <li>For the set values, see Table 14.4-5 "Machine Clock Division Ratio".</li> </ul>                              |

X : Undefined

| MD | DIV2 | DIV1 | DIV0 | div     |
|----|------|------|------|---------|
| 0  | -    | -    | -    | Stopped |
| 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.4-5 Machine Clock Division Ratio

div: Machine clock division ratio

#### Note:

If a division ratio is changed, wait two time cycles as clock stabilization time before starting communication.

The CDCR0 is a prescaler for the UART channel 0 (also serve as the serial I/O channel 2). The CDCR1 is a prescaler for the UART channel 1 (also serve as the serial I/O channel 3).

## 14.5 UART Interrupts

UART uses both reception and transmission interrupts and outputs an interrupt request for either of the following causes:

- A reception interrupt is output when receive data is set to the input data register (SIDR0/SIDR1) or a reception error occurs.
- A transmission interrupt is output when send data is transferred from the output data register (SODR0/SODR1) to the transmission shift register.

The extended intelligent I/O service ( $El^2OS$ ) is available for these interrupts.

#### UART Interrupts

#### Table 14.5-1 Interrupt Control Bits and Interrupt Causes of UART

| Reception/<br>transmission | Interrupt<br>request Mode |   |   | Interrupt cause | Interrupt<br>cause                                                                | When interrupt<br>request flag is |                                                                            |
|----------------------------|---------------------------|---|---|-----------------|-----------------------------------------------------------------------------------|-----------------------------------|----------------------------------------------------------------------------|
|                            | flag bit                  | 0 | 1 | 2               |                                                                                   | enable bit                        | cleared                                                                    |
|                            | RDRF                      | 0 | 0 | 0               | Loading receive data into<br>buffers (SIDR0/1)                                    |                                   | Receive data is read.                                                      |
| Reception                  | ORE                       | 0 | 0 | 0               | Overrun error                                                                     | SSR0/SSR1:<br>RIE                 | 0 is written to the<br>reception error flag<br>clear bit (SCR0/<br>1:REC). |
|                            | FRE                       | 0 | 0 | Х               | Framing error                                                                     |                                   |                                                                            |
|                            | PE                        | 0 | Х | Х               | Parity error                                                                      |                                   |                                                                            |
| Transmission               | TDRE                      | 0 | 0 | 0               | Send data transfer from<br>the output data register<br>(SODR0/SODR1)<br>completed | SSR0/<br>SSR1:TIE                 | Transmission data is written                                               |

O: Used

X: Not used

#### **O** Reception Interrupt

In reception mode, "1" is set to the reception data full flag bit (RDRF) or one of the reception error flag bits (ORE, FRE, PE) in the status register (SSR0/SSR1) when data reception is completed, or an overrun error, framing error, or parity error occurs. If the reception interrupt is enabled (SSR0/SSR1: RIE="1"), a reception interrupt request is output.

The reception data full flag bit (RDRF) of the status register (SSR0/SSR1) is cleared to "0" when the input data register (SIDR0/SIDR1) is read. All reception error flag bits (PE, ORE, FRE) of the status register (SSR0/SSR1) are cleared to "0" when the reception error flag clear bit (REC) of the status register (SCR0/SCR1) is set to "0".

#### **O** Transmission Interrupt

The transmission data empty flag bit (TDRE) of the status register (SSR0/SSR1) is set to "1" when send data is transferred from the output data register (SODR0/SODR1) to the transfer shift register. If the transmission interrupt is enabled (SSR0/SSR1: TIE="1"), a transmission interrupt request is output.

#### ■ UART Interrupts and El<sup>2</sup>OS

| Interrupt cause                 | Interrupt             | Interrup<br>regi | t control<br>ster   | Vect                | El <sup>2</sup> OS  |                     |       |
|---------------------------------|-----------------------|------------------|---------------------|---------------------|---------------------|---------------------|-------|
|                                 | number                | Register<br>name | Address             | Lower               | Upper               | Bank                | EI-05 |
| UART0 reception<br>interrupt    | #35(23 <sub>H</sub> ) | ICR12            | 0000BC <sub>H</sub> | FFFF70 <sub>H</sub> | FFFF71 <sub>H</sub> | FFFF72 <sub>H</sub> | Ø     |
| UART0 transmission<br>interrupt | #36(24 <sub>H</sub> ) | IGRIZ            |                     | FFFF6C <sub>H</sub> | FFFF6D <sub>H</sub> | FFFF6E <sub>H</sub> | Δ     |
| UART1 reception<br>interrupt    | #39(27 <sub>H</sub> ) | ICR14            |                     |                     | FFFF61 <sub>H</sub> | FFFF62 <sub>H</sub> | O     |
| UART1 transmission interrupt    | #40(28 <sub>H</sub> ) | ICR14            | 0000BE <sub>H</sub> | FFFF5C <sub>H</sub> | FFFF5D <sub>H</sub> | FFFF5E <sub>H</sub> | Δ     |

#### Table 14.5-2 UART Interrupts and El<sup>2</sup>OS

© : Provided with a function that detects a UART reception error and stops El<sup>2</sup>OS

△: Usable when interrupt causes that share the ICR12 and ICR14 or the interrupt vectors are not used

#### ■ UART EI<sup>2</sup>OS Functions

UART has a circuit for operating  $EI^2OS$ , which can be started up for either reception or transmission interrupts.

#### **O** For Reception

El<sup>2</sup>OS can be used regardless of the status of other resources.

#### **O** For Transmission

UART shares the interrupt registers (ICR14) with the UART reception interrupts. Therefore, EI<sup>2</sup>OS can be started up only when no UART reception interrupts are used.

## 14.5.1 Reception Interrupt Generation and Flag Set Timing

The following are reception interrupt causes: completion of reception (SSR0/SSR1: RDRF="1") and occurrence of a reception error (one of SSR0/SSR1: PE, ORE, and FRE is "1").

#### Reception Interrupt Generation and Flag Set Timing

Receive data is stored in the input data register (SIDR0/SIDR1) and the reception data full flag bit (RDRF) of the status register (SSR0/SSR1) is set to "1" when a stop bit is detected (in operation mode 0 or 1) or the last bit of data (D7) is detected (in operation mode 2). When a reception error occurs, one of the reception error flags (PE, ORE, FRE) is set to "1". If any of the reception error flag bits in each operation mode is set to "1", the value contained in the input data register (SIDR0/SIDR1) becomes invalid.

#### O Operation Mode 0 (Asynchronous, Normal Mode)

The reception data full flag bit (RDRF) of the status register (SSR0/SSR1) is set to "1" when a stop bit is detected. If a reception error is detected, "1" is set to one of the reception error flag bits (PE, ORE, FRE).

#### O Operation Mode 1 (Asynchronous, Multiprocessor Mode)

The reception data full flag bit (RDRF) of the status register (SSR0/SSR1) is set to "1" when a stop bit is detected. If a reception error is detected, "1" is set to either of the reception error flag bits (ORE, FRE). Parity errors cannot be detected.

#### O Operation Mode 2 (Synchronous, Normal Mode)

The reception data full flag bit (RDRF) of the status register (SSR0/SSR1) is set to "1" when the last bit (D7) of receive data is detected. If a reception error is detected, "1" is set to the reception error flag bit (ORE). Parity and framing errors cannot be detected.



#### Figure 14.5-1 Reception Operation and Flag Set Timing

\* : The PE flag cannot be used in mode 1.

The PE and PRE flags cannot be used in mode 2.

ST : Start bit

SP : Stop bit

A/D : Mode 2 (multiprocessor mode) address/data selection bit

#### **O** Reception Interrupt Output Timing

When the reception data full flag bit (RDRF) of the status register (SSR0/SSR1) or the one of the reception error flag bits (PE, ORE, FRE) is set to "1" while the reception interrupt is enabled (SSR0/SSR1: RIE="1"), a reception interrupt request is output.

## 14.5.2 Transmission Interrupt Generation and Flag Set Timing

A transmission interrupt is output when the output data register (SODR0/SODR1) is ready to accept writing of the next data item.

#### Transmission Interrupt Output and Flag Set Timing

The transmission data empty flag bit (TDRE) of the status register (SSR0/SSR1) is set to "1" when data written to the output data register (SODR0/SODR1) is transferred to the transmission shift register and the next piece of data is ready to be written. The transmission data empty flag bit (TDRE) is cleared to "0" when send data is written to the output data register (SODR0/ SODR1).



Figure 14.5-2 Transmission Operation and Flag Set Timing

#### O Transmission Interrupt Request Output Timing

When the transmission data empty flag bit (TDRE) of the status register (SSR0/SSR1) is set to "1" while the transmission interrupt is enabled (SSR0/SSR1: TIE="1"), a transmission interrupt request is output.

#### Note:

Because the transmission data empty flag bit (TDRE) of the status register (SSR0/SSR1) is set to "1" in the initial state, a transmission interrupt request is output when the transmission interrupt is enabled (SSR0/SSR1: TIE="1"). The transmission data empty flag bit (TDRE) is a read-only bit. Accordingly, the only way to clear it is to write new data to the output data register (SODR0/SODR1). Specify carefully the timing for enabling a transmission interrupt.

## 14.6 UART Baud Rates

One of the following can be selected as the UART transmitting/receiving block:

- Dedicated baud rate generator
- Internal clock (16-bit reload timer 0)
- External clock (clock input to the SCK pin)

#### ■ UART Baud Rate Selection

The baud rate selection circuit is designed as shown below. One of the following three types of baud rates can be selected:

#### **O** Baud Rates Determined Using the Dedicated Baud Rate Generator

UART has an internal dedicated baud rate generator. One of six baud rates can be selected using the mode control register (SMR0/1).

An asynchronous or clock synchronous baud rate is selected using the machine clock and CS2 to CS0 bits of the mode control register (SMR0/1).

#### **O** Baud Rates Determined Using the Internal Timer

The internal clock supplied from 16-bit reload timer is used as is (synchronous) or by dividing it by 16 (asynchronous) for the baud rate. Any baud rate can be set by setting the reload value.

#### **O** Baud Rates Determined Using the External Clock

The clock input from the UART clock input pin (SCK) is used as is as the baud rate in synchronous mode or as the divide-by-16 input clock in asynchronous mode. Note, however, that the frequency of the input external clock must be 2 MHz or less.



#### Figure 14.6-1 Baud Rate Selection Circuit

 $\varphi\,$  : Machine clock

## 14.6.1 Baud Rates Determined Using the Dedicated Baud Rate Generator

This section describes the baud rates that can be set when the clock from the dedicated baud rate generator is selected as the UART transfer clock.

#### ■ Baud Rates Determined Using the Dedicated Baud Rate Generator

When the clock setting bits of the mode register (SMR0/SMR1) are set to " $000_{B}$ - $101_{B}$ ", the baud rate is set by the dedicated baud rate generator.

When the transfer clock is generated by the dedicated baud rate generator, the machine clock is divided by the machine clock prescaler and then divided by using the transfer clock division ratio set by the clock selector. The machine clock division ratios are common to the asynchronous and synchronous baud rates, but the transfer clock division ratio is set by the clock setting bits (CS2 to CS0) of the mode register (SMR0/SMR1) separately for the asynchronous and synchronous baud rates.

The actual transfer ratio can be calculated by using the following formulas:

asynchronous baud rate =  $\phi$  / (prescaler division ratio) / (asynchronous transfer clock division ratio)

synchronous baud rate =  $\phi$  / (prescaler division ratio) / (synchronous transfer clock division ratio)

 $\boldsymbol{\phi}$  : Machine clock frequency

#### Division Ratios for the Prescaler (Common to Asynchronous and Synchronous Baud Rates)

As listed in Table 14.6-1 "Setting of Each Division Ratio by the Machine Clock Prescaler", the machine clock division ratio is set by the division ratio setting bits (DIV2 to DIV0) of the communication prescaler control register (CDCR0/CDCR1).

| MD | DIV2 | DIV1 | DIV0 | div     |
|----|------|------|------|---------|
| 0  | -    | -    | -    | Stopped |
| 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.6-1 Setting of Each Division Ratio by the Machine Clock Prescaler

div: Machine clock division ratio

#### **O** Synchronous Transfer Clock

The synchronous baud rate is set, as listed in Table 14.6-2 "Synchronous Baud Rate Division Ratio Setting", by the clock setting bits (CS2 to CS0) of the mode register (SMR0/SMR1).

| Table 14.6-2 | Synchronous Baud Rate Division Ratio Setting |
|--------------|----------------------------------------------|
|--------------|----------------------------------------------|

| CS2 | CS1 | CS0 | Division ratio for CLK synchronization | Calculation formula | SC0/SC1      |
|-----|-----|-----|----------------------------------------|---------------------|--------------|
| 0   | 0   | 0   | 16 Mbps                                | (ϕ / div)/1         | (φ / div)/1  |
| 0   | 0   | 1   | 8 Mbps                                 | (φ / div)/2         | (φ / div)/2  |
| 0   | 1   | 0   | 4 Mbps                                 | (φ / div)/4         | (φ / div)/4  |
| 0   | 1   | 1   | 2 Mbps                                 | (φ / div)/8         | (φ / div)/8  |
| 1   | 0   | 0   | 1 Mbps                                 | (φ / div)/16        | (φ / div)/16 |
| 1   | 0   | 1   | 500 kbps                               | (¢ / div)/32        | (¢ / div)/32 |

This calculation assumes a machine cycle frequency  $\phi = 16$  MHz and div = 4.

#### **O** Asynchronous Transfer Clock Division Ratios

Asynchronous baud rates is selected using the CS2 to CS0 bits of the mode control register (SMR0/1) as listed in Table 14.6-3 "Asynchronous Baud Rate Division Ratio Setting".

| Table 14.6-3 | Asynchronous | <b>Baud Rate Divis</b> | ion Ratio Setting |
|--------------|--------------|------------------------|-------------------|
|--------------|--------------|------------------------|-------------------|

| CS2 | CS1 | CS0 | Asynchronus<br>(start-stop<br>synchronization) | (start-stop Calculation formula |                    |  |  |
|-----|-----|-----|------------------------------------------------|---------------------------------|--------------------|--|--|
| 0   | 0   | 0   | 76,923 bps                                     | (\u03c6 / div)/(8 x 13 x 2)     | (φ / div)/(13 x 1) |  |  |
| 0   | 0   | 1   | 38,461 bps                                     | (\u03c6 / div)/(8 x 13 x 4)     | (φ / div)/(13 x 2) |  |  |
| 0   | 1   | 0   | 19,230 bps                                     | (\u03c6 / div)/(8 x 13 x 8)     | (φ / div)/(13 x 4) |  |  |
| 0   | 1   | 1   | 9,615 bps                                      | (φ / div)/(8 x 13 x 16)         | (φ / div)/(13 x 8) |  |  |
| 1   | 0   | 0   | 500 kbps                                       | (\u03c6 / div)/(8 x 2 x 2)      | (φ / div)/2        |  |  |
| 1   | 0   | 1   | 250 kbps                                       | (\u03c6 / div)/(8 x 2 x 4)      | (φ / div)/4        |  |  |

However, the baud rate is calculated based on the values of  $\phi$  (machine clock) = 16MHz and div (machine clock division ratio) = 1.

### 14.6.2 Baud Rates Determined Using the Internal Timer

This section describes the settings used when the internal clock supplied from 16-bit reload timer is selected as the UART transfer clock. It also shows the baud rate calculation formulas.

#### Baud Rates Determined Using the Internal Timer (16-bit Reload Timer 0)

If the clock setting bits (CS2 to CS0) of the mode register (SMR0/SMR1) are set to " $110_B$ ", the baud rate is set by the internal clock. The baud rate can be set by specifying the prescaler division ratio and reload value of the 16-bit reload timer.

#### Figure 14.6-2 Baud Rate Selection Circuit for the Internal Timer (16-bit Reload Timer 0)



#### **O** Baud Rate Calculation Formulas

Asynchronous baud rate =  $(\phi / N)/(16x2x (n+1))$  bps

Synchronous baud rate =  $(\phi / N)/(2x (n+1))$  bps

- N: Division ratio for the prescaler of 16-bit reload timer 0 (2<sup>1</sup>, 2<sup>3</sup>, or 2<sup>5</sup>)
- n: Reload value for 16-bit reload timer 0 (0 to 65535)

#### O Examples of Setting Reload Values (Machine Clock: 7.3728 MHz)

Table 14.6-4 Baud Rates and Reload Values

|           | Reload value (n)                                 |                                                  |                                                  |                                               |  |  |  |  |  |
|-----------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|-----------------------------------------------|--|--|--|--|--|
| Baud rate |                                                  | onous (start-stop<br>onization)                  | Clock synchronous                                |                                               |  |  |  |  |  |
|           | N=2 <sup>1</sup> (machine cycle<br>divided by 2) | N=2 <sup>3</sup> (machine cycle<br>divided by 8) | N=2 <sup>1</sup> (machine cycle<br>divided by 2) | N=2 <sup>3</sup> (machine cycle divided by 8) |  |  |  |  |  |
| 38400     | 2                                                | -                                                | 47                                               | 11                                            |  |  |  |  |  |
| 19200     | 5                                                | -                                                | 95                                               | 23                                            |  |  |  |  |  |
| 9600      | 11                                               | 2                                                | 191                                              | 47                                            |  |  |  |  |  |
| 4800      | 23                                               | 5                                                | 383                                              | 95                                            |  |  |  |  |  |
| 2400      | 47                                               | 11                                               | 767                                              | 191                                           |  |  |  |  |  |
| 1200      | 95                                               | 23                                               | 1535                                             | 383                                           |  |  |  |  |  |
| 600       | 191                                              | 47                                               | 3071                                             | 767                                           |  |  |  |  |  |
| 300       | 383                                              | 95                                               | 6143                                             | 1535                                          |  |  |  |  |  |

N: Division ratio for the prescaler of 16-bit reload timer 0

-: Setting not allowed

### 14.6.3 Baud Rates Determined Using the External Clock

This section describes the settings used when the external clock is selected as the UART transfer clock. It also shows the baud rate calculation formulas.

#### Baud Rates Determined Using the External Clock

The following three settings are required to select the baud rate determined by using the external clock:

- Write 111<sub>B</sub> to the CS2 to CS0 bits of the mode control register (SMR0/1) to select the baud rate determined by using the external clock input.
- Set the SC pin to be used as an input port.
- Write 0 to the SCKE bit of the mode control register (SMR0/1) to set the pin as an external clock input pin.

As shown in Figure 14.6-3 "Baud Rate Selection Circuit for the External Clock", a baud rate is selected using the external clock input from the SC pin. To change the baud rate, the external input clock cycle must be changed because the internal division ratio is fixed.

#### Figure 14.6-3 Baud Rate Selection Circuit for the External Clock



#### **O** Baud Rate Calculation Formulas

asynchronous baud rate = f/16 bps

synchronous baud rate = f bps

f: External clock (up to 2 MHz)

## 14.7 Operation of UART

## UART operates in operation modes 0 and 2 for normal bidirectional serial communication and in operation mode 1 for master-slave communication.

#### Operation of UART

#### O Operation modes

There are three UART operation modes: modes 0 to 2. As listed in Table 14.7-1 "UART Operation Mode", an operation mode can be selected according to the inter-CPU connection method and data transfer mode.

|   | Operation mode |                     | Data                                                     | length |                           |                           |  |
|---|----------------|---------------------|----------------------------------------------------------|--------|---------------------------|---------------------------|--|
|   |                |                     | tion mode When When parity is parity is disabled enabled |        | Synchroni-<br>zation mode | Stop bit length           |  |
| ľ | 0              | Normal mode         | 7 or 8 bits                                              |        | Asynchronous              | 1 or 2 bits <sup>*2</sup> |  |
| ľ | 1              | Multiprocessor mode | 8+1 <sup>*1</sup>                                        | -      | Asynchronous              |                           |  |
|   | 2              | Normal mode         | 8                                                        | -      | Synchronous               | None                      |  |

#### Table 14.7-1 UART Operation Mode

-: Setting not possible

\*1: "+1" indicates the address/data selection bit (A/D) for communication control.

\*2: During reception, only one stop bit can be detected.

#### Note:

Operation mode 1 of UART is used only from the master system during master-slave connection.

#### O Inter-CPU Connection Method

One-to-one connection (normal mode) and master-slave connection (multiprocessor mode) can be selected. For either connection method, the data length, whether to enable parity, and the synchronization method must be common to all CPU. Select an operation mode as follows:

- In the one-to-one connection method, operation mode 0 or 2 must be used in the two CPUs. Select operation mode 0 for asynchronous transfer mode and operation mode 2 for synchronous transfer mode.
- Select operation mode 1 for the master-slave connection method and use it from the master system. Select "When parity is disabled" for this connection method.

#### **O** Synchronization Method

Asynchronous mode (start-stop synchronization) or clock synchronous mode can be selected in any operation mode.

#### **O** Signal Method

UART can treat data only in non-return to zero (NRZ) format.

#### **O** Operation Enable

UART controls both transmission and reception using the control register (SCR0/SCR1) with its transmission enable bit (TXE) and reception enable bit (RXE). If any of the operations is disabled during operation, the following will occur:

- If reception operation is disabled during reception (data is input to the reception shift register), finish frame reception and store the received data in the input data register (SIDR0/1). Then stop the reception operation.
- If the transmission operation is disabled during transmission (data is output from the transmission shift register), wait until there is no data in the output data register (SODR0/1) before stopping the transmission operation.
- When mode 1 is selected for URAT, the received data bit 9 is ignored.

## 14.7.1 Operation in Asynchronous Mode (Operation Modes 0 and 1)

When UART is used in operation mode 0 (normal mode) or operation mode 1 (multiprocessor mode), asynchronous transfer mode is selected.

#### Operation in Asynchronous Mode

#### O Transfer Data Format

Transfer data always starts with the start bit ("L" level) and ends with the stop bit ("H" level). The data of the specified data bit length is transferred in "LSB first."

- In operation mode 0, data without a parity bit is always seven bits long and data with a parity bit is always eight bits long.
- In operation mode 1, the data is fixed to eight bits with an address/data setting bit (A/D) bit instead of a parity bit.

#### Figure 14.7-1 Transfer Data Format (Operation Modes 0 and 1)

| [Operation mode 0] | ST ( D0 ) D1 ) D2 ) D3 ) D4 ) D5 ) D6 ) D7/P SP              |
|--------------------|--------------------------------------------------------------|
| [Operation mode 1] | <u>ST ( D0 ( D1 ( D2 ( D3 ( D4 ( D5 ( D6 ( D7 ( A/D ) SP</u> |

- \* : D7(bit7)......When no parity bit is added
  - P(parity)......When a parity bit is added
- ST : Start bit
- SP : Stop bit
- A/D : Address/data setting bit of operation mode 1 (multiprocessor mode)

#### **O** Transmission Operation

When the transmission data empty flag bit (TDRE) of the status register (SSR0/SSR1) is set to "1", send data is written to the output data register (SODR0/SODR1). If the transmission is enabled (SCR0/SCR1: TXE="1"), data is sent.

When the send data is transferred to the transmission shift register and transmission is started, the transmission data empty flag bit (TDRE) of the status register (SSR0/SSR1) is set to "1" again so that the next piece of send data can be set. If the transmission interrupt request output is enabled (SSR0/SSR1: TIE="1"), a transmission interrupt request is output so that send data is set to the output data register (SODR0/SODR1). The transmission data empty flag bit (TDRE) is cleared to "0" after writing the send data to the output data register (SODR0/SODR1).

#### **O** Reception Operation

If the reception is enabled (SCR0/SCR1: RXE="1"), reception operation is always performed. When a start bit is detected, one frame of data is received in accordance with the data format specified in the control register (SCR0/SCR1). When reception of one frame is completed, if a reception error occurs, one of the reception error flag bits (PE, ORE, FRE) of the status register (SSR0/SSR1) is set to "1" and then the reception data full flag bit (RDRF) is set to "1". If the reception interrupt request output is enabled (SSR0/SSR1: RIE="1"), a reception interrupt request is output. Check each of the reception error flag bits (PE, ORE, FRE) of the status register (SSR0/SSR1). If no error occurred in reception, read the input data register (SIDR0/ SIDR1). If an error has occurred, take the appropriate measures to deal with the error. The reception data full flag bit (RDRF) is cleared to "0" after reading receive data from the input data register (SIDR0/SIDR1).

#### O Stop Bit

One or two stop bits can be set for transmission. The receiving side always evaluates the first one bit.

#### **O** Error Detection

- In operation mode 0, parity, overrun, and framing errors can be detected. ٠
- In operation mode 1, overrun and framing errors can be detected, but parity errors cannot be detected.

#### **O** Parity

Parity can be used only in operation mode 0. The parity presence/absence can be set in the parity enable bit (PEN) of the control register (SCR0/SCR1) and even parity/odd parity can be set in the parity setting bit (P). Parity cannot be used in operation mode 1.



#### Figure 14.7-2 Transmission Data when Parity is Enabled

ST: Start bit SP: Stop bit

Note: Parity cannot be used in operation modes 1 and 2.

## 14.7.2 Operation in Synchronous Mode (Operation Mode 2)

When UART is used in operation mode 2 (normal mode), the synchronous transfer mode is selected.

#### Operation in Synchronous Mode (Operation Mode 2)

#### **O** Transfer Data Format

In synchronous mode, 8-bit data is transferred in LSB first mode.

| <b>J</b> • • •               |   |     |   | - |     | <b>(</b> - <b> </b> |   |   |     | , |           |     |
|------------------------------|---|-----|---|---|-----|---------------------|---|---|-----|---|-----------|-----|
| Transmission data writing    | □ |     |   |   |     |                     |   |   |     |   | -         |     |
| Transmission/reception clock |   |     |   |   |     |                     |   |   |     |   | - Mark le | vel |
| RXE, TXE                     |   |     |   |   |     |                     |   |   |     |   | -         |     |
| Send/receive data            |   |     |   |   |     |                     |   |   |     |   | _         |     |
|                              |   | 1   | 0 | 1 | 1   | 0                   | 0 | 1 | 0   |   |           |     |
|                              |   | LSB |   |   | Dat | a                   |   |   | MSB |   |           |     |

#### Figure 14.7-3 Transfer Data Format (Operation Mode 2)

#### O Clock Supply

In clock synchronous (I/O extended serial) mode, as many clocks as the number of transmission/reception bits need to be supplied.

- If the internal clock is selected, a data reception synchronous clock is generated when data is received.
- If an external clock is selected, a clock for exactly one byte needs to be supplied from an
  external source after making sure that the output data register (SODR0/SODR1) on the
  sending side UART contains data (SSR0/SSR1: TDRE="0"). The mark level "H" must be
  retained before transmission starts and after it is completed.

#### O Error Detection

Only overrun errors can be detected, and parity and framing errors cannot be detected.

#### O Initialization

The following shows the values to be set to use synchronous mode:

#### [Mode register (SMR0/SMR1)]

MD1, MD0: Set "10<sub>B</sub>".

CS2, CS1, CS0: Specify the clock input of the clock selector.

SCKE: Set "1" for the dedicated baud rate generator or the internal clock. Set "0" for the clock output or an external clock.

SOE: Set "1" for transmission. Set "0" for reception.

#### [Control register (SCR0/SCR1)]

PEN: Set "0".

P, SBL, A/D: These bits make no sense.

CL: Set "1" (8-bit data).

REC: Set "0" (Clear all error flags for initialization).

RXE, TXE: Set "1" to either of the bits.

#### [Status register (SSR0/SSR1)]

RIE: Set "1" to use interrupts and "0" to not use interrupts.

TIE: Set "1" to use interrupts and "0" to not use interrupts.

#### **O** Communication Start

Write data to the output data register (SODR0/SODR1) start communication. Note that the receiving side must also write send data to the output data register (SODR0/SODR1) to start communication.

#### **O** Communication End

The reception data full flag bit (RDRF) of the status register (SSR0/SSR1) is set to "1" when transmission or reception of one frame of data is completed. When receiving data, check the overrun error flag bit (ORE) to see if the communication has been normally executed.

## 14.7.3 Bidirectional Communication Function (Normal Mode)

In operation mode 0 or 2, serial bidirectional communication (one-to-one connection) is available. Select operation mode 0 for asynchronous communication and operation mode 2 for synchronous communication.

#### Bidirectional Communication Function

The settings shown in Figure 14.7-4 "Settings for UART1 Operation Mode 0" are required to operate UART1 in normal mode (operation mode 0 or 2).



#### Figure 14.7-4 Settings for UART1 Operation Mode 0

#### ○ Inter-CPU Connection

As shown in Figure 14.7-5 "Connection Example of UART1 Bidirectional Communication", interconnect two CPU.

#### Figure 14.7-5 Connection Example of UART1 Bidirectional Communication



#### **O** Communication Procedure

Communication starts from the transmitting system when transmission data has been prepared. An ANS is returned periodically (byte by byte in this example) when the receiving system receives transmission data.



#### Figure 14.7-6 Example of Bidirectional Communication Flowchart

## 14.7.4 Master-slave Communication Function (Multiprocessor Mode)

With UART, communication with multiple CPU connected in master-slave mode is available. However, UART can be used only from the master system.

#### Master-slave Communication Function

The settings shown in Figure 14.7-7 "Settings for UART1 Operation Mode 1" are required to operate UART1 in multiprocessor mode (operation mode 1).



 $\triangle$  : Set 0 to use an input pin.

#### ○ Inter-CPU Connection

As shown in Figure 14.7-8 "Connection Example of UART1 Master-Slave Communication", a communication system consists of one master CPU and multiple slave CPU connected to two communication lines. UART1 can be used only from the master CPU.

Figure 14.7-8 Connection Example of UART1 Master-Slave Communication



#### **O** Function Selection

Select the operation mode and data transfer mode for master-slave communication as shown in Table 14.7-2 "Selection of the Master-Slave Communication Function".

| Table 14.7-2 Selection of the Master-Slave Con | mmunication Function |
|------------------------------------------------|----------------------|
|------------------------------------------------|----------------------|

|                                       | Operatio      | on mode      |                               |        | Currehreni                  | Stop bit    |  |
|---------------------------------------|---------------|--------------|-------------------------------|--------|-----------------------------|-------------|--|
|                                       | Master<br>CPU | Slave<br>CPU | Data                          | Parity | Synchroni-<br>zation method |             |  |
| Address transmission<br>and reception | Operation     |              | A/D="1"<br>+<br>8-bit address | None   |                             |             |  |
| Data transmission<br>and reception    | mode 1        | -            | A/D="0"<br>+<br>8-bit address | None   | Asynchronous                | 1 or 2 bits |  |

#### **O** Communication Procedure

When the master CPU transmits address data, communication starts. The A/D bit in the address data is set to 1, and the communication destination slave CPU is selected. Each slave CPU checks the address data using a program. When the address data indicates the address assigned to a slave CPU, the slave CPU communicates with the master CPU (ordinary data).





## 14.8 Notes on Using UART

#### Notes on using UART are given below.

#### Notes on Using UART

#### **O** Enabling Operations

UART has the transmission enable bit (TXE) and reception enable bit (RXE) in the control register (SCR0/SCR1). Both transmission and reception operations need to be enabled before starting transfer because the transmission/reception enable bits (TXE/RXE) are set to "0" in the initial state. The transfer can also be canceled by disabling the transmission/reception as required.

#### O Communication Mode Setting

Set the communication mode while the system is not operating. If the mode is set during transmission or reception, the transmission or reception data is not guaranteed.

#### **O** Synchronous Mode

UART clock synchronous mode (operation mode 2) uses clock control (I/O extended serial) mode, in which start and stop bits are not added to the data.

#### **O** Transmission Interrupt Enabling Timing

The default (initial value) of the transmission data empty flag bit (SSR0/1: TDRE) is 1 (no transmission data and transmission data write enable state). A transmission interrupt request is generated as soon as the transmission interrupt requests are enabled (SSR0/1: TIE=1). Be sure to set the TIE flag to 1 after setting the transmission data.

#### O Reception in Operation Mode 1 (Multiprocessor Mode)

In operation mode 1 (multiprocessor mode) of UART, the 9-bit receive operation cannot be performed.

**CHAPTER 14 UART** 

### CHAPTER 15 DTP/EXTERNAL INTERRUPT CIRCUIT

## This chapter describes the functions and operations of the DTP/external interrupt circuit of the MB90M405 series.

- 15.1 "Overview of the DTP/External Interrupt Circuit"
- 15.2 "Configuration of the DTP/External Interrupt Circuit"
- 15.3 "DTP/External Interrupt Circuit Pins"
- 15.4 "DTP/External Interrupt Circuit Registers"
- 15.5 "Operation of the DTP/External Interrupt Circuit"
- 15.6 "Usage Notes on the DTP/External Interrupt Circuit"

### 15.1 Overview of the DTP/External Interrupt Circuit

The data transfer peripheral (DTP)/external interrupt circuit detects interrupt request input from an external interrupt input pin in order to generate an interrupt request.

### ■ DTP/External Interrupt Functions

The DTP/external interrupt circuit function outputs an interrupt request when it detects an edge or level signal input to the external interrupt input pins.

When an interrupt request is accepted by the CPU and the extended intelligent I/O service  $(EI^2OS)$  is enabled, the automatic data transfer (DTP function) is performed by  $EI^2OS$  before branching to the interrupt processing routine. If  $EI^2OS$  is disabled, the automatic data transfer (DTP function) by  $EI^2OS$  is not activated; instead, direct branching to the interrupt processing routine takes place.

|                      | External interrupt function                                                                                   | DTP function                                                                                      |  |
|----------------------|---------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|--|
| Input pins           | Four (P80/INT0, P81/INT1, PB6/INT2, and PB7/INT3)                                                             |                                                                                                   |  |
| Interrupt cause      | By using the request level setting register (ELVR), the detection level or edge type can be set for each pin. |                                                                                                   |  |
| interrupt cause      | Input of the "L" level/"H" level                                                                              | Input of the rising edge/falling edge                                                             |  |
| Interrupt number     | #11 (0B <sub>H</sub> ), #13 (0D <sub>H</sub> ), #16 (10 <sub>H</sub> )                                        |                                                                                                   |  |
| Interrupt control    | The output of interrupt requests is enabled and disabled using the DTP/interrupt enable register (ENIR).      |                                                                                                   |  |
| Interrupt flag       | Interrupt causes are stored in the DTP/interrupt cause register (EIRR).                                       |                                                                                                   |  |
| Processing selection | $EI^2OS$ is disabled (ICR: ISE = 0).                                                                          | $EI^2OS$ is enabled (ICR: ISE = 1).                                                               |  |
| Processing           | The circuit branches to an external interrupt processing routine.                                             | Branching to the interrupt processing routine after automatic data transfer by El <sup>2</sup> OS |  |

Table 15.1-1 Overview of the DTP/External Interrupt Circuit

ICR: Interrupt control register

### ■ Interrupt of the DTP/external interrupt circuit and El<sup>2</sup>OS

| Channel | Interrupt              | Interrupt control register |                     | Vector table address |                     |                     | El <sup>2</sup> OS |
|---------|------------------------|----------------------------|---------------------|----------------------|---------------------|---------------------|--------------------|
| Channel | number                 | Register name              | Address             | Lower                | Upper               | Bank                | EI-05              |
| INT0    | #11 (0B <sub>H</sub> ) | ICR00                      | 0000B0 <sub>H</sub> | FFFFD0 <sub>H</sub>  | FFFFD1 <sub>H</sub> | FFFFD2 <sub>H</sub> |                    |
| INT1    | #13 (0D <sub>H</sub> ) | ICR01                      | 0000B1 <sub>H</sub> | FFFFC8 <sub>H</sub>  | FFFFC9 <sub>H</sub> | FFFFCA <sub>H</sub> | 0                  |
| INT2    | #16 (10 <sub>н</sub> ) | ICR02                      | 0000B2 <sub>H</sub> | FFFFBC <sub>H</sub>  | FFFFBD <sub>H</sub> | FFFFBE <sub>H</sub> |                    |
| INT3    | #10(10 <sub>H</sub> )  | ICROZ                      | 0000B2H             | гггвон               | гггвон              | rrrdch              |                    |

Table 15.1-2 Interrupt of the DTP/External Interrupt Circuit and EI<sup>2</sup>OS

### 15.2 Configuration of the DTP/External Interrupt Circuit

The DTP/external interrupt circuit consists of the following blocks:

- DTP/interrupt input detection circuit
- Request level setting register (ELVR)
- DTP/interrupt cause register (EIRR)
- DTP/interrupt enable register (ENIR)

■ Block Diagram of the DTP/External Interrupt Circuit





#### **O DTP/external interrupt input detection circuit**

Upon detecting a match of the signal input to an external interrupt input pin and the level or edge specified in the request level setting register (ELVR), the DTP/external interrupt cause flag bit (EIRR: ER3 to ER0) corresponding to the external interrupt input pin is set to "1".

#### **O** Request level setting register (ELVR)

This register sets the detection condition (level or edge) of interrupt requests for each external interrupt input pin.

#### O DTP/interrupt cause register (EIRR)

This register retains and clears interrupt causes.

### O DTP/interrupt enable register (ENIR)

This register enables/disables interrupt requests for each external interrupt input pin.

### **15.3 DTP/External Interrupt Circuit Pins**

This section describes the DTP/external interrupt circuit pins and provides a pin block diagram.

### ■ DTP/External Interrupt Circuit Pins

The DTP/external interrupt circuit pins are also used as I/O ports.

Table 15.3-1 DTP/External Interrupt Circuit Pins

| Pin<br>name | Function                           | I/O format           | Pull-up<br>resistor | Standby control                                   | Setting required to use<br>pins                   |
|-------------|------------------------------------|----------------------|---------------------|---------------------------------------------------|---------------------------------------------------|
| INTO        | Port 8 input-                      |                      | Net ere ide d       | Natarovidad                                       | Set the pin as an input port<br>(DDR8: bit0 = 0)  |
| INT1        | output/external<br>interrupt input | CMOS output/<br>CMOS |                     |                                                   | Set the pin as an input port<br>(DDR8: bit9 = 0)  |
| INT2        |                                    | Port B input-        | Not provided        | Set the pin as an input port<br>(DDRB: bit16 = 0) |                                                   |
| INT3        | output/external<br>interrupt input |                      |                     |                                                   | Set the pin as an input port<br>(DDRB: bit17 = 0) |

### ■ Block Diagram of the DTP/External Interrupt Circuit Pins



Figure 15.3-1 Block Diagram of the DTP/External Interrupt Circuit Pins

### 15.4 DTP/External Interrupt Circuit Registers

This section describes IDTP/external interrupt circuit registers.

### ■ DTP/External Interrupt Circuit register

bit15 ..... bit8 bit7 ..... bit0

DTP/interrupt cause register (EIRR) DTP/interrupt enable register (ENIR)

Request level setting register (ELVR)

### 15.4.1 DTP/Interrupt Cause Register (EIRR)

The DTP/interrupt cause register (EIRR) stores and clears interrupt causes.

### ■ DTP/Interrupt Cause Register (EIRR)



| Bit name             |                    | name                                      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------------|--------------------|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit15<br>to<br>bit12 | ER7:<br>to<br>ER4: |                                           | <ul> <li>Setting of any of these bits is invalid because the external input pins are<br/>INT0 through INT3.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| bit11                | ER3:               |                                           | <ul> <li>This bit is a flag that requests an interrupt.</li> <li>This bit is set to "1" when the level or edge signal set in the external interrupt request detection condition setting bit (LB3, LA3) of the request level setting register (ELVR) is detected in the external interrupt input pin (INT3).</li> <li>When this bit is set to "1" while the external interrupt request enable bit (EN3) of the DTP/external interrupt enable register (ENIR) is set to "1", an interrupt request is output.</li> <li>When this bit is "0", the interrupt request is cleared.</li> <li>When this bit is "1", operation is not affected.</li> </ul> |
| bit10                | ER2:               | External<br>interrupt<br>request flag bit | <ul> <li>This bit is a flag that requests an interrupt.</li> <li>This bit is set to "1" when the level or edge signal set in the external interrupt request detection condition setting bit (LB2, LA2) of the request level setting register (ELVR) is detected in the external interrupt input pin (INT2).</li> <li>When this bit is set to "1" while the external interrupt request enable bit (EN2) of the DTP/external interrupt enable register (ENIR) is set to "1", an interrupt request is output.</li> <li>When this bit is "0", the interrupt request is cleared.</li> <li>When this bit is "1", operation is not affected.</li> </ul> |
| bit9                 | ER1:               |                                           | <ul> <li>This bit is a flag that requests an interrupt.</li> <li>This bit is set to "1" when the level or edge signal set in the external interrupt request detection condition setting bit (LB1, LA1) of the request level setting register (ELVR) is detected in the external interrupt input pin (INT1).</li> <li>When this bit is set to "1" while the external interrupt request enable bit (EN1) of the DTP/external interrupt enable register (ENIR) is set to "1", an interrupt request is output.</li> <li>When this bit is "0", the interrupt request is cleared.</li> <li>When this bit is "1", operation is not affected.</li> </ul> |
| bit8                 | ER0:               |                                           | <ul> <li>This bit is a flag that requests an interrupt.</li> <li>This bit is set to "1" when the level or edge signal set in the external interrupt request detection condition setting bit (LB0, LA0) of the request level setting register (ELVR) is detected in the external interrupt input pin (INT0).</li> <li>When this bit is set to "1" while the external interrupt request enable bit (EN0) of the DTP/external interrupt enable register (ENR) is set to "1", an interrupt request is output.</li> <li>When this bit is "0", the interrupt request is cleared.</li> <li>When this bit is "1", operation is not affected.</li> </ul>  |

### Table 15.4-1 Function Description of Each Bit of the DTP/Interrupt Cause Register (EIRR)

### **Reference:**

When the extended intelligent I/O service ( $EI^2OS$ ) is activated as a DTP function, the corresponding external interrupt request flag bit (ER3 to ER0) is cleared to "0" when the transfer of one piece of data is completed.

#### Note:

Reading by read-modify-write type instructions always returns "1".

If multiple external interrupt request outputs are enabled (ENIR: EN3 to EN0=1), only the bits for which the CPU accepts an interrupt (bits for which "1" was set in ER3 to ER0) are cleared. No other bits must be cleared unconditionally.

### 15.4.2 DTP/Interrupt Enable Register (ENIR)

The DTP/interrupt enable register (ENIR) enables/disables an external interrupt request for each external interrupt pin (INT7 to INT0).

### ■ DTP/Interrupt Enable Register (ENIR)



|                    | Bit name           |                                                | Function                                                                                                                                                                                                                                      |
|--------------------|--------------------|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit7<br>to<br>bit4 | EN7:<br>to<br>EN4: |                                                | <ul> <li>Setting of any of these bits is invalid because the external input pins are<br/>INT0 through INT3.</li> </ul>                                                                                                                        |
| bit3               | EN3:               |                                                | <ul> <li>This bit enables an interrupt request.</li> <li>When the external interrupt request flag bit (ER3) of the DTP/interrupt cause register (EIRR) is set to "1" while this bit is set to "1", an interrupt request is output.</li> </ul> |
| bit2               | EN2:               | External<br>Interrupt<br>request enable<br>bit | <ul> <li>This bit enables an interrupt request.</li> <li>When the external interrupt request flag bit (ER2) of the DTP/interrupt cause register (EIRR) is set to "1" while this bit is set to "1", an interrupt request is output.</li> </ul> |
| bit1               | EN1:               |                                                | <ul> <li>This bit enables an interrupt request.</li> <li>When the external interrupt request flag bit (ER1) of the DTP/interrupt cause register (EIRR) is set to "1" while this bit is set to "1", an interrupt request is output.</li> </ul> |
| bit0               | EN0:               |                                                | <ul> <li>This bit enables an interrupt request.</li> <li>When the external interrupt request flag bit (ER0) of the DTP/interrupt cause register (EIRR) is set to "1" while this bit is set to "1", an interrupt request is output.</li> </ul> |

#### Reference:

To use an external interrupt input pin that also serves as an I/O port, set the bit that also serves the corresponding I/O port of the port direction register (DDR) to "0" to use the pin as an input port.

The states of the external interrupt input pins can be read directly using the port data register (PDR) regardless of the states of the external interrupt request enable bits (ENIR: EN3 to EN0).

External interrupt request flag bits (ER3 to ER0) of the DTP/interrupt cause register (EIRR) are set to "1" regardless of the values of the external interrupt request enable bits (ENIR: EN3 to EN0) when a DTP/external interrupt request signal is detected.

| Table 15.4-3 Correspondence between the DTP/Interrupt Control Registers (EIRR and |
|-----------------------------------------------------------------------------------|
| ENIR) and Each Channel                                                            |

| DTP/external<br>interrupt pin | Interrupt number       | External interrupt<br>request flag bit | External interrupt request enable bit |
|-------------------------------|------------------------|----------------------------------------|---------------------------------------|
| INT3                          | #16 (10 <sub>н</sub> ) | ER3                                    | EN3                                   |
| INT2                          | #10(10H)               | ER2                                    | EN2                                   |
| INT1                          | #13 (0D <sub>H</sub> ) | ER1                                    | EN1                                   |
| INT0                          | #11 (0B <sub>H</sub> ) | ER0                                    | ENO                                   |

### 15.4.3 Request Level Setting Register (ELVR)

The request level setting register (ELVR) sets the detection condition (level or edge) for interrupt requests for each external interrupt input pin.



### Request Level Setting Register (ELVR)

#### Table 15.4-4 Function Description of Each Bit of the Request Level Setting Register (ELVR)

|                     | Bit name                                 |                                         | Function                                                                                                                                          |  |
|---------------------|------------------------------------------|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit15<br>to<br>bit8 | LB7:<br>to<br>LB4:<br>LA7:<br>to<br>LA4: |                                         | <ul> <li>Setting of any of these bits is invalid because the external input pins<br/>are INT0 through INT3.</li> </ul>                            |  |
| bit7                | LB3:                                     |                                         | This bit is used to set the detection condition (level or edge) for     interrupt requests from the signal input to the outperiod interrupt input |  |
| bit6                | LA3:                                     | External interrupt                      | interrupt requests from the signal input to the external interrupt input pin (INT3).                                                              |  |
| bit5                | LB2:                                     | request detection condition setting bit | This bit is used to set the detection condition (level or edge) for     interrupt requests from the signal input to the external interrupt input  |  |
| bit4                | LA2:                                     |                                         | interrupt requests from the signal input to the external interrupt input pin (INT2).                                                              |  |
| bit3                | LB1:                                     |                                         | This bit is used to set the detection condition (level or edge) for     interrupt requests from the signal input to the outperiod interrupt input |  |
| bit2                | LA1:                                     |                                         | interrupt requests from the signal input to the external interrupt inp<br>pin (INT1).                                                             |  |
| bit1                | LB0:                                     |                                         | This bit is used to set the detection condition (level or edge) for     interrupt requests from the signal input to the external interrupt input  |  |
| bit0                | LA0:                                     |                                         | interrupt requests from the signal input to the external interrupt input pin (INT0).                                                              |  |

### Reference:

When the detection signal set in the request level setting register (ELVR) is input to an external interrupt input pin, the external interrupt request flag bit (EIRR: ER7 to ER0) of the corresponding pin is set to "1" regardless of the setting in the DTP/interrupt enable register (ENIR).

| External interrupt input pin | Interrupt number       | Bit name |
|------------------------------|------------------------|----------|
| INT3                         | #16 (10 <sub>H</sub> ) | LB3, LA3 |
| INT2                         | #10(10H)               | LB2, LA2 |
| INT1                         | #13 (0D <sub>H</sub> ) | LB1, LA1 |
| INTO                         | #11 (0B <sub>H</sub> ) | LB0, LA0 |

 Table 15.4-5
 Correspondence between Request Level Setting Register (ELVR) and Each

 Channel
 Image: Channel

### 15.5 Operation of the DTP/External Interrupt Circuit

# The DTP/external interrupt circuit provides the external interrupt function and the DTP function. This section describes the settings required for each function and the operation of the circuit.

### Setting the DTP/External Interrupt Circuit

Figure 15.5-1 "DTP/External Interrupt Circuit" shows the settings required to operate the DTP/ external interrupt circuit.



### Figure 15.5-1 DTP/External Interrupt Circuit

 $\Delta\,$  : Set the bit corresponding to the bit used to 0.

0 : Specifies 0.

1 : Specifies 1.

Set the DTP/external interrupt circuit registers in accordance with the following procedure because an interrupt request may be generated erroneously when setting them.

- 1. Set the DTP/interrupt enable register (ENIR) to  $"00_{H}"$  to disable interrupt requests.
- 2. Set the interrupt detection condition to the external interrupt request detection condition setting bit (LB3 to LB0, LA3 to LA0) corresponding to the external interrupt input pin of the request level setting register (ELVR).
- 3. Set the external interrupt request flag bit (ER3 to ER0) corresponding to the external interrupt input pin of the DTP/interrupt cause register (EIRR) to "0" to clear the interrupt request.
- 4. To enable an interrupt request, set the external interrupt request enable bit (EN3 to EN0) corresponding to the external interrupt input pin of the DTP/interrupt enable register (ENIR) to "1".

### O Switching between the external interrupt function and the DTP function

Switching between the external interrupt function and the DTP function is set by the  $EI^2OS$  enable bit (ISE) of the interrupt control register (ICR) corresponding to the interrupt cause to be used. When the  $EI^2OS$  enable bit (ISE) is set to "1", the extended intelligent I/O service ( $EI^2OS$ ) is enabled, operating as the DTP function. When the  $EI^2OS$  enable bit (ISE) is set to "0", the extended intelligent I/O service ( $EI^2OS$ ) is disabled, and the register operates as the external interrupt function.

### Operation of the DTP/External Interrupt Circuit

|                                       | DTP/external interrupt circuit                          |
|---------------------------------------|---------------------------------------------------------|
| External interrupt request flag bit   | EIRR: ER3 to ER0                                        |
| External interrupt request enable bit | ENIR: EN3 to EN0                                        |
| Interrupt cause                       | Input of an effective edge or level to pin INT3 to INT0 |

### Table 15.5-1 Control Bit and Interrupt Cause of the DTP/External Interrupt Circuit

The DTP/external interrupt circuit outputs an interrupt request to the interrupt controller when, after operations are set to the request level setting register (ELVR), DTP/interrupt cause register (EIRR), and DTP/interrupt enable register (ENIR), the detection condition set in the request level setting register (ELVR) is input to the corresponding external interrupt input pin. When the EI<sup>2</sup>OS enable bit (ICR: ISE) of the interrupt control register is "0", interrupt processing is performed. When the EI<sup>2</sup>OS enable bit (ICR: ISE) of the interrupt control register is "1", interrupt processing is performed after the extended intelligent I/O service processing (DTP processing) is executed.





Return from external interrupt

### **15.5.1 External Interrupt Function**

The DTP/external interrupt circuit has an external interrupt function that outputs an interrupt request when the input signal is input to an external interrupt input pin.

#### External Interrupt Function

When the detection condition (level or edge) set in the request level setting register (ELVR) is input to an external interrupt input pin, the external interrupt request flag bit (ER3 to ER0) corresponding to the pin of the DTP/external interrupt cause register (EIRR) is set to "1". If the external interrupt request enable bit (EN3 to EN0) corresponding to the external interrupt input pin of the DTP/external enable register (ENIR) is set to "1", an interrupt request is output to the interrupt controller. The interrupt controller determines the interrupt level (ICR: IL2 to IL0) of interrupt requests from peripheral functions (resources) and priorities when interrupt requests are output simultaneously. The CPU determines whether to accept an interrupt request based on the interrupt level mask register (PS: ILM) and interrupt processing before branching to the interrupt processing routine. In the interrupt processing program, set the corresponding external interrupt request flag bit (ER3 to ER0) to "0" and clear the interrupt request before returning from the interrupt using an interrupt return instruction.

#### Note:

When the interrupt processing program is activated, be sure to set the external interrupt request flag bit (EIRR: EN3 to EN0) that caused the activation to "0". It is not possible to return from an interrupt while the external interrupt request flag bit (EIRR: EN3 to EN0) is set to "1".

### 15.5.2 DTP Function

The DTP/external interrupt circuit has a DTP (Data Transfer Peripheral) function that detects the data transfer request signal input to an external interrupt input pin from external peripheral devices and activates the extended intelligent I/O service.

#### Operation of the DTP Function

The DTP function is a function for detecting the data transfer request signal input to an external interrupt input pin from external peripheral devices to automatically transfer data between memory and the peripheral devices.

The extended intelligent I/O service is activated by the external interrupt function. The operation of the DTP function is the same as that of the external interrupt function until an interrupt request is accepted by the CPU. If the El<sup>2</sup>OS operation is enabled (ICR: ISE="1"), El<sup>2</sup>OS is activated when an interrupt request is accepted to start data transfer. When the data transfer is completed, the descriptor is updated and the external interrupt request flag bit (EIRR: ER3 to ER0) is cleared to "0" to operate as the external interrupt function again. When the transfer by El<sup>2</sup>OS is completed, branching to the interrupt processing routine pointed to by the vector address of the external interrupt occurs. Peripheral devices that are externally connected should remove the cause input of the data transfer request signal (DTP cause) within three machine cycles after the first transfer started.





\*1 Three machine cycles

<sup>\*2</sup> Must be removed within three machine cycles of transfer.

<sup>\*3</sup> If the extended intelligent I/O service is in peripheral  $\rightarrow$  memory transfer mode.

### 15.6 Usage Notes on the DTP/External Interrupt Circuit

Notes on the signal to be input to the DTP/external interrupt circuit, release from standby mode, and interrupts are given below.

### ■ Usage Notes on the DTP/External Interrupt Circuit

### **O** Conditions for external peripherals using the DTP function

To support the DTP function, peripheral devices that are externally connected must be able to automatically clear data transfer requests after transfer is carried out. If an externally connected peripheral device continues to output a transfer request longer than three machine cycles after the CPU started the transfer operation, the DTP/external interrupt circuit interprets the request as another transfer request and performs the data transfer operation again.

#### O Input polarities of external interrupts

- If the request level setting register (ELVR) is set for edge detection, the pulse width of at least three machine cycles is required from the point of change of the input level to detect the input of an edge that is to become an interrupt request.
- If the request level setting register (ELVR) is set for level detection, and the level for interrupt request is input, the cause flip-flop in the DTP/interrupt cause register (EIRR) is set to "1" and retains the cause, as shown in Figure 15.6-1 "Clearing the Cause Retention Circuit When a Level is Specified". Thus, even if the interrupt cause is removed, the request to the interrupt controller remains active. To cancel the request to the interrupt controller, set the external interrupt request flag bits (EIRR: ER3 to ER0) to "0" to clear the cause flip-flop to "0", as shown in Figure 15.6-2 "DTP/External Interrupt Cause and Interrupt Request When the Output of Interrupt Requests is Enabled".

#### Figure 15.6-1 Clearing the Cause Retention Circuit When a Level is Specified



The cause is stored until the register is cleared.

#### Figure 15.6-2 DTP/External Interrupt Cause and Interrupt Request When the Output of Interrupt Requests is Enabled



Becomes inactive by clearing cause FF.

### **O** Notes about interrupts

When the external interrupt function is used to branch to an interrupt processing routine, it is not possible to return from the interrupt processing program if an external interrupt request flag bit (EIRR: ER3 to ER0) is "1" and an external interrupt request enable bit (ENIR: EN3 to EN0) is "1". Be sure to clear the external interrupt request flag bits (EIRR: ER3 to ER0) to "0" in the processing program. (When using the DTP function, the external interrupt request flag bits (EIRR: ER3 to ER0) are cleared to "0" by El<sup>2</sup>OS.)

If the register is set for level detection, it is not possible to return from the interrupt processing program when the level signal of an interrupt request is input to an external interrupt input pin (INT3 to INT0) because, even if an external interrupt request flag bit (EIRR: ER3 to ER0) is set to "0", it is set to "1" again. Thus, disable an interrupt request or remove the level signal for an interrupt request.

## CHAPTER 16 I<sup>2</sup>C INTERFACE

# This chapter describes the functions and operations of the I<sup>2</sup>C interface of the MB90M405 series.

- 16.1 "Overview of the I<sup>2</sup>C Interface"
- 16.2 "Block Diagram and Configuration of the I<sup>2</sup>C Interface"
- 16.3 "I<sup>2</sup>C Interface Registers"
- 16.4 "Operation of the I<sup>2</sup>C Interface"

### 16.1 Overview of the I<sup>2</sup>C Interface

## The $I^2C$ interface operates as a master or slave device on the $I^2C$ bus at the serial I/O port that supports an inter-IC bus.

### ■ Features of the I<sup>2</sup>C Interface

MB90M405 series microcontrollers use one channel for the I<sup>2</sup>C built-in interface.

The  $I^2C$  interface has the following features:

- Master/slave transmission
- Arbitration function
- Clock synchronization function
- Function for detecting a slave address and a general call address
- Function for detecting the transfer direction
- Function for repeated generation and detection of the start condition
- Bus error detection function
- Support of a transfer rate up to 100 kbps

### 16.2 Block Diagram and Configuration of the I<sup>2</sup>C Interface

Figure 16.2-1 "Block Diagram of the  $I^2C$  Interface" shows a block diagram of the  $I^2C$  interface. Figure 16.2-2 "Configuration of the  $I^2C$  Interface" shows the configuration of the  $I^2C$  interface.

■ Block Diagram of the I<sup>2</sup>C Interface



Figure 16.2-1 Block Diagram of the I<sup>2</sup>C Interface

### ■ Configuration of the I<sup>2</sup>C Interface





### **16.3** I<sup>2</sup>C Interface Registers

The I<sup>2</sup>C interface uses the following six types of registers:

- I<sup>2</sup>C status register (IBSR)
- I<sup>2</sup>C control register (IBCR)
- I<sup>2</sup>C clock control register (ICCR)
- I<sup>2</sup>C address register (IADR)
- I<sup>2</sup>C data register (IDAR)
- I<sup>2</sup>C port select register (ISEL)

### ■ I<sup>2</sup>C Interface Registers

### Figure 16.3-1 I<sup>2</sup>C Interface Registers

bit15 ..... bit8 bit7 ..... bit0

| I <sup>2</sup> C port select register (ISEL) | I <sup>2</sup> C status register (IBSR)        |
|----------------------------------------------|------------------------------------------------|
| I <sup>2</sup> C control register (IBCR)     |                                                |
|                                              | I <sup>2</sup> C clock control register (ICCR) |
| I <sup>2</sup> C address register (IADR)     |                                                |
|                                              | I <sup>2</sup> C data register (IDAR)          |

### 16.3.1 I<sup>2</sup>C Status Register (IBSR)

The I<sup>2</sup>C status register (IBSR) has the following functions:

- Detection of a repeated start condition
- Detection of arbitration lost
- Storage of acknowledgements
- Detection of the first byte
- Detection of addressing
- Detection of the general call address
- Data transfer
- I<sup>2</sup>C Status Register (IBSR)



### Figure 16.3-2 I<sup>2</sup>C Status Register (IBSR)



 Table 16.3-1
 Functions of the I<sup>2</sup>C Status Register (IBSR) Bits

|      | Bit name                                          | Function                                                                                                                                                                                                                                                                                                                                                                               |
|------|---------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit7 | BB:<br>Bus status bit                             | <ul> <li>This bit shows the I<sup>2</sup>C bus status.</li> <li>"0" is read from this bit if the stop condition is detected.</li> <li>"1" is read from this bit if the start condition is detected.</li> </ul>                                                                                                                                                                         |
| bit6 | RSC:<br>Repeated start<br>condition detection bit | <ul> <li>This bit shows whether the repeated start condition is detected.</li> <li>"1" is read from this bit if the start condition is detected again while the bus is in use.</li> <li>This bit is cleared to "0" if the start condition or the stop condition is detected during the bus stop status while the INT bit is set to "0" and addressing is not in slave mode.</li> </ul> |
| bit5 | AL:<br>Arbitration lost<br>detection bit          | <ul> <li>This bit shows whether arbitration lost is detected.</li> <li>"1" is read from this bit if arbitration lost has occurred during transfer by the master or if the MSS bit is set to "1" while another system is using the bus.</li> <li>This bit is cleared to "0" if the INT bit is set to "0".</li> </ul>                                                                    |
| bit4 | LRB:<br>Acknowledge storage<br>bit                | <ul><li>This bit stores an acknowledgement from the receiving system.</li><li>This bit is cleared if a start or stop condition is detected.</li></ul>                                                                                                                                                                                                                                  |
| bit3 | TRX:<br>Transfer status bit                       | <ul> <li>This bit shows the data transfer send or receive status</li> <li>"0" is read from this bit during receiving</li> <li>"1" is read from this bit during sending.</li> </ul>                                                                                                                                                                                                     |
| bit2 | AAS:<br>Address detection bit                     | <ul> <li>This bit shows whether addressing is detected.</li> <li>"1" is read from this bit if addressing was in slave mode.</li> <li>This bit is cleared to "0" if the start or stop condition is detected.</li> </ul>                                                                                                                                                                 |
| bit1 | GCA:<br>General call address<br>detection bit     | <ul> <li>This bit shows whether the general call address (00<sub>H</sub>) is detected.</li> <li>"1" is read from this bit if the general call address is received in slave mode.</li> <li>This bit is cleared to "0" if the start or stop condition is detected.</li> </ul>                                                                                                            |
| bit0 | FBT:<br>First byte detection bit                  | <ul> <li>This bit shows whether the first byte is detected.</li> <li>Read operations return "1" for this bit if the received byte is the first byte (address data).</li> <li>Even if this bit has been set to "1" due to detection of a start condition, it will be cleared to "0" if the INT bit is set to "0" or addressing was in other than slave mode.</li> </ul>                 |

### 16.3.2 I<sup>2</sup>C Control Register (IBCR)

The I<sup>2</sup>C control register (IBCR) has the following functions:

- Interrupt request and interrupt enable •
- Generation of the start condition •
- Setting a system as the master or slave •
- Enabling of generation of acknowledgements •
- I<sup>2</sup>C Control Register (IBCR)



Figure 16.3-3 I<sup>2</sup>C Control Register (IBCR)



R/W : Read/write enabled : Initial value

Table 16.3-2 Functions of the I<sup>2</sup>C Control Register (IBCR) Bits

| Bit name |                                                    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
|----------|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| bit15    | BER:<br>Bus error interrupt<br>request flag bit    | <ul> <li>This is a bus error interrupt request flag bit.</li> <li>An interrupt request is output if this bit is set to "1" while the bus error interrupt request enable bit (BEIE) is "1".</li> <li>If this bit is set to "1", the EN bit of the CCR register is cleared, the I<sup>2</sup>C interface is stopped, and data transfer is halted.</li> <li>If this bit is set to "0", the interrupt request is cleared.</li> <li>Setting this bit to "1" does not effect operation.</li> </ul> |  |
| bit14    | BEIE:<br>Bus error interrupt<br>request enable bit | <ul> <li>This is a bus error interrupt enable bit.</li> <li>An interrupt is generated if the bus error interrupt request flag bit (BER) is set to "1" while this bit is "1".</li> </ul>                                                                                                                                                                                                                                                                                                      |  |
| bit13    | SCC:<br>Start condition<br>generation bit          | <ul> <li>This is a start condition generation bit.</li> <li>If this bit is set to "1", the start condition is generated again during transfer by the master and address data transfer is started.</li> <li>The read value is always "0".</li> </ul>                                                                                                                                                                                                                                          |  |
| bit12    | MSS:<br>Master/slave setting<br>bit.               | <ul> <li>This bit sets either master or slave mode.</li> <li>If this bit is set to "0", slave mode is entered after the stop condition is generated and the transfer ends.</li> <li>If this bit is set to "1", address data transfer is started after master mode is entered and the start condition is generated again.</li> <li>This bit is cleared to "0" and slave mode starts if arbitration lost occurs during transfer by the master.</li> </ul>                                      |  |
| bit11    | ACK:<br>Acknowledgement<br>generation enable bit   | <ul> <li>This bit enables generation of an acknowledgement when data is received.</li> <li>If this bit is set to "1", an acknowledgement is generated.</li> <li>This bit is invalid if address data is received in slave mode.</li> </ul>                                                                                                                                                                                                                                                    |  |
| bit10    | GCAA:<br>Acknowledgement<br>generation enable bit  | <ul> <li>This bit enables generation of an acknowledgement when the general call address is received.</li> <li>If this bit is set to "1", an acknowledgement is generated.</li> </ul>                                                                                                                                                                                                                                                                                                        |  |
| bit9     | INTE:<br>Interrupt request<br>enable bit           | <ul> <li>This bit enables interrupts.</li> <li>An interrupt is generated if the transfer end interrupt request flag bit (INT) is set to "1" while this bit is set to "1".</li> </ul>                                                                                                                                                                                                                                                                                                         |  |
| bit8     | INT:<br>Transfer end interrupt<br>request flag bit | <ul> <li>This is the transmission end interrupt request flag bit.</li> <li>If this bit is set to "1", the SCL line is kept at the "L" level.</li> <li>If this bit is set to "0", the interrupt request is cleared, the SCL line is released, and the next byte is transferred.</li> <li>This bit is cleared to "0" if the start or stop condition is generated in master mode.</li> </ul>                                                                                                    |  |

### Notes on Competition among the SCC, MSS and INT Bits

When simultaneous writing to the SCC, MSS, and INT bits occurs, there is competition for transmission of the next byte or generation of the start or stop condition. The priority is determined as explained below.

#### 1) Transmission of the next byte or generation of the stop condition

When the INT bit is set to "0" and the MSS bit is set to "0", the "0" setting of the MSS bit takes precedence, and the stop condition is generated.

### 2) Transmission of the next byte or generation of the start condition

When the INT bit is set to "0" and the SCC bit is set to "1", the "1" setting of the SCC bit takes precedence, and the start condition is generated.

### 3) Generation of the start or stop condition

Setting the SCC bit to "1" and the MSS bit to "0" at the same time is prohibited.

### 16.3.3 I<sup>2</sup>C Clock Control Register (ICCR)

The I<sup>2</sup>C clock control register (ICCR) has the following functions:

- Enabling operation of the I<sup>2</sup>C interface
- Setting the frequency of the serial clock

■ I<sup>2</sup>C Clock Control Register (ICCR)



Table 16.3-3 Functions of the I<sup>2</sup>C Clock Control Register (ICCR) Bits

| Bit name                                                                                                                                                                                                                                                             |                                                           | Function                                                                                                                                                                                                                                                                                                                                           |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| bit7<br>bit6                                                                                                                                                                                                                                                         | -:<br>Undefined bit                                       | <ul><li>The read value of this bit is undefined.</li><li>The value set for this bit does not affect operation.</li></ul>                                                                                                                                                                                                                           |  |
| bit5                                                                                                                                                                                                                                                                 | EN:<br>I <sup>2</sup> C interface operation<br>enable bit | <ul> <li>This bit enables operation of the I<sup>2</sup>C interface.</li> <li>If this bit is set to "0", the bits of the I<sup>2</sup>C bus status register (IBSR) and the I<sup>2</sup>C bus control register (IBCR), except for the BER and BEIE bits, are cleared.</li> <li>This bit is cleared to "0" if the BER bit is set to "1".</li> </ul> |  |
| bit4<br>to<br>bit0CS4 to CS0:<br>Serial clock frequency<br>setting bits• These bits set the frequency of the serial clock<br>• The frequency of the shift clock (fsck) is set as follows<br>$fsck = \frac{\phi}{m \times n + 4}$<br>$\phi$ : Machine clock frequency |                                                           | <ul> <li>The frequency of the shift clock (fsck) is set as follows:</li> <li>fsck =</li></ul>                                                                                                                                                                                                                                                      |  |

| m | CS4 | CS3 |
|---|-----|-----|
| 5 | 0   | 0   |
| 6 | 0   | 1   |
| 7 | 1   | 0   |
| 8 | 1   | 1   |

Table 16.3-4 Serial Clock Frequency Settings (CS4 and CS3)

| n   | CS2 | CS1 | CS0 |
|-----|-----|-----|-----|
| 4   | 0   | 0   | 0   |
| 8   | 0   | 0   | 1   |
| 16  | 0   | 1   | 0   |
| 32  | 0   | 1   | 1   |
| 64  | 1   | 0   | 0   |
| 128 | 1   | 0   | 1   |
| 256 | 1   | 1   | 0   |
| 512 | 1   | 1   | 1   |

If, for example, m = 5 and n = 32 are selected when  $\phi$  = 16 MHz, the resulting serial clock frequency is 97.561 kHz.

### Notes:

- The addition of four cycles is the minimum overhead required to check whether the output level of the SCL pin has changed. More cycles are required if the rising edge delay on the SCPL pin is greater or the clock period on the slave device is prolonged.
- According to the setting of the I<sup>2</sup>C operation enable bit (EN bit), the output from the I<sup>2</sup>C common port pin varies as follows:
  - When the EN bit is set to 1 (operation is enabled): An I<sup>2</sup>C output signal is output from the SDA/D90 and SCL/P91 pins regardless of the setting values (input or output settings) of bit 8 of DDR9 bit 9 of DDR9.
  - When the EN bit is set to 0 (operation is disabled): The P90 and P91 setting values of the PDR9 register are output from the SDA/D90 and SCL/P91 pins if bit 8 of the DDR9 is "1" and bit 9 of DDR9 is also "1" (output setting).
- While the I<sup>2</sup>C is in operation, execution of an RMW instruction for the port data register (PDR9) reflecting the setting of the I<sup>2</sup>C pin reads the pin level into bit 8 and bit 9 of PDR9 during reads operations. Accordingly, note that the values of bit 8 and bit 9 of PDR9 may change depending on the level of the P91/SCL and P90/SDA pins.

| I <sup>2</sup> C operation<br>enabled/disabled                | I <sup>2</sup> C operation enabled: EN bit=1 | I <sup>2</sup> C operation disabled: EN bit = 0                                    |  |
|---------------------------------------------------------------|----------------------------------------------|------------------------------------------------------------------------------------|--|
| SCL/P91                                                       |                                              | DDR9: bit9 = 0: Hi-z for input setting<br>DDR9: bit9 = 1: New PDRA value is output |  |
| SDA/P90                                                       |                                              | DDR9: bit8 = 0: Hi-z for input setting<br>DDR9: bit8 = 1: New PDRA value is output |  |
| Timing for executing an RMW instruction for the PDRA register | RMW instruction executed                     |                                                                                    |  |
| PDRA register value                                           | Previous data X Varies depending             | on the pin level at the time the RMW instruction is executed                       |  |

### Figure 16.3-5 Change Timing for the I<sup>2</sup>C Common Port

Γ

## 16.3.4 I<sup>2</sup>C Address Register (IADR)

### The I<sup>2</sup>C address register (IADR) specifies the slave address.

### ■ I<sup>2</sup>C Address Register (IADR)

#### Figure 16.3-6 I<sup>2</sup>C Address Register (IADR) Bit 15 14 13 12 11 10 9 8 Initial value XXXXXXXXB A6 A5 A4 A0 A3 A2 A1 -R/W R/W R/W R/W R/W R/W R/W \_

R/W : Read/write enabled

X : Undefined

This register specifies the slave address. In slave mode, received address data is compared with the DAR register, and if a match occurs, an acknowledgement is sent to the master.

# 16.3.5 I<sup>2</sup>C Data Register (IDAR)

# The I<sup>2</sup>C data register (IDAR) is used for serial transfer.

### ■ I<sup>2</sup>C Data Register (IDAR)

Figure 16.3-7 I<sup>2</sup>C Data Register (IDAR)

| Bit | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   | Initial value |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|---------------|
|     | D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  | XXXXXXXXB     |
|     | R/W |               |

R/W : Read/write enabled X : Undefined

The data register is used for serial transfer. Data is transferred starting from the MSB. The data output value is "1" if data is being received (TRX="0").

The writing side of this register is double-buffered. While the bus is in use (BB="1"), the write data is loaded into the register for serial transfer for each byte is transferred. During reading, data is read directly from the register for serial transfer. Thus, the received data is valid only while the INT bit is set.

# 16.3.6 I<sup>2</sup>C Port Select Register (ISEL)

# The $I^2C$ port select register (ISEL) contains the settings for the $I^2C$ .

# ■ I<sup>2</sup>C Port Select Register (ISEL)

Figure 16.3-8 I<sup>2</sup>C Port Select Register (ISEL)



Х : Undefined bit -

# Table 16.3-6 Functions of the I<sup>2</sup>C Port Select Register (ISEL) Bits

| Bit name            |                                      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit15<br>to<br>bit9 | -:<br>Undefined bit                  | <ul><li>The value read from this bit is undefined.</li><li>Setting this bit to a new value does not affect operation.</li></ul>                                                                                                                                                                                                                                                                                                                      |
| bit8                | SEL:<br>I <sup>2</sup> C setting bit | <ul> <li>Set this bit to use the I<sup>2</sup>C pin functions.</li> <li>If this bit is set to "0", the port or UART ch.3 is enabled.</li> <li>If this bit is set to "1" and the I<sup>2</sup>C interface operation enable bit (EN) of the I<sup>2</sup>C clock control register (ICCR) is set to "1", the pins become the I<sup>2</sup>C I/O pins.</li> <li>Note:<br/>Be sure to set this bit to "1" to use the I<sup>2</sup>C interface.</li> </ul> |

# **16.4** Operation of the I<sup>2</sup>C Interface

The I<sup>2</sup>C bus, which serves as a bidirectional bus line for communications, consists of a serial data line (SDA) and a serial clock line (SCL). As the I<sup>2</sup>C interface, SDA and SCL can be used as open drain I/O pins (SDA and SCL), enabling wired logic. The input withstand voltage is 5 V (Typ.).

### Start Condition

If the MSS bit is set to "1" while the bus is free (BB="0" and MSS="1"), the  $I^2C$  interface enters master mode and generates the start condition at the same time. In master mode, you can generate the start condition again by setting the SCC bit to "1" even though the bus line is in use (BB="1").

The start condition is generated for either of the following conditions:

- 1. The MSS bit is set to "1" while the bus is free (MSS="0", BB="0", INT="0", AL="0").
- 2. The SCC bit is set to "1" in an interrupt state in bus master mode (MSS="1", BB="1", INT="1", AL="0").

If the MSS bit is set to "1" while the bus is being used by another system (idle state), the AL bit is set to "1". Under conditions other than (1) and (2), the "1" setting in the MSS and SCC bits is ignored.

### Stop Condition

In master mode, setting the MSS bit to "0" generates a stop condition, causing the I<sup>2</sup>C interface to enter slave mode.

The stop condition is generated under the following condition:

The MSS bit is set to "0" in an interrupt state in bus master mode (MSS="1", BB="1", INT="1", AL="0").

Under conditions other than the above, an MSS bit setting of "0" is ignored.

### Addressing

If, in master mode, a start condition is generated, the BB bit is set to "1", the TRX bit is set to "1", and the contents of the IDAR register are output starting from the MSB. If, after the address data is sent, an acknowledgement is received from the slave, bit 0 of the send data (IDAR bit 0 after sending) is inverted and stored in the TRX bit.

If, in slave mode, the start condition is generated, the BB bit is set to "1", the TRX bit is cleared to "0", and the send data from the master is received in the IDAR register. After the address data is received, the IDAR and IADR registers are compared. If the register values match, AAS is set to "1" and an acknowledgement is sent to the master. Then, bit 0 of the receive data (IDAR bit 0 after receiving) is stored in the TRX bit.

### Arbitration

Arbitration occurs if data is sent in master mode and another master sends data at the same time. If the send data is "1" and the data on the SDA line is at the "L level", the sender assumes that it has lost the arbitration and sets the AL bit to "1". The AL bit is set to "1" also if the start condition is generated while the bus is in use.

If the AL bit is set to "1", both the MSS and TRX bits are set to "0", causing the I<sup>2</sup>C interface to enter slave receive mode.

### Acknowledgement

An acknowledgement is sent from the receiver to the sender. While data is being received, the ACK bit is used to set whether an acknowledgement should be used. While data is being sent, an acknowledgement is stored in the LRB bit.

If, in slave send mode, no acknowledgement is received from the master receiver, the TRX bit is set to "0", causing the  $I^2C$  interface to enter slave receive mode. Thus, the master can generate the stop condition when the slave frees the SCL line.

### Bus Error

If any of the following conditions occurs, a bus error is assumed and the  $I^2C$  interface is stopped.

- A basic specification violation is detected on the I<sup>2</sup>C bus during data transfer (including the ACK bit).
- The stop condition is detected in master mode.
- A basic specification violation is detected on the I<sup>2</sup>C bus when the bus is idle.

#### ■ Execution of Start Condition Generation Instruction While SDA=LOW and SCL=LOW

When the start condition generation instruction (which writes 1 to the MSS bit) is executed while SDA=LOW and SCL=LOW, this results in BB=0 and AL=1. In this case, the transfer end interrupt request flag (INT bit) is not set because the transfer is not completed. Consequently, detect this status by monitoring the BB and AL bits from the program.

#### Figure 16.4-1 Change Timing for Flags When the Start Condition Generation Instruction is Executed While SDA=LOW and SCL=LOW

| SCL             |                            | "L" |
|-----------------|----------------------------|-----|
| SDA             |                            | "L" |
| Start condition | Setting the MSS bit to "1" |     |
| Arbitration     | AL bit of IBSR             |     |
| Interrupt       | INT bit of IBCR            | "L" |
| Bus busy        | BB bit of IBSR             | "L" |

# 16.4.1 Transfer Flow of the I<sup>2</sup>C Interface

Figure 16.4-2 "One-byte Transfer Flow from the Master to the Slave" shows the flow of a one-byte transfer from the master to the slave. Figure 16.4-3 "One-byte Transfer Flow from the Slave to the Master" shows the flow of a one-byte transfer from the slave to the master.

# ■ Transfer Flow of the I<sup>2</sup>C Interface



349



#### Figure 16.4-3 One-byte Transfer Flow from the Slave to the Master

# 16.4.2 Mode Flow of the I<sup>2</sup>C Interface

Figure 16.4-4 "I<sup>2</sup>C Mode Flow" shows the flow of mode transitions for the I<sup>2</sup>C interface.

# ■ Flow of I<sup>2</sup>C Interface Mode Transitions



### Figure 16.4-4 I<sup>2</sup>C Mode Flow

# 16.4.3 Operation Flow of the I<sup>2</sup>C Interface

Figure 16.4-5 "Operation Flow of the Master Send/Receive Program (with Interrupts) for the  $I^2C$  Interface" shows the operation flow of a master send/receive program (with interrupts) for the  $I^2C$  interface. Figure 16.4-6 "Operation Flow of the Slave Program (with Interrupts) for the  $I^2C$  Interface" shows the operation flow of the slave program (with interrupts) for the  $I^2C$  Interface.

# Operation Flow of the I<sup>2</sup>C Interface







### Figure 16.4-6 Operation Flow of the Slave Program (with Interrupts) for the I<sup>2</sup>C Interface

### CHAPTER 16 I2C INTERFACE

# CHAPTER 17 8/10-BIT A/D CONVERTER

This chapter describes the functions and operations of the MB90M405 series 8/10-bit A/D converter.

- 17.1 "Overview of the 8/10-Bit A/D Converter"
- 17.2 "Configuration of the 8/10-Bit A/D Converter"
- 17.3 "8/10-Bit A/D Converter Pins"
- 17.4 "8/10-Bit A/D Converter Registers"
- 17.5 "8/10-Bit A/D Converter Interrupts"
- 17.6 "Operation of the 8/10-Bit A/D Converter"
- 17.7 "Usage Notes on the 8/10-Bit A/D Converter"

# 17.1 Overview of the 8/10-Bit A/D Converter

The 8/10-bit A/D converter has a function for converting the analog input voltage into a 10-bit or 8-bit value using the RC-type successive approximation conversion method.

### ■ Functions of the 8/10-Bit A/D Converter

The following shows the functions of the 8/10-bit A/D converter:

- The minimum conversion time is 5.9  $\mu s$  (for a machine clock of 16.8 MHz; includes the sampling time).
- The minimum sampling time is 2.1  $\mu$ s (for a machine clock of 16.8 MHz).
- The converter uses the RC-type successive approximation conversion method with a sample hold circuit.
- A resolution of 10 bits or 8 bits can be selected.
- The input signal can be set using a program from the 8-channel analog input pins.
- At the end of A/D conversion, an interrupt request can be generated and El<sup>2</sup>OS can be activated.
- If A/D conversion is performed while an interrupt is enabled, the conversion data protection function is activated.
- The conversion can be activated by software, 16-bit reload timer 1 output (rising edge), and 16-bit free-running timer zero detection edge.

Table 17.1-1 "8/10-bit A/D Converter Conversion Modes" lists four types of conversion modes.

Table 17.1-1 8/10-bit A/D Converter Conversion Modes

| Conversion mode                                      | Single conversion                                                                                                          | Scan conversion                                                                                                                                   |
|------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Single conversion mode 1<br>Single conversion mode 2 | Converts the input of a specified channel (single channel) just once.                                                      | Converts the inputs of two or more consecutive channels (up to 16 channels) just once.                                                            |
| Continuous conversion mode                           | Converts the input of a specified channel (single channel) repeatedly.                                                     | Repeatedly converts the inputs of two or more consecutive channels (up to 16 channels).                                                           |
| Stop conversion mode                                 | Converts the input of a specified<br>channel (single channel), after which<br>it is on standby for the next<br>activation. | Converts the inputs of two or more<br>consecutive channels (up to 16<br>channels) once, then enters standby<br>mode and waits for the next start. |

# ■ 8/10-Bit A/D Converter Interrupts and El<sup>2</sup>OS

|                        | Interrupt co     | ntrol register      | Vect                |                     |                     |                    |
|------------------------|------------------|---------------------|---------------------|---------------------|---------------------|--------------------|
| Interrupt No.          | Register<br>name | Address             | Lower               | Upper               | Bank                | El <sup>2</sup> OS |
| #37 (25 <sub>H</sub> ) | ICR13            | 0000BD <sub>H</sub> | FFFF68 <sub>H</sub> | FFFF69 <sub>H</sub> | FFFF6A <sub>H</sub> | 0                  |

Table 17.1-2 8/10-Bit A/D Converter Interrupts and El<sup>2</sup>OS

O: Available

# 17.2 Configuration of the 8/10-Bit A/D Converter

The 8/10-bit A/D converter consists of the following blocks:

- A/D control status register (ADCS0/ADCS1) •
- A/D data register (ADCR0/ADCR1) •
- A/D conversion channel select register (ADMR)
- Clock selector (Input clock selector for activating A/D conversion) •
- Decoder •
- Analog channel selector .
- Sample hold circuit •
- D/A converter •
- Comparator •
- **Control circuit** •

# Block Diagram of the 8/10-Bit A/D Converter



Figure 17.2-1 Block Diagram of the 8/10-Bit A/D Converter

φ: Machine clock

\* : Interrupt signal

### O A/D control status register (ADCS0/ADCS1)

The A/D control status register (ADCS0) sets the A/D conversion mode.

The A/D control status register (ADCS1) sets the A/D conversion activation trigger and enable/ disable of interrupt requests and checks the interrupt request status and whether the A/D conversion has halted/is in progress.

### O A/D data register (ADCR0/ADCR1)

This register stores the results of A/D conversion. It also sets the resolution for A/D conversion, sampling time during A/D conversion, and compare time during A/D conversion.

#### O A/D conversion channel select register (ADMR)

A/D conversion channel select register (ADMR) sets the A/D conversion start/end channel.

#### O Clock selector

The clock selector selects the clock for starting A/D conversion. The 16-bit reload timer 1 output can be used as the start clock.

#### O Decoder

This circuit sets the analog input pin to be used based on the A/D conversion end channel setting bits (ANE0 to ANE3) and A/D conversion start channel setting bits (ANS0 to ANS3) of the A/D control status register (ADCS0).

#### **O** Analog channel selector

This circuit selects the pin to be used from among 16 analog input pins.

#### **O** Sample hold circuit

This circuit maintains the input voltage from the pin set by the analog channel selector. By maintaining the input voltage just after starting A/D conversion, it is not affected by input voltage variations during A/D conversion (during comparison).

#### O D/A converter

This circuit generates a reference voltage for comparison with the input voltage maintained by the sample hold circuit.

#### **O** Comparator

This circuit compares the input voltage maintained by the sample hold circuit with the output voltage of the D/A converter to determine which is greater.

#### **O** Control circuit

This circuit determines the A/D conversion value based on the decision signal generated by the comparator. When the A/D conversion has been completed, the circuit sets the conversion result in the A/D data register (ADCR0/ADCR1) and generates an interrupt request.

# 17.3 8/10-Bit A/D Converter Pins

# This section describes the 8/10-bit A/D converter pins and provides pin block diagrams.

### ■ 8/10-Bit A/D Converter Pins

The A/D converter pins are also used as I/O ports.

Table 17.3-1 8/10-bit A/D Converter Pins

| Function   | Pin name | Pin function              | Input-output<br>signal type                                    | Pull-up<br>option | Standby<br>control | Setting for using the pin                                                                                                |
|------------|----------|---------------------------|----------------------------------------------------------------|-------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| Channel 0  | PA0/AN0  |                           |                                                                | Not<br>selectable |                    | Set Port A as<br>an input port<br>(DDRA:bit0 to<br>bit7="0").<br>Set as an<br>analog port<br>(ADER0:bit0<br>to bit7="1") |
| Channel 1  | PA1/AN1  |                           |                                                                |                   |                    |                                                                                                                          |
| Channel 2  | PA2/AN2  |                           | CMOS output/                                                   |                   |                    |                                                                                                                          |
| Channel 3  | PA3/AN3  | Port A input-             | CMOS                                                           |                   | Not<br>selectable  |                                                                                                                          |
| Channel 4  | PA4/AN4  | output or<br>analog input | hysteresis<br>input or                                         |                   |                    |                                                                                                                          |
| Channel 5  | PA5/AN5  |                           | analog input                                                   |                   |                    |                                                                                                                          |
| Channel 6  | PA6/AN6  |                           |                                                                |                   |                    |                                                                                                                          |
| Channel 7  | PA7/AN7  |                           |                                                                |                   |                    |                                                                                                                          |
| Channel 8  | PB0/AN8  |                           | CMOS output/<br>CMOS<br>hysteresis<br>input or<br>analog input | Not<br>selectable | Not<br>selectable  | Set Port B as<br>an input port<br>(DDRB:bit0 to<br>bit7="0").<br>Set as an<br>analog port<br>(ADER1:bit0<br>to bit7="1") |
| Channel 9  | PB1/AN9  |                           |                                                                |                   |                    |                                                                                                                          |
| Channel 10 | PB2/AN10 |                           |                                                                |                   |                    |                                                                                                                          |
| Channel 11 | PB3/AN11 | Port B input-             |                                                                |                   |                    |                                                                                                                          |
| Channel 12 | PB4/AN12 | output or<br>analog input |                                                                |                   |                    |                                                                                                                          |
| Channel 13 | PB5/AN13 |                           |                                                                |                   |                    |                                                                                                                          |
| Channel 14 | PB6/AN14 | 1                         |                                                                |                   |                    |                                                                                                                          |
| Channel 15 | PB7/AN15 | ]                         |                                                                |                   |                    |                                                                                                                          |

#### ■ Block Diagrams of the 8/10-Bit A/D Converter Pins



Figure 17.3-1 Block Diagram of the PA0/AN0 to PB7/AN15 Pins

Standby control: Stop mode and LPMCR: SPL="1"

### Notes:

- To use a pin as an input port, set the corresponding bit (bit7 to bit0) of the port direction registers (DDRA and DDRB) to "0" and the corresponding bit (bit15 to bit0) of the analog input enable registers (ADER0 and ADER1) to "0".
- To use a pin as an analog input pin, set the corresponding bit (bit15 to bit0) of the analog input enable registers (ADER0 and ADER1) to "1". The value read from each of the port data registers (PDRA and PDRB) is 00<sub>H</sub>.

# 17.4 8/10-Bit A/D Converter Registers

This section lists the 8/10-bit A/D converter registers.

# ■ 8/10-Bit A/D Converter Registers

| bit15 ····· bit8                              | bit7 bit0                           |
|-----------------------------------------------|-------------------------------------|
| A/D control status register (ADCS1)           | A/D control status register (ADCS0) |
| A/D data register (ADCR1)                     | A/D data register (ADCR0)           |
| A/D conversion channel select register (ADMR) |                                     |

### Figure 17.4-1 List of Registers of the 8/10-Bit A/D Converter

# 17.4.1 A/D Control Status Register 1 (ADCS1)

The A/D control status register (ADCS1) sets the A/D conversion activation trigger and enable/disable of interrupt requests and checks the interrupt request status and whether the A/D conversion has halted/is in progress.

■ A/D Control Status Register 1 (ADCS1)



R/W : Read/write W : Write only

: Initial value

|                | Bit name                                    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit15          | BUSY:<br>Busy bit                           | <ul> <li>This bit indicates the operating status of the A/D converter</li> <li>When this bit is "0", the A/D conversion has halted.</li> <li>When this bit is "1", the A/D conversion is in progress.</li> <li>When this bit is set to "0", the A/D conversion is forced to halt.</li> <li>When this bit is set to "1", operation is not affected.</li> <li>Note:<br/>Do not set the forced A/D conversion stop and the activation (BUSY="0", STRT="1") simultaneously.</li> </ul>                                                                                                                                                                  |
| bit14          | INT:<br>Interrupt request<br>flag bit       | <ul> <li>This bit is a flag that requests an interrupt.</li> <li>This bit is set to "1" when A/D conversion results are stored in the A/D data register (ADCR0/ADCR1).</li> <li>When this bit is set to "1" while the interrupt request enable bit (INTE) is "1", an interrupt request is output.</li> <li>When this bit is set to "0", the interrupt request is cleared.</li> <li>When this bit is set to "1", operation is not affected.</li> <li>When El<sup>2</sup>OS is used, this bit is cleared to "0".</li> <li>Note:<br/>To clear the interrupt requests, stop the A/D conversion.</li> </ul>                                              |
| bit13          | INTE:<br>Interrupt request<br>enable bit    | <ul> <li>This bit enables an interrupt request.</li> <li>When the interrupt request flag bit (INT) is set to "1" while this bit is set to "1", an interrupt request is output.</li> <li>To use El<sup>2</sup>OS, set this bit to "1".</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                    |
| bit12          | PAUS:<br>Halt flag bit                      | <ul> <li>This bit is set to "1" when the A/D conversion stops temporarily.</li> <li>When El<sup>2</sup>OS is used in continuous conversion mode, this bit is set to "1" if transfer of the last piece of data to memory has not been completed even though A/D conversion is completed. Thus, the A/D conversion is stopped temporarily and conversion data is not stored in the A/D data register (ADCR0/ADCR1).</li> <li>When data transfer of the last piece of data to memory is completed, this bit is cleared to "0" and the A/D conversion is then restarted.</li> <li>Note:<br/>This bit is valid when El<sup>2</sup>OS is used.</li> </ul> |
| bit11<br>bit10 | STS1, STS0:<br>A/D activation<br>select bit | <ul> <li>These bits select how A/D conversion is to be activated.</li> <li>When two or more activation causes are shared, activation is the result of the cause that occurs first.</li> <li>Note:<br/>Change the setting during A/D conversion only while there is no corresponding activation cause, since the change becomes effective immediately.</li> </ul>                                                                                                                                                                                                                                                                                    |
| bit9           | STRT:<br>A/D conversion<br>activation bit   | <ul> <li>This bit allows software to start A/D conversion.</li> <li>Writing 1 to this bit activates A/D conversion.</li> <li>In stop conversion mode, conversion cannot be reactivated with this bit.</li> <li>Note:<br/>Never perform the forced stop and activation (BUSY="0", STRT="1") of the A/D conversion simultaneously.</li> </ul>                                                                                                                                                                                                                                                                                                         |
| bit8           | RESV:<br>Reserved bit                       | Note:<br>Always write 0 to this bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

# Table 17.4-1 Function Description of Each Bit of A/D Control Status Register 1 (ADCS1)

# 17.4.2 A/D Control Status Register 0 (ADCS0)

The A/D control status register (ADCS0) sets the A/D conversion mode.

### ■ A/D Control Status Register 0 (ADCS0)



Figure 17.4-3 A/D Control Status Register 0 (ADCS0)

- : Undefined bit

: Initial value

| Bit name     |                                                 | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------|-------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit7<br>bit6 | MD1, MD0:<br>A/D conversion<br>mode setting bit | <ul> <li>This bit is used to set the A/D conversion mode.</li> <li>Single conversion mode 1, single conversion mode 2, continuous conversion mode, and stop conversion mode can be set.</li> <li>Single conversion mode 1:         <ul> <li>A/D conversion is performed from the channel specified by the A/D conversion end channel setting bits (ANS3 to ANS0) to that specified by the A/D conversion end channel setting bits (ANE3 to ANE0) before terminating. Reactivation during operation is allowed.</li> </ul> </li> <li>Single conversion mode 2:         <ul> <li>A/D conversion is performed from the channel specified by the A/D conversion start channel setting bits (ANS3 to ANS0) to that specified by the A/D conversion start channel setting bits (ANS3 to ANS0) to that specified by the A/D conversion start channel setting bits (ANE3 to ANE0) before terminating. Reactivation during operation is not allowed.</li> </ul> </li> <li>Continuous conversion mode:         <ul> <li>A/D conversion is performed from the channel specified by the A/D conversion start channel setting bits (ANE3 to ANE0) before terminating. Reactivation during operation is not allowed.</li> </ul> </li> <li>Continuous conversion mode:         <ul> <li>A/D conversion end channel setting bits (ANE3 to ANS0) to that specified by the A/D conversion start channel setting bits (ANE3 to ANE0) is repeated until the conversion stop is forcibly implemented by the Converting bit (BUSY). Reactivation during operation is not allowed.</li> </ul> </li> <li>Stop conversion mode:         <ul> <li>A/D conversion end channel setting bits (ANE3 to ANS0) to that specified by the A/D conversion start channel setting bits (ANE3 to ANS0) to that specified by the A/D conversion stop is forcibly implemented by the Conversion stop is forcibly implemented by the Conversion stop is conversion start channel setting bits (ANS3 to ANS0) to that specified</li></ul></li></ul> |

# Table 17.4-2 Function Description of Each Bit of A/D Control Status Register 0 (ADCS0)

# 17.4.3 A/D Data Register (ADCR0/ADCR1)

The A/D data register (ADCR0/ADCR1) stores the results of A/D conversion. It also sets the resolution for A/D conversion, sampling time during A/D conversion, and compare time during A/D conversion.

### A/D Data Register (ADCR0/ADCR1)



Figure 17.4-4 A/D Data Register (ADCR0/ADCR1)

| R/W | - | Read-only  |
|-----|---|------------|
| W   | : | Write-only |
| Х   | : | Undefined  |

: Undefined bit

: Initial value

 $\overline{\phi}$  : Machine clock frequency

|                | Bit name                                         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|----------------|--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| bit15          | S10:<br>A/D conversion<br>resolution setting bit | <ul> <li>This bit is used to set the resolution for A/D conversion.</li> <li>When this bit is "0", the 10-bit resolution is set.</li> <li>When this bit is "1", the 8-bit resolution is set.</li> <li>Note: <ul> <li>A/D data bits to be used depend on the resolution. In 10-bit resolution mode, the D9 to D0 bits are used. In 8-bit resolution mode, the D7 to D0 bits are used.</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                     |  |  |
| bit14<br>bit13 | ST1, ST0: Sampling<br>time setting bit           | <ul> <li>This bit is used to set the sampling time for A/D conversion.</li> <li>When A/D conversion is activated, the analog input is captured for the time interval specified by the sampling time setting bits (ST1, ST0).</li> <li>Note:</li> <li>When "00<sub>B</sub>" is set, the machine clock frequency should be equal to or less than 8 MHz.</li> <li>If "00<sub>B</sub>" is set when the machine clock frequency is 16 MHz, normal analog conversion values may not be obtained.</li> </ul>                                                                                                                                                                                                           |  |  |
| bit12<br>bit11 | CT1, CT0:<br>Comparison time<br>setting bit      | <ul> <li>This bit is used to set the compare time for A/D conversion.</li> <li>The A/D conversion result is determined after the analog input is captured (sampling time passed) and the compare time interval specified by the compare time setting bits (CT1, CT0). In 10-bit resolution mode, the result is stored in the A/D data bits (D9 to D0). In 8-bit resolution mode, the result is stored in the A/D data bits (D7 to D0).</li> <li>Note:</li> <li>When "00<sub>B</sub>" is set, the machine clock frequency should be equal to or less than 8 MHz.</li> <li>If "00<sub>B</sub>" is set when the machine clock frequency is 16 MHz, normal analog conversion values may not be obtained.</li> </ul> |  |  |
| vit10          | -:<br>Undefined bit                              | <ul><li>The value read from this bit is undefined.</li><li>The value set to this bit does not affect operation.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| bit9 - bit0    | D9 - D0:<br>A/D data bit                         | <ul> <li>These bits are used to store A/D conversion results. They are rewritten after each A/D conversion is completed.</li> <li>Normally, the final conversion value is stored.</li> <li>The initial value is undefined.</li> <li>Note: <ul> <li>The A/D conversion data protection function is available (For details, see Section 17.6 "Operation of the 8/10-Bit A/D Converter").</li> <li>Do not write data to the A/D data bits during A/D conversion.</li> </ul> </li> </ul>                                                                                                                                                                                                                            |  |  |

#### Notes:

- Be sure to stop the A/D conversion before rewriting the A/D conversion resolution setting bit (S10). If the bit is rewritten after the A/D conversion started, the A/D data register (ADCR0/ ADCR1) contents are undefined.
- To read the A/D data register (ADCR0/ADCR1), be sure to use the word transfer instructions (such as MOVW A and 002E<sub>H</sub>) when 10-bit resolution mode is specified.

# 17.4.4 A/D Conversion Channel Select Register (ADMR)

The A/D Conversion Channel Select Register (ADMR) selects an A/D conversion channel.

## ■ A/D Conversion Channel Select Register (ADMR)

Bit



Figure 17.4-5 A/D Conversion Channel Select Register (ADMR)

R/W : Read/write enabled

| Bit name                     |                                                                                 | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
|------------------------------|---------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| bit7<br>bit6<br>bit5<br>bit4 | ANS3, ANS2,<br>ANS1, ANS0:<br>A/D conversion<br>start channel<br>selection bits | <ul> <li>These bits are used to select an A/D conversion start channel and check a channel number being converted.</li> <li>A/D conversion starts from the channel selected via the A/D conversion start channel selection bits (ANS3 to ANS0).</li> <li>During A/D conversion, a channel number that is being converted is read. During temporary stop in stop conversion mode, a channel number converted just before the temporary stop is read.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| bit3<br>bit2<br>bit1<br>bit0 | ANE3, ANE2,<br>ANE1, ANE0:<br>A/D conversion<br>end channel<br>selection bits   | <ul> <li>These bits are used to select an A/D conversion end channel.</li> <li>A/D conversion ends with the channel selected by the A/D conversion end channel selection bits (ANE3 to ANE0).</li> <li>If the same channel is selected both by the A/D conversion start channel selection bits (ANS3 to ANS0) and by the A/D conversion end channel selection bits, A/D conversion is performed on the specified channel.</li> <li>If continuous conversion mode or stop conversion mode is specified, A/D conversion ends with the channel selected by the A/D conversion end channel selection bits (ANE3 to ANE0) and conversion is then repeated starting with the start channel selected by the A/D conversion start channel selection bits (ANS3 to ANE0). If the value specifying the start channel is greater than the value specifying the end channel, A/D conversion is performed on the start channel through AN15 and then on AN0 through the end channel, completing the first phase of conversion operation.</li> </ul> |  |  |  |

# Table 17.4-4 Functions of the A/D Conversion Channel Selection Register (ADMR) Bits

# 17.5 8/10-Bit A/D Converter Interrupts

The 8/10-bit A/D converter can generate an interrupt request when the data for the A/D conversion is set in the A/D data register. This function supports the extended intelligent I/O service (El<sup>2</sup>OS).

## ■ 8/10-bit A/D Converter Interrupts

|                              | 8/10-bit A/D converter                                     |  |  |
|------------------------------|------------------------------------------------------------|--|--|
| Interrupt request flag bit   | ADCS: INT="1"                                              |  |  |
| Interrupt request enable bit | ADCS: INTE="1"                                             |  |  |
| Interrupt cause              | Writing the A/D conversion result to the A/D data register |  |  |

When A/D conversion is started and the A/D conversion result is stored in the A/D data register (ADCR0 and ADCR1), the interrupt request flag bit (INT) of the A/D control status register (ADCS1) is set to "1". If the interrupt request enable bit (INTE) has been set to "1", an interrupt request is output to the CPU.

## ■ 8/10-Bit A/D Converter Interrupts and El<sup>2</sup>OS

| Table 17.5-2 8 | 3/10-Bit A/D Converter | Interrupts and El <sup>2</sup> OS |
|----------------|------------------------|-----------------------------------|
|----------------|------------------------|-----------------------------------|

| Interrupt              | Interrupt control register |                     | Vector table address |                     |                     | El <sup>2</sup> OS |
|------------------------|----------------------------|---------------------|----------------------|---------------------|---------------------|--------------------|
| No.                    | Register name              | Address             | Lower                | Upper               | Bank                | EI-03              |
| #37 (25 <sub>H</sub> ) | ICR13                      | 0000BD <sub>H</sub> | FFFF68 <sub>H</sub>  | FFFF69 <sub>H</sub> | FFFF6A <sub>H</sub> | 0                  |

o: Available

# ■ El<sup>2</sup>OS Function of the 8/10-Bit A/D Converter

The 10-bit A/D converter can transfer A/D conversion results to memory using the  $EI^2OS$  function. When the  $EI^2OS$  function is used, the conversion data protection function is activated to temporarily stop A/D conversion until A/D conversion data has been transferred to memory and the interrupt request flag bit (INT) of the A/D control status register (ADCS1) is cleared to "0". This function is useful for preventing the omission of data.

# 17.6 Operation of the 8/10-Bit A/D Converter

The 8/10-bit A/D converter has four conversion modes: single conversion mode 1, single conversion mode 2, continuous conversion mode, and stop conversion mode. This section explains each of these modes.

### Operation in Single Conversion Mode

In single conversion mode, analog input specified by the ANS and ANE bits is converted in sequence. A/D conversion ends when it is performed on an end channel specified by the ANE bits. If the start channel and the end channel are the same (ANS=ANE), only one channel specified by the ANS bits is converted. To use single conversion mode, make settings as shown in Figure 17.6-1 "Settings for Single Conversion Mode".



#### Figure 17.6-1 Settings for Single Conversion Mode

ANS = 0000<sub>B</sub>, ANE = 0011<sub>B</sub>:AN0 --> AN1 --> AN2 --> AN3 --> End

ANS = 1110<sub>B</sub>, ANE = 0010<sub>B</sub>:AN14 --> AN15 --> AN0 --> AN1 --> AN2 --> End

ANS = 0011<sub>B</sub>, ANE = 0011<sub>B</sub>:AN3 --> END

#### Operation in Continuous Conversion Mode

In continuous conversion mode, analog input from the start channel specified by the A/D conversion start channel setting bits (ANS3 to ANS0) of the A/D control status register (ADCS0) to the end channel specified by the A/D conversion end channel setting bits (ANE3 to ANE0) is A/D converted to return to the analog input specified by the A/D conversion start channel setting bits (ANS3 to ANS0) to repeat the A/D conversion.

If the start channel and the end channel are the same, the A/D conversion of the channel specified by the A/D conversion start channel setting bits (ANS3 to ANS0) is repeated.

The A/D conversion does not stop until the Converting bit (BUSY) of the A/D control status register (ADCS1) is set to "0". Reactivation during operation is not possible. For operation in continuous conversion mode, the settings shown in Figure 17.6-2 "Settings for Continuous Conversion Mode" are required.



Figure 17.6-2 Settings for Continuous Conversion Mode

The following are sample conversion sequences in continuous conversion mode:  $ANS = 0000_B$ ,  $ANE = 0011_B$ :AN0 --> AN1 --> AN2--> AN3--> AN0--> Repeat  $ANS = 1110_B$ ,  $ANE = 0010_B$ :AN14 --> AN15 --> AN0--> AN1--> AN2 --> AN14 --> Repeat $ANS = 0011_B$ ,  $ANE = 0011_B$ :AN3 --> AN3 --> Repeat

#### Operation in Stop Conversion Mode

In stop conversion mode, analog input from the start channel specified by the A/D conversion start channel setting bits (ANS3 to ANS0) of the A/D control status register (ADCS0) to the end channel specified by the A/D conversion end channel setting bits (ANE3 to ANE0) is A/D converted by making a pause for each channel before returning to the analog input specified by the A/D conversion start channel setting bits (ANS3 to ANS0) to repeat the A/D conversion and pause.

If the start channel and the end channel are the same, the A/D conversion of the channel specified by the A/D conversion start channel setting bits (ANS3 to ANS0) is repeated.

In the pause state, reactivation method of the A/D conversion depends on the activation cause specified in the activation cause set bit (STS1, STS0) in the A/D control status register (ADCS1).

The A/D conversion does not stop until the Converting bit (BUSY) of the A/D control status register (ADCS1) is set to "0". Reactivation during operation is not possible. For operation in stop conversion mode, the settings shown in Figure 17.6-3 "Settings for Stop Conversion Mode" are required.



Figure 17.6-3 Settings for Stop Conversion Mode

The following are sample conversion sequences in stop conversion mode:

 $ANS = 0000_B$ ,  $ANE = 0011_B$ :

AN0 --> Pause --> AN1 --> Pause --> AN2 --> Pause --> AN3 --> Pause --> AN0 --> Repeat ANS =  $1100_{B}$ , ANE =  $0001_{B}$ :

AN14 --> Pause --> AN15 --> Pause --> AN0 --> Pause --> AN1 --> Pause --> AN14 --> Repeat

 $ANS = 0011_B$ ,  $ANE = 0011_B$ :

AN3 --> Pause --> AN3 --> Pause --> Repeat

# 17.6.1 Conversion Using El<sup>2</sup>OS

# The 8/10-bit A/D converter can use El<sup>2</sup>OS transfer the A/D conversion result to memory.

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





\*1 The number of times is determined by an EI2OS setting.

When El<sup>2</sup>OS is used, the conversion data protection function prevents any part of the data from being lost even in continuous conversion. Multiple data items can be safely transferred to memory.

# 17.6.2 A/D Conversion Data Protection Function

When A/D conversion is performed in the interrupt enabled state, the conversion data protection function operates.

#### ■ A/D Conversion Data Protection Function

The 8/10-bit A/D converter has only one data register for conversion data storage. Thus, when A/D conversion is performed, the data stored in the data register is rewritten when the conversion is completed. In continuous conversion mode, if conversion data is transferred to memory too late, part of the stored data will be missing.

As measures against such data omission, the data protection function works as shown below if an interrupt request is enabled (ADCS1: INTE="1").

### O Data protection function when El<sup>2</sup>OS is not used

When conversion data is stored in the A/D data register (ADCR0/ADCR1), the interrupt request flag bit (INT) of the A/D control status register 1 (ADCS1) is set to "1" and the A/D conversion is halted. The A/D conversion is restarted after transferring the A/D data register (ADCR0/ADCR1) values to memory in the interrupt routine and the interrupt request flag bit (INT) is cleared to "0".

### • Data protection function when El<sup>2</sup>OS is used

In continuous conversion mode, the pause flag bit (PAUS) of the A/D control status register 1 (ADCS1) is set to "1" if El<sup>2</sup>OS is used and A/D conversion is completed, but the transfer of the last piece of data to memory is not completed so that the A/D conversion is halted and conversion data is not stored in the A/D data register (ADCR0/ADCR1). When the transfer of the last piece of data to memory is completed, the pause flag bit (PAUS) is cleared to "0" and the A/D conversion is restarted.



Figure 17.6-5 Flow of the Data Protection Function when El<sup>2</sup>OS is Used

<Caution> The steps followed while the A/D converter is stopped are omitted.

#### Notes:

- The conversion data protection function operates only in the interrupt enabled state (ADCS1: INTE = 1).
- If interrupts are disabled during a pause of A/D conversion while EI<sup>2</sup>OS is operating, the A/D conversion may be reactivated. This will cause new data to be written before the old data is transferred.
- Reactivation attempted during a pause will destroy the standby data.

# 17.7 Usage Notes on the 8/10-Bit A/D Converter

# Notes on using the 8/10-bit A/D converter.

### ■ Usage Notes on the 8/10-Bit A/D Converter

### O Analog input pin

The analog input pins of the A/D converter are used also as the I/O pins of ports A and B. Use these pins by switching the port direction registers (DDRA and DDRB) and the analog input enable registers (ADER0 and ADER1). To use a pin as an analog input pin of the A/D converter, set the corresponding bit (bit 7 to bit 0) of the port direction registers (DDRA and DDRB) to "0" (set it as an input port) and then set the corresponding bit (bit 7 to bit 0 and bit 15 to bit 8) of the analog input enable registers 0 and 1 (ADER0 and ADER1) to "1" to permanently select the input gate on the port side. In port I/O mode (bit 7 to bit 0 of ADER0 and ADER1 ="0" and bit7 to bit0="0"), the input of an intermediate-level signal causes an input leakage current to flow through the gate.

### O Note on using an internal timer

To activate the A/D converter with the internal timer, set the A/D activation trigger setting bits (STS1, STS0) of the A/D control status register (ADCS1). Set the internal timer to the inactive level ("L" for the internal clock). If the internal clock remains at the active level and data is written to the A/D control status register (ADCS0/ADCS1), the A/D converter may be activated.

#### O Sequence of turning on the A/D converter and analog input

Be sure to apply the voltage to the power supply pins (AV<sub>CC</sub>, AVR, and AV<sub>SS</sub>) of the A/D converter and the analog input pins (AN0 to AN15) after turning on the digital power supply (V<sub>CC</sub>). Turn off the digital power supply (V<sub>CC</sub>) after turning off the A/D converter and the analog input power supply. Turn on and turn off the voltage so that AVR does not exceed AV<sub>CC</sub>.

### O Supply voltage to the A/D converter

The supply voltage to the A/D converter (AV<sub>CC</sub>) must not exceed the digital power supply (V<sub>CC</sub>); otherwise, latchup may occur.

# CHAPTER 18 FL CONTROL CIRCUIT

This chapter explains the functions and operation of the MB90M405 series FL control circuit.

- 18.1 "Overview of FL Control Circuit"
- 18.2 "Configuration of FL Control Circuit"
- 18.3 "FL Control Circuit Pins"
- 18.4 "FL Control Circuit Operation"

# **18.1 Overview of FL Control Circuit**

The FL control circuit provides functions for automatic display on fluorescent tube and LED displays.

The automatic fluorescent display function provides up to 32 points for displaying digits and up to 60 points for displaying digits and segments.

The automatic LED display function can output data at a 1/2-duty cycle from the LED01 to LED16 pins while using the LED00 pin as common output.

### High Dielectric Output Pins

- 60 high dielectric output pins (FIP0 to FIP59) are provided.
- 34 high-current output pins (FIP0 to FIP33) and 26 medium-current output pins (FIP34 to FIP59) are provided.
- Use of pull-down resistors can be set for all high dielectric outputs as well as for combinations of high dielectric outputs.

### ■ Automatic Fluorescent Tube Display Function

- A display RAM area of 32 x 60 bits is provided.
- The display timing can be specified with a value from 1 to 32.
- For each point of the timing, 60 bits can be used for specifying a combination of digits and segments.
- The digit pins from FIP0 to FIP31 can be consecutively set according to the numbers stored in the digit count register, starting with the pin for which start of display is specified.
- Output control of up to 59 segments is supported.
- Four types of display scan cycles (segment widths) are supported.
- In segment output, digit dimmer control is performed during the two T periods that apply to each digit output, as shown in Figure 18.1-1 "Digit Dimmer Control". Seven steps of adjustment are supported. (Dimming is effective for all digits.)
- The output level of all digits and segments can be inverted from "H" to "L" or "L" to "H".
- Gradation display (use of a segment dimmer) can be applied to segment output with an arbitrary timing. As shown in Figure 18.1-2 "Segment Dimmer Control", control is performed for the two T periods that apply to each segment output.



#### Figure 18.1-1 Digit Dimmer Control





#### Automatic LED Display Function

- Any LED pin from LED00 to LED16 can be set, provided it has not already been set.
- As shown in Figure 18.1-3 "Timing Chart of Automatic LED Display", pin LED00 becomes a common pin, while the 16 pins from LED01 to LED16 become LED segment outputs.
- When pin LED00 is at the "H" level, the corresponding value is output to pins LED01 to LED16 at the point "T1" of the timing stored in the display RAM. When pin LED00 is at the "L" level, the corresponding value is output to pins LED01 to LED16 at the point "T2".
- By inverting the output level of common pin LED00 externally, LED output with 1/2-duty cycle can be obtained.
- Figure 18.1-3 "Timing Chart of Automatic LED Display" shows the output time for pins LED01 to LED16 as determined by pin LED00 and its inverting signal. Pin LED00 has an output time of 5.12 ms, and pins LED01 to LED16 have an output time of 4.096 ms each (for a machine clock [peripheral operation clock] frequency of 16 MHz).



#### Figure 18.1-3 Timing Chart of Automatic LED Display

# **18.2 Configuration of FL Control Circuit**

The FL control circuit consists of the following blocks:

- Control circuit for automatic fluorescent tube display
- Control circuit for automatic LED display
- Display RAM
- Display control register (FLC1)
- Display control register (FLC2)
- Digit setting register (FLDG)
- Digit count register (FLDC)
- Segment dimmer setting register (SEGD0 to SEGD7)
- Port register (FLPD0 to FLPD2)
- Status/authorization register (FLST)

Block Diagram of the FL Control Circuit



Figure 18.2-1 Block Diagram 1 of the FL Control Circuit

# 18.3 FL Control Circuit Pins

This section describes the FL control circuit pins and provides a block diagram.

# Block Diagram of FL Control Circuit Pins



#### Figure 18.3-1 Block Diagram of the FL Control Circuit Pins (FIP00 to FIP16)







# Figure 18.3-3 Block Diagram of the FL Control Circuit Pins (FIP36 to FIP59)

# 18.3.1 Display Control Register 1 (FLC1)

This register is used to start, stop, and set up the automatic fluorescent tube and LED display.

This register is a write-only register and does not support bit operations. Byte access to this register is supported.

Display Control Register 1 (FLC1)



Figure 18.3-4 Display Control Register 1 (FLC1)

# CHAPTER 18 FL CONTROL CIRCUIT

# Table 18.3-1 Functions of the Display Control Register 1 (FLC1) Bits

| Bit r                | name                                                                     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------------|--------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 7<br>to<br>Bit 2 | -:<br>Unused bits                                                        | <ul><li>Read value is undefined.</li><li>Setting a value has no effect on operation.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 1                | FLLE:<br>Bit for<br>starting<br>automatic<br>LED display                 | <ul> <li>This bit specifies the start of automatic LED display.</li> <li>When this bit is set to 1, automatic LED display starts.</li> <li>When this bit is set to 0, automatic LED display stops.</li> <li>When automatic LED display starts, LED00 outputs the "H" level and the display RAM value for T1 is output.</li> <li>When automatic LED display stops, all LED outputs are switched off even during display.</li> <li>Note:<br/>After the required display settings have been made, set display control register 2, the digit setting register, and the digit count register to "1".</li> </ul>                                                                                                                                           |
| Bit 0                | FLFE:<br>Bit for<br>starting<br>automatic<br>fluorescent<br>tube display | <ul> <li>This bit specifies the start of automatic fluorescent tube display.</li> <li>When this bit is set to "1", automatic fluorescent tube display starts.</li> <li>When this bit is set to "0", automatic fluorescent tube display stops.</li> <li>When automatic fluorescent tube display starts, output starts with the display RAM value for T1.</li> <li>When automatic fluorescent tube display stops, the output is set to off after output for the current timing value has ended.</li> <li>Note: <ul> <li>After the required display settings have been made, set display control register 2, the digit setting register, the digit count register, the display RAM digits, and the segment dimmer (SEGD) to "1".</li> </ul> </li> </ul> |

# 18.3.2 Display Control Register 2 (FLC2)

This register is used to set inverted output and to specify a segment width and timing value. This register is a write-only register and does not support bit operations. Byte access to this register is supported.

# ■ Display Control Register 2 (FLC2)

|               | i igui | 0.0 | ••• | 2.01    |                    |                    | ••••  |                   | 0101 2 (1   | 202)       |                      |
|---------------|--------|-----|-----|---------|--------------------|--------------------|-------|-------------------|-------------|------------|----------------------|
| Bit           | 7      | 6   |     | 5       | 4                  | 3                  |       | 2                 | 1           | 0          | Initial value        |
|               | FLDX   | FLS | 1   | FLS0    | FLT4               | FLT                | 3     | FLT2              | 2 FLT1      | FLT0       | 0000000 <sub>B</sub> |
| Ľ             | W      | W   |     | W       | W                  | w                  |       | W                 | W           | W          | I                    |
|               |        |     |     |         | 1                  | 1                  |       | 1                 |             | 1          |                      |
|               |        |     |     |         |                    |                    |       |                   |             |            |                      |
|               |        |     |     |         |                    |                    |       |                   |             |            |                      |
|               |        |     |     |         |                    |                    |       |                   |             |            |                      |
|               |        | F   | LT4 | FLT3    | FLT2               | FLT1               | FĽ    | то                | Dis         | splay tim  | ing                  |
|               |        |     | 0   | 0       | 0                  | 0                  | (     | C                 | Repe        | etition of | T1 timing            |
|               |        |     | 0   | 0       | 0                  | 0                  | 1     | 1 R               | epetition c | f T1, T2,  | T1. T2.              |
|               |        |     | 0   | 0       | 0                  | 1                  |       |                   |             |            | T3,T1,T2,            |
|               |        |     | 0   | 0       | 0                  | 1                  | 1     |                   |             |            | .T4,T1,T2,           |
|               |        |     | 0   | 0       | 1                  | 0                  | 0     |                   | •           |            | .T5,T1,T2,           |
|               |        |     | 0   | 0       | 1                  | 0                  | 1     | 1 R               | epetition c | of T1,T2,. | .T6,T1,T2,           |
|               |        |     |     |         |                    |                    |       |                   |             |            |                      |
|               |        |     | 1   | 1       | 1                  | 0                  |       | R                 | epetition c | f T1,T2,.  | .T29,T1,T2,          |
|               |        |     | 1   | 1       | 1                  | 0                  | 1     |                   |             |            | .T30,T1,T2,          |
|               |        |     | 1   |         | 1                  | 1                  |       |                   |             |            | .T31,T1,T2,          |
|               |        |     | 1   | 1       | 1                  | 1                  | 1     | 1 R               | epetition c | of 11,12,. | .T32,T1,T2,          |
|               |        |     |     |         |                    |                    |       |                   |             |            |                      |
|               |        | > F | LS1 | FLS0    | S                  | egme               | nt w  | vidth se          | etting bit  |            |                      |
|               |        |     | 0   | 0       |                    | 2 <sup>11</sup> /N | 1CL   | K(128             | μs)         |            |                      |
|               |        |     | 0   | 1       |                    | 2 <sup>12</sup> /№ | 1CL   | K(256             | us)         |            |                      |
|               |        |     | 1   | 0       |                    | 2 <sup>13</sup> /N | 1CL   | K(512             | μs)         |            |                      |
|               |        |     | 1   | 1       |                    | 2 <sup>14</sup> /M | CLł   | <b>&lt;</b> (1024 | 4 μs)       |            |                      |
|               |        |     |     |         | with a<br>ck) of 1 |                    |       | clock (           | peripheral  |            |                      |
|               |        |     | DX  | Bits fo | or digit a         | and se             | gme   | ent out           | put inversi | on         |                      |
|               |        |     | 0   |         |                    | No                 | t inv | /erted            |             |            |                      |
| W: Write onl  | v      |     | 1   |         |                    | In                 | vert  | ted               |             | 1          |                      |
| : Initial val |        | L   |     | 1       |                    |                    |       |                   |             |            |                      |

Figure 18.3-5 Display Control Register 2 (FLC2)

### CHAPTER 18 FL CONTROL CIRCUIT

# Table 18.3-2 Functions of the Display Control Circuit 2 (FLC2) Bits

| Bit                  | name                                                      | Function                                                                                                                                                                                                                       |  |  |  |  |  |
|----------------------|-----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bit 7                | FLDX:<br>Bit for digit and<br>segment output<br>inversion | <ul> <li>When this bit is set to "1", the digit and segment output levels for automatic fluorescent tube display are inverted. <sup>(*1)</sup></li> <li>The output level for automatic LED display is not inverted.</li> </ul> |  |  |  |  |  |
| Bit 6<br>Bit 5       | FLS1, FLS0:<br>Segment width<br>setting bit               | • Sets a segment width. <sup>(*1)</sup>                                                                                                                                                                                        |  |  |  |  |  |
| Bit 4<br>to<br>Bit 0 | FLT4 to FLT0:<br>Display timing<br>setting bit            | Sets a display timing value. (*1)                                                                                                                                                                                              |  |  |  |  |  |

\*1: Make the settings while the automatic fluorescent tube and LED display are stopped.

# 18.3.3 Digit Setting Register (FLDG)

This register is used to set the digit dimmer and digit display starting pin. This register is a write-only register and does not support bit operations. Byte access to this register is supported.

### ■ Digit Setting Register (FLDG)

| Bit | 7     | 6               |        | 5      | 4      | 3      |       | 2   | 2                       | 1                      | 0          | Initial value              |
|-----|-------|-----------------|--------|--------|--------|--------|-------|-----|-------------------------|------------------------|------------|----------------------------|
|     | FLDM2 | FLDN            | 1 F    | LDM0   | FLDS4  | FLDS   | 53 F  | FLC | S2                      | FLDS1                  | FLDS0      | 00000000 <sub>B</sub>      |
|     | W     | W               |        | W      | W      | W      |       | V   | V                       | W                      | W          |                            |
|     |       |                 |        |        |        |        |       |     |                         |                        |            |                            |
|     |       |                 |        | _      |        | •      |       |     |                         |                        |            |                            |
|     |       |                 |        |        |        |        |       |     |                         |                        |            |                            |
|     |       | FL              | DS4    | FLDS3  | FLDS2  | FLDS1  | FLD   | S0  |                         | for speci<br>t display |            | start pin of               |
|     |       |                 | 0      | 0      | 0      | 0      | 0     |     | S                       | tarts dig              | it display | from FIP00.                |
|     |       |                 | 0      | 0      | 0      | 0      | 1     |     |                         |                        |            | from FIP01.                |
|     |       |                 | 0      | 0      | 0      | 1      | 0     |     |                         |                        |            | from FIP02.                |
|     |       |                 | 0<br>0 | 0      | 0      | 1<br>0 | 1     |     |                         |                        |            | from FIP03.<br>from FIP04. |
|     |       |                 | 0      | 0      | 1      | 0      | 1     |     | S                       | tarts dig              | t display  | from FIP05.                |
|     |       |                 | •      | •      | •      | -      | •     |     | S                       | tarts dig              | it display | from FIP06.                |
|     |       |                 | 1      | 1      | 1      | 0      | 0     |     |                         |                        | :          |                            |
|     |       |                 | 1      | 1      | 1      | 0      | 1     |     | S                       | tarts dig              | it display | from FIP29.                |
|     |       |                 | 1      | 1      | 1      | 1      | 0     |     | S                       | tarts dig              | t display  | from FIP30.                |
|     |       |                 | 1      | 1      | 1      | 1      | 1     |     | S                       | tarts dig              | t display  | from FIP31.                |
|     |       |                 |        |        |        |        |       |     |                         |                        |            |                            |
|     |       | → <sub>FL</sub> | DM2    | FLDM1  | FLDM0  | Digi   | t din | nm  | er se                   | etting bit             |            |                            |
|     |       |                 | 0      | 0      | 0      |        |       |     | 2/1                     | 6                      |            |                            |
|     |       |                 | 0      | 0      | 1      |        |       |     | 4/1                     | 6                      |            |                            |
|     |       |                 | 0      | 1      | 0      |        |       |     | 6/1                     |                        |            |                            |
|     |       |                 | 0<br>1 | 1<br>0 | 1<br>0 |        |       |     | 8/1<br>10/ <sup>-</sup> |                        |            |                            |
|     |       |                 | 1      | 0      | 1      |        |       |     | 12/                     |                        |            |                            |
|     |       |                 | 1      | 1      | 0      |        |       |     | 14/                     | 16                     |            |                            |

Figure 18.3-6 Digit Setting Register (FLDG)

W : Write only

: Initial value

### CHAPTER 18 FL CONTROL CIRCUIT

# Table 18.3-3 Functions of the Digit Setting Register (FLDG) Bits

|                      | Bit name                                                       | Function                                                                                                                                                                               |  |  |  |  |  |
|----------------------|----------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bit 7<br>to<br>Bit 5 | FLDM2, FLDM1, FLDM0:<br>Digit dimmer setting bits              | <ul> <li>These bits specify the digit dimmer width. <sup>(*1)</sup></li> <li>When set to 000<sub>B</sub> (2/16), the following waveform is generated.</li> <li>Digit output</li> </ul> |  |  |  |  |  |
| Bit 4<br>to<br>Bit 0 | FLDS4 to FLDS0:<br>Setting bits for digit<br>display start pin | These bits specify the digit display start pin. (*1)                                                                                                                                   |  |  |  |  |  |

\*1: Make the settings while the automatic fluorescent tube and LED display is stopped.

# 18.3.4 Digit Count Register (FLDC)

The digit count register is used to set the segment dimmer and digit pin count. This register is a write-only register and does not support bit operations. Byte access to this register is supported.

## ■ Digit Count Register (FLDC)

Bit

| FLSD2 |       |         |        |       |      | 2   | 1                                                      | 0                 | Initial value         |
|-------|-------|---------|--------|-------|------|-----|--------------------------------------------------------|-------------------|-----------------------|
| 10/   | FLODI | FLSD0   | FLDC4  | FLDC  | 3 FL | DC2 | FLDC1                                                  | FLDC0             | 00000000 <sub>B</sub> |
| VV    | W     | W       | W      | W     |      | W   | W                                                      | W                 |                       |
|       |       |         |        |       |      |     |                                                        | 1                 |                       |
|       |       |         |        |       |      |     |                                                        |                   |                       |
|       |       |         |        |       |      | _   |                                                        |                   |                       |
|       |       |         |        |       |      |     |                                                        |                   |                       |
|       |       | 4 FLDC3 | FLDC2  | FLDC1 |      |     | Digit o                                                | count set         | tina hit              |
|       |       |         | 1 2002 |       |      |     | Digit (                                                |                   |                       |
|       | 0     | 0       | 0      | 0     | 0    |     | Setting                                                | for digit         | count 1               |
|       | 0     | 0       | 0      | 0     | 1    |     | Catting                                                | fordiait          | accurat 0             |
|       | 0     | 0       | 0      | 1     | 0    |     | -                                                      | for digit count 2 |                       |
|       | 0     | 0       | 0      | 1     | 1    |     | Setting for digit count 3<br>Setting for digit count 4 |                   |                       |
|       | 0     | 0       |        | 0     | 0    |     | Setting for digit count 5                              |                   |                       |
|       | 0     | 0       |        | 0     | 1    |     | 0                                                      | for digit         |                       |
|       |       |         | :      | .     |      |     | Cotting                                                |                   |                       |
|       |       |         | .      | .     |      |     |                                                        |                   |                       |
|       | 1     | 1       | 1      | 0     | 0    |     | Settina                                                | for diait         | count 29              |
|       | 1     | 1       |        | 0     | 1    |     | 0                                                      | 0                 | count 30              |
|       | 1     | 1       |        | 1     | 0    |     | 0                                                      | for digit         |                       |
|       | 1     | 1       | 1      | 1     | 1    |     | -                                                      | -                 | count 32              |

Figure 18.3-7 Digit Count Register (FLDC)

| $\rightarrow$ | FLSD2 | FLSD1 | FLSD0 | Segment dimmer setting bits |
|---------------|-------|-------|-------|-----------------------------|
|               | 0     | 0     | 0     | 2/16                        |
|               | 0     | 0     | 1     | 4/16                        |
|               | 0     | 1     | 0     | 6/16                        |
|               | 0     | 1     | 1     | 8/16                        |
|               | 1     | 0     | 0     | 10/16                       |
|               | 1     | 0     | 1     | 12/16                       |
|               | 1     | 1     | 0     | 14/16                       |
|               |       |       |       |                             |

W : Write only

: Initial value

| Table 18.3-4 Functions of the Digit Count Register (FLDC) | Bits |
|-----------------------------------------------------------|------|
|-----------------------------------------------------------|------|

|                      | Bit name                                          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------------|---------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 7<br>to<br>Bit 5 | FLSD2 to FLSD0:<br>Segment dimmer<br>setting bits | Holds the settings for the segment dimmer waveform. <sup>(*1)</sup><br>SEGDT (bit 7 of address $0E0_H$ to $0FF_H$ ) in the display RAM specifies<br>the display timing that is to be applied to the segment dimmer. The<br>segment dimmer register (SEGD) specifies segments.<br>When the segment dimmer settings have not been made, set the<br>segment dimmer register (SEGD) or SEGDT to all zeros.<br>When value $000_B$ (2/16) is set, the following waveform is generated. |
| Bit 4<br>to<br>Bit 0 | FLDC4 to FLDC0:<br>Digit count setting bit        | <ul> <li>Specify a digit count. <sup>(*1)</sup></li> <li>The settings of the digit display start bits (bit 0 to bit 4 of FLDG) take priority over the digit count settings. 32 pins (FIP00 to FIP31) can be specified by the digit count value. If the digit display start bit is set for FIP30, the maximum digit count becomes 2, and 2 will be assumed if a digit count of 3 or more is set.</li> </ul>                                                                       |

\*1: Make the settings while the automatic fluorescent tube and LED display is stopped.

### **Reference:**

The segment dimmer is set only for the segment output at specific times (T01 to T32). This makes it possible to set the dimmer for the segment in a specific digit; in other words, control of dimmer operation for a specific character is supported.

# 18.3.5 Port Register (FLPD)

The 24 pins from FIP36 to FIP59 can be used as output ports by setting a value in the port register. When a pin is used as an output port, "0" must be set for that pin in the display RAM for all times before automatic fluorescent tube display is started. This register is a write-only register and does not support bit operations. Byte access to this register is supported.

## Port Register (FLPD)

| Bit   | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     | Initial value         |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-----------------------|
| FLPD0 | FIP43 | FIP42 | FIP41 | FIP40 | FIP39 | FIP38 | FIP37 | FIP36 | 00000000 <sub>B</sub> |
| FLPD1 | FIP51 | FIP50 | FIP49 | FIP48 | FIP47 | FIP46 | FIP45 | FIP44 | 00000000 <sub>B</sub> |
| FLPD2 | FIP59 | FIP58 | FIP57 | FIP56 | FIP55 | FIP54 | FIP53 | FIP52 | 00000000 <sub>B</sub> |
|       | W     | W     | W     | W     | W     | W     | W     | W     |                       |

#### Figure 18.3-8 Port Register (FLPD)

W: Write only

### Port Register

#### O When a pin is used as a port

Before automatic fluorescent tube display is started, "0" must be set for that pin in the display RAM for all times.

When FLDX (bit for inverted digit/segment output) is set to specify display in reverse video, "1" must be set for that pin in the display RAM for all times before automatic fluorescent tube display is started.

When the port register (FLPD) is set to "0", the Pch high dielectric output is switched off, and the  $V_{KK}$  pin voltage is connected via the pull-down resistor.

We recommend the addition of a diode clamping circuit.

When the port register (FLPD) is set to "1", the Pch high dielectric output is switched on.

#### O When a pin is used for automatic fluorescent tube display

A "0" must be set in the port register (FLPD) for the pin.

Because the initial value of the port register (FLPD) is 0 at power-on and reset, automatic fluorescent tube display is assumed unless the register is set to another value.

# 18.3.6 Status/Authorization Register (FLST)

This register includes the following types of bits: Bits for confirming fluorescent tube and automatic LED display, write authorization bits for display RAM and registers (display control register 1, display control register 2, digit setting register, digit count register, and segment dimmer setting register), and bits for preventing access to the display RAM and registers.

Bit 7 and bit 6 are write-only, while bit 5, bit 1, and bit 0 are read-only bits. Bit operations are not supported for this register, but byte access is.

■ Status/Authorization Register (FLST)



Figure 18.3-9 Status/Authorization Register (FLST)

| Table 18.3-5 | Functions of the | Status/Authorization Register Bits |
|--------------|------------------|------------------------------------|
|--------------|------------------|------------------------------------|

| Bit                  | name                                                                                         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
|----------------------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Bit 7                | FLINI:<br>Bit for<br>authorizing<br>writing to<br>display RAM or<br>registers                | <ul> <li>This bit authorizes writing to the display RAM or a register.</li> <li>When setting a value in the display RAM or a registers (display control register 1, display control register 2, digit setting register, digit count register, or segment dimmer setting register), the respective value changes after this bit is set to "1".</li> <li>Setting this bit to "0" has no effect on operation.</li> </ul>                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |
| Bit 6                | FL1WR:<br>Bit for<br>authorizing<br>writing of one<br>byte to display<br>RAM or<br>registers | <ul> <li>This bit authorizes writing of one byte to the display RAM or a register.</li> <li>When setting a one-byte value in the display RAM or a register (display control register 1, display control register 2, digit setting register, digit count register, or segment dimmer setting register), the respective value changes after this bit is set to "1".</li> <li>Setting this bit to "0" has no effect on operation.</li> <li>When FLFS=1 or FLLS=1, writing of any new value to display control register 2, the digit setting register, the digit count register, or the segment dimmer setting register is not authorized. To authorize a write operation for these registers, select FLFE=0 and FLLE=0.</li> </ul> |  |  |  |  |  |  |  |
| Bit 5                | FLDNE:<br>Bit for<br>preventing<br>display RAM<br>and register<br>access                     | <ul> <li>This bit prevents access to the display RAM and registers.</li> <li>When this bit is set to "1", reading from or writing to the display RAM and reading from or writing to any of the registers is allowed.</li> <li>When this bit is set to "0", access to the display RAM and all registers is prohibited (with the exception of reading from the status/authorization register).</li> </ul>                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |
| Bit 4<br>to<br>Bit 2 | -:<br>Undefined                                                                              | <ul><li>The value read from this bit is undefined.</li><li>Setting this bit has no effect on operation.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
| Bit 1                | FLFS:<br>Status bit for<br>automatic<br>fluorescent tube<br>display                          | <ul> <li>This bit indicates the status of automatic fluorescent tube display.</li> <li>When this bit is "1", automatic fluorescent tube display is active.</li> <li>When this bit is "0", automatic fluorescent tube display is inactive.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |
| Bit 0                | FLLS:<br>Automatic LED<br>display status<br>bit                                              | <ul> <li>This bit indicates the status of automatic LED display.</li> <li>When this bit is "1", automatic LED display is active.</li> <li>When this bit is "0", automatic LED display is inactive.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |

# 18.3.7 Display RAM

The display RAM contains the settings for digit and segment data based on the timing for automatic fluorescent tube display.

Make settings for automatic LED display using the bits for the T01 and TP2 timing LED pins.

Specify the time at which the segment dimmer operates in bit 7 of the addresses  $1E0_{H}$  to  $11FF_{H}$ .

Display RAM

|                                                                                                              | Timing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin                                                                                                          | コーイー         コーイ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| FIP00 bit0<br>FIP01 bit1<br>FIP02 bit2<br>FIP03 bit3<br>FIP04 bit4<br>FIP05 bit5<br>FIP06 bit6<br>FIP07 bit7 | Display RAM can<br>be read and<br>11106 F L0020<br>11106 F L0020<br>11116 F F F L0020<br>11116 F F F L0020<br>11116 F F F F F F F F F F F F F F F F F |
| FIP08 bit0<br>FIP09 bit1<br>FIP10 bit2<br>FIP11 bit3<br>FIP12 bit4<br>FIP13 bit5<br>FIP14 bit6<br>FIP15 bit7 | written, but bit operations are not supported. Byte access to the display RAM is supported. 11364 FL0656 11364 FL0566 FL0566 11364 FL0566 FL0                                                                                                         |
| FIP16 bit0<br>FIP17 bit1<br>FIP18 bit2<br>FIP19 bit3<br>FIP20 bit4<br>FIP21 bit5<br>FIP22 bit6<br>FIP23 bit7 | П 1140н FL064<br>11142н FL066<br>11142н FL066<br>1143н FL067<br>1143н FL067<br>1115Fн FL085                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| FIP24 bit0<br>FIP25 bit1<br>FIP26 bit2<br>FIP27 bit3<br>FIP28 bit4<br>FIP29 bit5<br>FIP30 bit6<br>FIP31 bit7 | 1160H FL096<br>1161H FL097                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| FIP32 bit0<br>FIP33 bit1<br>FIP34 bit2<br>FIP35 bit3<br>FIP36 bit4<br>FIP37 bit5<br>FIP38 bit6<br>FIP39 bit7 | 1180, FL128<br>1181, FL129                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| FIP40 bit0<br>FIP41 bit1<br>FIP42 bit2<br>FIP43 bit3<br>FIP44 bit4<br>FIP45 bit5<br>FIP46 bit6<br>FIP47 bit7 | 11A0 <sub>H</sub> FL160<br>11A1 <sub>H</sub> FL161<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| FIP48 bit0<br>FIP49 bit1<br>FIP50 bit2<br>FIP51 bit3<br>FIP52 bit4<br>FIP53 bit5<br>FIP54 bit6<br>FIP55 bit7 | 100     1100       FF     See Figure 48.4.8. "Segment       Dimmer-Register (SEGD)."       Set a time for dimmer operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| FIP56 bit0<br>FIP57 bit1<br>FIP58 bit2<br>FIP59 bit3                                                         | The time is set with a value<br>The time is set with a value<br>indefined.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| SEGDT bit7                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

Figure 18.3-10 Display RAM

# 18.3.8 Segment Dimmer Setting Register (SEGD)

Dimming can be set for any time and any segment of the fluorescent tube. Using the segment dimmer setting register, set a timing for the segment with bit 7 of

 $11E0_{H}$  to  $11FF_{H}$  in the display RAM.

This register is a write-only register and does not support bit operations. Write data to this register while automatic fluorescent tube and LED display are stopped.

Byte access is supported for this register.

Segment Dimmer Setting Register (SEGD)

| Bit   | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     | Initial value         |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-----------------------|
| SEGD0 | FIP07 | FIP06 | FIP05 | FIP04 | FIP03 | FIP02 | FIP01 | FIP00 | XXXXXXXX <sub>B</sub> |
| SEGD1 | FIP15 | FIP14 | FIP13 | FIP12 | FIP11 | FIP10 | FIP09 | FIP08 | XXXXXXXX <sub>B</sub> |
| SEGD2 | FIP23 | FIP22 | FIP21 | FIP20 | FIP19 | FIP18 | FIP17 | FIP16 | XXXXXXXX <sub>B</sub> |
| SEGD3 | FIP31 | FIP30 | FIP29 | FIP28 | FIP27 | FIP26 | FIP25 | FIP24 | XXXXXXXX <sub>B</sub> |
| SEGD4 | FIP39 | FIP38 | FIP37 | FIP36 | FIP35 | FIP34 | FIP33 | FIP32 | XXXXXXXX <sub>B</sub> |
| SEGD5 | FIP47 | FIP46 | FIP45 | FIP44 | FIP43 | FIP42 | FIP41 | FIP40 | XXXXXXXX <sub>B</sub> |
| SEGD6 | FIP55 | FIP54 | FIP53 | FIP52 | FIP51 | FIP50 | FIP49 | FIP48 | XXXXXXXX <sub>B</sub> |
| SEGD7 | -     | -     | -     | -     | FIP59 | FIP58 | FIP57 | FIP56 | XXXXXXXX <sub>B</sub> |
|       | W     | W     | W     | W     | W     | W     | W     | W     |                       |

## Figure 18.3-11 Segment Dimmer Setting Register (SEGD)

W: Write only

# Segment Gradation Display (Segment Dimmer)

Specify a segment using registers SEGD0 to SEGD7. Specify the segment by setting a value of "1".

Set a timing with bit 7 of  $11E0_{H}$  to  $11FF_{H}$  in the display RAM.

Specify the timing by writing a value of "1".

The SEGD0 to SEGD7 bits for digit pins are ignored.

Dimmer operation can be specified more than once.

### Note:

Because the initial values of SEGD0 to SEGD7 and  $11E0_H$  to  $11FF_H$  of the display RAM are undefined, set these values before starting with display.

# **18.4 FL Control Circuit Operation**

# This section explains the operation of automatic fluorescent tube and LED display.

#### Assignment of Automatic Fluorescent Tube Display Digits and Segments and Automatic LED Display Pins

Automatic fluorescent tube display digits can be specified using pins FIP0 to FIP31. These digits are consecutively set according to the count specified in the digit count setting bits of the digit count register, starting with the pin that is specified in the digit display starting pin setting bits of the digit setting register.

Figure 18.4-1 "Example of assignment for LED, Digit, and Segment Display" shows an example of the resulting assignment.

When both the digit display start setting bit and digit count setting bit are set, the digit display start setting bit has priority. (In item [3] of Figure 18.4-1 "Example of assignment for LED, Digit, and Segment Display", the digit count setting bits are set to 1FH (32 digits), but 16 digit pins are used in the actual operation.)

All pins after pins that are used for setting digits become segment pins.

When the value expressed in the digit display pin setting bits is larger than 17H, all pins from FIP17 to the one before the pin specified in the digit display starting pin selection bit are used for segments. (See item [4] in Figure 18.4-1 "Example of assignment for LED, Digit, and Segment Display.")

The automatic LED display pins are set in the LED00 to LED16 registers that are not used for automatic fluorescent tube display.

| -                                                           | -                         |                | -                 |                         |                | -                       | -              |                |                         |
|-------------------------------------------------------------|---------------------------|----------------|-------------------|-------------------------|----------------|-------------------------|----------------|----------------|-------------------------|
|                                                             | FIP01<br>FIP00            | FIP07<br>FIP06 | FIP10             | FIP17<br>FIP16<br>FIP15 | FIP24<br>FIP23 | FIP32<br>FIP31          | FIP40<br>FIP39 | FIP48<br>FIP47 | FIP59<br>FIP56<br>FIP55 |
|                                                             | 1 LED comm                | on 4           | digits            |                         |                |                         |                |                |                         |
| [1]                                                         | 6 LED segme               | ents 7         |                   |                         |                | 52 segments             |                |                |                         |
| Digit display starting 07 <sub>H</sub>                      | EE                        |                | л                 | עעע                     |                | תת                      | <br>           | תת             | יי ביב                  |
| Digit count 03 <sub>H</sub><br>setting bit                  | LED01                     | FIP07<br>LED06 | FIP10             | FIP17<br>FIP16<br>FIP15 | FIP24<br>FIP23 | FIP32<br>FIP31          | FIP40<br>FIP39 | FIP48<br>FIP47 | FIP59<br>FIP56<br>FIP55 |
| [2]                                                         |                           |                | 32 digits         | 5                       |                |                         | 28 seg         | ments          |                         |
| Digit display starting 00 <sub>H</sub>                      |                           | πп             | $\mathcal{V}_{1}$ |                         | ΠП             | πп                      | <br>           | <br>           | ת תת                    |
| Digit count 1F <sub>H</sub>                                 | FIP01<br>FIP00            | FIP07<br>FIP06 | FIP10             | 11P17                   | FIP24<br>FIP23 | FIP32<br>FIP31          | FIP40<br>FIP39 | FIP48<br>FIP47 | FIP59<br>FIP56<br>FIP55 |
| setting bit                                                 |                           |                | 0                 | 007                     | 4ω             | N                       | 00             | 700            | ഗ്ര ഗ്                  |
| [3]                                                         | 1 LED comn<br>15 segments |                |                   |                         | 16 digits      |                         | 28 seg         | gments         |                         |
| Digit display starting 10 <sub>H</sub><br>pin selection bit | FF                        | EE             | E                 |                         |                |                         | <u></u>        | תת             | ת תת                    |
| Digit count 1F.                                             | ED01                      | ED07           | LED10             | FIP17<br>FIP16<br>LED15 | FIP24<br>FIP23 | FIP32<br>FIP31          | FIP40<br>FIP39 | FIP48<br>FIP47 | FIP59<br>FIP56<br>FIP55 |
| Setting bit                                                 | 1 LED comm                |                | 0                 |                         | o FIP27 are    |                         |                | 100            | 010, 0                  |
| [4]                                                         | 16 segments               |                |                   |                         | segments.      |                         | 28 seg         | gments         |                         |
| Digit display starting 1C <sub>H</sub><br>pin selection bit | 됴됴                        | ĒĒ             | LE                | FIP                     | ПП             |                         | πп             | <u>π</u> π     | ת תת                    |
| Digit count 03                                              | ED01                      | ED07<br>ED06   | ED10              | ED16<br>ED15            | FIP24<br>FIP23 | FIP32<br>FIP31<br>FIP28 | FIP40<br>FIP39 | FIP48<br>FIP47 | FIP59<br>FIP56<br>FIP55 |
| setting bit                                                 | 07                        | 67             | 0                 | 50                      | 400            | ω = I0                  |                | 400            | 010, 0                  |
| _                                                           |                           |                |                   |                         |                |                         |                |                |                         |
|                                                             | LED output                | ut pin         |                   | Digit                   | pin            | S                       | egment pi      | n              |                         |
|                                                             |                           |                |                   |                         |                |                         |                | ]              |                         |
|                                                             |                           |                |                   |                         |                |                         |                |                |                         |

| Figure 18.4-1 | Example of assignment for | LED, Digit, and Segment Display |  |
|---------------|---------------------------|---------------------------------|--|
|               |                           |                                 |  |

#### ■ Reading from/Writing to Registers or Display RAM in the FL Control Circuit

Display RAM and the following registers support byte access, but not bit operations.

- · Registers in the FL control circuit
- Display control register 1 (FLC1)
- Display control register 2 (FLC2)
- Digit setting register (FLDG)
- Digit count register (FLDC)
- Segment dimmer setting registers (SEGD0 to SEGD7)
- Port registers (FLPD0 to FLPD2)
- Status/authorization register (FLST)

Writing to the display RAM and the registers in the FL control circuit can only be performed when a "1" is set in the status/authorization register (FLST) display RAM and the bit for preventing register access (FLDNE).

Reading from the display RAM can be performed even when the bit for preventing register access (FLDNE) is set to "1".

After writing to the display RAM and any register other than the status/authorization register (FLST), the display RAM/register write authorization bit (FLINI) in the status/authorization register (FLST) must be set to "1".

The following diagram explains the operation.

#### **O** At initialization



### Figure 18.4-2 At Initialization

 When segment data (multiple bytes) is overwritten during automatic fluorescent tube display





The last one-byte writing operation to the FLST register FL1WR is authorized. The following diagram explains this operation.

O Stop while operation is in progress or start from stop state (for 1 byte)



Figure 18.4-4 Stop While Operation Is in Progress or Start from Stop State (for 1 Byte)

The following diagram provides an example for combined setting of FL1WR of the FLST register and FLINI of the FLST register. Note that the value of FLINI can only be changed after a reset.

### ○ Setting FL1WR after setting FLINI



Figure 18.4-5 Setting FL1WR after Setting FLINI

### ■ Start and Stop Timings of Automatic Fluorescent Tube Display

Automatic fluorescent tube display starts with timing point T1. When automatic fluorescent tube display is stopped, output stops after the output of the current segment output has been completed.



Figure 18.4-6 Example of Start and Stop Timing of Automatic Fluorescent Tube Display

#### Start and Stop Timing of Automatic LED Display

Up to the first 5 milliseconds after the start of automatic LED display, "L" level (the Pch open drain output is off) is output from common and segment output.

Next, the data for the timing point of T1 is output as segment output when the common output (LED0) is at the "H" level. When automatic LED display stops, the common and segment output switch to "L" level after authorization of writing to the registers.



#### Figure 18.4-7 Start and Stop Timings of Automatic LED Display

### Operation in Stop Mode and Sleep Mode

#### O In stop mode

The FL control circuit is reset in stop mode. (All Pch high dielectric outputs are switched off.) After stop mode is released, initialization must be performed.

#### O In sleep mode

The FL control circuit is operational in sleep mode. To enter low-power mode, such operations as stopping automatic display must be performed before sleep mode is set.

# CHAPTER 19 WATCH CLOCK OUTPUT

This chapter describes the functions and operations of MB90M405 series watch clock output.

- 19.1 "Overview of the Watch Clock Output Circuit"
- 19.2 "Configuration of the Watch Clock Output Circuit"
- 19.3 "Watch Clock Output Control Register (TMCS)"

# 19.1 Overview of the Watch Clock Output Circuit

The watch clock output circuit divides the oscillation clock by the timebase timer and outputs the specified divided clock externally.

One of the divisions 32, 64, 128, and 256 of the oscillation clock can be selected.

#### Watch Clock Output Circuit

The watch clock output circuit is disabled during a reset or in stop mode and in enabled in normal run mode, sleep mode, and pseudo watch mode.

 Table 19.1-1
 Watch Clock Output Modes

|                  | PLL_Run | Main_Run | Sleep | Pseudo watch | STOP | Reset |
|------------------|---------|----------|-------|--------------|------|-------|
| Operating status | 0       | 0        | 0     | 0            | х    | х     |

#### Notes:

The clock cannot be output correctly if the timebase timer is cleared while the watch clock output circuit is in use.

For information about the conditions for clearing the timebase timer, see Chapter 10, "Timebase Timer".

# 19.2 Configuration of the Watch Clock Output Circuit

The watch clock output circuit consists of the following blocks:

- Watch clock selection circuit
- Watch clock output control register (TMCS)

### Block Diagram of the Watch Clock Selection Circuit





# 19.3 Watch Clock Output Control Register (TMCS)

The watch clock output control register (TMCS) sets the watch clock division ratio.

# ■ Watch Clock Output Control Register (TMCS)



### Figure 19.3-1 Watch Clock Output Control Register (TMCS)

R/W : Read/write enabled

- : Undefined bit

: Initial value

HCLK: Oscillation clock frequency

# Table 19.3-1 Functions of the I<sup>2</sup>C Status Register (IBSR) Bits

| Bit name             |                                                       | Function                                                                                                                                     |  |  |  |  |
|----------------------|-------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| bit15<br>to<br>bit11 | -:<br>Undefined bit                                   | <ul><li>The reading value read from this bit is undefined.</li><li>The value set for this bit does not affect operation.</li></ul>           |  |  |  |  |
| bit10                | TEN:<br>Watch clock output<br>enable bit              | • This bit enables watch clock output. To use this function, be sure to specify a port in ADER0 and to specify output from the port in DDRA. |  |  |  |  |
| bit9<br>bit8         | TS1, TS0:<br>Time clock division<br>ratio setting bit | <ul> <li>Set TS1 and TS2, and specify output from the port to output the clock for<br/>the watch clock.</li> </ul>                           |  |  |  |  |

### Note:

The first waveform that is output when the TEN bit is set to Enabled may be different from the actually specified output waveform because the watch clock is started asynchronously with the timebase timer.

# CHAPTER 20 DELAYED INTERRUPT GENERATOR MODULE

This chapter describes the functions and operation of the MB90M405 series delayed interrupt generator module.

- 20.1 "Overview of the Delayed Interrupt Generator Module"
- 20.2 "Delayed Interrupt Cause/Cancel Register (DIRR)"
- 20.3 "Operation of the Delayed Interrupt Generator Module"
- 20.4 "Precautions to Follow when Using the Delayed Interrupt Generator Module"

# 20.1 Overview of the Delayed Interrupt Generator Module

The delayed interrupt generator module outputs interrupt requests for task switching. By using this module, interrupt requests for task switching can be output and canceled for the MB90M405 series CPU via software.

# ■ Block Diagram of the Delayed Interrupt Generator Module





# 20.2 Delayed Interrupt Cause/Cancel Register (DIRR)

This section explains the delayed interrupt cause/cancel register (DIRR).

## Delayed Interrupt Cause/Cancel Register (DIRR)

### Figure 20.2-1 Delayed Interrupt Cause/Cancel Register (DIRR)



| Bit name      |                                                   | Function                                                                                                                                                                                                                                                                                                                   |
|---------------|---------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit15 to bit9 | -:<br>Undefined bit                               | <ul><li>When these bits are read, the values are undefined.</li><li>Writing to these bits does not affect operation.</li></ul>                                                                                                                                                                                             |
| bit8          | R0:<br>Delayed<br>interrupt request<br>output bit | <ul> <li>This bit sets the generation/cancel of a delayed interrupt request.</li> <li>When this bit is "1", a delayed interrupt request is output.</li> <li>When this bit is "0", the delayed interrupt request is cleared.</li> <li>When a reset is specified, interrupt causes are canceled (cleared to "0").</li> </ul> |

# 20.3 Operation of the Delayed Interrupt Generator Module

When the delayed interrupt request output bit (R0) of the delayed interrupt cause/ cancel register (DIRR) is set to "1" using software, a delayed interrupt request is output to the interrupt controller.

### ■ Operation of the Delayed Interrupt Generator Module

When the delayed interrupt request output bit (R0) of the delayed interrupt cause/cancel register (DIRR) is set to "1" using software, an interrupt request is output to the interrupt controller. If interrupt requests other than the delayed interrupt have lower priorities or there is no interrupt request other than the delayed interrupt request, the interrupt controller outputs an interrupt request to the CPU. The CPU compares the interrupt request level with the interrupt level mask register (ILM) in the processor status register (PS). If the interrupt request level is higher than the interrupt level mask register (ILM), the hardware imbedded processing microprogram is activated after the instruction currently being executed is completed, to execute the delayed interrupt processing routine. If the delayed interrupt request output bit (R0) of the delayed interrupt cause/cancel register (DIRR) is set to "0" in the interrupt processing routine, the delayed interrupt cause is cleared and the task is switched.



#### Figure 20.3-1 Operation of the Delayed Interrupt Generator Module

DIRR : Delayed interrupt cause/cancel register

IL : Interrupt level setting bit in the interrupt control register (ICR)

ILM : Interrupt level mask register in PS

CMP : Comparator

ICR : Interrupt control register

# 20.4 Precautions to Follow when Using the Delayed Interrupt Generator Module

This section explains the precautions to follow when using the delayed interrupt generator module.

### ■ Precautions to Follow when Using the Delayed Interrupt Generator Module

### O Delayed interrupt request

If the delayed interrupt request output bit (R0) of the delayed interrupt cause/cancel register (DIRR) is not set to "0" after interrupt processing is completed using an interrupt processing routine or while an interrupt processing routine is being executed, it is not possible to return from the interrupt processing.

# CHAPTER 21 ADDRESS MATCH DETECTION FUNCTION

This chapter describes the address match detection function of the MB90M405 series and its operations.

- 21.1 "Overview of the Address Match Detection Function"
- 21.2 "Registers of the Address Match Detection Function"
- 21.3 "Operation of the Address Match Detection Function"
- 21.4 "Example of Using the Address Match Detection Function"

# 21.1 Overview of the Address Match Detection Function

If the program address matches the value set in the address match detection register, the instruction code to be read by the CPU is replaced with an INT9 instruction code. By performing processing using an INT #9 interrupt routine, a program patch application function can be implemented.

## ■ Block Diagram of the Address Match Detection Function





# 21.2 Registers of the Address Match Detection Function

This section shows a list of registers of the address match detection function.

■ List of Registers of the Address Match Detection Function

Figure 21.2-1 List of Registers of the Address Match Detection Function

bit23 .....bit8 bit7.....bit0

PADR0 (program address detection register; upper/middle/lower)

PADR1 (program address detection register; upper/middle/lower)

PACSR (program address detection control status register)

# 21.2.1 Program Address Detection Register for Upper, Middle, and Lower Parts of Address (PADR0/PADR1)

The program address detection register for upper, middle, and lower parts of an address (PADR0/PADR1) is used to set an address for comparison.

### Program Address Detection Register for Upper, Middle and Lower Parts of an Address (PADR0/ PADR1)

# Figure 21.2-2 Program Address Detection Register for Upper, Middle, and Lower Parts of an Address (PADR0/PADR1)

|       | bit23 bit16 | bit15 bit8 | bit7 bit0 | Initial value |
|-------|-------------|------------|-----------|---------------|
| PADR0 | Upper       | Middle     | Lower     | XXXXXXXXX     |
|       | R/W         | R/W        | R/W       |               |
|       | bit23 bit16 | bit15 bit8 | bit7 bit0 |               |
| PADR1 | Upper       | Middle     | Lower     | XXXXXXXXX     |
|       | R/W         | R/W        | R/W       |               |

R/W : Read/write enabled

X : Undefined

If the corresponding interrupt enable bit of the program address detection control status register (ACSR) is set to "1", the program address is compared with the value stored in the program address detection register for the upper, middle, and lower parts of an address (PADR0/PADR1). If the program address value (PC value) matches the value stored in the program address detection register for upper, middle, and lower parts of an address (PADR0/PADR1), the corresponding interrupt flag bit is set to "1" and an INT9 instruction is output. If the interrupt enable bit is set to "0", no INT9 instruction is output.

The following table lists the correspondence between the program address detection control status register (PASCR) and the interrupt request enable bits and the interrupt request flag bits.

| Address detection register | Interrupt enable bit | Interrupt request flag bit |  |  |
|----------------------------|----------------------|----------------------------|--|--|
| PADR0                      | AD0E                 | AD0D                       |  |  |
| PADR1                      | AD1E                 | AD1D                       |  |  |

# 21.2.2 Program Address Detection Control Status Register (PACSR)

The program address detection control status register (PACSR) is used to perform the interrupt control of the address match detection function.

#### ■ Program Address Detection Control Status Register (PACSR)

#### Figure 21.2-3 Program Address Detection Control Status Register (PACSR)

| Bit | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    | Initial value |
|-----|------|------|------|------|------|------|------|------|---------------|
|     | RESV | RESV | RESV | RESV | AD1E | AD1D | AD0E | AD0D | 0000000в      |
|     | R/W  |               |

R/W : Read/write X : Undefined

# Table 21.2-1 Functional Explanation of Each Bit of the Program Address Detection Control Status Register (PACSR)

|                    | Bit name                                       | Function                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|--------------------|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| bit7<br>to<br>bit4 | RESV:<br>Reserved bit                          | Always set "0".                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| bit3               | AD1E:<br>PADR1 interrupt request<br>enable bit | <ul> <li>This bit enables an interrupt of PADR1.</li> <li>When this bit is "1", the program address detection register (PADR1) and the program address are compared. If the program address detection register (PADR1) matches the program address, the PADR1 interrupt flag bit (AD1D) is set to "1" and an INT9 instruction is output.</li> </ul>                                                                                   |  |  |  |  |
| bit2               | AD1D:<br>PADR1 interrupt request<br>flag bit   | <ul> <li>This bit enables an interrupt request of PADR1.</li> <li>This bit is set to "1" when the program address detection register (PADR1) and the program address are compared and match.</li> <li>While the PAD1 request enable bit (AD1E) is "1", setting this bit to "1" outputs an INT9 instruction.</li> <li>Setting this bit to "0"clears it to "0".</li> <li>Setting this bit to "1" has no effect on operation.</li> </ul> |  |  |  |  |
| bit1               | AD0E:<br>PADR0 interrupt request<br>enable bit | <ul> <li>This bit enables an interrupt of PADR0.</li> <li>When this bit is "1", the program address detection register (PADR0) value and the program address are compared. If both match, the interrupt flag bit (AD0D) of the PADR0 is set to "1" and an INT9 instruction is output.</li> </ul>                                                                                                                                      |  |  |  |  |
| bit0               | AD0D:<br>PADR0 interrupt request<br>flag bit   | <ul> <li>This bit enables an interrupt request of PADR0.</li> <li>This bit is set to "1" when the program address detection register (PADR1) and the program address are compared and match.</li> <li>While the PAD0 request enable bit (AD0E) is "1", setting this bit to "1" outputs an INT9 instruction.</li> <li>Setting this bit to "0" clears it to "0".</li> <li>Setting this bit to "1" does not affect operation.</li> </ul> |  |  |  |  |

## 21.3 Operation of the Address Match Detection Function

#### This section explains the operation of the address match detection function.

#### Operation of the Address Match Detection Function

If the program address matches the value set in the address match detection register, the instruction code to be read by the CPU is replaced with an INT9 instruction code  $(01_H)$ . When the CPU executes the instruction at the specified program address, the INT9 instruction is executed. By performing processing using an INT #9 interrupt routine, a program patch application function can be implemented.

There are two program address detection registers (PADR0/PADR1), each of which has an interrupt enable bit (AD1E, AD0E) and an interrupt flag bit (AD1D, AD0D). If the interrupt enable bit (AD1E, AD0E) is set to "1", the value stored in the address detection register and the program address are compared. If they match, the interrupt flag bit (AD1D, AD0D) is set to "1", and the instruction code to be read by the CPU is replaced with an INT9 instruction code. Setting the interrupt flag bit (AD1D, AD0D) to "0"clears it to "0".

#### Note:

The address detection function does not work correctly if a program address after the 1st byte of the instruction is set in the address detection register. Change the address detection register after setting the interrupt enable bit to "0". If the setting of the address detection register is changed while the interrupt enable bit is set to "1", an address detection may be mistakenly performed while making settings.

# 21.4 Example of Using the Address Match Detection Function

This section contains example of Using the Address Match Detection Function.

#### System Configuration



Figure 21.4-1 System Configuration Example

#### ■ E<sup>2</sup>PROM Memory Map

 Table 21.4-1
 E<sup>2</sup>PROM Memory Map

| Address                                                          | Meaning                                                            |
|------------------------------------------------------------------|--------------------------------------------------------------------|
| 0000 <sub>H</sub>                                                | Number of bytes of patch program No. 0<br>(0 for no program error) |
| 0001 <sub>H</sub>                                                | Bit 7 to bit 0 of program address No. 0                            |
| 0002 <sub>H</sub>                                                | Bit 15 to bit 8 of program address No. 0                           |
| 0003 <sub>H</sub>                                                | Bit 24 to bit 16 of program address No. 0                          |
| 0004 <sub>H</sub>                                                | Number of bytes of patch program No. 1<br>(0 for no program error) |
| 0005 <sub>H</sub>                                                | Bit 7 to bit 0 of program address No. 1                            |
| 0006 <sub>H</sub>                                                | Bit 15 to bit 8 of program address No. 1                           |
| 0007 <sub>H</sub>                                                | Bit 24 to bit 16 of program address No. 1                          |
| 0010 <sub>H</sub> +<br>Number of bytes of patch<br>program No. 0 | Original of patch program No. 0                                    |

#### Initial State

The contents of E<sup>2</sup>PROM are all 0s.

#### INT9 Interrupt

An interrupt routine finds the address detection cause for which an interrupt request was output by referencing the interrupt flag bits (AD1D, AD0D) of the detection control status register (PACSR). The routine then causes a branch to the program from which the interrupt request was output. If a branch to the program is caused, information saved on the stack due to the interrupt becomes invalid, and the interrupt flag bits (AD1D, AD0D) are cleared to "0".



Figure 21.4-2 System Configuration Example



Figure 21.4-3 Flowchart of Program Patch Processing

# CHAPTER 22 ROM MIRRORING FUNCTION SELECTION MODULE

This chapter describes the function and operation of the MB90M405 series ROM mirroring function selection module.

- 22.1 "Overview of the ROM Mirroring Function Selection Module"
- 22.2 "ROM Mirroring Function Selection Register (ROMM)"

## 22.1 Overview of the ROM Mirroring Function Selection Module

The ROM mirroring function selection module can access ROM data in bank FF from bank 00 by setting its register.

The ROM mirroring function enables access from the target area (FF4000<sub>H</sub> to FFFFF<sub>H</sub>) to the I/O area or the RAM area without bank accesses.

#### ■ Block diagram of the ROM mirroring function selection module



Figure 22.1-1 Block Diagram

# 22.2 ROM Mirroring Function Selection Register (ROMM)

This section explains the register in the ROM mirroring function selection module.

#### ROM Mirroring Function Selection Register (ROMM)





X : Undefined

: Undefined bit

Note:

Do not set the ROM mirroring function selection register while accessing the addresses "004000<sub>H</sub> to 00FFFF<sub>H</sub>".

Table 22.2-1 Functional Explanation of the ROM Mirroring Function Selection Register (ROMM)

|                     | Bit name                                     | Function                                                                                                                                                                                                                             |  |  |  |
|---------------------|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| bit15<br>to<br>bit9 | -:<br>Undefined bit                          | <ul><li>The values read from these bits are undefined.</li><li>Setting these bits to a new value does not affect operation.</li></ul>                                                                                                |  |  |  |
| bit8                | MI:<br>ROM mirroring<br>function setting bit | <ul> <li>This bit is used to set the ROM mirroring function.</li> <li>When this bit is "1", ROM data in bank FF can be read from bank 00.</li> <li>When this bit is "0", ROM data in bank FF cannot be read from bank 00.</li> </ul> |  |  |  |

#### Note:

The ROM mirroring function accesses addresses 004000<sub>H</sub> to 00FFFF<sub>H</sub> from addresses FF4000<sub>H</sub> to FFFFF<sub>H</sub>. Therefore, addresses FF0000<sub>H</sub> to FF3FFF<sub>H</sub> cannot be accessed when use of the ROM mirroring function is set.

|           | MB90M407/M407A      | MB90M408/M408A      | MB90MF408/MF408A    | MB90MV405           |
|-----------|---------------------|---------------------|---------------------|---------------------|
| Address 1 | FE8000 <sub>H</sub> | FE0000 <sub>H</sub> | FE0000 <sub>H</sub> | FE0000 <sub>H</sub> |
| Address 2 | 001100 <sub>H</sub> | 001100 <sub>H</sub> | 001100 <sub>H</sub> | 001100 <sub>H</sub> |



#### Figure 22.2-2 Memory Space

# CHAPTER 23 1M-BIT FLASH MEMORY

# This chapter describes the functions and operations of the MB90M405 series 1M-bit flash memory.

- 23.1 "Overview of the 1M-Bit Flash Memory"
- 23.2 "Registers and Sector Configuration of the Flash Memory"
- 23.3 "Flash Memory Control Status Register (FMCS)"
- 23.4 "Starting the Automatic Algorithm of the Flash Memory"
- 23.5 "Detailed Description of Flash Memory Writing and Deletion"

### 23.1 Overview of the 1M-Bit Flash Memory

The 1M-bit flash memory is allocated in banks  $FE_H$  and  $FF_H$  on the CPU memory map. Like mask ROM, it does support read access and program access from the CPU because of the flash memory interface circuit function. Data can be written to or deleted from the flash memory via the flash memory interface circuit using CPU instructions. Because this approach enables rewriting the flash memory when it is installed under control of the built-in CPU, programs and data can be changed more efficiently.

#### Writing Data to or Deleting Data from the Flash Memory

You can write data to or delete data from the flash memory in one of the following two ways:

- 1. Dedicated serial programmer (AF220 manufactured by YDC)
- 2. Writing and deletion using a program

This section describes the second option of executing a program.

#### Features of the 1M-bit Flash Memory

- Configuration of 128K words x 8K or 64K words x 16 bits (16K + 8K + 8K + 32K + 64K) sector
- Automatic program algorithm (equivalent to Embedded Algorithm: MBM29F400TA)
- Function for temporarily stopping and restarting deletion
- · Detection of the completion of writing and deletion using CPU interrupts
- · Compatibility with JEDEC standard commands
- Sector-by-sector deletion (Any combination of sectors)
- 10,000 writes and deletes guaranteed

Embedded Algorithm is a trademark of Advanced Micro Devices Corporation.

#### Writing to and Deletion from the Flash Memory

Writing to and deletion from the flash memory must not be performed at the same time. To write data to or delete data from the flash memory, first copy the program to RAM and then execute the copied program in RAM.

For more information, see Section 23.5.2 "Writing Data to the Flash Memory".

### 23.2 Registers and Sector Configuration of the Flash Memory

Figure 23.2-1 "Sector Configuration of the 1M-bit Flash Memory" shows the registers and sector configuration of the flash memory.

#### Registers of the Flash Memory

**O** Flash memory control status register (FMCS)



W : Write only

#### Sector Configuration

Figure 23.2-1 "Sector Configuration of the 1M-bit Flash Memory" shows the sector configuration of the 1M-bit flash memory. In this figure, high-order and low-order addresses are shown for each sector.

For access from the CPU, SA0 is stored in the FE bank register and SA1 to SA4 are stored in the FF bank register.

#### Figure 23.2-1 Sector Configuration of the 1M-bit Flash Memory

| Flash memory | CPU address |
|--------------|-------------|
| High order   | FFFFFh      |
| SA4(16 KB)   |             |
| Low order    | FFC000H     |
| High order   | FFBFFFH     |
| SA3(8 KB)    |             |
| Low order    | FFA000н     |
| High order   | FF9FFFH     |
| SA2(8 KB)    |             |
| Low order    | FF8000н     |
| High order   | FF7FFFH     |
| SA1(32 KB)   |             |
| Low order    | FF0000H     |
| High order   | FEFFFFH     |
| SA0(64 KB)   |             |
| Low order    | FE0000н     |

# 23.3 Flash Memory Control Status Register (FMCS)

This section describes the functions of the flash memory control status register (FMCS).

#### ■ Flash Memory Control Status Register (FMCS)



Figure 23.3-1 Flash Memory Control Status Register (FMCS)

R/W R W

: Write only : Initial value

|              | Bit name                                                     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------|--------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit7         | INTE:<br>Interrupt request<br>enable bit                     | <ul> <li>This bit enables the output of an interrupt request to the CPU when a flash memory write or delete operation is completed.</li> <li>An interrupt request is output if this bit is set to "1" and the RDYINT bit is set to "1".</li> <li>No interrupt request is output if this bit is set to "0" and the RDYINT bit is set to "1".</li> </ul>                                                                                                                                                                                                                                                      |
| bit6         | RDYINT:<br>Write/delete operation<br>completion flag bit     | <ul> <li>When a flash memory write or delete operation is completed, this bit is set to "1", enabling a flash memory write or delete operation.</li> <li>If this bit is set to "0", this bit is cleared to "0", disabling flash memory write or delete operations.</li> <li>Setting this bit to "1" does not affect operation.</li> <li>This bit is also set to "1" when the automatic algorithm (see Section 23.4 "Starting the Automatic Algorithm of the Flash Memory") of the flash memory has been completed.</li> <li>Read-modify-write (RMW) instructions always return "1" for this bit.</li> </ul> |
| bit5         | WE:<br>Write/delete operation<br>enable bit                  | <ul> <li>If this bit is set to "1", writing to or deletion from the flash memory is enabled after the write/delete command sequence to the FF bank is completed (see Section 23.4 "Startting the Automatic Algorithm of the Flash Memory").</li> <li>If this bit is set to "0", the execution of the write/delete command sequence to the FF bank does not generate a write or a delete signal.</li> <li>Note:</li> <li>Set this bit to "0" if neither a write nor a delete operation will be used.</li> </ul>                                                                                              |
| bit4         | RDY:<br>Write/delete operation<br>enable bit                 | <ul> <li>When this bit is "0", writing to or deletion from the flash memory is disabled.</li> <li>When this bit is "0", read, reset and suspend commands, such as during temporary stop of sector deletion, can be accepted.</li> <li>This bit is set to "1" when a write or delete operation has been completed.</li> </ul>                                                                                                                                                                                                                                                                                |
| bit3<br>bit1 | Reserved:<br>Reserved bit                                    | Be sure to set this bit to "0".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| bit2<br>bit0 | LPM1, LPM0:<br>Low power<br>consumption mode<br>setting bits | <ul> <li>These bits allow power consumption of the flash memory to be controlled from the CPU.</li> <li>The values that can be specified in these bits vary depending on the internal operating frequency.</li> <li>The lower the internal operating frequency, the lower the power consumption of the flash memory.</li> </ul>                                                                                                                                                                                                                                                                             |

Table 23.3-1 Functions of the Flash Memory Control Status Register (FMCS) Bits

#### Note:

The operation completion flag bit (RDYINT) and the write/delete status bit (RDY) do not change at the same time. Create a program so that the completion of writing or deletion is determined using the RDYINT or the RDY bit.



# 23.4 Starting the Automatic Algorithm of the Flash Memory

Four types of commands are supported to start the automatic algorithm of the flash memory: read/reset, write, chip deletion, and sector deletion. Temporary stop and restart can be controlled for sector deletion.

#### ■ Command Sequence Table

Table 23.4-1 "Command Sequence Table" lists the commands used to write data to and delete data from the flash memory. Although all the data items to be written to the command register have a length of bytes, use word access to write data. The data in the upper bytes written during word access will be ignored.

Table 23.4-1 Command Sequence Table

| Com-<br>mand                           | Bus<br>write | 1st bus write cycle |                   | 2nd bus write cycle                                                                                                 |                   | 3rd bus write cycle |                   | 4th bus write cycle |                   | 5th bus write cycle |                   | 6th bus write cycle |                   |
|----------------------------------------|--------------|---------------------|-------------------|---------------------------------------------------------------------------------------------------------------------|-------------------|---------------------|-------------------|---------------------|-------------------|---------------------|-------------------|---------------------|-------------------|
| se-<br>quence                          | access       | Address             | Data              | Address                                                                                                             | Data              | Address             | Data              | Address             | Data              | Address             | Data              | Address             | Data              |
| Read/<br>reset (*1)                    | 1            | FxXXXX <sub>H</sub> | XXF0 <sub>H</sub> | -                                                                                                                   | -                 | -                   | -                 | -                   | -                 | -                   | -                 | -                   | -                 |
| Read/<br>reset (*1)                    | 4            | FxAAAA <sub>H</sub> | XXAA <sub>H</sub> | Fx5554 <sub>H</sub>                                                                                                 | XX55 <sub>H</sub> | FxAAAA <sub>H</sub> | XXF0 <sub>H</sub> | RA                  | RD                | -                   | -                 | -                   | -                 |
| Write<br>program                       | 4            | FxAAAA <sub>H</sub> | XXAA <sub>H</sub> | Fx5554 <sub>H</sub>                                                                                                 | XX55 <sub>H</sub> | FxAAAA <sub>H</sub> | XXA0 <sub>H</sub> | PA(even)            | PD<br>(word)      | -                   | -                 | -                   | -                 |
| Chip<br>deletion                       | 6            | FxAAAA <sub>H</sub> | XXAA <sub>H</sub> | Fx5554 <sub>H</sub>                                                                                                 | XX55 <sub>H</sub> | FxAAAA <sub>H</sub> | XX80 <sub>H</sub> | FxAAAA <sub>H</sub> | XXAA <sub>H</sub> | Fx5554 <sub>H</sub> | XX55 <sub>H</sub> | FxAAAA <sub>H</sub> | XX10 <sub>H</sub> |
| Sector deletion                        | 6            | FxAAAA <sub>H</sub> | XXAA <sub>H</sub> | Fx5554 <sub>H</sub>                                                                                                 | XX55 <sub>H</sub> | FxAAAA <sub>H</sub> | XX80 <sub>H</sub> | FxAAAA <sub>H</sub> | XXAA <sub>H</sub> | Fx5554 <sub>H</sub> | XX55 <sub>H</sub> | SA(even)            | XX30 <sub>H</sub> |
| Sector deletion temporary stop Enter t |              |                     | Enter the         | nter the data (XXB0 <sub>H</sub> ) at address FXXXXX <sub>H</sub> to temporarily stop sector deletion.              |                   |                     |                   |                     |                   |                     |                   |                     |                   |
| Sector deletion restart Ent            |              |                     | Enter the         | nter the data (XX30 <sub>H</sub> ) at address FXXXXX <sub>H</sub> to resume sector deletion after temporarily stop. |                   |                     |                   |                     |                   |                     |                   |                     |                   |

\*1: These two types of read/reset commands can reset the flash memory to read mode.

#### Notes:

- Address Fx in the table means FF and FE. Use the address for the bank to be accessed during address-related operations.
- The address in the table is a value in the CPU memory map. "X" stands for an arbitrary value.
- RA: Read address
- PA: Write address. An even-numbered address can be specified.
- SA: Sector address. See Section 23.2 "Registers and Sector Configuration of the Flash Memory". An even-numbered address can be specified.
- RD: Read data
- PD: Write data. Word data can be specified.

## 23.5 Detailed Description of Flash Memory Writing and Deletion

This section describes the procedures for issuing commands that start the automatic algorithm to perform read/reset, write, chip deletion, sector deletion, temporary stop of sector deletion, or restart of sector deletion for the flash memory.

#### ■ Detailed Description of Flash Memory Writing and Deletion

The automatic algorithm can start read/reset, write, chip deletion, sector deletion, sector deletion temporary stop, or sector deletion restart operations by writing a command sequence (see Section 23.4 "Starting the Automatic Algorithm of the Flash Memory") from the CPU to the flash memory. Writing from the CPU to the flash memory must be performed continuously. When writing ends normally, the status returns to the read or reset status.

The subsequent sections describe the details of the deletion restart operation in the following order:

- Placing the flash memory in read/reset status
- Writing data
- Deleting all data items (all chip deletion)
- Deleting a data item (sector deletion)
- Temporarily stopping sector deletion
- Restarting sector deletion

## 23.5.1 Placing the Flash Memory in Read/Reset Status

This section describes the procedure for executing the read/reset command to place the flash memory in read/reset status.

#### ■ Placing Flash Memory in Read/Reset Status

To place the flash memory in read/reset status, continuously send the read/reset command listed in the command sequence table (Table 23.4-1 "Command Sequence Table") from the CPU to the flash memory.

There are two command sequences for the read/reset command, the results of which are the same.

Read/reset status is the initial status of the flash memory. The flash memory is always in read/ reset status immediately after power is turned on or a command ends normally. In read/reset status, the system waits for input of a new command.

In read/reset status, perform read access to the flash memory to read flash memory data. Like the mask ROM, flash memory does support program access from the CPU. No read/reset command is required to perform read access to the flash memory.

If a command does not end normally, use the read/reset command to initialize the automatic algorithm.

## 23.5.2 Writing Data to the Flash Memory

This section describes the procedure for executing the write command to write data to the flash memory. Figure 23.5-1 "Example of the Procedure for Flash Memory Writing" shows an example of the procedure for flash memory writing.

#### Writing Data to the Flash Memory

To start the automatic algorithm for writing data to the flash memory, continuously send the write command listed in the command sequence table (Table 23.4-1 "Command Sequence Table"), from the CPU to the flash memory. When data writing to the target address ends after the fourth cycle, the automatic algorithm is started to start automatic writing.

#### Addressing

Only an even-numbered address can be specified as the write address in the write data cycle. If an odd-numbered address is specified, data cannot be written correctly. Use word access to write to an even-numbered address in word units.

Writing is enabled in any order of addresses and across sector boundaries. However, only one word of data is written each time the write command is executed.

#### Notes on Writing Data

The data of a bit cannot be changed from "0" to "1" by write operations. When there is an attempt to overwrite "0" by "1", the data polling algorithm or the toggle operation does not end, the flash memory component will be assumed to be faulty. IN this case, it will only appear as if "1" had been written, but "0" will be returned when the data is read in read/reset status. To change a bit from "0" to "1", perform a delete operation.

All other commands are ignored while automatic writing is in progress. Data at a write address cannot be assured if a hardware reset occurs during writing.



Figure 23.5-1 Example of the Procedure for Flash Memory Writing

# 23.5.3 Deleting All Data Items from the Flash Memory (Chip Deletion)

This section describes the procedure for executing the chip deletion command to delete all data items from the flash memory.

#### Deleting All Data Items from the Flash Memory (Chip Deletion)

To delete all data items from the flash memory, continuously send the chip deletion command listed in the command sequence table (Table 23.4-1 "Command Sequence Table") from the CPU to the flash memory.

The chip deletion command starts the chip deletion operation when writing completes after the sixth cycle. Writing to the flash memory before chip deletion is not required. During the processing for the automatic deletion function, the flash memory performs verification by writing "0" before deleting all bits of the data.

# 23.5.4 Deleting a Data Item from the Flash Memory (Sector Deletion)

This section describes the procedure for executing the sector deletion command to delete a data item from the flash memory (sector deletion). Data in any sector can be deleted. More than one sector can be specified for deletion. Figure 23.5-2 "Example of the Sector Deletion Procedure for the Flash Memory" shows an example of the procedure for flash memory sector deletion.

#### ■ Deleting a Data Item from the Flash Memory (Sector Deletion)

To delete data in any sector of the flash memory, continuously send the sector deletion command listed in the command sequence table (Table 23.4-1 "Command Sequence Table") from the CPU to the flash memory.

#### Specifying a Sector

The sector deletion command starts a sector deletion wait of 50  $\mu$ s by writing in the sixth cycle the sector deletion code (30<sub>H</sub>) to any even-numbered address in the target sector that can be accessed. To delete more than one sector, write the deletion code (30<sub>H</sub>) to the addresses of additional sectors to be deleted.

#### Notes on Specifying More Than One Sector

Deletion starts upon completion of the 50  $\mu$ s sector deletion wait period since the last sector deletion code was written. To delete more than one sector at the same time, input the deletion sector address and the deletion code (in the sixth cycle of the command sequence) within 50  $\mu$ s. The address and the code are accepted only if they are input within 50  $\mu$ s.

Figure 23.5-2 Example of the Sector Deletion Procedure for the Flash Memory



## 23.5.5 Temporarily Stopping Deletion of Sectors from the Flash Memory

This section describes the procedure for executing the sector deletion temporary stop command to temporarily stop the deletion of sectors from the flash memory. Data can be read from sectors that are not being deleted.

#### Temporarily Stopping Sector Deletion

To temporarily stop the deletion of sectors from the flash memory, continuously send the sector deletion temporary stop command listed in the command sequence table (Table 23.4-1 "Command Sequence Table") from the CPU to the flash memory.

The sector deletion temporary stop command temporarily stops the deletion of sectors and the reading of data from sectors that are not being deleted. In sector deletion temporary stop status, reading is enabled and writing is disabled. The sector deletion temporary stop command is valid only during sector deletion (including the deletion wait time) and is ignored during chip deletion or writing.

To execute the sector deletion temporary stop command, write the deletion temporary stop code  $(B0_H)$ . Specify any address in the flash memory. During deletion temporary stop, the deletion temporary stop command is ignored if it is executed.

If the sector deletion temporary stop command is input during the sector deletion wait period, the sector deletion wait ends and deletion is suspended, causing the system to enter deletion stop status. If the deletion temporary stop command is input during sector deletion after the sector deletion wait period, the system enters deletion temporary stop status after waiting for a maximum of 15  $\mu s.$ 

## 23.5.6 Resuming Flash Memory Sector Deletion

This section describes the procedure for issuing the sector deletion restart command to resume a flash memory sector deletion that has been temporarily stopped.

#### Resuming the Flash Memory Sector Deletion

To resume a sector deletion that has been temporarily stopped, continuously send the sector deletion restart command listed in the command sequence table (Table 23.4-1 "Command Sequence Table") from the CPU to the flash memory.

The sector deletion restart command is used to restart sector deletion that has been temporarily stopped by execution of the sector deletion temporary stop command. To execute the sector deletion restart command, write the sector deletion restart code  $(30_H)$ . Specify any address in the flash memory.

During sector deletion, the sector deletion restart command is ignored if it is executed.

# CHAPTER 24 EXAMPLE OF MB90MF408/MF408A SERIAL PROGRAMMING CONNECTION

This chapter provides examples of connection for serial programming using the AF220 flash microcomputer programmer manufactured by YDC Corporation.

- 24.1 "Standard Configuration for Serial Programming Connection to MB90MF408/MF408A"
- 24.2 "Example of Connection for Serial Programming (Power Supplied by User)"
- 24.3 "Example of Connection for Serial Programming (Power Supplied from Programmer)"
- 24.4 "Example of Minimum Connection to Flash Microcomputer Programmer (Power Supplied by User)"
- 24.5 "Example of Minimum Connection to Flash Microcomputer Programmer (Power Supplied from Programmer)"

# 24.1 Standard Configuration for Serial Programming Connection to MB90MF408/MF408A

MB90MF408/MF408A supports serial on-board writing (Fujitsu standard) to flash ROM. This describes the specifications for serial on-board writing.

#### Standard Configuration for Serial Programming Connection to MB90MF408/MF408A

The AF220 flash microcomputer programmer, manufactured by YDC, is used for Fujitsu standard serial on-board writing.



Note:

Contact YDC for information about the functions and operations of the AF220 flash microcomputer programmer and information about the general-purpose common connection cable (AZ210) and connectors.

| Table 24.1-1 | Pins Used for Fujitsu Standard Serial on-board Programming |
|--------------|------------------------------------------------------------|
|--------------|------------------------------------------------------------|

| Pin             | Function                                                                  | Description                                                                                                                                                                                                                                                          |  |  |  |
|-----------------|---------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| MD2,MD1,<br>MD0 | Mode pin Switches to programming mode from the flash microcomputer progra |                                                                                                                                                                                                                                                                      |  |  |  |
| X0, X1          | Oscillator pin                                                            | Since the internal operating clock of the CPU is set to the same clock cycle as the PLL clock, the oscillation clock frequency is used as the internal operation clock. An oscillation clock from 1 MHz to 16 MHz is therefore used for serial on-board programming. |  |  |  |
| P80, P81        | Programming start pin                                                     | -                                                                                                                                                                                                                                                                    |  |  |  |
| RST             | Reset pin                                                                 | -                                                                                                                                                                                                                                                                    |  |  |  |
| SI1             | Serial data input pin                                                     | The UART is used in clock synchronous mode.                                                                                                                                                                                                                          |  |  |  |
| SO1             | Serial data output pin                                                    |                                                                                                                                                                                                                                                                      |  |  |  |
| SC0             | Serial clock input pin                                                    |                                                                                                                                                                                                                                                                      |  |  |  |
| С               | C terminal                                                                | Capacitor terminal for stabilizing the power supply. Connect an external ceramic capacitor of about 0.1 $\mu\text{F}.$                                                                                                                                               |  |  |  |

| Pin             | Function         | Description                                                                                                                                                                                                                                           |
|-----------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| V <sub>CC</sub> | Power supply pin | The flash microcomputer programmer does not need to be connected to supply the programming voltage (5 V $\pm$ 10%) from the user system. When you connect this pin, make sure that no short-circuit occurs between it and the user-side power supply. |
| V <sub>SS</sub> | Ground pin       | Also use this pin as the ground pin for the flash microcomputer programmer.                                                                                                                                                                           |

When the P80, SI0, SO0, and SC0 pins are also used by the user system, the control circuit shown in Figure 24.1-1 "Control Circuit" is required. (The TCIS signal of the flash microcomputer programmer can separate the user circuit during serial writing. See the connection example shown later.)



Refer to the following four serial writing examples in Sections 24.2 to 24.5.

- Example of serial programming connection
  - When power supplied by user
- Example of serial programming connection
  - When power is supplied from the programmer
- Example of minimum connection to flash microcomputer programmer
  - When power supplied from user
- Example of minimum connection to flash microcomputer programmer
  - · When power is supplied from the programmer

# Table 24.1-2 System Configuration of AF220 Flash Microcomputer Programmer (Manufactured by YDC)

| Model     | Function                                                          |
|-----------|-------------------------------------------------------------------|
| AF220     | Advanced flash microcomputer programmer                           |
| AF200 ACP | AC adapter (center +) (optional)                                  |
| AZ201     | Host interface cable (RS232C cable for PCAT)                      |
| AZ210     | Standard target probe (Type A) Length: 1 m                        |
| FF001     | Fujitsu F <sup>2</sup> MC-16LX flash microcomputer control module |
| FF001 P2  | 2 MB PC card (optional)                                           |
| FF001 P4  | 4 MB PC card (optional)                                           |

For additional information, contact: YDC Corporation Telephone number: (81)-42-333-6224

# 24.2 Example of Connection for Serial Programming (Power Supplied by User)

Figure 24.2-1 "Example of Connection for Serial Programming by MB90MF408/MF408A (Power Supplied by User)" shows an example of connection when microcomputer power is supplied by the user. The mode pins are set to single-chip mode (MD0=1, MD1=1, and MD2=0).

#### Example of Connection for Serial Programming (When Power Supplied by User)





Connector (Hirose Electronics) pin layout

 When the user system also uses the P80, SI0, SO0, and SC0 pins, the following control circuit is necessary. During serial programming, disconnect the user circuit using the TCIS signal of the flash microcomputer programmer.



• Before connecting to AF220, turn off the user power.

# 24.3 Example of Connection for Serial Programming (When Power Supplied from Programmer)

Figure 24.3-1 "Example of Connection for Serial Programming by MB90MF408/MF408A (Power Supplied by Programmer)" shows an example of connection when microcomputer power is supplied by the programmer. The mode pins are set to single-chip mode (MD0=1, MD1=1, and MD2=0).

Example of Connection for Serial Programming (When Power Supplied from Programmer)





Connector (made by Hirose Electronics) pin layout

#### 24.3 Example of Connection for Serial Programming (When Power Supplied from Programmer)

 When the user system also uses the P80, SI0, SO0, and SC0 pins, the following control circuit is necessary. During serial programming, disconnect the user circuit using the TCIS signal of the flash microcomputer programmer.



- Before connecting the AF220, turn off the power supplied by the user.
- When supplying power from the AF220, do not create a short circuit to the power supplied by the user.

# 24.4 Example of Minimum Connection with Flash Microcomputer Programmer (When Power Supplied from User)

Figure 24.4-1 "Example of Minimum Connection with Flash Microcomputer Programmer (When Power Supplied by User)" shows an example of minimum connection with the flash microcomputer programmer.

Example of Minimum Connection with Flash Microcomputer Programmer (When Power Supplied by User)

If the pins are set as shown in Figure 24.4-1 "Example of Minimum Connection with Flash Microcomputer Programmer (When Power Supplied by User)" for writing data to the flash memory, then MD2, MD1, MD0, and P80 do not need to be connected to the flash microcomputer programmer.

# Figure 24.4-1 Example of Minimum Connection with Flash Microcomputer Programmer (When Power Supplied by User)



• Turn off the user circuit power before connecting to the AF220.

# 24.5 Example of Minimum Connection with Flash Microcomputer Programmer (When Power Supplied from Programmer)

Figure 24.5-1 "Example of Minimum Connection with Flash Microcomputer Programmer (When Power Supplied from programmer)" shows an example of minimum connection with the flash microcomputer programmer.

Example of Minimum Connection with Flash Microcomputer Programmer (When Power Supplied from programmer)

If data is written to the flash memory with the pin settings as shown in Figure 24.5-1 "Example of Minimum Connection with Flash Microcomputer Programmer (When Power Supplied from programmer)", MD2, MD1, MD0, and P80 do not need to be connected to the flash microcomputer programmer.

## Figure 24.5-1 Example of Minimum Connection with Flash Microcomputer Programmer (When Power Supplied from programmer)



- Before connecting the AF220, turn off the power supplied by the user.
- When power is supplied from the AF220, do not create a short circuit to the power supplied by the user.

### APPENDIX

This appendix includes I/O maps, instruction lists, and other information.

APPENDIX A "I/O Map" APPENDIX B "Instructions" APPENDIX C "Index of Registers" APPENDIX D "Index of Pin Functions"

## APPENDIX A I/O Map

# Table A-1 lists the addresses assigned to the registers for peripheral functions in the MB90M405 series.

#### ■ I/O Map

#### Table A-1 I/O Map

| Address                                          | Abbreviation    | Register                       | Read/write | Resource name | Initial value         |  |  |  |
|--------------------------------------------------|-----------------|--------------------------------|------------|---------------|-----------------------|--|--|--|
| 000000 <sub>H</sub><br>to<br>000007 <sub>H</sub> | Prohibited area |                                |            |               |                       |  |  |  |
| 000008 <sub>H</sub>                              | PDR8            | Port 8 data register           | R/W        | Port 8        | XXXXXXXXB             |  |  |  |
| 000009 <sub>H</sub>                              | PDR9            | Port 9 data register           | R/W        | Port 9        | XXXXXXXXB             |  |  |  |
| 00000A <sub>H</sub>                              | PDRA            | Port A data register           | R/W        | Port A        | XXXXXXXX <sub>B</sub> |  |  |  |
| 00000B <sub>H</sub>                              | PDRB            | Port B data register           | R/W        | Port B        | XXXXXXXXB             |  |  |  |
| 00000C <sub>H</sub><br>to<br>000017 <sub>H</sub> | Prohibited area |                                |            |               |                       |  |  |  |
| 000018 <sub>H</sub>                              | DDR8            | Port 8 direction register      | R/W        | Port 8        | 00000000 <sub>B</sub> |  |  |  |
| 000019 <sub>H</sub>                              | DDR9            | Port 9 direction register      | R/W        | Port 9        | XXXXXX00 <sub>B</sub> |  |  |  |
| 00001A <sub>H</sub>                              | DDRA            | Port A direction register      | R/W        | Port A        | 00000000 <sub>B</sub> |  |  |  |
| 00001B <sub>H</sub>                              | DDRB            | Port B direction register      | R/W        | Port B        | 00000000 <sub>B</sub> |  |  |  |
| 00001C <sub>H</sub><br>to<br>00001D <sub>H</sub> |                 | Prohibited area                |            |               |                       |  |  |  |
| 00001E <sub>H</sub>                              | ADER0           | Analog input enable register 0 | R/W        | Port A, A/D   | 11111111 <sub>B</sub> |  |  |  |
| 00001F <sub>H</sub>                              | ADER1           | Analog input enable register 1 | R/W        | Port B, A/D   | 11111111 <sub>B</sub> |  |  |  |
| 000020 <sub>H</sub>                              | SMR0            | Mode register ch0              | R/W        |               | 00000X00 <sub>B</sub> |  |  |  |
| 000021 <sub>H</sub>                              | SCR0            | Control register ch0           | R/W        |               | 00000100 <sub>B</sub> |  |  |  |
| 000022                                           | SIDR0           | Input data register ch0        | R          | UART ch0      | ~~~~~~                |  |  |  |
| 000022 <sub>H</sub>                              | SODR0           | Output data register ch0 W     |            |               | XXXXXXXXB             |  |  |  |
| 000023 <sub>H</sub>                              | SSR0            | Status register ch0            | R/W        |               | 00001000 <sub>B</sub> |  |  |  |

| Address                                          | Abbreviation    | Register                                     | Read/write            | Resource name                 | Initial value         |  |  |
|--------------------------------------------------|-----------------|----------------------------------------------|-----------------------|-------------------------------|-----------------------|--|--|
| 000024 <sub>H</sub>                              | SMR1            | Mode register ch1                            | R/W                   |                               | 00000X00 <sub>B</sub> |  |  |
| 000025 <sub>H</sub>                              | SCR1            | Control register ch1                         | R/W                   |                               | 00000100 <sub>B</sub> |  |  |
| 000026                                           | SIDR1           | Input data register ch1                      | R                     | UART ch1                      | ~~~~~                 |  |  |
| 000026 <sub>H</sub>                              | SODR1           | Output data register ch1                     | W                     |                               | XXXXXXXX              |  |  |
| 000027 <sub>H</sub>                              | SSR1            | Status register ch1                          | R/W                   |                               | 00001000 <sub>B</sub> |  |  |
| 000028 <sub>H</sub>                              | CDCR0           | Communication prescaler control register ch0 | R/W                   | Communication prescaler 0     | 0XXX0000 <sub>B</sub> |  |  |
| 000029 <sub>H</sub>                              | CDCR1           | Communication prescaler control register ch1 | R/W                   | Communication prescaler 1     | 0XXX0000 <sub>B</sub> |  |  |
| 00002A <sub>H</sub>                              | IBSR            | I <sup>2</sup> C status register             | R                     |                               | 00000000 <sub>B</sub> |  |  |
| 00002B <sub>H</sub>                              | IBCR            | I <sup>2</sup> C control register            | R/W                   |                               | 00000000 <sub>B</sub> |  |  |
| 00002C <sub>H</sub>                              | ICCR            | I <sup>2</sup> C clock control register      | R/W                   | I <sup>2</sup> C interface    | XX0XXXXX <sub>B</sub> |  |  |
| 00002D <sub>H</sub>                              | IADR            | I <sup>2</sup> C address register            | R/W                   | I-C Interface                 | XXXXXXXX              |  |  |
| 00002E <sub>H</sub>                              | IDAR            | I <sup>2</sup> C data register               | R/W                   |                               | XXXXXXXX              |  |  |
| 00002F <sub>H</sub>                              | ISEL            | I <sup>2</sup> C port selection register     | XXXXXXX0 <sub>E</sub> |                               |                       |  |  |
| 000030 <sub>H</sub>                              | ENIR            | DTP/interrupt enable register                |                       |                               | XXXX0000 <sub>B</sub> |  |  |
| 000031 <sub>H</sub>                              | EIRR            | DTP/interrupt cause register                 | R/W                   | DTP/external<br>interrupt     | XXXXXXXX              |  |  |
| 000032 <sub>H</sub>                              | ELVR            | Request level setting register               |                       | 00000000 <sub>B</sub>         |                       |  |  |
| 000033 <sub>H</sub>                              |                 | Prohibite                                    | d area                |                               |                       |  |  |
| 000034 <sub>H</sub>                              | ADCS0           | A/D control status register 0<br>(lower)     | R/W                   |                               | 00XXXXXX <sub>B</sub> |  |  |
| 000035 <sub>H</sub>                              | ADCS1           | A/D control status register 1<br>(upper)     | R/W                   | A/D converter                 | 00000000 <sub>B</sub> |  |  |
| 000036 <sub>H</sub>                              | ADCR0           | A/D data register 0 (lower)                  | R/W                   |                               | XXXXXXXX              |  |  |
| 000037 <sub>H</sub>                              | ADCR1           | A/D data register 1 (upper)                  | R/W                   |                               | 00000XXX <sub>B</sub> |  |  |
| 000038 <sub>H</sub>                              |                 | Prohibite                                    | d area                |                               |                       |  |  |
| 000039 <sub>H</sub>                              | ADMR            | A/D conversion channel select R/W            |                       | A/D converter                 | 00000000 <sub>B</sub> |  |  |
| 00003A <sub>H</sub><br>to<br>00003F <sub>H</sub> | Prohibited area |                                              |                       |                               |                       |  |  |
| 000040 <sub>H</sub>                              | TCCS            | Timer counter control status register        | R/W                   | 16-bit free-<br>running timer | 00000000 <sub>B</sub> |  |  |
| 000041 <sub>H</sub>                              |                 | Prohibite                                    | d area                |                               |                       |  |  |

#### APPENDIX A I/O Map

| Address                                          | Abbreviation                                  | Register                                            | Read/write | Resource name              | Initial value         |  |  |  |  |
|--------------------------------------------------|-----------------------------------------------|-----------------------------------------------------|------------|----------------------------|-----------------------|--|--|--|--|
| 000042 <sub>H</sub>                              | TODT                                          | Tinon countre data conistan                         | DAM        | 16-bit free-               | 00000000 <sub>B</sub> |  |  |  |  |
| 000043 <sub>H</sub>                              | TCDT                                          | Timer counter data register R/W                     |            | running timer              | 00000000 <sub>B</sub> |  |  |  |  |
| 000044 <sub>H</sub>                              | IPC0                                          | Input conture data register ch0                     | Р          |                            | XXXXXXXAB             |  |  |  |  |
| 000045 <sub>H</sub>                              | IPCU                                          | Input capture data register ch0                     | R          |                            | XXXXXXXAB             |  |  |  |  |
| 000046 <sub>H</sub>                              | IPC1                                          | Input conturo doto rogistor ch1                     | R          | Input capture              | XXXXXXXAB             |  |  |  |  |
| 000047 <sub>H</sub>                              | IFCI                                          | Input capture data register ch1                     | n.         |                            | XXXXXXXXB             |  |  |  |  |
| 000048 <sub>H</sub>                              | ICSO1                                         | Input capture control status<br>register            | R/W        |                            | 00000000 <sub>B</sub> |  |  |  |  |
| 000049 <sub>H</sub>                              |                                               | Prohibite                                           | ed area    |                            |                       |  |  |  |  |
| 00004A <sub>H</sub>                              | OCCP0                                         |                                                     | R/W        |                            | XXXXXXXAB             |  |  |  |  |
| 00004B <sub>H</sub>                              | UCCFU                                         | Output compare register                             | r/w        | Output compare             | XXXXXXXAB             |  |  |  |  |
| 00004C <sub>H</sub>                              | OCS0                                          | Output compare control status register              | R/W        |                            | XX00XXX0 <sub>B</sub> |  |  |  |  |
| 00004D <sub>H</sub>                              |                                               | Reserved area                                       |            |                            |                       |  |  |  |  |
| 00004E <sub>H</sub><br>to<br>00004F <sub>H</sub> |                                               | Prohibited area                                     |            |                            |                       |  |  |  |  |
| 000050 <sub>H</sub>                              | THOODS                                        | Timer control status register ch0 R/                | DAM        | 16-bit reload timer<br>ch0 | 00000000 <sub>B</sub> |  |  |  |  |
| 000051 <sub>H</sub>                              | TMCSR0                                        |                                                     | R/W        |                            | XXXX0000 <sub>B</sub> |  |  |  |  |
| 000052 <sub>H</sub>                              | TMR0/                                         | TMR0/ 16-bit timer register ch0 (R)                 | TMR0: R    |                            | XXXXXXXAB             |  |  |  |  |
| 000053 <sub>H</sub>                              | TMRLR0                                        | 16-bit reload register ch0 (W)                      | TMRLR0: W  |                            | XXXXXXXAB             |  |  |  |  |
| 000054 <sub>H</sub>                              | TMCSR1                                        | Timer central status register ch1                   | R/W        | 16-bit reload timer        | 00000000 <sub>B</sub> |  |  |  |  |
| 000055 <sub>H</sub>                              | TMCSRT                                        | Timer control status register ch1                   | R/W        |                            | XXXX0000 <sub>B</sub> |  |  |  |  |
| 000056 <sub>H</sub>                              | TMR1/                                         | 16-bit timer register ch1 (R)                       | TMR1: R    | ch1                        | XXXXXXXXB             |  |  |  |  |
| 000057 <sub>H</sub>                              | TMRLR1                                        | TMRLR1   16-bit reload register ch1 (W)   TMRLR1: W |            |                            | XXXXXXXAB             |  |  |  |  |
| 000058 <sub>H</sub>                              | TMCSR2                                        | Timer control status register ch2                   | R/W        |                            | 00000000 <sub>B</sub> |  |  |  |  |
| 000059 <sub>H</sub>                              | TMCGRZ                                        |                                                     | r///       | 16-bit reload timer<br>ch2 | XXXX0000 <sub>B</sub> |  |  |  |  |
| 00005A <sub>H</sub>                              | TMR2/                                         | 16-bit timer register ch2 (R)                       | TMR2: R    |                            | XXXXXXXAB             |  |  |  |  |
| 00005B <sub>H</sub>                              | TMRLR216-bit reload register ch2 (W)TMRLR2: W |                                                     |            | XXXXXXXAB                  |                       |  |  |  |  |
| 00005C <sub>H</sub><br>to<br>00005F <sub>H</sub> | Prohibited area                               |                                                     |            |                            |                       |  |  |  |  |

| Address                                          | Abbreviation    | Registe                                        | Register                            |        | Resource name                                 | Initial value         |                       |
|--------------------------------------------------|-----------------|------------------------------------------------|-------------------------------------|--------|-----------------------------------------------|-----------------------|-----------------------|
| 000060 <sub>H</sub>                              | 0140000         | Serial mode control s                          | Serial mode control status register |        |                                               | XXXX0000 <sub>B</sub> |                       |
| 000061 <sub>H</sub>                              | SMCS2           | ch2                                            | 0                                   | R/W    | Serial I/O ch2                                | 00000010 <sub>B</sub> |                       |
| 000062 <sub>H</sub>                              | SDR2            | Serial shift data regis                        | ter ch2                             | R/W    |                                               | XXXXXXXXB             |                       |
| 000063 <sub>H</sub>                              |                 |                                                | Prohibite                           | d area |                                               |                       |                       |
| 000064 <sub>H</sub>                              | SMCS3           | Serial mode control s                          | tatus register                      | R/W    |                                               | XXXX0000 <sub>B</sub> |                       |
| 000065 <sub>H</sub>                              | 310033          | ch3                                            | -                                   | R/W    | Serial I/O ch3                                | 00000010 <sub>B</sub> |                       |
| 000066 <sub>H</sub>                              | SDR3            | Serial shift data regis                        | ter ch3                             | R/W    |                                               | XXXXXXXAB             |                       |
| 000067 <sub>H</sub>                              |                 |                                                | Prohibite                           | d area |                                               |                       |                       |
| 000068 <sub>H</sub>                              | FLC1            | Display control regist                         | er 1                                | W      |                                               | XXXXXX00 <sub>B</sub> |                       |
| 000069 <sub>H</sub>                              | FLC2            | Display control regist                         | er 2                                | W      |                                               | 00000000 <sub>B</sub> |                       |
| 00006A <sub>H</sub>                              | FLDG            | Digit setting register                         |                                     | W      | FL control circuit                            | 00000000 <sub>B</sub> |                       |
| 00006B <sub>H</sub>                              | FLDC            | Digit count register                           |                                     | W      |                                               | 00000000 <sub>B</sub> |                       |
| 00006C <sub>H</sub>                              |                 |                                                | Prohibite                           | d area |                                               |                       |                       |
| 00006D                                           | FLST            | _                                              | Status register/establishment       |        |                                               | FL control circuit    | XX1XXX00 <sub>B</sub> |
| 00006D <sub>H</sub>                              | FLOI            | register                                       |                                     | W      |                                               | 00XXXXXX <sub>B</sub> |                       |
| 00006E <sub>H</sub>                              |                 |                                                | Prohibite                           | d area |                                               |                       |                       |
| 00006F <sub>H</sub>                              | ROMM            | ROM mirroring functi<br>register               | on selection                        | W      | ROM mirroring<br>function selection<br>module | XXXXXXX1 <sub>B</sub> |                       |
| 000070 <sub>H</sub><br>to<br>000077 <sub>H</sub> | SEGD0 to 7      | Segment dimmer set                             | ting register                       | W      |                                               | XXXXXXXX              |                       |
| 000078 <sub>H</sub>                              | FLPD0           |                                                | FIP36 to 43                         | W      | FL control circuit                            | 00000000 <sub>B</sub> |                       |
| 000079 <sub>H</sub>                              | FLPD1           | Port register                                  | FIP44 to 51                         | W      |                                               | 00000000 <sub>B</sub> |                       |
| 00007A <sub>H</sub>                              | FLPD2           |                                                | FIP52 to 59                         | W      |                                               | 00000000 <sub>B</sub> |                       |
| 00007B <sub>H</sub><br>to<br>00009D <sub>H</sub> | Prohibited area |                                                |                                     |        |                                               |                       |                       |
| 00009E <sub>H</sub>                              | PACSR           | Program address det status register            | ection control                      | R/W    | Address match detection circuit               | 00000000 <sub>B</sub> |                       |
| 00009F <sub>H</sub>                              | DIRR            | Delayed interrupt cau<br>generation/release re |                                     | R/W    | Delayed interrupt                             | XXXXXXX0 <sub>B</sub> |                       |
| 0000A0 <sub>H</sub>                              | LPMCR           | Low power consumption control register         | tion mode                           | R/W    | Low power<br>consumption                      | 00011000 <sub>B</sub> |                       |
| 0000A1 <sub>H</sub>                              | CKSCR           | Clock selection regis                          | ter                                 | R/W    | control circuit                               | 11111100 <sub>B</sub> |                       |

| Address                                          | Abbreviation    | Register                                       | Read/write | Resource name           | Initial value         |  |  |  |
|--------------------------------------------------|-----------------|------------------------------------------------|------------|-------------------------|-----------------------|--|--|--|
| 0000A2 <sub>H</sub><br>to<br>0000A7 <sub>H</sub> | Prohibited area |                                                |            |                         |                       |  |  |  |
| 0000A8 <sub>H</sub>                              | WDTC            | Watchdog timer control register                | R/W        | Watchdog timer          | XXXXX111 <sub>B</sub> |  |  |  |
| 0000A9 <sub>H</sub>                              | TBTC            | Timebase timer control register                | R/W        | Timebase timer          | 1XX00100 <sub>B</sub> |  |  |  |
| 0000AA <sub>H</sub><br>to<br>0000AD <sub>H</sub> |                 | Prohibite                                      | d area     |                         |                       |  |  |  |
| 0000AE <sub>H</sub>                              | FMCS            | Flash memory control status<br>register        | R/W        | 1M-bit flash<br>memory  | 00000000 <sub>B</sub> |  |  |  |
| 0000AF <sub>H</sub>                              | TMCS            | Watch clock output control register            | R/W        | Watch clock<br>division | XXXXX000 <sub>B</sub> |  |  |  |
| 0000В0 <sub>Н</sub>                              | ICR00           | Interrupt control register 00<br>(for writing) | W, R/W     |                         | 00000111 <sub>B</sub> |  |  |  |
| 0000B0H                                          | ICKUU           | Interrupt control register 00<br>(for reading) | R, R/W     |                         | XX000111 <sub>B</sub> |  |  |  |
| 000081                                           |                 | Interrupt control register 01<br>(for writing) | W, R/W     |                         | 00000111 <sub>B</sub> |  |  |  |
| 0000B1 <sub>H</sub> ICR01                        | ICKUI           | Interrupt control register 01<br>(for reading) | R, R/W     |                         | XX000111 <sub>B</sub> |  |  |  |
| 0000000                                          | 100.00          | Interrupt control register 02<br>(for writing) | W, R/W     |                         | 00000111 <sub>B</sub> |  |  |  |
| 0000B2 <sub>H</sub>                              | ICR02           | Interrupt control register 02<br>(for reading) | R, R/W     |                         | XX000111 <sub>B</sub> |  |  |  |
| 0000000                                          | 100.00          | Interrupt control register 03<br>(for writing) | W, R/W     |                         | 00000111 <sub>B</sub> |  |  |  |
| 0000B3 <sub>H</sub>                              | ICR03           | Interrupt control register 03<br>(for reading) | R, R/W     | Interrupt               | XX000111 <sub>B</sub> |  |  |  |
| 0000004                                          |                 | Interrupt control register 04<br>(for writing) | W, R/W     |                         | 00000111 <sub>B</sub> |  |  |  |
| 0000B4 <sub>H</sub>                              | ICR04           | Interrupt control register 04<br>(for reading) | R, R/W     |                         | XX000111 <sub>B</sub> |  |  |  |
| 0000055                                          |                 | Interrupt control register 05<br>(for writing) | W, R/W     |                         | 00000111 <sub>B</sub> |  |  |  |
| 0000B5 <sub>H</sub> ICR05                        | CUNUI           | Interrupt control register 05<br>(for reading) | R, R/W     |                         | XX000111 <sub>B</sub> |  |  |  |
| 0000000                                          |                 | Interrupt control register 06<br>(for writing) | W, R/W     |                         | 00000111 <sub>B</sub> |  |  |  |
| 0000B6 <sub>H</sub>                              | ICR06           | Interrupt control register 06<br>(for reading) | R, R/W     |                         | XX000111 <sub>B</sub> |  |  |  |

| Address                   | Abbreviation | Register Read/write                            |        | Resource name | Initial value         |  |
|---------------------------|--------------|------------------------------------------------|--------|---------------|-----------------------|--|
| 0000B7 <sub>H</sub>       | ICR07        | Interrupt control register 07<br>(for writing) | W, R/W |               | 00000111 <sub>B</sub> |  |
| 0000B7H                   |              | nterrupt control register 07<br>(for reading)  |        |               | XX000111 <sub>B</sub> |  |
| 000088                    | ICR08        | Interrupt control register 08<br>(for writing) | W, R/W |               | 00000111 <sub>B</sub> |  |
| 0000B8 <sub>H</sub>       | ICKUO        | Interrupt control register 08<br>(for reading) | R, R/W |               | XX000111 <sub>B</sub> |  |
| 0000000                   |              | Interrupt control register 09<br>(for writing) | W, R/W |               | 00000111 <sub>B</sub> |  |
| 0000B9 <sub>H</sub>       | ICR09        | Interrupt control register 09<br>(for reading) | R, R/W |               | XX000111 <sub>B</sub> |  |
| 000000                    |              | Interrupt control register 10<br>(for writing) | W, R/W |               | 00000111 <sub>B</sub> |  |
| 0000BA <sub>H</sub>       | ICR10        | Interrupt control register 10<br>(for reading) | R, R/W |               | XX000111 <sub>B</sub> |  |
| 0000000                   |              | Interrupt control register 11<br>(for writing) | W, R/W | Interrupt     | 00000111 <sub>B</sub> |  |
| 0000BB <sub>H</sub>       | ICR11        | Interrupt control register 11<br>(for reading) | R, R/W | Interrupt     | XX000111 <sub>B</sub> |  |
| 0000BC <sub>H</sub>       | ICR12        | Interrupt control register 12<br>(for writing) | W, R/W |               | 00000111 <sub>B</sub> |  |
| 0000BCH                   |              | Interrupt control register 12<br>(for reading) | R, R/W |               | XX000111 <sub>B</sub> |  |
| 000080                    | ICR13        | Interrupt control register 13<br>(for writing) | W, R/W |               | 00000111 <sub>B</sub> |  |
| 0000BD <sub>H</sub>       | ICK13        | Interrupt control register 13<br>(for reading) | R, R/W |               | XX000111 <sub>B</sub> |  |
| 00000                     | ICR14        | Interrupt control register 14<br>(for writing) | W, R/W |               | 00000111 <sub>B</sub> |  |
| 0000BE <sub>H</sub>       | ICK14        | Interrupt control register 14<br>(for reading) | R, R/W |               | XX000111 <sub>B</sub> |  |
| 000000                    |              | Interrupt control register 15<br>(for writing) | W, R/W |               | 00000111 <sub>B</sub> |  |
| 0000BF <sub>H</sub>       | ICR15        | Interrupt control register 15<br>(for reading) | R, R/W |               | XX000111 <sub>B</sub> |  |
| 0000C0 <sub>H</sub><br>to |              |                                                |        |               |                       |  |
| 0000FF <sub>H</sub>       | Unused area  |                                                |        |               |                       |  |

| Table A-1 | I/O Map | (Continued) |
|-----------|---------|-------------|
|-----------|---------|-------------|

#### **APPENDIX A I/O Map**

#### Table A-1 I/O Map (Continued)

| Address                                          | Abbreviation  | Register                                    | Read/write | Resource name      | Initial value         |  |  |  |
|--------------------------------------------------|---------------|---------------------------------------------|------------|--------------------|-----------------------|--|--|--|
| 000100 <sub>H</sub><br>to<br># <sub>H</sub>      |               | RAM area                                    |            |                    |                       |  |  |  |
| 001100 <sub>H</sub><br>to<br>0011FF <sub>H</sub> | FL000 to 255  | Display data RAM                            | R/W        | FL control circuit | XXXXXXXX <sub>B</sub> |  |  |  |
| 001200 <sub>H</sub><br>to<br>001FEF <sub>H</sub> | Reserved area |                                             |            |                    |                       |  |  |  |
| 001FF0 <sub>H</sub>                              |               | Program address detection register (lower)  | R/W        |                    | XXXXXXXX <sub>B</sub> |  |  |  |
| 001FF1 <sub>H</sub>                              | PADR0         | Program address detection register (middle) | R/W        |                    | XXXXXXXX <sub>B</sub> |  |  |  |
| 001FF2 <sub>H</sub>                              |               | Program address detection register (upper)  | R/W        | Address match      | XXXXXXXXB             |  |  |  |
| 001FF3 <sub>H</sub>                              |               | Program address detection register (lower)  | R/W        | detection function | XXXXXXXX <sub>B</sub> |  |  |  |
| 001FF4 <sub>H</sub>                              | PADR1         | Program address detection register (middle) | R/W        |                    | XXXXXXXX <sub>B</sub> |  |  |  |
| 001FF5 <sub>H</sub>                              |               | Program address detection register (upper)  | R/W        |                    | XXXXXXXXB             |  |  |  |
| 001FF6 <sub>H</sub><br>to<br>001FFF <sub>H</sub> | Unused area   |                                             |            |                    |                       |  |  |  |

#### O Meaning of abbreviations used for reading and writing

R/W: Read/write enabled

- R: Read only
- W: Write only

#### O Explanation of initial values

- 0: The initial value is 0.
- 1: The initial value is 1.
- X: The initial value is undefined.

### **APPENDIX B** Instructions

## Appendix B describes the instructions used by the $F^2MC-16LX$ .

- B.1 "Instruction Types"
- B.2 "Addressing"
- B.3 "Direct Addressing"
- B.4 "Indirect Addressing"
- B.5 "Execution Cycle Count"
- B.6 "Effective Address Field"
- B.7 "How to Read the Instruction List"
- B.8 "F<sup>2</sup>MC-16LX Instruction List"
- B.9 "Instruction Map"

## **B.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^2MC-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

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

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

#### **APPENDIX B Instructions**

#### Effective Address Field

Table B.2-1 "Effective Address Field" lists the address formats specified by the effective address field.

| Code                                         | R                                                                                                                                                                                                                                                                                                     | Representation |                                              | Address format                                                                                                         | Default<br>bank          |
|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------|--------------------------|
| 00<br>01<br>02<br>03<br>04<br>05<br>06<br>07 | R0         RW0         RL0           R1         RW1         (RL0)           R2         RW2         RL1           R3         RW3         (RL1)           R4         RW4         RL2           R5         RW5         (RL2)           R6         RW6         RL3           R7         RW7         (RL3) |                | (RL0)<br>RL1<br>(RL1)<br>RL2<br>(RL2)<br>RL3 | Register direct: Individual parts correspond to the byte, word, and long word types in order from the left.            | None                     |
| 08<br>09<br>0A<br>0B                         | @RW0<br>@RW1<br>@RW2<br>@RW3                                                                                                                                                                                                                                                                          |                |                                              | Register indirect                                                                                                      | DTB<br>DTB<br>ADB<br>SPB |
| 0C<br>0D<br>0E<br>0F                         | @RW0+<br>@RW1+<br>@RW2+<br>@RW3+                                                                                                                                                                                                                                                                      |                |                                              | Register indirect with post increment                                                                                  | DTB<br>DTB<br>ADB<br>SPB |
| 10<br>11<br>12<br>13                         | @RW0+disp8<br>@RW1+disp8<br>@RW2+disp8<br>@RW3+disp8                                                                                                                                                                                                                                                  |                |                                              | Register indirect with 8-bit displacement                                                                              | DTB<br>DTB<br>ADB<br>SPB |
| 14<br>15<br>16<br>17                         | @RW4+disp8<br>@RW5+disp8<br>@RW6+disp8<br>@RW7+disp8                                                                                                                                                                                                                                                  |                |                                              | Register indirect with 8-bit displacement                                                                              | DTB<br>DTB<br>ADB<br>SPB |
| 18<br>19<br>1A<br>1B                         | @RW0+disp16<br>@RW1+disp16<br>@RW2+disp16<br>@RW3+disp16                                                                                                                                                                                                                                              |                |                                              | Register indirect with 16-bit<br>displacement                                                                          | DTB<br>DTB<br>ADB<br>SPB |
| 1C<br>1D<br>1E<br>1F                         | @RW0+RW7<br>@RW1+RW7<br>@PC+disp16<br>addr16                                                                                                                                                                                                                                                          |                |                                              | Register indirect with index<br>Register indirect with index<br>PC indirect with 16-bit displacement<br>Direct address | DTB<br>DTB<br>PCB<br>DTB |

Table B.2-1 Effective Address Field

### **B.3 Direct Addressing**

An operand value, register, or address is specified explicitly in direct addressing mode.

#### Direct Addressing

#### O Immediate addressing (#imm)

Specify an operand value explicitly (#imm4/ #imm8/ #imm16/ #imm32).

#### Figure B.3-1 Example of immediate addressing (#imm)

| MOVW A, #01212H (This instruction stores the operand value in A.) |   |                                                 |  |  |  |
|-------------------------------------------------------------------|---|-------------------------------------------------|--|--|--|
| Before execution                                                  | А | 22334455                                        |  |  |  |
| After execution                                                   | А | 44551212 (Some instructions transfer AL to AH.) |  |  |  |

#### **O** Register direct addressing

Specify a register explicitly as an operand. Table B.3-1 "Direct Addressing Registers" lists the registers that can be specified. Figure B.3-2 "Example of Register Direct Addressing" shows an example of register direct addressing.

#### Table B.3-1 Direct Addressing Registers

| General-purpose | Byte        | R0, R1, R2, R3, R4, R5, R6, R7            |
|-----------------|-------------|-------------------------------------------|
| register        | Word        | RW0, RW1, RW2, RW3, RW4, R5W,<br>RW6, RW7 |
|                 | Long word   | RL0, RL1, RL2, RL3                        |
| Special-purpose | Accumulator | A, AL                                     |
| register        | Pointer     | SP <sup>*1</sup>                          |
|                 | Bank        | PCB, DTB, USB, SSB, ADB                   |
|                 | Page        | DPR                                       |
|                 | Control     | PS, CCR, RP, ILM                          |

\*1: 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.

| 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 <u>34</u> |  |  |

#### Figure B.3-2 Example of Register Direct Addressing

#### O Direct branch addressing (addr16)

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



| JMP 3B20H (This instruc<br>in a bank.) | tion causes an un | conditional b | ranch by di                   | irect branch a    | addressing |
|----------------------------------------|-------------------|---------------|-------------------------------|-------------------|------------|
| Before execution                       | PC 3C20           | PCB 4 F       |                               | Memory space      |            |
|                                        |                   |               | 4F3C22H<br>4F3C21H<br>4F3C20H | 3 B<br>2 0<br>6 2 | JMP 3B20F  |
| After execution                        | PC 3 B 2 0        | PCB 4 F       | 4F3B20H                       | Next instruction  |            |

#### O 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.

| JMPP 333B20H (This instruction causes an unconditional branch by direct branch 24-bit addressing.) |         |         |                                          |                      |      |         |
|----------------------------------------------------------------------------------------------------|---------|---------|------------------------------------------|----------------------|------|---------|
| 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 3B20 | PCB 33  | 333B20H                                  | Next instruction     |      |         |

#### ○ I/O direct addressing (io)

Specify an 8-bit offset explicitly for the memory address in an operand. The I/O address space in the physical address space from 000000H to 0000FFH is accessed regardless of the data bank register (DTB) and direct page register (DPR). A bank select prefix for bank addressing is invalid if specified before an instruction using I/O direct addressing.

Figure B.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                                                                          | А | 07162534  | Men                | nory space |
| After execution                                                                           | A | 2534 FFEE | 0000C1H<br>0000C0H | FF<br>EE   |

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



#### Figure B.3-6 Example of Abbreviated Direct Addressing (dir)

#### O 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.

#### Figure B.3-7 Example of Direct Addressing (addr16)

| BRA 3B20H (This instruc | tion causes an unconditi | ional relative branch.)                             |
|-------------------------|--------------------------|-----------------------------------------------------|
| Before execution        | PC 3C20 PCB4F            | Memory space                                        |
|                         |                          | 4F3C22H F F<br>4F3C21H F E<br>4F3C20H 6 0 BRA 3B20H |
| After execution         | PC 3 B 2 0 PCB 4 F       | 4F3B20H                                             |

#### ○ I/O direct bit addressing (io:bp)

Specify bits in physical addresses 000000H to 0000FFH 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).

| Figure B.3-8 | Example of | I/O Direct Bit | Addressing | (io:bp) |
|--------------|------------|----------------|------------|---------|
|--------------|------------|----------------|------------|---------|

| SETB I:0C1H: (This instruct | ction sets bits by I/O direct bit addressing.)<br>Memory space |
|-----------------------------|----------------------------------------------------------------|
| Before execution            | 0000C1H 0 0                                                    |
| After execution             | 0000C1H 0 1                                                    |

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

Figure B.3-9 Example of Abbreviated Direct Bit Addressing (dir:bp)

| SETB S:10H:0 (This instruction sets bits by abbreviated direct bit addressing.) |        |        |                             |
|---------------------------------------------------------------------------------|--------|--------|-----------------------------|
| Before execution                                                                | DTB 55 | DPR 66 | Memory space<br>556610H 0 0 |
| After execution                                                                 | DTB 55 | DPR 66 | Memory space<br>556610H 0 1 |

#### O 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 B.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 |  |

#### ○ 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.





#### Table B.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    | XXFFF8 <sub>H</sub> | 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.

#### Note:

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 B.3-2 "CALLV Vector List").

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

Figure B.4-1 Example of Register Indirect Addressing (@RWj j = 0 to 3)

| MOVW A, @RW1 (This instr | uction reads data by register inc | direct addressing and stores it in A.) |
|--------------------------|-----------------------------------|----------------------------------------|
| Before execution         | A 07162534                        | Memory space                           |
|                          | RW1 D 3 0 F DTB 7 8               | 78D310H FF<br>78D30FH EE               |
| After execution          | A 2534 FFEE                       |                                        |
|                          | RW1 D30F DTB 78                   |                                        |

#### $\bigcirc$ 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.



## Figure B.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 generalpurpose 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.





#### O 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 B.4-4 Example of Long Register Indirect Addressing with Offset (@RLi + disp8 i = 0 to 3)



#### O 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 B.4-5 Example of Program Counter Indirect Addressing with Offset (@PC + disp16)



#### O 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 general-purpose register RW7. Address bits 16 to 23 are indicated by the data bank register (DTB).

#### Figure B.4-6 Example of Register Indirect Addressing with Base Index (@RW0 + RW7, @RW1 + RW7)



#### **O** 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 B.4-7 Example of Program Counter Relative Branch Addressing (rel)

| BRA | 3B20H (This instructi | ion causes an unconditional r | elative branch.)                                    |
|-----|-----------------------|-------------------------------|-----------------------------------------------------|
|     | Before execution      | PC 3C20 PCB 4F                | Memory space                                        |
|     |                       |                               | 4F3C22H F F<br>4F3C21H F E<br>4F3C20H 6 0 BRA 3B20H |
|     | After execution       | PC 3B20 PCB4F                 | 4F3B20H Next instruction                            |

#### O Register list (rlst)

Specify a register to be pushed onto or popped from a stack.

Figure B.4-8 Configuration of the Register List





Figure B.4-9 Example of Register List (rlst)

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





#### O 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 B.4-11 Example of Accumulator Indirect Branch Addressing (@A)



#### O Indirect specification branch addressing (@ear)

The address of the branch destination is the word data at the address indicated by ear.

#### Figure B.4-12 Example of Indirect Specification Branch Addressing (@ear)



#### O Indirect specification branch addressing (@eam)

The address of the branch destination is the word data at the address indicated by eam.

#### Figure B.4-13 Example of Indirect Specification Branch Addressing (@eam)

| IN ID O DIAKO (This is struction |                                |                                      |
|----------------------------------|--------------------------------|--------------------------------------|
| JMP @RW0 (This instruction       | i causes an unconditional bran | ch by register indirect addressing.) |
| Before execution                 | n PC 3C20 PCB4F                | Memory space                         |
|                                  | PW0 3 B 2 0                    | 4F3C21H 00                           |
|                                  |                                |                                      |
|                                  |                                | 4F3C20H 73 JMP @RW0                  |
|                                  |                                |                                      |
| After execution                  | PC 3B20 PCB 4F                 | 4F3B20H Next instruction             |
|                                  |                                |                                      |
|                                  | PW0 3 B 2 0                    |                                      |

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

#### ■ Calculating the Execution Cycle Count

Table B.5-1 "Execution Cycle Counts in Each Addressing Mode" lists execution cycle counts and Table B.5-2 "Cycle Count Correction Values for Counting Execution Cycles" and Table B.5-3 "Cycle Count Correction Values for Counting Instruction Fetch Cycles" summarize correction value data.

|                      |                                              | (a) <sup>(*1)</sup>                              | Register access count in each addressing mode |  |  |  |  |  |
|----------------------|----------------------------------------------|--------------------------------------------------|-----------------------------------------------|--|--|--|--|--|
| Code                 | Operand                                      | Execution cycle count in<br>each addressing mode |                                               |  |  |  |  |  |
| 00<br> <br>07        | Ri<br>Rwi<br>RLi                             | See the instruction list.                        | See the instruction list.                     |  |  |  |  |  |
| 08<br> <br>0B        | @RWj                                         | 2                                                | 1                                             |  |  |  |  |  |
| 0C<br> <br>0F        | @RWj+                                        | 4                                                | 2                                             |  |  |  |  |  |
| 10<br> <br>17        | @RWi+disp8                                   | 2                                                | 1                                             |  |  |  |  |  |
| 18<br> <br>1B        | @RWi+disp16                                  | 2                                                | 1                                             |  |  |  |  |  |
| 1C<br>1D<br>1E<br>1F | @RW0+RW7<br>@RW1+RW7<br>@PC+disp16<br>addr16 | 4<br>4<br>2<br>1                                 | 2<br>2<br>0<br>0                              |  |  |  |  |  |

 Table B.5-1 Execution Cycle Counts in Each Addressing Mode

\*1: (a) is used for ~ (cycle count) and B (correction value) in B.8 "F<sup>2</sup>MC-16LX Instruction List".

|                                          | (b) b          | yte <sup>(*1)</sup> | (c) wo         | ord <sup>(*1)</sup> | (d) long <sup>(*1)</sup> |                 |  |
|------------------------------------------|----------------|---------------------|----------------|---------------------|--------------------------|-----------------|--|
| Operand                                  | 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           |                | +8                  | 4                        |                 |  |
| External data bus<br>8-bits              | +1             | 1                   | +4             | 2                   | +8                       | 4               |  |

 Table B.5-2 Cycle Count Correction Values for Counting Execution Cycles

\*1: (b), (c), and (d) are used for ~ (cycle count) and B (correction value) in B.8 "F<sup>2</sup>MC-16LX Instruction List".

#### 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 B.5-3 | Cycle Count C | <b>Correction Values</b> | for Counting I | nstruction Fetch Cycles |
|-------------|---------------|--------------------------|----------------|-------------------------|
|-------------|---------------|--------------------------|----------------|-------------------------|

| Instruction               | Byte boundary | Word<br>boundary |
|---------------------------|---------------|------------------|
| Internal memory           | -             | +2               |
| External data bus 16-bits | -             | +3               |
| External data bus 8-bits  | +3            | -                |

#### 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.
- Actually, instruction execution is not delayed by every instruction fetch. Therefore, use the correction values to calculate the worst case.

## **B.6 Effective Address Field**

#### Table B.6-1 "Effective Address Field" shows the effective address field.

#### Effective Address Field

| Code                                         | Representation                                                                                                                                                                                                                                                                                        |  |   | Address format                                                                                                         | Byte count of<br>extended<br>address part<br>(*1) |
|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|---|------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|
| 00<br>01<br>02<br>03<br>04<br>05<br>06<br>07 | R0         RW0         RL0           R1         RW1         (RL0)           R2         RW2         RL1           R3         RW3         (RL1)           R4         RW4         RL2           R5         RW5         (RL2)           R6         RW6         RL3           R7         RW7         (RL3) |  |   | Register direct: Individual parts<br>correspond to the byte, word, and<br>long word types in order from the<br>left.   | -                                                 |
| 08<br>09<br>0A<br>0B                         | @RW0<br>@RW1<br>@RW2<br>@RW3                                                                                                                                                                                                                                                                          |  | 0 |                                                                                                                        |                                                   |
| 0C<br>0D<br>0E<br>0F                         | @RW0+<br>@RW1+<br>@RW2+<br>@RW3+                                                                                                                                                                                                                                                                      |  |   | Register indirect with post increment                                                                                  | 0                                                 |
| 10<br>11<br>12<br>13<br>14<br>15<br>16<br>17 | <ul> <li>@RW0+disp8</li> <li>@RW1+disp8</li> <li>@RW2+disp8</li> <li>@RW3+disp8</li> <li>@RW4+disp8</li> <li>@RW5+disp8</li> <li>@RW6+disp8</li> <li>@RW7+disp8</li> </ul>                                                                                                                            |  |   | Register indirect with 8-bit<br>displacement                                                                           | 1                                                 |
| 18<br>19<br>1A<br>1B                         | @RW0+disp16<br>@RW1+disp16<br>@RW2+disp16<br>@RW3+disp16                                                                                                                                                                                                                                              |  |   | Register indirect with 16-bit<br>displacement                                                                          | 2                                                 |
| 1C<br>1D<br>1E<br>1F                         | @RW0+RW7<br>@RW1+RW7<br>@PC+disp16<br>addr16                                                                                                                                                                                                                                                          |  |   | Register indirect with index<br>Register indirect with index<br>PC indirect with 16-bit displacement<br>Direct address | 0<br>0<br>2<br>2                                  |

Table B.6-1 Effective Address Field

\*1: Each byte count of the extended address part applies to + in the # (byte count) column in B.8 "F<sup>2</sup>MC-16LX Instruction List".

## **B.7** How to Read the Instruction List

Table B.7-1 "Description of Items in the Instruction List" describes the items used in the F2MC-16LX Instruction List, and Table B.7-2 "Explanation on Symbols in the Instruction List" describes the symbols used in the same list.

Description of instruction presentation items and symbols

| ltem      | 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 B.2-1 "Effective Address Field" 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.                                                          |
| В         | 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        | Indicates the special operation for bits 15 to 08 of the accumulator.<br>Z: Transfers 0.<br>X: Transfers after sign extension.<br>-: No transfer                                                                                            |
| АН        | Indicates the special operation for the 16 high-order bits of the<br>accumulator.<br>*: Transfers from AL to AH.<br>-: No transfer<br>Z: Transfers 00 to AH.<br>X: Transfers 00H or FFH to AH after AL sign extension.                      |

Table B.7-1 Description of Items in the Instruction List

| Item | Description                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| I    |                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |
| S    | Each indicates the state of each flag: 1 (interrupt enable) S (stack) T                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |
| Т    | Each indicates the state of each flag: I (interrupt enable), S (stack), T (sticky bit), N (negative), Z (zero), V (overflow), C (carry).                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |
| N    | <ul><li>*: Changes upon instruction execution.</li><li>-: No change</li></ul>                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |
| Z    | Z: Set upon instruction execution.<br>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> <li>Note: Cannot be used for an address that has different meanings between read and write operations.</li> </ul> </li> </ul> |  |  |  |  |  |  |  |

Table B.7-1 Description of Items in the Instruction List (Continued)

#### Table B.7-2 Explanation on Symbols in the Instruction List

| Symbol   | Explanation                                                                                                                                                                        |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A        | The bit length used varies depending on the 32-bit accumulator<br>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<br>AL | 16 high-order bits of A<br>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                                                                                                                                                       |
| Ri       | R0, R1, R2, R3, R4, R5, R6, R7                                                                                                                                                     |

| Symbol                                           | Explanation                                                                                                                                                                                                  |
|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RWi                                              | RW0, RW1, RW2, RW3, RW4, RW5, RW6, RW7                                                                                                                                                                       |
| RWj                                              | RW0, RW1, RW2, RW3                                                                                                                                                                                           |
| RLi                                              | RL0, RL1, RL2, RL3                                                                                                                                                                                           |
| dir                                              | Abbreviated direct addressing                                                                                                                                                                                |
| addr16<br>addr24<br>ad24 0-15<br>ad24 16-23      | Direct addressing<br>Physical direct addressing<br>Bits 0 to 15 of addr24<br>Bits 16 to 23 of addr24                                                                                                         |
| io                                               | I/O area (000000H to 0000FFH)                                                                                                                                                                                |
| #imm4<br>#imm8<br>#imm16<br>#imm32<br>ext (imm8) | <ul> <li>4-bit immediate data</li> <li>8-bit immediate data</li> <li>16-bit immediate data</li> <li>32-bit immediate data</li> <li>16-bit data obtained by sign extension of 8-bit immediate data</li> </ul> |
| disp8<br>disp16                                  | 8-bit displacement<br>16-bit displacement                                                                                                                                                                    |
| bp                                               | Bit offset                                                                                                                                                                                                   |
| vct4<br>vct8                                     | Vector number (0 to 15)<br>Vector number (0 to 255)                                                                                                                                                          |
| ( ) b                                            | Bit address                                                                                                                                                                                                  |
| rel                                              | PC relative branch                                                                                                                                                                                           |
| ear<br>eam                                       | Effective addressing (code 00 to 07)<br>Effective addressing (code 08 to 1F)                                                                                                                                 |
| rlst                                             | Register list                                                                                                                                                                                                |

#### Table B.7-2 Explanation on Symbols in the Instruction List (Continued)

## B.8 F<sup>2</sup>MC-16LX Instruction List

# Table B.8-1 "41 Transfer Instructions (byte)" to Table B.9-19 "MOVW ea, Rwi Instruction (first byte = 7DH)" list the instructions used by the $F^2MC-16LX$ .

#### ■ F<sup>2</sup>MC-16LX Instruction List

| Table B.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<br>MOV<br>MOV<br>MOV<br>MOV<br>MOV<br>MOV<br>MOV               | A,dir<br>A,addr16<br>A,Ri<br>A,ear<br>A,eam<br>A,io<br>A,#imm8<br>A,@A<br>A,@A<br>A,@RLi+disp8<br>A,#imm4                                                                                                      | 2<br>3<br>1<br>2<br>2+<br>2<br>2<br>3<br>1                                  | 3<br>4<br>2<br>3+(a)<br>3<br>2<br>3<br>10<br>1                                                | 0<br>0<br>1<br>1<br>0<br>0<br>0<br>2<br>0                                                   | (b)<br>(b)<br>0<br>(b)<br>(b)<br>(b)<br>0<br>(b)<br>(b)<br>0       | byte (A) < (dir)<br>byte (A) < (addr16)<br>byte (A) < (Ri)<br>byte (A) < (ear)<br>byte (A) < (earn)<br>byte (A) < (io)<br>byte (A) < (io)<br>byte (A) < (inm8<br>byte (A) < ((A))<br>byte (A) < ((RLi)+disp8)<br>byte (A) < imm4                                                                                                                                                                                                                 | Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z | * * * * * * - * *                                                                 |                                                                    |                                                                         | *<br>*<br>*<br>*<br>*                                                                       | * * * * * * * *           |                           |   |             |             |
| MOVX<br>MOVX<br>MOVX<br>MOVX<br>MOVX<br>MOVX<br>MOVX<br>MOVX       | A,dir<br>A,addr16<br>A,Ri<br>A,ear<br>A,eam<br>A,io<br>A,#imm8<br>A,@A<br>A,@RWi+disp8<br>A,@RLi+disp8                                                                                                         | 2<br>3<br>2<br>2<br>+<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>3               | 3<br>4<br>2<br>3+(a)<br>3<br>2<br>3<br>5<br>10                                                | 0<br>0<br>1<br>1<br>0<br>0<br>0<br>0<br>1<br>2                                              | (b)<br>(b)<br>0<br>(b)<br>(b)<br>(b)<br>(b)<br>(b)                 | byte (A) < (dir)<br>byte (A) < (addr16)<br>byte (A) < (Ri)<br>byte (A) < (ear)<br>byte (A) < (earm)<br>byte (A) < (io)<br>byte (A) < (io)<br>byte (A) < (i(A))<br>byte (A) < ((A))<br>byte (A) < ((RWi)+disp8)<br>byte (A) < ((RLi)+disp8                                                                                                                                                                                                        | × × × × × × × × × × × × × × × × × × ×          | * * * * * * - * *                                                                 |                                                                    |                                                                         |                                                                                             | * * * * * * * *           | * * * * * * * * *         |   |             |             |
| MOV<br>MOV<br>MOV<br>MOV<br>MOV<br>MOV<br>MOV<br>MOV<br>MOV<br>MOV | dir,A<br>addr16,A<br>Ri,A<br>ear,A<br>eam,A<br>io,A<br>@RLi+disp8,A<br>Ri,ear<br>Ri,ear<br>Ri,ear<br>Ri,ear<br>Ri,#imm8<br>io,#imm8<br>dir,#imm8<br>ear,#imm8<br>ear,#imm8<br>eam,#imm8<br>@AL,AH/ MOV<br>@A,T | 2<br>3<br>1<br>2<br>2+<br>2<br>2+<br>2<br>2+<br>2<br>3<br>3<br>3<br>3+<br>2 | 3<br>4<br>2<br>3+(a)<br>3<br>10<br>3<br>4+(a)<br>4<br>5+(a)<br>2<br>5<br>5<br>2<br>4+(a)<br>3 | 0<br>0<br>1<br>1<br>0<br>2<br>2<br>1<br>2<br>1<br>1<br>2<br>1<br>1<br>0<br>0<br>1<br>0<br>0 | (b)<br>(b)<br>(b)<br>(b)<br>(b)<br>(b)<br>(b)<br>(b)<br>(b)<br>(b) | byte (dir) < (A)<br>byte (addr16) < (A)<br>byte (Ri) < (A)<br>byte (ear) < (A)<br>byte (ear) < (A)<br>byte (in) < (A)<br>byte (Ri) < (ear)<br>byte (Ri) < (ear)<br>byte (ear) < (Ri)<br>byte (ear) < (Ri)<br>byte (ear) < imm8<br>byte (dir) < imm8<br>byte (ear) < imm8 |                                                | -<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>- | -<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>- | -<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>- | -<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>- | * * * * * * * * * * * - * | * * * * * * * * * * * - * |   |             |             |
| XCH<br>XCH<br>XCH<br>XCH                                           | A,ear<br>A,eam<br>Ri,ear<br>Ri,eam                                                                                                                                                                             | 2<br>2+<br>2<br>2+                                                          | 4<br>5+(a)<br>7<br>9+(a)                                                                      | 2<br>0<br>4<br>2                                                                            | 0<br>2×(b)<br>0<br>2×(b)                                           | byte (A) <> (ear)<br>byte (A) <> (ear)<br>byte (Ri) <> (ear)<br>byte (Ri) <> (ear)                                                                                                                                                                                                                                                                                                                                                               | Z<br>Z<br>-                                    | -<br>-<br>-                                                                       |                                                                    | -<br>-<br>-                                                             | -<br>-<br>-<br>-                                                                            | -<br>-<br>-               |                           |   | -<br>-<br>- | -<br>-<br>- |

#### Note:

| Mnemonic                                                     |                                                                                                                                                                                                                                                     | #                                                                                                   | ~                                                        | RG                                                                 | В                                                                                                                            | Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | L | Α                                                                       | I | s                                                                       | т           | Ν                               | z                           | v           | С | R<br>M      |
|--------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|----------------------------------------------------------|--------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|-------------------------------------------------------------------------|---|-------------------------------------------------------------------------|-------------|---------------------------------|-----------------------------|-------------|---|-------------|
|                                                              |                                                                                                                                                                                                                                                     |                                                                                                     |                                                          |                                                                    |                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | н | н                                                                       |   |                                                                         |             |                                 |                             |             |   | W           |
| MOVW<br>MOVW<br>MOVW<br>MOVW<br>MOVW<br>MOVW<br>MOVW<br>MOVW | A,dir<br>A,addr16<br>A,SP<br>A,RWi<br>A,ear<br>A,eam<br>A,io<br>A,@A<br>A,#imm16<br>A,@RWi+disp8<br>A,@RLi+disp8                                                                                                                                    | 2<br>3<br>1<br>2<br>2+<br>2<br>3<br>2<br>3<br>3                                                     | 3<br>4<br>1<br>2<br>2<br>3+(a)<br>3<br>3<br>2<br>5<br>10 | 0<br>0<br>1<br>1<br>0<br>0<br>0<br>0<br>1<br>2                     | (c)<br>(c)<br>0<br>0<br>(c)<br>(c)<br>(c)<br>(c)<br>(c)<br>(c)<br>(c)                                                        | word (A) < (dir)<br>word (A) < (addr16)<br>word (A) < (SP)<br>word (A) < (RWi)<br>word (A) < (ear)<br>word (A) < (ear)<br>word (A) < (io)<br>word (A) < ((A))<br>word (A) < ((RWi)+disp8)<br>word (A) < ((RLi)+disp8)                                                                                                                                                                                                                                                             |   | * * * * * * - * *                                                       |   |                                                                         |             | * * * * * * * * *               | * * * * * * * * *           |             |   |             |
| MOVW<br>MOVW<br>MOVW<br>MOVW<br>MOVW<br>MOVW<br>MOVW<br>MOVW | dir,A<br>addr16,A<br>SP,A<br>RWi,A<br>ear,A<br>eam,A<br>io,A<br>@ RWi+disp8,A<br>@ RLi+disp8,A<br>@ RLi+disp8,A<br>RWi,ear<br>RWi,ear<br>RWi,ear<br>RWi,ear<br>RWi,ear<br>RWi,ear<br>RWi,aimm16<br>io,#imm16<br>ear,#imm16<br>@ AL,AH/MOVW<br>@ A,T | 2<br>3<br>1<br>1<br>2<br>2+<br>2<br>2<br>3<br>2<br>2+<br>2<br>2+<br>3<br>4<br>4<br>4<br>4<br>4<br>2 | 341223+(a)351034+(a)45+(a)2524+(a)3                      | 0<br>0<br>1<br>1<br>2<br>2<br>1<br>2<br>1<br>1<br>0<br>1<br>0<br>0 | (c)<br>(c)<br>0<br>0<br>(c)<br>(c)<br>(c)<br>(c)<br>(c)<br>0<br>(c)<br>0<br>(c)<br>0<br>(c)<br>0<br>(c)<br>(c)<br>(c)<br>(c) | word (dir) < (A)<br>word (addr16) < (A)<br>word (SP) < (A)<br>word (RWi) < (A)<br>word (ear) < (A)<br>word (ear) < (A)<br>word (interpretain (A)<br>word (interpretain (A)<br>word (interpretain (RWi) < (A)<br>word (RWi) < (ear)<br>word (RWi) < (ear)<br>word (RWi) < (ear)<br>word (ear) < (RWi)<br>word (ear) < (RWi)<br>word (ear) < imm16<br>word (A) < (AH) |   | -<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>- |   | -<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>- |             | * * * * * * * * * * * * - * - * | * * * * * * * * * * * * * * |             |   |             |
| XCHW<br>XCHW<br>XCHW<br>XCHW                                 | A,ear<br>A,eam<br>RWi, ear<br>RWi, eam                                                                                                                                                                                                              | 2<br>2+<br>2<br>2+                                                                                  | 4<br>5+(a)<br>7<br>9+(a)                                 | 2<br>0<br>4<br>2                                                   | 0<br>2 x (c)<br>0<br>2 x (c)                                                                                                 | word (A) <> (ear)<br>word (A) <> (eam)<br>word (RWi) <> (ear)<br>word (RWi) <> (eam)                                                                                                                                                                                                                                                                                                                                                                                              |   | -<br>-<br>-                                                             |   |                                                                         | -<br>-<br>- |                                 |                             | -<br>-<br>- |   |             |
| MOVL<br>MOVL<br>MOVL                                         | A,ear<br>A,eam<br>A,#imm32                                                                                                                                                                                                                          | 2<br>2+<br>5                                                                                        | 4<br>5+(a)<br>3                                          | 2<br>0<br>0                                                        | 0<br>(d)<br>0                                                                                                                | long (A) < (ear)<br>long (A) < (eam)<br>long (A) < imm32                                                                                                                                                                                                                                                                                                                                                                                                                          |   | -<br>-<br>-                                                             | - |                                                                         | -<br>-      | * *                             | *<br>*                      | -<br>-      | - | -<br>-<br>- |
| MOVL<br>MOVL                                                 | ear,A<br>eam,A                                                                                                                                                                                                                                      | 2<br>2+                                                                                             | 4<br>5+(a)                                               | 2<br>0                                                             | 0<br>(d)                                                                                                                     | long (ear1) < (A)<br>long(eam1) < (A)                                                                                                                                                                                                                                                                                                                                                                                                                                             | - | -                                                                       | - | -                                                                       | -           | *                               | *                           | -           | - | -           |

#### Note:

| м                                                                                                                     | Inemonic                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | #                                                                                                                                                                                                                                                                | ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RG                                                                                                                                                                                                                                 | В                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | L<br>H                                                                                      | A<br>H | I | s | т | Ν                               | z                                 | v                               | с                               | R<br>M<br>W |
|-----------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|--------|---|---|---|---------------------------------|-----------------------------------|---------------------------------|---------------------------------|-------------|
| ADD<br>ADD<br>ADD<br>ADD<br>ADD<br>ADD<br>ADDC<br>ADDC<br>ADDC                                                        | A,#imm8<br>A,dir<br>A,ear<br>A,ear<br>ear,A<br>eam,A<br>A<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ea<br>A,ea<br>A,ea<br>A,<br>A,ea<br>A,ea<br>A,<br>A,ea<br>A,ea | 2<br>2<br>2+<br>2<br>2+<br>1<br>2<br>2+<br>1<br>2<br>2+<br>2<br>2+<br>2<br>2+<br>1<br>2<br>2+<br>1<br>2<br>2+<br>1<br>2<br>2+<br>1<br>2<br>2+<br>1<br>2<br>2<br>2+<br>1<br>2<br>2+<br>1<br>2<br>2+<br>1<br>2<br>2+<br>1<br>2<br>2<br>2+<br>1<br>2<br>2<br>2<br>2 | $2 \\ 5 \\ 3 \\ 4+(a) \\ 3 \\ 5+(a) \\ 2 \\ 3 \\ 4+(a) \\ 3 \\ 2 \\ 5 \\ 3 \\ 4+(a) \\ 3 \\ 5+(a) \\ 2 \\ 3 \\ 4+(a) \\ 3 \\ 5+(a) \\ 2 \\ 3 \\ 4+(a) \\ 3 \\ 5+(a) \\ 2 \\ 3 \\ 4+(a) \\ 3 \\ 5+(a) \\ 2 \\ 3 \\ 5+(a) \\ 5+(a$ | 0<br>0<br>1<br>0<br>2<br>0<br>0<br>1<br>0<br>0<br>1<br>0<br>0<br>1<br>0<br>0<br>1<br>0<br>0<br>1<br>0<br>0<br>0<br>1<br>0<br>0<br>0<br>1<br>0<br>0<br>0<br>0<br>1<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | 0<br>(b)<br>0<br>(b)<br>0<br>2x(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>2x(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>2x(b)<br>0<br>0<br>(b)<br>0<br>0<br>2x(b)<br>0<br>0<br>(b)<br>0<br>0<br>2x(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>2x(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>0<br>(b)<br>(b)<br>0<br>(b)<br>(b)<br>(b)<br>(b)<br>(b)<br>(b)<br>(b)<br>(b)<br>(b)<br>(b) | byte (A) < (A) + imm8<br>byte (A) < (A) + (dir)<br>byte (A) < (A) + (ear)<br>byte (A) < (A) + (ear)<br>byte (A) < (A) + (eam)<br>byte (ear) < (ear) + (A)<br>byte (ear) < (AH) + (AL) + (C)<br>byte (A) < (A) + (ear)+ (C)<br>byte (A) < (A) - (ear)<br>byte (A) < (A) - (dir)<br>byte (A) < (A) - (ear)<br>byte (A) < (A) - (A)<br>byte (A) < (A) - (C)<br>byte (A) < (A) - (ear) - (C)<br>byte (A) < (AH) - (AL) - (C)<br>(decimal) | Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z |        |   |   |   | * * * * * * * * * * * * * * * * | * * * * * * * * * * * * * * * * * | * * * * * * * * * * * * * * * * | * * * * * * * * * * * * * * * * |             |
| ADDW<br>ADDW<br>ADDW<br>ADDW<br>ADDW<br>ADDCW<br>ADDCW<br>SUBW<br>SUBW<br>SUBW<br>SUBW<br>SUBW<br>SUBW<br>SUBW<br>SUB | A<br>A,ear<br>A,eam<br>A,#imm16<br>ear,A<br>eam,A<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,ear<br>A,#imm16<br>ear,A<br>eam,A<br>A,ear<br>A,ear                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1<br>2<br>2+<br>3<br>2<br>2+<br>2<br>2+<br>1<br>2<br>2+<br>3<br>2<br>2+<br>2<br>2+<br>2                                                                                                                                                                          | 2 3 4+(a) 2 3 5+(a) 3 4+(a) 2 3 4+(a) 2 3 5+(a) 3 4+(a) 4+(a) 2 3 5+(a) 4+(a) 2 3 5+(a) 3 4+(a) 2 3 5+(a) 5+(a) 3 5+(a) 5+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0<br>1<br>0<br>2<br>0<br>1<br>0<br>0<br>1<br>0<br>0<br>2<br>0<br>1<br>0<br>0                                                                                                                                                       | $\begin{array}{c} 0 \\ 0 \\ (c) \\ 0 \\ 2x(c) \\ 0 \\ (c) \\ 0 \\ (c) \\ 0 \\ 0 \\ 2x(c) \\ 0 \\ (c) \\ 0 \\ (c) \\ 0 \\ (c) \\ 0 \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | word (A) < (AH) + (AL)<br>word (A) < (A) + (ear)<br>word (A) < (A) + (ear)<br>word (A) < (A) + (eam)<br>word (A) < (A) + imm16<br>word (ear) < (ear) + (A)<br>word (a) < (A) + (ear) + (C)<br>word (A) < (A) + (ear) + (C)<br>word (A) < (A) + (ear) + (C)<br>word (A) < (A) - (ear)<br>word (A) < (A) - (ear)<br>word (A) < (A) - (ear)<br>word (A) < (A) - imm16<br>word (ear) < (ear) - (A)<br>word (A) < (A) - (ear) - (C)<br>word (A) < (A) - (eam) - (C)                                                                                                                                                                             |                                                                                             |        |   |   |   | * * * * * * * * * * * * *       | * * * * * * * * * * * * *         | * * * * * * * * * * * * * *     | * * * * * * * * * * * * *       |             |
| ADDL<br>ADDL<br>ADDL<br>SUBL<br>SUBL<br>SUBL                                                                          | A,ear<br>A,eam<br>A,#imm32<br>A,ear<br>A,eam<br>A,#imm32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 2<br>2+<br>5<br>2<br>2+<br>5                                                                                                                                                                                                                                     | 6<br>7+(a)<br>4<br>6<br>7+(a)<br>4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 2<br>0<br>2<br>0<br>0                                                                                                                                                                                                              | 0<br>(d)<br>0<br>(d)<br>0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | long (A) < (A) + (ear)<br>long (A) < (A) + (eam)<br>long (A) < (A) + imm32<br>long (A) < (A) - (ear)<br>long (A) < (A) - (eam)<br>long (A) < (A) - imm32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                             |        |   |   | - | * * * * *                       | * * * * *                         | * * * * *                       | * * * * *                       |             |

Table B.8-3 42 Addition/subtraction Instructions (byte, word, long word)

#### Note:

| N            | Inemonic   | #       | ~          | RG     | В          | Operation                                        | L<br>H | A<br>H | I | S | т | Ν | Z | v | с | R<br>M<br>W |
|--------------|------------|---------|------------|--------|------------|--------------------------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| INC<br>INC   | ear<br>eam | 2<br>2+ | 3<br>5+(a) | 2<br>0 | 0<br>2×(b) | byte (ear) < (ear) + 1<br>byte (eam) < (eam) + 1 | -      | -      | - | - | - | * | * | * | - | -<br>*      |
| DEC<br>DEC   | ear<br>eam | 2<br>2+ | 3<br>5+(a) | 2<br>0 | 0<br>2×(b) | byte (ear) < (ear) - 1<br>byte (eam) < (eam) - 1 | -<br>- | -      | - | - | - | * | * | * | - | -<br>*      |
| INCW<br>INCW | ear<br>eam | 2<br>2+ | 3<br>5+(a) | 2<br>0 | 0<br>2×(c) | word (ear) < (ear) + 1<br>word (eam) < (eam) + 1 | -      | -      | - | - | - | * | * | * | - | -<br>*      |
| DECW<br>DECW | ear<br>eam | 2<br>2+ | 3<br>5+(a) | 2<br>0 | 0<br>2×(c) | word (ear) < (ear) - 1<br>word (eam) < (eam) - 1 | -      | -      | - | - | - | * | * | * | - | -<br>*      |
| INCL<br>INCL | ear<br>eam | 2<br>2+ | 7<br>9+(a) | 4<br>0 | 0<br>2×(d) | long (ear) < (ear) + 1<br>long (eam) < (eam) + 1 | -      | -      | - | - | - | * | * | * | - | -<br>*      |
| DECL<br>DECL | ear<br>eam | 2<br>2+ | 7<br>9+(a) | 4<br>0 | 0<br>2×(d) | long (ear) < (ear) - 1<br>long (eam) < (eam) - 1 | -<br>- | -      | - | - | - | * | * | * | - | -<br>*      |

#### Table B.8-4 12 Increment/decrement Instructions (byte, word, long word)

#### Note:

See Table B.5-1 "Execution Cycle Counts in Each Addressing Mode" and Table B.5-2 "Cycle Count Correction Values for Counting Execution Cycles" for information on (a) to (d) in the table.

 Table B.8-5
 11 Compare Instructions (byte, word, long word)

| N                            | Inemonic                        | #                 | ~                    | RG               | В                  | Operation                                                                    | L<br>H      | A<br>H      | I           | S           | т           | Ν     | Z     | v     | С       | R<br>M<br>W |
|------------------------------|---------------------------------|-------------------|----------------------|------------------|--------------------|------------------------------------------------------------------------------|-------------|-------------|-------------|-------------|-------------|-------|-------|-------|---------|-------------|
| CMP<br>CMP<br>CMP<br>CMP     | A<br>A,ear<br>A,eam<br>A,#imm8  | 1<br>2<br>2+<br>2 | 1<br>2<br>3+(a)<br>2 | 0<br>1<br>0<br>0 | 0<br>0<br>(b)<br>0 | byte (AH) - (AL)<br>byte (A) - (ear)<br>byte (A) - (eam)<br>byte (A) - imm8  | -<br>-<br>- | -<br>-<br>- | -<br>-<br>- | -<br>-<br>- | -<br>-<br>- | * * * | * * * | * * * | * * *   | -<br>-<br>- |
| CMPW<br>CMPW<br>CMPW<br>CMPW | A<br>A,ear<br>A,eam<br>A,#imm16 | 1<br>2<br>2+<br>3 | 1<br>2<br>3+(a)<br>2 | 0<br>1<br>0<br>0 | 0<br>0<br>(c)<br>0 | word (AH) - (AL)<br>word (A) - (ear)<br>word (A) - (eam)<br>word (A) - imm16 | -<br>-<br>- | -<br>-<br>- | -<br>-<br>- | -<br>-<br>- | -<br>-<br>- | * * * | * * * | * * * | * * * * | -<br>-<br>- |
| CMPL<br>CMPL<br>CMPL         | A,ear<br>A,eam<br>A,#imm32      | 2<br>2+<br>5      | 6<br>7+(a)<br>3      | 2<br>0<br>0      | 0<br>(d)<br>0      | long (A) - (ear)<br>long (A) - (eam)<br>long (A) - imm32                     | -<br>-      | -<br>-      | -<br>-      | -<br>-      | -<br>-      | * *   | * * * | * *   | * *     | -<br>-      |

#### Note:

| Mner           | nonic          | #       | ~          | 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        | quotient -> byte (AL) remainder -> byte (AL)<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           | A              | 1       | *8         | 0      | 0        | byte (AH) * byte (AL)> word (A)                                                          | -      | -      | - | - | - | - | - | - | - | -           |
| MULU<br>MULU   | A,ear<br>A,eam | 2<br>2+ | *9<br>*10  | 1<br>0 | 0<br>(b) | byte (A) * byte (ear)> word (A)<br>byte (A) * byte (eam)> word (A)                       | -      | -      | - | - | - | - | - | - | - | -           |
| MULUW          | A              | 1       | *11        | 0      | 0        | word (AH) * word (AL)> Long (A)                                                          | -      | -      | - | - | - | - | - | - | - | -           |
| MULUW<br>MULUW | A,ear<br>A,eam | 2<br>2+ | *12<br>*13 | 1<br>0 | 0<br>(c) | word (A) * word (ear)> Long (A)<br>word (A) * word (eam)> Long (A)                       | -      | -      | - | - | - | - | - | - | - | -           |

Table B.8-6 11 unsigned multiplication/division instructions (word, long word)

\*1: 3: Division by 0 7: Overflow 15: Normal

\*2: 4: Division by 0 8: Overflow 16: Normal

\*3: 6+(a): Division by 0 9+(a): Overflow 19+(a): Normal

\*4: 4: Division by 0 7: Overflow 22: Normal

\*5: 6+(a): Division by 0 8+(a): Overflow 26+(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. 7: Byte (AH) is not 0.

\*9: 4: Byte (ear) is 0. 8: Byte (ear) is not 0.

\*10: 5+(a): Byte (eam) is 0, 9+(a): Byte (eam) is not 0.

\*11: 3: Word(AH) is 0. 11: Word (AH) is not 0.

\*12: 4: Word(ear) is 0. 12: Word (ear) is not 0.

\*13: 5+(a): Word (eam) is 0. 13+(a): Word (eam) is not 0.

#### Note:

| Mne                                | monic                                      | #                                       | ~                                    | RG                         | В                    | Operation                                                                                                                                                                                                       | LH | ΗÞ | I | S           | т | Z | Z | v | С | R<br>M<br>W |
|------------------------------------|--------------------------------------------|-----------------------------------------|--------------------------------------|----------------------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|---|-------------|---|---|---|---|---|-------------|
| DIVU                               | А                                          | 2                                       | *1                                   | 0                          | 0                    | word (AH) / byte (AL)                                                                                                                                                                                           | Z  | -  | - | -           | - | - | - | * | * | -           |
| DIVU                               | A,ear                                      | 2                                       | *2                                   | 1                          | 0                    | quotient> byte (AL) remainder> byte (AH)<br>word (A) / byte (ear)<br>quotient> byte (A) remainder> byte (ear)                                                                                                   | z  | -  | - | -           | - | - | - | * | * | -           |
| DIVU                               | A,eam                                      | 2+                                      | *3                                   | 0                          | *6                   | word (A) / byte (eam)<br>quotient> byte (A) remainder> byte (eam)                                                                                                                                               | Z  | -  | - | -           | - | - | - | * | * | -           |
| DIVUW                              | A,ear                                      | 2                                       | *4                                   | 1                          | 0                    | long (A) / word (ear)                                                                                                                                                                                           | -  | -  | - | -           | - | - | - | * | * | -           |
| DIVUW                              | A,eam                                      | 2+                                      | *5                                   | 0                          | *7                   | quotient> word(A) remainder> word(ear)<br>long (A) / word (eam)<br>quotient> word(A) remainder> word(eam)                                                                                                       | -  | -  | - | -           | - | - | - | * | * | -           |
| MUL<br>MUL<br>MULW<br>MULW<br>MULW | A<br>A,ear<br>A,eam<br>A<br>A,ear<br>A,eam | 2<br>2<br>2+<br>2<br>2<br>2+<br>2<br>2+ | *8<br>*9<br>*10<br>*11<br>*12<br>*13 | 0<br>1<br>0<br>1<br>1<br>0 | 0<br>(b)<br>0<br>(c) | byte (AH) * byte (AL)> word (A)<br>byte (A) * byte (ear)> word (A)<br>byte (A) * byte (ear)> word (A)<br>word (AH) * word (AL)> Long (A)<br>word (A) * word (ear)> Long (A)<br>word (A) * word (earm)> Long (A) |    |    |   | -<br>-<br>- |   |   |   |   |   |             |

#### Table B.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
- \*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

#### Note:

- The execution cycle count found when an overflow occurs in a DIV or DIVW instruction may be a pre-operation 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 B.5-1 "Execution Cycle Counts in Each Addressing Mode" and Table B.5-2 "Cycle Count Correction Values for Counting Execution Cycles" for information on (a) to (d) in the table.

| Mn                                                           | emonic                                                               | #                                            | ~                                                     | RG                                        | В                                         | Operation                                                                                                                                                                                                                                         | L<br>H                | A<br>H           | I                | s                     | т                | N             | z             | v                     | С | R<br>M<br>W           |
|--------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------|-------------------------------------------------------|-------------------------------------------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|------------------|------------------|-----------------------|------------------|---------------|---------------|-----------------------|---|-----------------------|
| AND<br>AND<br>AND<br>AND<br>AND                              | A,#imm8<br>A,ear<br>A,eam<br>ear,A<br>eam,A                          | 2<br>2<br>2+<br>2<br>2+                      | 2<br>3<br>4+(a)<br>3<br>5+(a)                         | 0<br>1<br>0<br>2<br>0                     | 0<br>0<br>(b)<br>0<br>2×(b)               | byte (A) < (A) and imm8<br>byte (A) < (A) and (ear)<br>byte (A) < (A) and (eam)<br>byte (ear) < (ear)and (A)<br>byte (eam) < (eam)and (A)                                                                                                         | -<br>-<br>-<br>-      | -<br>-<br>-<br>- | -<br>-<br>-<br>- | -<br>-<br>-<br>-      | -<br>-<br>-<br>- | * * * *       | * * * *       | R<br>R<br>R<br>R<br>R |   | -<br>-<br>-<br>*      |
| OR<br>OR<br>OR<br>OR<br>OR                                   | A,#imm8<br>A,ear<br>A,eam<br>ear,A<br>eam,A                          | 2<br>2<br>2+<br>2<br>2+                      | 2<br>3<br>4+(a)<br>3<br>5+(a)                         | 0<br>1<br>0<br>2<br>0                     | 0<br>0<br>(b)<br>0<br>2×(b)               | byte (A) < (A) or imm8<br>byte (A) < (A) or (ear)<br>byte (A) < (A) or (eam)<br>byte (ear) < (ear)or (A)<br>byte (eam) < (eam)or (A)                                                                                                              |                       | -<br>-<br>-      |                  |                       | -<br>-<br>-      | * * * *       | * * * *       | R<br>R<br>R<br>R<br>R |   | -<br>-<br>-<br>*      |
| XOR<br>XOR<br>XOR<br>XOR<br>XOR<br>NOT<br>NOT                | A,#imm8<br>A,ear<br>A,eam<br>ear,A<br>eam,A<br>A<br>ear<br>eam       | 2<br>2+<br>2<br>2+<br>1<br>2<br>2+           | 2<br>3<br>4+(a)<br>3<br>5+(a)<br>2<br>3<br>5+(a)      | 0<br>1<br>2<br>0<br>0<br>2<br>0           | 0<br>(b)<br>0<br>2×(b)<br>0<br>2×(b)      | byte (A) < (A) xor imm8<br>byte (A) < (A) xor (ear)<br>byte (A) < (A) xor (ear)<br>byte (ear) < (ear) xor (A)<br>byte (ear) < not (A)<br>byte (A) < not (A)<br>byte (ear) < not (ear)<br>byte (eam) < not (eam)                                   | -<br>-<br>-<br>-<br>- |                  |                  | -<br>-<br>-<br>-<br>- |                  | * * * * * *   | * * * * * *   | R R R R R R R         |   | -<br>-<br>*<br>-<br>* |
| ANDW<br>ANDW<br>ANDW<br>ANDW<br>ANDW<br>ANDW                 | A<br>A,#imm16<br>A,ear<br>A,eam<br>ear,A<br>eam,A                    | 1<br>3<br>2+<br>2+<br>2+                     | 2<br>2<br>3<br>4+(a)<br>3<br>5+(a)                    | 0<br>0<br>1<br>0<br>2<br>0                | 0<br>0<br>(c)<br>0<br>2×(c)               | word (A) < (AH) and (A)<br>word (A) < (A) and imm16<br>word (A) < (A) and (ear)<br>word (A) < (A) and (eam)<br>word (ear) < (ear) and (A)<br>word (eam) < (eam) and (A)                                                                           |                       |                  |                  |                       |                  | * * * * *     | * * * * *     | R R R R R R           |   | -<br>-<br>-<br>*      |
| ORW<br>ORW<br>ORW<br>ORW<br>ORW<br>ORW                       | A<br>A,#imm16<br>A,ear<br>A,eam<br>ear,A<br>eam,A                    | 1<br>3<br>2<br>2+<br>2<br>2+                 | 2<br>2<br>3<br>4+(a)<br>3<br>5+(a)                    | 0<br>0<br>1<br>0<br>2<br>0                | 0<br>0<br>(c)<br>0<br>2×(c)               | word (A) < (AH) or (A)<br>word (A) < (A) or imm16<br>word (A) < (A) or (ear)<br>word (A) < (A) or (eam)<br>word (ear) < (ear) or (A)<br>word (eam) < (eam) or (A)                                                                                 |                       |                  |                  |                       |                  | * * * * *     | * * * * *     | R<br>R<br>R<br>R<br>R |   | -<br>-<br>-<br>*      |
| XORW<br>XORW<br>XORW<br>XORW<br>XORW<br>XORW<br>NOTW<br>NOTW | A<br>A,#imm16<br>A,ear<br>A,eam<br>ear,A<br>eam,A<br>A<br>ear<br>eam | 1<br>3<br>2<br>2+<br>2<br>2+<br>1<br>2<br>2+ | 2<br>2<br>3<br>4+(a)<br>3<br>5+(a)<br>2<br>3<br>5+(a) | 0<br>0<br>1<br>0<br>2<br>0<br>0<br>2<br>0 | 0<br>0<br>(c)<br>0<br>2×(c)<br>0<br>2×(c) | word (A) < (AH) xor (A)<br>word (A) < (A) xor imm16<br>word (A) < (A) xor (ear)<br>word (A) < (A) xor (eam)<br>word (ear) < (ear) xor (A)<br>word (eam) < (eam) xor (A)<br>word (A) < not (A)<br>word (ear) < not (ear)<br>word (eam) < not (eam) |                       |                  |                  |                       |                  | * * * * * * * | * * * * * * * | R R R R R R R R       |   | -<br>-<br>*<br>-<br>* |

Table B.8-8 39 Logic 1 Instructions (byte, word)

#### Note:

 Table B.8-9 Six Logic 2 Instructions (long word)

| Mne          | emonic         | #       | ~          | RG     | В        | Operation                                            | L<br>H | A<br>H | I | S | т | Ν | Z | v      | С | R<br>M<br>W |
|--------------|----------------|---------|------------|--------|----------|------------------------------------------------------|--------|--------|---|---|---|---|---|--------|---|-------------|
| ANDL<br>ANDL | A,ear<br>A,eam | 2<br>2+ | 6<br>7+(a) | 2<br>0 | 0<br>(d) | long (A) < (A) and (ear)<br>long (A) < (A) and (eam) | -      | -      | - |   |   | * | * | R<br>R | - | -           |
| ORL<br>ORL   | A,ear<br>A,eam | 2<br>2+ | 6<br>7+(a) | 2<br>0 | 0<br>(d) | long (A) < (A) or (ear)<br>long (A) < (A) or (eam)   | -      | -      | - | - | - | * | * | R<br>R | - | -           |
| XORL<br>XORL | A,ear<br>A,eam | 2<br>2+ | 6<br>7+(a) | 2<br>0 | 0<br>(d) | long (A) < (A) xor (ear)<br>long (A) < (A) xor (eam) | -      |        | - | - | - | * | * | R<br>R |   | -           |

Note:

See Table B.5-1 "Execution Cycle Counts in Each Addressing Mode" and Table B.5-2 "Cycle Count Correction Values for Counting Execution Cycles" for information on (a) to (d) in the table.

Table B.8-10 Six Sign Inversion Instructions (byte, word)

| Mne                  | emonic          | #            | ~               | RG          | В               | Operation                                                              | L<br>H      | A<br>H | I | S | т | N   | z   | v   | С   | R<br>M<br>W |
|----------------------|-----------------|--------------|-----------------|-------------|-----------------|------------------------------------------------------------------------|-------------|--------|---|---|---|-----|-----|-----|-----|-------------|
| NEG<br>NEG<br>NEG    | A<br>ear<br>eam | 1<br>2<br>2+ | 2<br>3<br>5+(a) | 0<br>2<br>0 | 0<br>0<br>2×(b) | byte (A) < 0 - (A)<br>byte (ear) < 0 - (ear)<br>byte (eam) < 0 - (eam) | X<br>-<br>- | -      | - | - | - | * * | * * | * * | * * | - *         |
| NEGW<br>NEGW<br>NEGW | A<br>ear<br>eam | 1<br>2<br>2+ | 2<br>3<br>5+(a) | 0<br>2<br>0 | 0<br>0<br>2×(c) | word (A) < 0 - (A)<br>word (ear) < 0 - (ear)<br>word (eam) < 0 - (eam) | -           | -      | - | - | - | * * | * * | * * | * * | -<br>- *    |

#### Note:

See Table B.5-1 "Execution Cycle Counts in Each Addressing Mode" and Table B.5-2 "Cycle Count Correction Values for Counting Execution Cycles" for information on (a) to (d) in the table.

Table B.8-11 One Normalization Instruction (long word)

| Mnemonic  | # | 2  | RG | В | Operation                                                                                                         | L<br>H | A<br>H | I | S | т | N | Z | v | С | R<br>M<br>W |
|-----------|---|----|----|---|-------------------------------------------------------------------------------------------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| NRML A,R0 | 2 | *1 | 1  | 0 | long (A) < Shifts to the position where<br>'1' is set for the first time.<br>byte (RD) < Shift count at that time | -      | -      | - | - | - | - | * | - | - | -           |

\*1: 4 when all accumulators have a value of 0; otherwise, 6+(R0)

| Mn                           | emonic                    | #                  | ~                        | R<br>G           | В                        | Operation                                                                                                                                                          | L<br>H      | A<br>H | I           | S      | т     | Ν           | z      | v | С           | R<br>M<br>W |
|------------------------------|---------------------------|--------------------|--------------------------|------------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------|-------------|--------|-------|-------------|--------|---|-------------|-------------|
|                              |                           |                    |                          |                  |                          |                                                                                                                                                                    |             |        |             |        |       |             |        |   |             |             |
| RORC<br>ROLC                 | A<br>A                    | 2<br>2             | 2<br>2                   | 0<br>0           | 0<br>0                   | byte (A) < With right rotation carry<br>byte (A) < With left rotation carry                                                                                        | -           | -      | -           | -      | -     | *           | *      | - | *           | -           |
| RORC<br>RORC<br>ROLC<br>ROLC | ear<br>eam<br>ear<br>eam  | 2<br>2+<br>2<br>2+ | 3<br>5+(a)<br>3<br>5+(a) | 2<br>0<br>2<br>0 | 0<br>2×(b)<br>0<br>2×(b) | byte (ear) < With right rotation carry<br>byte (eam) < With right rotation carry<br>byte (ear) < With left rotation carry<br>byte (eam) < With left rotation carry | -<br>-<br>- |        | -<br>-<br>- |        |       | *<br>*<br>* | * * *  |   | * * *       | - *         |
| ASR<br>LSR<br>LSL            | A,R0<br>A,R0<br>A,R0      | 2<br>2<br>2        | *1<br>*1<br>*1           | 1<br>1<br>1      | 0<br>0<br>0              | byte (A) < Arithmetic right shift (A, 1 bit)<br>byte (A) < Logical right barrel shift (A, R0)<br>byte (A) < Logical left barrel shift (A, R0)                      | -<br>-<br>- |        | -<br>-      | -<br>- | *     | *<br>*<br>* | *<br>* |   | *<br>*<br>* | -<br>-      |
| ASRW<br>LSRW<br>LSLW         | A<br>A/SHRW A<br>A/SHLW A | 1<br>1<br>1        | 2<br>2<br>2              | 0<br>0<br>0      | 0<br>0<br>0              | word (A) < Arithmetic right shift (A, 1 bit)<br>word (A) < Logical right shift (A, 1 bit)<br>word (A) < Logical left shift (A, 1 bit)                              | -           |        |             |        | - * * | *<br>R<br>* | *<br>* |   | * * *       | -<br>-      |
| ASRW<br>LSRW<br>LSLW         | A,R0<br>A,R0<br>A,R0      | 2<br>2<br>2        | *1<br>*1<br>*1           | 1<br>1<br>1      | 0<br>0<br>0              | word (A) < Arithmetic right barrel shift (A, R0)<br>word (A) < Logical right barrel shift (A, R0)<br>word (A) < Logical left barrel shift (A, R0)                  | -<br>-<br>- |        |             |        | * -   | * * *       | * *    |   | *<br>*<br>* | -<br>-      |
| ASRL<br>LSRL<br>LSLL         | A,R0<br>A,R0<br>A,R0      | 2<br>2<br>2        | *2<br>*2<br>*2           | 1<br>1<br>1      | 0<br>0<br>0              | long (A) < Arithmetic right barrel shift (A, R0)<br>long (A) < Logical right barrel shift (A, R0)<br>long (A) < Logical left barrel shift (A, R0)                  |             |        |             |        | - * * | * * *       | * *    |   | * * *       | -<br>-      |

Table B.8-12 18 Shift Instructions (byte, word, long word)

\*1: 6 when R0 is 0; otherwise, 5 + (R0)

\*2: 6 when R0 is 0; otherwise, 6 + (R0)

#### Note:

Table B.8-13 31 Branch 1 Instructions

| Mne                                                                                                                                 | monic                                                              | #                                                                                           | ~                                                                               | RG                                                                                          | В                                                                                           | Operation                                                                                                                                                                                                                                                                                                                                                                                                      | L<br>H | A<br>H      | I                                                                                           | s                                                                                           | т           | N | Z | v | С | R<br>M<br>W |
|-------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|-------------|---|---|---|---|-------------|
| BZ/BEQ<br>BNZ/BNE<br>BC/BLO<br>BNC/BHS<br>BN<br>BV<br>BV<br>BT<br>BNV<br>BT<br>BNT<br>BLT<br>BGE<br>BLE<br>BGT<br>BLS<br>BHI<br>BRA | rel<br>rel<br>rel<br>rel<br>rel<br>rel<br>rel<br>rel<br>rel<br>rel | 2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2 | *1<br>*1<br>*1<br>*1<br>*1<br>*1<br>*1<br>*1<br>*1<br>*1<br>*1<br>*1<br>*1<br>* | 0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | 0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | Branch on (Z) = 1<br>Branch on (Z) = 0<br>Branch on (C) = 1<br>Branch on (C) = 0<br>Branch on (N) = 1<br>Branch on (N) = 0<br>Branch on (V) = 0<br>Branch on (T) = 1<br>Branch on (T) = 0<br>Branch on (V) nor (N) = 1<br>Branch on (V) nor (N) = 0<br>Branch on (V) xor (N)) or (Z) = 1<br>Branch on ((V) xor (N)) or (Z) = 0<br>Branch on (C) or (Z) = 1<br>Branch on (C) or (Z) = 0<br>Unconditional branch |        |             | -<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>- | -<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>- |             |   |   |   |   |             |
| JMP<br>JMP<br>JMP<br>JMP<br>JMPP<br>JMPP<br>JMPP                                                                                    | @A<br>addr16<br>@ear<br>@eam<br>@ear *3<br>@eam *3<br>addr24       | 1<br>3<br>2<br>2+<br>2<br>2+<br>4                                                           | 2<br>3<br>4+(a)<br>5<br>6+(a)<br>4                                              | 0<br>0<br>1<br>0<br>2<br>0<br>0                                                             | 0<br>0<br>(c)<br>0<br>(d)<br>0                                                              | word (PC) < (A)<br>word (PC) < addr16<br>word (PC) < (ear)<br>word (PC) < (eam)<br>word (PC) < (eam), (PCB) < (ear+2)<br>word (PC) < (eam), (PCB) < (eam+2)<br>word(PC) < ad24 0-15,(PCB) < ad24<br>16-23                                                                                                                                                                                                      |        |             |                                                                                             |                                                                                             |             |   |   |   |   |             |
| CALL<br>CALL<br>CALL<br>CALLV<br>CALLP<br>CALLP                                                                                     | @ear *4<br>@eam *4<br>addr16 *5<br>#vct4 *5<br>@ear *6<br>@eam *6  | 2<br>2+<br>3<br>1<br>2<br>2+                                                                | 6<br>7+(a)<br>6<br>7<br>10<br>11+(a)                                            | 1<br>0<br>0<br>2<br>0                                                                       | (c)<br>2×(c)<br>(c)<br>2×(c)<br>2×(c)<br>*2                                                 | word (PC) < (ear)<br>word (PC) < (eam)<br>word (PC) < addr16<br>Vector call instruction<br>word(PC) < (ear)0-15,(PCB) <<br>(ear)16-23<br>word(PC) < (eam)0-15,(PCB) <<br>(eam)16-23                                                                                                                                                                                                                            |        | -<br>-<br>- |                                                                                             |                                                                                             | -<br>-<br>- |   |   |   |   |             |
| CALLP                                                                                                                               | addr24 *7                                                          | 4                                                                                           | 10                                                                              | 0                                                                                           | 2×(c)                                                                                       | word(PC) < addr0-15, (PCB) <<br>addr16-23                                                                                                                                                                                                                                                                                                                                                                      | -      | -           | -                                                                                           | -                                                                                           | -           | - | - | - | - | -           |

\*1: 4 when a branch is made; otherwise, 3

\*2: 3 x (c) + (b)

\*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:

| 1                                  | Mnemonic                                                                | #                     | 2                          | R<br>G           | В                                      | Operation                                                                                                                                                                 | L<br>H | A<br>H | I                     | S                     | т                | N                | z                | v                | С       | R<br>M<br>W |
|------------------------------------|-------------------------------------------------------------------------|-----------------------|----------------------------|------------------|----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|-----------------------|-----------------------|------------------|------------------|------------------|------------------|---------|-------------|
|                                    |                                                                         |                       |                            |                  |                                        |                                                                                                                                                                           |        |        |                       |                       |                  |                  |                  |                  |         | vv          |
| CBNE<br>CWBNE                      | A,#imm8,rel<br>A,#imm16,rel                                             | 3<br>4                | *1<br>*1                   | 0<br>0           | 0<br>0                                 | Branch on byte (A) not equal to imm8<br>Branch on word (A) not equal to imm16                                                                                             |        |        |                       | -                     | -                | * *              | * *              | * *              | * *     | -           |
| CBNE<br>CBNE<br>CWBNE<br>CWBNE     | ear,#imm8,rel<br>eam,#imm8,rel *9<br>ear,#imm16,rel<br>eam,#imm16,rel*9 | 4<br>4+<br>5<br>5+    | *2<br>*3<br>*4<br>*3       | 1<br>0<br>1<br>0 | 0<br>(b)<br>0<br>(c)                   | Branch on byte (ear) not equal to imm8<br>Branch on byte (eam) not equal to imm8<br>Branch on word (ear) not equal to imm16<br>Branch on word (eam) not equal to<br>imm16 |        |        |                       |                       |                  | * * * *          | * * * *          | * * * *          | * * * * | -<br>-<br>- |
| DBNZ<br>DBNZ                       | ear,rel<br>eam,rel                                                      | 3<br>3+               | *5<br>*6                   | 2<br>2           | 0<br>2×(b)                             | Branch on byte (ear) = (ear) - 1, (ear)not<br>equal to 0<br>Branch on byte (eam) = (eam) - 1, (eam)<br>not equal to 0                                                     | -      | -      | -                     | -                     | -                | *                | *                | *                | -       | -<br>*      |
| DWBNZ<br>DWBNZ                     | ear,rel<br>eam,rel                                                      | 3<br>3+               | *5<br>*6                   | 2<br>2           | 0<br>2×(c)                             | Branch on word (ear) = (ear) - 1, (ear) not<br>equal to 0<br>Branch on word (eam) = (eam) - 1, (eam)<br>not equal to 0                                                    | -      | -      | -                     | -                     | -                | *                | *                | *                |         | -<br>*      |
| INT<br>INT<br>INTP<br>INT9<br>RETI | #vct8<br>addr16<br>addr24                                               | 2<br>3<br>4<br>1<br>1 | 20<br>16<br>17<br>20<br>*8 | 0<br>0<br>0<br>0 | 8x(c)<br>6x(c)<br>6x(c)<br>8x(c)<br>*7 | Software interrupt<br>Software interrupt<br>Software interrupt<br>Software interrupt<br>Return from interrupt                                                             |        |        | R<br>R<br>R<br>R<br>* | S<br>S<br>S<br>S<br>* | -<br>-<br>-<br>* | -<br>-<br>-<br>* | -<br>-<br>-<br>* | -<br>-<br>-<br>* | *       | -<br>-<br>- |
| LINK                               | #imm8                                                                   | 2                     | 6                          | 0                | (c)                                    | Saves the old frame pointer in the stack<br>upon entering the function, then sets the<br>new frame pointer and reserves the local<br>pointer area.                        | -      | -      | -                     | -                     | -                | -                | -                | -                | -       | -           |
| UNLINK                             |                                                                         | 1                     | 5                          | 0                | (c)                                    | Recovers the old frame pointer from the stack upon exiting the function.                                                                                                  | -      | -      | -                     | -                     | -                | -                | -                | -                | -       | -           |
| RET<br>RETP                        | *10<br>*11                                                              | 1<br>1                | 4<br>6                     | 0<br>0           | (c)<br>(d)                             | Return from subroutine<br>Return from subroutine                                                                                                                          | -      | -      | -                     | -                     | -                | -                | -                | -                | -       | -           |

Table B.8-14 19 Branch 2 Instructions

\*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:

| Mr                                            | nemonic                              | #                          | ~                          | RG                         | В                          | Operation                                                                                                                                                                                                                          | L<br>H      | A<br>H      | I                | S                | т     | Ν     | Z           | v      | С   | R<br>M<br>W |
|-----------------------------------------------|--------------------------------------|----------------------------|----------------------------|----------------------------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------|------------------|------------------|-------|-------|-------------|--------|-----|-------------|
| PUSHW<br>PUSHW<br>PUSHW<br>PUSHW              | A<br>AH<br>PS<br>rlst                | 1<br>1<br>1<br>2           | 4<br>4<br>4<br>*3          | 0<br>0<br>0<br>*5          | (c)<br>(c)<br>(c)<br>*4    | word (SP) < (SP) - 2 , ((SP)) < (A)<br>word (SP) < (SP) - 2 , ((SP)) < (AH)<br>word (SP) < (SP) - 2 , ((SP)) < (PS)<br>(SP) < (SP) - 2n , ((SP)) < (rlst)                                                                          | -<br>-<br>- | -<br>-<br>- | -<br>-<br>-      | -<br>-<br>-      |       |       | -<br>-<br>- |        |     |             |
| POPW<br>POPW<br>POPW<br>POPW                  | A<br>AH<br>PS<br>rlst                | 1<br>1<br>1<br>2           | 3<br>3<br>4<br>*2          | 0<br>0<br>0<br>*5          | (c)<br>(c)<br>(c)<br>*4    | word (A) < ((SP)) , (SP) < (SP) + 2<br>word (AH) < ((SP)) , (SP) < (SP) + 2<br>word (PS) < ((SP)) , (SP) < (SP) + 2<br>(rlst) < ((SP)) , (SP) < (SP)                                                                               | -<br>-<br>- | *<br>-<br>- | -<br>-<br>*<br>- | -<br>-<br>*<br>- | - * - | - * - | -<br>-<br>* | -<br>* | * - |             |
| JCTX                                          | @A                                   | 1                          | 14                         | 0                          | 6×(c)                      | Context switch instruction                                                                                                                                                                                                         | -           | -           | *                | *                | *     | *     | *           | *      | *   | -           |
| AND<br>OR                                     | CCR,#imm8<br>CCR,#imm8               | 2<br>2                     | 3<br>3                     | 0<br>0                     | 0<br>0                     | byte (CCR) < (CCR) and imm8<br>byte(CCR) < (CCR) or imm8                                                                                                                                                                           | -           | -           | *                | *                | * *   | *     | *           | *      | * * | -           |
| MOV<br>MOV                                    | RP,#imm8<br>ILM,#imm8                | 2<br>2                     | 2<br>2                     | 0<br>0                     | 0<br>0                     | byte (RP) < imm8<br>byte (ILM) < imm8                                                                                                                                                                                              | -           | -           | -                | -                | -     | -     | -           | -      | -   | -           |
| MOVEA<br>MOVEA<br>MOVEA<br>MOVEA              | RWi,ear<br>RWi,eam<br>A,ear<br>A,eam | 2<br>2+<br>2<br>2+         | 3<br>2+(a)<br>1<br>1+(a)   | 1<br>1<br>0<br>0           | 0<br>0<br>0<br>0           | word (RWi) < ear<br>word (RWi) < eam<br>word (A) < ear<br>word (A) < eam                                                                                                                                                           | -<br>-<br>- | -<br>-<br>* | -<br>-<br>-      | -<br>-<br>-      |       |       | -<br>-<br>- |        |     |             |
| ADDSP<br>ADDSP                                | #imm8<br>#imm16                      | 2<br>3                     | 3<br>3                     | 0<br>0                     | 0<br>0                     | word (SP) < ext(imm8)<br>word (SP) < imm16                                                                                                                                                                                         | -           | -           | -                | -                | -     | -     | -           | -      |     | -           |
| MOV<br>MOV                                    | A,brg1<br>brg2,A                     | 2<br>2                     | *1<br>1                    | 0<br>0                     | 0<br>0                     | byte (A) < (brg1)<br>byte (brg2) < (A)                                                                                                                                                                                             | Z<br>-      | *           | -                | -                | -     | *     | *           | -      | -   | -           |
| NOP<br>ADB<br>DTB<br>PCB<br>SPB<br>NCC<br>CMR |                                      | 1<br>1<br>1<br>1<br>1<br>1 | 1<br>1<br>1<br>1<br>1<br>1 | 0<br>0<br>0<br>0<br>0<br>0 | 0<br>0<br>0<br>0<br>0<br>0 | No operation<br>Prefix code for AD space access<br>Prefix code for DT space access<br>Prefix code for PC space access<br>Prefix code for SP space access<br>Prefix code for flag no-change<br>Prefix code for common register bank |             |             |                  |                  |       |       |             |        |     |             |

 Table B.8-15
 28 Other Control Instructions (byte, word, long word)

\*1: PCB, ADB, SSB, USB, SPB: 1, DTB, DPR: 2

\*2: 7 +  $3 \times (POP \text{ count}) + 2 \times (POP \text{ last register number})$ , 7 when RLST = 0 (no transfer register)

\*3: 29 + 3×(PUSH count) - 3×(PUSH last register number), 8 when RLST = 0 (no transfer register)

\*4: (POP count)×(c) or (PUSH count)×(c)

\*5: (POP count) or (PUSH count)

#### Note:

| м                    | nemonic                                  | #           | ~              | RG          | В                       | Operation                                                                                | L<br>H      | A<br>H      | I           | S           | т           | Ν      | z           | v      | С      | R<br>M<br>W |
|----------------------|------------------------------------------|-------------|----------------|-------------|-------------------------|------------------------------------------------------------------------------------------|-------------|-------------|-------------|-------------|-------------|--------|-------------|--------|--------|-------------|
| MOVB<br>MOVB<br>MOVB | A,dir:bp<br>A,addr16:bp<br>A,io:bp       | 3<br>4<br>3 | 5<br>5<br>4    | 0<br>0<br>0 | (b)<br>(b)<br>(b)       | byte (A) < ( dir:bp )b<br>byte (A) < ( addr16:bp )b<br>byte (A) < ( io:bp )b             | Z<br>Z<br>Z | *<br>*      | -<br>-<br>- | -<br>-<br>- | -<br>-<br>- | *<br>* | *<br>*<br>* | -<br>- | -<br>- | -<br>-<br>- |
| MOVB<br>MOVB<br>MOVB | dir:bp,A<br>addr16:bp,A<br>io:bp,A       | 3<br>4<br>3 | 7<br>7<br>6    | 0<br>0<br>0 | 2x(b)<br>2x(b)<br>2x(b) | bit ( dir:bp )b < (A)<br>bit ( addr16:bp )b < (A)<br>bit ( io:bp )b < (A)                | -<br>-      | -<br>-      | -<br>-      | -<br>-      | -<br>-      | * *    | * *         | -      | -      | *<br>*<br>* |
| SETB<br>SETB<br>SETB | dir:bp<br>addr16:bp<br>io:bp             | 3<br>4<br>3 | 7<br>7<br>7    | 0<br>0<br>0 | 2x(b)<br>2x(b)<br>2x(b) | bit ( dir:bp )b < 1<br>bit ( addr16:bp )b < 1<br>bit ( io:bp )b < 1                      | -<br>-<br>- | -<br>-      | -<br>-<br>- | -<br>-<br>- | -           |        | -<br>-<br>- | -      | -<br>- | * * *       |
| CLRB<br>CLRB<br>CLRB | dir:bp<br>addr16:bp<br>io:bp             | 3<br>4<br>3 | 7<br>7<br>7    | 0<br>0<br>0 | 2x(b)<br>2x(b)<br>2x(b) | bit ( dir:bp )b < 0<br>bit ( addr16:bp )b < 0<br>bit ( io:bp )b < 0                      | -<br>-<br>- | -<br>-      | -<br>-<br>- | -<br>-<br>- | -           |        | -<br>-<br>- | -      | -<br>- | * * *       |
| BBC<br>BBC<br>BBC    | dir:bp,rel<br>addr16:bp,rel<br>io:bp,rel | 4<br>5<br>4 | *1<br>*1<br>*2 | 0<br>0<br>0 | (b)<br>(b)<br>(b)       | Branch on (dir:bp) $b = 0$<br>Branch on (addr16:bp) $b = 0$<br>Branch on (io:bp) $b = 0$ | -<br>-<br>- | -<br>-      | -<br>-<br>- | -<br>-<br>- | -           |        | * *         | -      | -<br>- | -<br>-<br>- |
| BBS<br>BBS<br>BBS    | dir:bp,rel<br>addr16:bp,rel<br>io:bp,rel | 4<br>5<br>4 | *1<br>*1<br>*1 | 0<br>0<br>0 | (b)<br>(b)<br>(b)       | Branch on (dir:bp) $b = 1$<br>Branch on (addr16:bp) $b = 1$<br>Branch on (io:bp) $b = 1$ | -<br>-      | -<br>-<br>- | -<br>-      | -<br>-      | -           | -<br>- | * * *       | -<br>- | -<br>- | -<br>-      |
| SBBS                 | addr16:bp,rel                            | 5           | *3             | 0           | 2x(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 B.8-16 21 Bit Operand Instructions

\*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:

| Table B.8-17 | Six Accumulator O | peration Instructions | (byte, word) |
|--------------|-------------------|-----------------------|--------------|
|--------------|-------------------|-----------------------|--------------|

| Mnemonic               | # | ~ | RG | В      | Operation                                | L<br>H | A<br>H | I | S | т | N | z | v | С | R<br>M<br>W |
|------------------------|---|---|----|--------|------------------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
|                        |   |   |    |        |                                          |        |        |   |   |   |   |   |   |   |             |
| SWAP<br>SWAPW/XCHW A,T | 1 | 3 | 0  | 0      | byte (A)0-7 <> (A)8-15                   | -      | -      | - | - | - | - | - | - | - | -           |
| EXT                    | 1 | 2 | 0  | 0<br>0 | word (AH) <> (AL)<br>Byte sign extension | x      | -      | - | - | - | * | * | - | - | -           |
| 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 | * | - | - | -           |

 Table B.8-18
 Ten String Instructions

| Mnemonic              | #      | ~        | RG       | В        | Operation                                                                            | L<br>H | A<br>H | I | S | т | N | z | v | С | R<br>M<br>W |
|-----------------------|--------|----------|----------|----------|--------------------------------------------------------------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| MOVS / MOVSI<br>MOVSD | 2<br>2 | *2<br>*2 | *5<br>*5 | *3<br>*3 | byte transfer @AH+ < @AL+, counter = RW0<br>byte transfer @AH- < @AL-, counter = RW0 | -      | -      | - | - | - | - | - | - | - | -           |
| SCEQ / SCEQI<br>SCEQD | 2<br>2 | *1<br>*1 | *5<br>*5 | *4<br>*4 | byte search @AH+ < AL, counter RW0<br>byte search @AH- < AL, counter RW0             | -      | -      | - | - | - | * | * | * | * | -           |
| FILS / FILSI          | 2      | 6m+6     | *5       | *3       | byte fill @AH+ < AL, counter RW0                                                     | -      | -      | - | - | - | * | * | - | - | -           |
| MOVSW / MOVSWI        | 2      | *2       | *8       | *6       | word transfer @AH+ < @AL+, counter = RW0                                             | -      | -      | - | - | - | - | - | - | - | -           |
| MOVSWD                | 2      | *2       | *8       | *6       | word transfer @AH- < @AL-, counter = RW0                                             | -      | -      | - | - | - | - | - | - | - | -           |
| SCWEQ / SCWEQI        | 2      | *1       | *8       | *7       | word search @AH+ - AL, counter = RW0                                                 | -      | -      | - | - | - | * | * | * | * | -           |
| SCWEQD                | 2      | *1       | *8       | *7       | word search @AH AL, counter = RW0                                                    | -      | -      | - | - | - | * | * | * | * | -           |
| FILSW / FILSWI        | 2      | 6m+6     | *8       | *6       | word fill @AH+ < AL, counter = RW0                                                   | -      | -      | - | - | - | * | * | - | - | -           |

\*1: 5 when RW0 is 0, 4 + 7 × (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)  $\times$  (RW0) + (b)  $\times$  (RW0) When the source and destination access different areas, calculate the (b) item individually.

\*4: (b) × n

\*5: 2 × (R × W0)

\*6: (c) × (RW0) + (c) × (RW0) When the source and destination access different areas, calculate the (c) item individually.

\*7: (c) × n

\*8: 2 × 0(RW0)

#### Note:

m: RW0 value (counter value), n: Loop count

## **B.9** Instruction Map

Each  $F^2MC-16LX$  instruction code consists of 1 or 2 bytes. Therefore, the instruction map consists of multiple pages. Table B.9-2 "Basic Page Map" to Table B.9-21 "XCHW RWi, ea Instruction (first byte =  $7F_H$ )" summarize the  $F^2MC-16LX$  instruction map.

#### ■ Structure of Instruction Map





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 B.9-2 "Correspondence between Actual Instruction Code and Instruction Map" shows the correspondence between an actual instruction code and instruction map.



#### Figure B.9-2 Correspondence between Actual Instruction Code and Instruction Map

\*1 The extended page map is a generic name of maps for bit operation instructions, character string operation instructions, 2-byte instructions, and ea instructions. Actually, there are multiple extended page maps for each type of instructions.

An example of an instruction code is shown in Table B.9-1 "Example of an Instruction Code".

Table B.9-1 Example of an Instruction Code

| Instruction    | Byte 1<br>(from basic page map) | Byte 2<br>(from extended page<br>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                              |

| APPENDIX B | Instructions |
|------------|--------------|
|------------|--------------|

#### Table B.9-2 Basic Page Map

| Eo | ВЕQ         | re      | BNZ/BNE     | re     | вго         | re       | BNC /BHS    | re       |             | re     |             | re     |             | re     |             | e        |             | rel     |        | re     |          | re       |      | re       |               | le          |       | le     |           | e                   |        | le          |
|----|-------------|---------|-------------|--------|-------------|----------|-------------|----------|-------------|--------|-------------|--------|-------------|--------|-------------|----------|-------------|---------|--------|--------|----------|----------|------|----------|---------------|-------------|-------|--------|-----------|---------------------|--------|-------------|
|    | BZ /BEQ     | #4      |             |        | BC /BLO     |          | BNC         |          | BN          |        | ВР          |        | BV          |        | BNV         |          | ВТ          |         | BNT    |        | BLT      |          | BGE  |          | BLE           |             | BGT   |        | BLS       |                     | ВН     |             |
| EO | CALLV       | #       | -           |        |             |          |             |          |             |        |             |        |             |        |             |          |             |         |        |        |          |          |      |          |               |             |       |        |           |                     |        | *           |
| DO | MOVN        | A,#4    | -           |        |             |          |             |          |             |        |             |        |             |        |             |          |             |         |        |        |          |          |      |          |               |             |       |        |           |                     | ,      | ۲           |
| co | MOVX A,     | @RWi+d8 | -           |        |             |          |             |          |             |        |             |        |             |        | ,           | •        | MOVW @R     | Wi+d8,A |        |        |          |          |      |          |               |             |       |        |           |                     | ,      | ۲           |
| BO | MOVX        | A,Ri    | -           |        |             |          |             |          |             |        |             |        |             |        | ,           | •        | MOVW A,     | @RWi+d8 |        |        |          |          |      |          |               |             |       |        |           |                     | ,      | ۲           |
| AO | MOV         | 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- | 11011 4  | ea instruc- | tion 5 | ea instruc- | tion 6 | ea instruc- | tion 7 | ea instruc- | tion 8   | ea instruc- | tion 9  | MOVEA  | RWi,ea | MOV      | Ri,ea    | MOVW | RWi,ea   | MOV           | ea,Ri       | MOVW  | ea,RWi | хсн       | Ri,ea               | XC     | RWi,ea      |
| 60 | BRA         | rel     | JMP         | @Α     | JMP         | addr16   | JMPP        | addr24   | CALL        | addr16 | CALLP       | addr24 | RETP        |        | RET         |          | INT         | #vct8   | INT    | addr16 | INTP     | addr24   | RETI |          | Bit operation | instruction |       |        | Character | PS 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      |                     | POPW   | rlst        |
| 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     |                     | PUSHW  | rlst        |
| 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,re   | CMPW |          | 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 | NNIA        | A      | MULU        | A        | MDDM        | A       | Maus   | A      | CBNE A,  | #8,re    | CMPW |          | ANDW          | A           | ORW   | A      | XORW      | A                   | 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 |          | RN            | A           |       |        | ASRW      | A                   | LSRW   | A           |
|    |             | 0 +     | -           | +      |             | + 2      |             | γ<br>+   | -           | +<br>+ | -           | ۵<br>+ | -           | 9<br>+ |             | \<br>+   |             | + 8     |        | 6+     |          | + +      |      | 8<br>+   |               | с<br>+      |       | 0<br>+ |           | ш<br>+              |        | ⊥<br>+      |

| FO |                   |   |     |     |     |   |    |          | SBBS<br>a ddr16:bp   |     |     |        |        |        |        | <b>→</b>      |
|----|-------------------|---|-----|-----|-----|---|----|----------|----------------------|-----|-----|--------|--------|--------|--------|---------------|
| EO | WBTC<br>io:bp     |   |     |     |     |   |    | <b>→</b> |                      |     |     |        |        |        |        |               |
| DO |                   |   |     |     |     |   |    |          |                      |     |     |        |        |        |        |               |
| 8  | WBTS<br>io:bp     |   |     |     |     |   |    | <b>→</b> |                      |     |     |        |        |        |        |               |
| BO |                   |   |     |     |     |   |    |          | BBS ad16<br>:bp,rel  |     |     |        |        |        |        | <b>→</b>      |
| AO | BBS io<br>:bp,rel |   |     |     |     |   |    | <b>→</b> | BBS<br>dir:bp,rel    |     |     |        |        |        |        | $\rightarrow$ |
| 06 |                   |   |     |     |     |   |    |          | BBC ad16<br>:bp,rel  |     |     |        |        |        |        | <b>→</b>      |
| 80 | BBC io<br>:bp,rel |   |     |     |     |   |    | <b>→</b> | BBC<br>dir:bp,rel    |     |     |        |        |        |        | $\rightarrow$ |
| 20 |                   |   |     |     |     |   |    |          | SETB<br>a ddr16:bp   |     |     |        |        |        |        | $\rightarrow$ |
| 60 | SETB<br>io:bp     |   |     |     |     |   |    | <b>→</b> | SETB<br>diribp       |     |     |        |        |        |        | <b>→</b>      |
| 50 |                   |   |     |     |     |   |    |          | CLRB a<br>ddr16:bp   |     |     |        |        |        |        | $\rightarrow$ |
| 40 | CLRB<br>io:bp     |   |     |     |     |   |    | <b>→</b> | CLRB<br>dir:bp       |     |     |        |        |        |        | $\rightarrow$ |
| 30 |                   |   |     |     |     |   |    |          | MOVB<br>addr16:bp,A  |     |     |        |        |        |        | <b>→</b>      |
| 20 | MOVB<br>io:bp,A   |   |     |     |     |   |    | <b>→</b> | MOVB<br>dir:bp,A     |     |     |        |        |        |        | $\rightarrow$ |
| 10 |                   |   |     |     |     |   |    |          | MOVB A,a<br>ddr16:bp |     |     |        |        |        |        | <b>→</b>      |
| 00 | MOVB<br>A,io:bp   |   |     |     |     |   |    | <b>→</b> | MOVB<br>A,dir:bp     |     |     |        |        |        |        | <b>→</b>      |
|    | 0+                | + | + 2 | + 3 | + 4 | + | 9+ | 2 +      | 8 +                  | 6 + | + A | +<br>+ | C<br>+ | Q<br>+ | н<br>Н | ш<br>+        |

## Table B.9-3 Bit Operation Instruction Map (first byte = $6C_H$ )

| 00            | 10       |        | 08     | 40 | 50 | 60 | 70 | 80           | 90           | AO            | BO     | 00<br>ii     | DO | EO     | Ъ |
|---------------|----------|--------|--------|----|----|----|----|--------------|--------------|---------------|--------|--------------|----|--------|---|
| OVSI PCB, PCB | MOVSD    | MOVSWI | MOVSWD |    |    |    |    | SCEQI<br>PCB | SCEQD<br>PCB | SCWEQI<br>PCB | SCWEQD | FILSI<br>PCB |    | FILSWI |   |
| PCB,DTB       |          |        |        |    |    |    |    |              | DTB          | DTB           | DTB    | DTB          |    | DTB    |   |
| PCB,ADB       |          |        |        |    |    |    |    | ADB          | ADB          | ADB           | ADB    | ADB          |    | ADB    |   |
| PCB,SPB       | 1        |        |        |    |    |    |    | ♦ SPB        | ♦ SPB        | ♦ SPB         | V SPB  | ♦ SPB        |    | ♦ SPB  |   |
| DTB,PCB       | 1        |        |        |    |    |    |    |              |              |               |        |              |    |        |   |
| DTB,DTB       | +        |        |        |    |    |    |    |              |              |               |        |              |    |        |   |
| DTB,ADB       |          |        | 1      |    |    |    |    |              |              |               |        |              |    |        |   |
| DTB,SPB       | +        |        |        |    |    |    |    |              |              |               |        |              |    |        |   |
| ADB,PCB       |          |        |        |    |    |    |    |              |              |               |        |              |    |        |   |
| ADB,DTB       |          |        |        |    |    |    |    |              |              |               |        |              |    |        |   |
| ADB,ADB       |          |        |        |    |    |    |    |              |              |               |        |              |    |        |   |
| ADB,SPB       |          |        |        |    |    |    |    |              |              |               |        |              |    |        |   |
| SPB,PCB       | :        |        | 1      |    |    |    |    |              |              |               |        |              |    |        |   |
| :<br>SPB,DTB  |          |        | 1      |    |    |    |    |              |              |               |        |              |    |        |   |
| SPB,ADB       |          |        |        |    |    |    |    |              |              |               |        |              |    |        |   |
| SPB,SPB       | <b>→</b> |        |        |    |    |    |    |              |              |               |        |              |    |        |   |

### Table B.9-4 Character String Operation Instruction Map (first byte = $6E_H$ )

| FO |                   |              |                    |              |                    |               |                    |        |                    |           |                    |        |                    |                |                    |              |
|----|-------------------|--------------|--------------------|--------------|--------------------|---------------|--------------------|--------|--------------------|-----------|--------------------|--------|--------------------|----------------|--------------------|--------------|
| EO |                   |              |                    |              |                    |               |                    |        |                    |           |                    |        |                    |                |                    |              |
| DO |                   |              |                    |              |                    |               |                    |        |                    |           |                    |        |                    |                |                    |              |
| CC |                   |              |                    |              |                    |               |                    |        |                    |           |                    |        |                    |                |                    |              |
| BO |                   |              |                    |              |                    |               |                    |        |                    |           |                    |        |                    |                |                    |              |
| AO |                   |              |                    |              |                    |               |                    |        |                    |           |                    |        |                    |                |                    |              |
| 06 |                   |              |                    |              |                    |               |                    |        |                    |           |                    |        |                    |                |                    |              |
| 80 |                   |              |                    |              |                    |               |                    |        |                    |           |                    |        |                    |                |                    |              |
| 20 |                   |              |                    |              |                    |               |                    |        |                    |           |                    |        |                    |                |                    |              |
| 60 |                   |              |                    |              |                    |               |                    |        | MULA               | MULW<br>A | DIVU<br>A          |        |                    |                |                    |              |
| 50 |                   |              |                    |              |                    |               |                    |        |                    |           |                    |        |                    |                |                    |              |
| 40 | MOV A,<br>@RL0+d8 |              | MOV A,<br>@RL1+d8  |              | MOV A,<br>@RL2+d8  |               | MOV A,<br>@RL3+d8  |        | MOVW A,<br>@RL0+d8 |           | MOVW A,<br>@RL1+d8 |        | MOVW A,<br>@RL2+d8 |                | MOVW A,<br>@RL3+d8 |              |
| 30 | @RL0              |              | MOV @RL1<br>+d8,A  |              | MOV @RL2<br>+d8,A  |               | MOV @RL3<br>+d8,A  |        |                    |           | MOVW @RL<br>1+d8,A |        | MOVW @RL<br>2+d8,A |                | MOVW @RL<br>3+d8,A |              |
| 20 | @RL0+d8 +d8,A     |              | MOVX A,<br>@RL1+d8 |              | MOVX A,<br>@RL2+d8 |               | MOVX A,<br>@RL3+d8 |        |                    |           |                    |        | A,RO               | NRML<br>A,R0   | ASR<br>A,R0        | LSR          |
| 10 | MOV<br>DTB,A      | MOV<br>ADB,A | MOV<br>SSB,A       | MOV<br>USB,A | AOV<br>DPR,A       | AOV<br>@AL,AH | MOVX<br>A,@A       | RORC   |                    |           |                    |        | LSLL<br>A,R0       | MOVW<br>@AL,AH | ASRL<br>A,R0       | LSRL<br>A,R0 |
| 00 | MOV<br>A,DTB      | MOV<br>A,ADB | MOV<br>A,SSB       | MOV<br>A,USB | MOV A,DPR          | MOV<br>A,@A   | MOV A,PCB          | ROLC A |                    |           |                    |        | LSLW<br>A,R0       | ı,@A           | A,R0               | LSRW<br>A,R0 |
|    | 0+                | +            | +2                 | +3           | +4                 | +5            | 9+                 | 7+7    | +                  | 6+        | + A                | +<br>+ | + C                | 0+             | ш<br>+             | ш<br>+       |

### Table B.9-5 2-byte Instruction Map (first byte = $6F_H$ )

|        | 00      | 10        | 20      | 30       | 40         | 50        | 60      | 02       | 08      | 06       | AO      | BO       | CO      | 00        | EО         | FO       |
|--------|---------|-----------|---------|----------|------------|-----------|---------|----------|---------|----------|---------|----------|---------|-----------|------------|----------|
|        |         |           |         |          | CWBNE ↓    | CWBNE ↓   |         |          |         |          |         |          |         |           | CBNE ↓     | CBNE ↓   |
| c<br>- | ADDL    | ADDL A,   | SUBL    | SUBL A,  | RW0,       | @RW0+d8,  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | R0,        | @RW0+d8, |
| 5      | 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    |           | SUBL    |          | RW1,       |           | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | R1,        | @RW1+d8, |
| -<br>+ | A,RL0   | @RW1+d8   | A,RL0   | @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    | ADDL A,   | SUBL    |          | RW2,       | @RW2+d8,  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | R2,        | @RW2+d8, |
| + 5    | 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 A,  | RW3,       | @RW3+d8,  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | R3,        | @RW3+d8, |
| r<br>+ | 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    |           | SUBL    | SUBL A,  | RW4,       | @RW4+d8,  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | R4,        | @RW4+d8, |
| + 4    | 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 A,  | 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    |           | SUBL    | SUBL A,  | RW6,       | @RW6+d8,  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | : XORL A, | R6,        | @RW6+d8, |
| 9+     | 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    |           | SUBL    | SUBL A,  | 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    |           |         | SUBL A,  | @RW0,      | @RW0+d16  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | @RW0,      | @RW0+d16 |
| + 8    | A,@RW0  | @RW0+d16  | A,@RW0  | @RW0+d16 | #16,re     | , #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,   |         |          | @RW1,      | @RW1+d16  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | @RW1,      | @RW1+d16 |
| 6 +    | 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    |           |         |          | @RW2,      | @RW2+d16  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | @RW2,      | @RW2+d16 |
| +      | A,@RW2  | @RW2+d16  | 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    |           | SUBL    |          | @RW3,      | @RW3+d16  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | @RW3,      | @RW3+d16 |
| а<br>+ | 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,rel     | ,#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+ | RW7       | A,@RW0+ |          | 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,  | Use        | @RW1+RW7  | CMPL    | CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,   | Use        | @RW1+RW7 |
| н н    | 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,rel  |
| 1      | ADDL    | : ADDL A, | SUBL    | SUBL A,  | Use        | @PC+d16,  | CMPL    | CMPL A,  | ANDL    | :ANDL A, | ORL     | ORL A,   | XORL    | XORL A,   | Use        | @PC+d16, |
| ш<br>+ | A,@RW2+ | @PC+d16   | A,@RW2+ | @PC+d16  | prohibited |           | A,@RW2+ | 16       | 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,rel   | A,@RW3+ | addr16   | A,@RW3+ | addr16   | A,@RW3+ | addr16   | A,@RW3+ | addr16    | prohibited | #8,rel   |

### Table B.9-6 ea Instruction 1 (first byte = $70_H$ )

### Table B.9-7 ea Instruction 2 (first byte = $71_{H}$ )

|        | 8      | 10              | 50      | 30         | 40    | 50       | 09    | 20       | 80      | 06        | AO      | BO        | CC       | DO       | EO      | F0       |
|--------|--------|-----------------|---------|------------|-------|----------|-------|----------|---------|-----------|---------|-----------|----------|----------|---------|----------|
| -      | JMPP   | JMPP            | CALLP   | CALLP      | INCL  | INCL     | DECL  | DECL     | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | MOV @R   | MOVEA   | MOVEA A, |
| ><br>+ | @RL0   | @ @ RW0+d8      | @RL0    | @ @ RW0+d8 | RLO   | @RW0+d8  | RL0   | @RW0+d8  | A,RL0   | @RW0+d8   | RL0,A   | W0+d8,A   | R0,#8    | W0+d8,#8 | A,RW0   | @RW0+d8  |
| -      | JMPP   | JMPP            | CALLP   | CALLP      | INCL  | INCL     | DECL  |          | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | MOV @R   | MOVEA   | MOVEA A, |
| +      | @RL0   | @ @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   | JMPP            | CALLP   | CALLP      | INCL  | INCL     | DECL  | DECL     | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | MOV @R   | MOVEA   | MOVEA A, |
| N<br>+ | @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  |
| -<br>- | JMPP   | JMPP            | CALLP   | CALLP      | INCL  | INCL     | DECL  | DECL     | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | MOV @R   | MOVEA   | MOVEA A, |
| ი<br>+ | @RL1   | @RL1 : @@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  |
| -      | JMPP   | : JMPP          |         |            | INCL  | INCL     | DECL  |          | MOVL    | MOVL A,   | MOVL    | 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  |
|        | JMPP   |                 | CALLP   |            | INCL  | INCL     | DECL  |          | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | MOV @R   | MOVEA   | MOVEA A, |
| م<br>+ | @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            | CALLP   | CALLP      | INCL  | INCL     | DECL  | DECL     | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | MOV @R   | MOVEA   | MOVEA A, |
| 9+     | @RL3   | @ @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  |
| -      | JMPP   | JMPP            |         |            | INCL  | INCL     | DECL  | DECL     | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | MOV @R   | MOVEA   | MOVEA A, |
| L +    | @RL3   | @ @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   | @ ddwr          |         |            | INCL  | INCL     | DECL  |          | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | MOV @RW  | MOVEA   | MOVEA A, |
| + 8    | @ @RW0 | @RW0+d16        | @@RW0   | @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 |
|        | JMPP   | @ ddwr          | CALLP   | CALLP @    | INCL  | INCL     | DECL  |          | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | MOV @RW  | MOVEA   | MOVEA A, |
| 6+     | @ @RW1 | @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   | JMPP @          | CALLP   | CALLP @    | INCL  | INCL     | DECL  | DECL     | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | MOV @RW  | MOVEA   | MOVEA A, |
| 4 +    | @@RW2  | @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 |
|        | JMPP   | MPP @           | CALLP   | CALLP @    | INCL  | INCL     | DECL  | DECL     | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | MOV @RW  | MOVEA   | MOVEA A, |
| מ<br>+ | @ @RW3 | @RW3+d16        | @@RW3   | @RW3+d16   | @RW3  | @RW3+d16 | @RW3  | @RW3+d16 | A,@RW3  | @RW3+d16  | @RW3,A  | W3+d16,A  | @RW3,#8  | 3+d16,#8 | A,@RW3  | @RW3+d16 |
|        | JMPP   | JMPP @          | CALLP   | CALLP @    | INCL  | INCL     | DECL  | DECL     | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | MOV @RW  | MOVEA   | MOVEA A, |
| с<br>+ | @@RW0+ | @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 |
|        | JMPP   | JMPP @          | CALLP   | CALLP @    | INCL  | INCL     | DECL  | DECL     | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | MOV @RW  | MOVEA   | MOVEA A, |
| 0<br>+ | @@RW1+ | @RW1+RW7        |         | @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   |                 | CALLP   | CALLP      | INCL  | INCL     | DECL  | DECL     | MOVL    | MOVL A,   | MOVL    | MOVL @P   | MOV      | MOV @P   | MOVEA   | MOVEA A, |
| ш<br>+ | @@RW2+ | @@PC+d16        | @ @RW2+ |            | @RW2+ | @PC+d16  | @RW2+ | d16      | A,@RW2+ | @PC+d16   | @RW2+,A | :C+d16,A  | @RW2+,#8 | C+d16,#8 | A,@RW2+ | @PC+d16  |
|        | JMPP   | JMPP JMPP       | CALLP   | CALLP      | INCL  | INCL     | DECL  | DECL     | MOVL    | : MOVL A, | MOVL    | :MOVL     | MOV      | MOV a    | MOVEA   | MOVEA A, |
| ц<br>+ | @@RW3+ | @addr16         | @ @RW3+ | @addr16    | @RW3+ | addr16   | @RW3+ | addr16   | A,@RW3+ | addr16    | @RW3+,A | addr16,A  | @RW3+,#8 | ddr16,#8 | A,@RW3+ | addr16   |

|        | 00    | 10        | 20    | 30       | 40    | 50       | 09    | 20       | 80      | 06       | AO      | BO         | S       | DO        | EO      | F0       |
|--------|-------|-----------|-------|----------|-------|----------|-------|----------|---------|----------|---------|------------|---------|-----------|---------|----------|
|        | ROLC  | ROLC      | RORC  | RORC     | INC   | INC      | DEC   | DEC      | MOV     | MOV A,   | MOV     | :MOV @R    | MOVX    | MOVX A,   | XCH     | XCH A,   |
| ⊃<br>+ | RO    | @RW0+d8   | R     | @RW0+d8  | R0    | @RW0+d8  | RO    | @RW0+d8  | A,R0    | @RW0+d8  | R0,A    | W0+d8,A    | A,R0    | @RW0+d8   | A,R0    | @RW0+d8  |
| Ŧ      | ROLC  | ROLC      | RORC  |          | INC   | INC      | DEC   | DEC      | MOV     | MOV A,   | MOV     |            | MOVX    | MOVX A,   | XCH     | XCH A,   |
| -<br>+ | æ     | @RW1+d8   | Æ     | @RW1+d8  | Æ     | @RW1+d8  | Ε.    | @RW1+d8  | A,R1    | @RW1+d8  | R1,A    | W1+d8,A    | A,R1    | @RW1+d8   | A,R1    | @RW1+d8  |
|        | ROLC  |           | RORC  |          | INC   | INC      | DEC   |          | MOV     | MOV A,   | MOV     |            | MOVX    | MOVX A,   | XCH     | XCH A,   |
| 7      | R2    | @RW2+d8   | R2    | @RW2+d8  | R2    | @RW2+d8  | R2    | @RW2+d8  | A,R2    | @RW2+d8  | R2,A    | W2+d8,A    | A,R2    | @RW2+d8   | A,R2    | @RW2+d8  |
|        | ROLC  |           | RORC  |          | INC   | INC      | DEC   | DEC      | MOV     | MOV A,   | MOV     |            | MOVX    | MOVX A,   | XCH     | XCH A,   |
| ν<br>+ | ß     | @RW3+d8   | ß     | @RW3+d8  | £     | @RW3+d8  | ß     | @RW3+d8  | A,R3    | @RW3+d8  | R3,A    | W3+d8,A    | A,R3    | @RW3+d8   | A,R3    | @RW3+d8  |
|        | ROLC  |           | RORC  |          | INC   | INC      | DEC   | : DEC    | MOV     | MOV A,   | MOV     | MOV @R     | MOVX    | MOVX A,   | XCH     | XCH A,   |
| + 4    | R4    | @RW4+d8   | R4    | @RW4+d8  | R4    | @RW4+d8  | R4    | @RW4+d8  | A,R4    | @RW4+d8  | R4,A    | W4+d8,A    | A,R4    | @RW4+d8   | A,R4    | @RW4+d8  |
|        | ROLC  |           | RORC  |          | INC   | INC      | DEC   | DEC      | MOV     | MOV A,   | MOV     |            | MOVX    | MOVX A,   | хсн     | XCH A,   |
| م<br>+ | R5    | @RW5+d8   | R5    | @RW5+d8  | R5    | @RW5+d8  | R5    | @RW5+d8  | A,R5    | @RW5+d8  | R5,A    | W5+d8,A    | A,R5    | @RW5+d8   | A,R5    | @RW5+d8  |
|        | ROLC  |           | RORC  |          | INC   | INC      | DEC   | DEC      | MOV     | MOV A,   | MOV     |            | MOVX    | MOVX A,   | XCH     | XCH A,   |
| 9<br>+ | R6    | @RW6+d8   | R6    | @RW6+d8  | R6    | @RW6+d8  | R6    | @RW6+d8  | A,R6    | @RW6+d8  | R6,A    | W6+d8,A    | A,R6    | @RW6+d8   | A,R6    | @RW6+d8  |
| -      | ROLC  |           | RORC  |          | INC   | INC      | DEC   | DEC      | MOV     | MOV A,   | MOV     | MOV @R     | MOVX    | MOVX A,   | XCH     | XCH A,   |
| / +    | R7    |           | R7    | @RW7+d8  | R7    | @RW7+d8  | R7    | @RW7+d8  | A,R7    | @RW7+d8  | R7,A    | W7+d8,A    | A,R7    | @RW7+d8   | A,R7    | @RW7+d8  |
|        | ROLC  | ROLC      | RORC  | RORC     | INC   | INC      | DEC   | : DEC    | MOV     | MOV A,   | MOV     | MOV @R     | MOVX    | , MOVX A, | XCH     | XCH A,   |
| 8+     | @RW0  | @RW0+d16  | @RW0  | @RW0+d16 | @RW0  | @RW0+d16 | @RW0  | @RW0+d16 | A,@RW0  | @RW0+d16 | @RW0,A  | : W0+d16,A | A,@RW0  | @RW0+d16  | A,@RW0  | @RW0+d16 |
|        | ROLC  | ROLC      | RORC  | RORC     | INC   | INC      | DEC   | DEC      | MOV     | MOV A,   | MOV     | MOV @R     | MOVX    | MOVX A,   | хсн     | XCH A,   |
| ი<br>+ | @RW1  | @RW1+d16  |       | @RW1+d16 | @RW1  | @RW1+d16 | @RW1  | @RW1+d16 | A,@RW1  | @RW1+d16 | @RW1,A  | W1+d16,A   | A,@RW1  | :         | A,@RW1  | @RW1+d16 |
|        | ROLC  |           | RORC  | RORC     | INC   | INC      | DEC   | DEC      | MOV     | MOV A,   | MOV     | MOV @R     | MOVX    | MOVX A,   | XCH     | XCH A,   |
| +      | @RW2  |           | @RW2  | @RW2+d16 | @RW2  | @RW2+d16 | @RW2  | @RW2+d16 | A,@RW2  | @RW2+d16 | @RW2,A  | W2+d16,A   | A,@RW2  | @RW2+d16  | A,@RW2  | @RW2+d16 |
|        | ROLC  | ROLC      | RORC  | RORC     | INC   | INC      | DEC   | DEC      | MOV     | MOV A,   | NOV     | MOV @R     | MOVX    | MOVX A,   | XCH     | XCH A,   |
| я<br>+ | @RW3  |           | @RW3  | @RW3+d16 | @RW3  | @RW3+d16 | @RW3  | @RW3+d16 | A,@RW3  | @RW3+d16 | @RW3,A  | W3+d16,A   | A,@RW3  | @RW3+d16  | A,@RW3  | @RW3+d16 |
|        | ROLC  | ROLC      | RORC  | RORC     | INC   | INC      | DEC   | : DEC    | MOV     | MOV A,   | MOV     | MOV @R     | MOVX    | MOVX A,   | XCH     | XCH A,   |
| ပ<br>+ | @RW0+ | • • • • • | @RW0+ | @RW0+RW7 | @RW0+ | @RW0+RW7 | @RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 | @RW0+,A | W0+RW7,A   | A,@RW0+ | @RW0+RW7  | A,@RW0+ | @RW0+RW7 |
|        | ROLC  | ROLC      | RORC  | RORC     | INC   | INC      | DEC   | DEC      | MOV     | MOV A,   | MOV     | MOV @R     | MOVX    | MOVX A,   | хсн     | XCH A,   |
| ก<br>+ | @RW1+ |           | @RW1+ |          | @RW1+ | @RW1+RW7 | @RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 | @RW1+,A | : W1+RW7,A | A,@RW1+ | @RW1+RW7  | A,@RW1+ | @RW1+RW7 |
|        | ROLC  | ROLC      | RORC  | RORC     | INC   | INC      | DEC   | DEC      | MOV     | MOV A,   | MOV     | MOV @P     | MOVX    | MOVX A,   | XCH     | XCH A,   |
| ш<br>+ | @RW2+ | @PC+d16   | @RW2+ | @PC+d16  | @RW2+ | @PC+d16  | @RW2+ | @PC+d16  | A,@RW2+ | @PC+d16  | @RW2+,A | C+d16,A    | A,@RW2+ | @PC+d16   | A,@RW2+ | @PC+d16  |
| l<br>- | ROLC  | ROLC      | RORC  | RORC     | INC   | INC      | DEC   | DEC      | NOV     | MOV A,   | MOV     | NOV        | MOVX    | MOVX A,   | XCH     | XCH A,   |
| ⊥<br>+ | @RW3+ | addr16    | @RW3+ | addr16   | @RW3+ | addr16   | @RW3+ | addr16   | A,@RW3+ | addr16   | @RW3+,A | addr16,A   | A,@RW3+ | addr16    | A,@RW3+ | addr16   |

### Table B.9-8 ea Instruction 3 (first byte = $72_{H}$ )

Table B.9-9 ea Instruction 4 (first byte =  $73_{H}$ )

| F0 | KCHW A,  | @RW0+d8    | (CHW A,  | @RW1+d8         | XCHW A,  | @RW2+d8   | XCHW A,  | @RW3+d8    | XCHW A,  | @RW4+d8    | KCHW A,  | @RW5+d8   | KCHW A,  | @RW6+d8   | XCHW A,  | @RW7+d8    | KCHW A,  | @RW0+d16 | XCHW A,  | @RW1+d16 | XCHW A,  | @RW2+d16 | XCHW A,  | @RW3+d16 | XCHW A,  | @RW0+RW7 | XCHW A,  | @RW1+RW7 | XCHW A,  | @PC+d16    | XCHW A, | addr16   |
|----|----------|------------|----------|-----------------|----------|-----------|----------|------------|----------|------------|----------|-----------|----------|-----------|----------|------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|------------|---------|----------|
|    | : XCHI   | 0 @RV      | XCH      |                 | •••••    |           | XCH      |            | XCH      |            | XCH      | ••••      | XCHI     | ••••      | HOX :    | ••••       | XCH      |          | XCHI     | ••••     |          |          | ••••     | ••••     | XCHN     | ••••     | XCH      | ••••     | XCH      |            | XCH     |          |
| EO | XCHW     | A,RW       | XCHW     | A,RW1           | XCHW     | A,RW2     | XCHW     | A,RW3      | XCHW     | A,RW4      | XCHW     | A,RW5     | XCHW     | A,RW6     | XCHW     | A,RW7      | XCHW     | A,@RW0   | XCHW     | A,@RW1   | XCHW     | A,@RW2   | XCHW     | A,@RW3   | XCHW     | A,@RW0+  | XCHW     | A,@RW1+  | XCHW     | A,@RW2+    | XCHW    | A,@RW3+  |
| DO | MOVW @RW | 0+d8,#16   | MOVW @RW | 1+d8,#16        | MOVW @RW | 2+d8,#16  | MOVW @RW | 3+d8,#16   | MOVW @RW | 4+d8,#16   | MOVW @RW | 5+d8,#16  | MOVW @RW | 6+d8,#16  | MOVW @RW | 7+d8,#16   | MOVW@RW0 | +d16,#16 | MOVW@RW1 | +d16,#16 | MOVW@RW2 | +d16,#16 | MOVW@RW3 | +d16,#16 | MOVW@RW0 | +RW7,#16 | MOVW@RW1 | +RW7,#16 | MOVW @PC | +d16,#16   | MOVW ad | dr16,#16 |
| C0 | MOW      | RW0,#16    | MOVW     | RW1,#16         | MOW      | RW2,#16   | MOW      | RW3,#16    | MOVW     | RW4,#16    | MOW      | RW5,#16   | MOVW     | RW6,#16   | MOVW     | RW7,#16    | MOVW     | @RW0,#16 | MOVW     | @RW1,#16 | MOVW     | @RW2,#16 | MOW      | @RW3,#16 | @ MVOM   | RW0+,#16 | MOVW @   | RW1+,#16 | MOVW @   | RW2+,#16   | MOVW @  | RW3+,#16 |
| BO | MOVW @R  | W0+d8,A    | MOVW @R  | W1+d8,A         | MOVW @R  | W2+d8,A   | MOVW @R  | W3+d8,A    | MOVW @R  | W4+d8,A    | MOVW @R  | W5+d8,A   | MOVW @R  | W6+d8,A   | MOVW @R  | W7+d8,A    | MOVW @R  | W0+d16,A | MOVW @R  | W1+d16,A | MOVW @R  | W2+d16,A | MOVW @R  | W3+d16,A | MOVW @R  | W0+RW7,A | MOVW @R  | W1+RW7,A | MOVW @P  | C+d16,A    | MOVW    | addr16,A |
| θO | MOVW     | RW0,A      | MOVW     | RW1,A           | MOW      | RW2,A     | MOW      | RW3,A      | MOVW     | RW4,A      | MOW      | RW5,A     | MOVW     | RW6,A     | MOVW     | RW7,A      | MOVW     | @RW0,A   | MOVW     | @RW1,A   | MOVW     | @RW2,A   | MOVW     | @RW3,A   | MOVW     | @RW0+,A  | MOW      | @RW1+,A  | MOVW     | @RW2+,A    | MOVW    | @RW3+,A  |
| 06 | MOVW A,  | @RW0+d8    | MOVW A,  | @RW1+d8         | MOVW A,  | @RW2+d8   | MOVW A,  | @RW3+d8    | MOVW A,  | @RW4+d8    | MOVW A,  | @RW5+d8   | MOVW A,  | @RW6+d8   | MOVW A,  | @RW7+d8    | MOVW A,  | @RW0+d16 | MOVW A,  | @RW1+d16 | MOVW A,  | @RW2+d16 | MOVW A,  | @RW3+d16 | MOVW A,  | @RW0+RW7 | MOVW A,  | @RW1+RW7 | MOVW A,  | @PC+d16    | MOVW A, | addr16   |
| 80 | MOW      | A,RW0      | MOW      | A,RW1           | MOW      | A,RW2     | MOW      | A,RW3      | MOW      | A,RW4      | MOW      | A,RW5     | MOW      | A,RW6     | MOW      | A,RW7      | MOW      | A,@RW0   | MOW      | A,@RW1   | MOVW     | A,@RW2   | MOVW     | RW3      | MOW      | A,@RW0+  | MOW      | A,@RW1+  | MOW      | A,@RW2+    | MOVW    | A,@RW3+  |
| 70 | DECW     | @RW0+d8    |          | @RW1+d8         | DECW     | @RW2+d8   |          | @RW3+d8    |          | @RW4+d8    | DECW     | @RW5+d8   | DECW     | @RW6+d8   | DECW     | @RW7+d8    | DECW     | @RW0+d16 | DECW     | @RW1+d16 | DECW     | @RW2+d16 | DECW     | @RW3+d16 | DECW     | @RW0+RW7 | DECW     | @RW1+RW7 | DECW     | @PC+d16    | DECW    | addr16   |
| 60 | DECW     | RWO        | DECW     | RW1             | DECW     | RW2       | DECW     | RW3        | DECW     | RW4        | DECW     | RW5       | DECW     | RW6       | DECW     | RW7        | DECW     | @RW0     | DECW     | @RW1     | DECW     | @RW2     | DECW     | @RW3     | DECW     | @RW0+    | DECW     | @RW1+    | DECW     | @RW2+      | DECW    | @RW3+    |
| 50 | INCW     | @RW0+d8    | NCW      | @RW1+d8         | NCW      | @RW2+d8   | NCW      | @RW3+d8    | NCW      | @RW4+d8    | NCW      | @RW5+d8   | NCW      | @RW6+d8   | NCW      | @RW7+d8    | NCW      | @RW0+d16 | NCW      | @RW1+d16 | INCW     | @RW2+d16 | INCW     | @RW3+d16 | NCW      | @RW0+RW7 | NCW      | @RW1+RW7 | NCW      | @PC+d16    | NCW     | addr16   |
| 40 | INCW     | RWO        | INCW     | RW1             | INCW     | RW2       | INCW     | RW3        | INCW     | RW4        | INCW     | RW5       | INCW     | RW6       | INCW     | RW7        | INCW     | @RW0     | INCW     | @RW1     | INCW     | @RW2     | INCW     | @RW3     | INCW     | @RW0+    | INCW     | @RW1+    | INCW     | @RW2+      | INCW    | @RW3+    |
| 30 | CALL     | @ @ RW0+d8 | CALL     | @ @RW1+d8       |          | @ @RW2+d8 | CALL     | @ @RW3+d8  | CALL     | @ @RW4+d8  | CALL     | @ @RW5+d8 | CALL     | @ @RW6+d8 | CALL     | @ @RW7+d8  | CALL @   | @RW0+d16 | CALL @   | @RW1+d16 | CALL @   | @RW2+d16 | CALL @   | @RW3+d16 | CALL @   | @RW0+RW7 | CALL @   | @RW1+RW7 | CALL     | @ @ PC+d16 | CALL    | @addr16  |
| 20 | CALL     | @RW0       | CALL     | @RW1            | CALL     | @RW2      | CALL     | @RW3       | CALL     | @RW4       | CALL     | @RW5      | CALL     | @RW6      | CALL     | @RW7       | CALL     | @ @RW0   | CALL     | @@RW1    | CALL     | @@RW2    | CALL     | @@RW3    | CALL     | @ @RW0+  | CALL     | @ @RW1+  | CALL     | @ @RW2+    | CALL    | @@RW3+   |
| 10 | JMP      | @ @ RW0+d8 | JMP      | @RW1 : @@RW1+d8 | JMP      | @@RW2+d8  | JMP      | @ @ RW3+d8 | JMP      | @ @ RW4+d8 |          | @@RW5+d8  | JMP      | @@RW6+d8  | JMP      | @ @ RW7+d8 | JMP @    | @RW0+d16 | JMP @    | @RW1+d16 | JMP @    | @RW2+d16 | JMP @    | @RW3+d16 | JMP @    | @RW0+RW7 | JMP @    | @RW1+RW7 | JMP      | @@PC+d16   | JMP     | @addr16  |
| 00 | JMP      | @RW0       | JMP      | @RW1            | JMP      | @RW2      |          | @RW3       | JMP      | @RW4       | JMP      | @RW5      | JMP      | @RW6      | JMP      | @RW7       | JMP      | @ @RW0   | JMP      | @@RW1    | JMP      | @@RW2    | JMP      | @@RW3    | JMP      | @@RW0+   | JMP      | @@RW1+   | JMP      | @@RW2+     | JMP     | @ @ RW3+ |
|    | -        | ⊃<br>+     | -        | <br>+           | -        | N<br>+    | -        | ε<br>τ     |          | + +        |          | ი<br>+    |          | + 6       |          | + 7        |          | + 8      |          | 6<br>+   |          | 4 +      |          | я<br>+   |          | ပ<br>+   |          | ก<br>+   |          | ш<br>+     |         | ш<br>+   |

|        | 00      | 10       | 20      | 30       | 40      | 50       | 60      | 70       | 80      | 06       | AO      | BO       | CO      | DO       | EO      | F0       |
|--------|---------|----------|---------|----------|---------|----------|---------|----------|---------|----------|---------|----------|---------|----------|---------|----------|
| 0 1    | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | ОВ      | OR A,    | XOR     | XOR A,   | DBNZ    | DBNZ @   |
| ><br>+ | A,R0    | @RW0+d8  | R0,r    | RW0+d8,r |
|        | ADD     | , ADD A, | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | OR      | OR A,    | XOR     | XOR A,   | DBNZ    | DBNZ @   |
| -<br>+ | A,R1    | @RW1+d8  | R1,r    | RW1+d8,r |
|        | ADD     | , ADD A, | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | Ю       | OR A,    | XOR     | XOR A,   | DBNZ    | DBNZ @   |
| + 2    | A,R2    | @RW2+d8  | R2,r    | RW2+d8,r |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | OR      | OR A,    | XOR     | XOR A,   | DBNZ    | DBNZ @   |
| ν<br>+ | A,R3    | @RW3+d8  | R3,r    | RW3+d8,r |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | OR      | OR A,    | XOR     | XOR A,   | DBNZ    | DBNZ @   |
| + +    | A,R4    | @RW4+d8  | R4,r    | RW4+d8,r |
| 4      | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | OR      | OR A,    | XOR     | XOR A,   | DBNZ    | DBNZ @   |
| 0<br>+ | A,R5    | @RW5+d8  | R5,r    | RW5+d8,r |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | OR      | OR A,    | XOR     | XOR A,   | DBNZ    | DBNZ @   |
| + 6    | A,R6    | @RW6+d8  | R6,r    | RW6+d8,r |
|        | ADD     | , ADD A, | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | OR      | OR A,    | XOR     | XOR A,   | DBNZ    | DBNZ @   |
| + 7    | A,R7    | @RW7+d8  | R7,r    | RW7+d8,r |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | ОЯ      | OR A,    | XOR     | XOR A,   | DBNZ    | DBNZ @R  |
| + 8    | A,@RW0  | @RW0+d16 | @RW0,r  | W0+d16,r |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | OR      | OR A,    | XOR     | XOR A,   | DBNZ    | DBNZ @R  |
| 6 +    | A,@RW1  | @RW1+d16 | @RW1,r  | W1+d16,r |
| -      | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | OR      | OR A,    | XOR     | XOR A,   | DBNZ    | DBNZ @R  |
| +      | A,@RW2  | @RW2+d16 | @RW2,r  | W2+d16,r |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | : CMP A, | AND     | AND A,   | OR      | OR A,    | XOR     | XOR A,   | DBNZ    | DBNZ @R  |
| н<br>Н | A,@RW3  | @RW3+d16 | @RW3,r  | W3+d16,r |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | OR      | OR A,    | XOR     | XOR A,   | DBNZ    | DBNZ @R  |
| с<br>+ | A,@RW0+ | @RW0+RW7 | @RW0+,r | W0+RW7,r |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | OR      | OR A,    | XOR     | XOR A,   | DBNZ    | DBNZ @R  |
| 0 +    | A,@RW1+ | @RW1+RW7 | A,@RW1+ |          | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 |         | @RW1+RW7 | @RW1+,r | W1+RW7,r |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | OR      | OR A,    | XOR     | XOR A,   | DBNZ    | DBNZ @   |
| ш<br>+ | A,@RW2+ | @PC+d16  | A,@RW2+ |          | A,@RW2+ | @PC+d16  | @RW2+,r | PC+d16,r |
|        | ADD     | ADD A,   | SUB     | : SUB A, | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | OR      | OR A,    | XOR     | XOR A,   | DBNZ    | DBNZ     |
| ц<br>+ | A,@RW3+ | addr16   | @RW3+,r | addr16,r |

### Table B.9-10 ea Instruction 5 (first byte = $74_{H}$ )

|                | 00      | 10         | 20      | 30         | 40      | 50       | 60    | 02       | 80      | 06       | AO      | BO         | C0      | DO       | EO    | FO       |
|----------------|---------|------------|---------|------------|---------|----------|-------|----------|---------|----------|---------|------------|---------|----------|-------|----------|
| -              | ADD     | ADD @R     | SUB     | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      | AND     | AND @R   | OR      | OR @R      | XOR     | XOR @R   | NOT   | NOT      |
|                | R0,A    | W0+d8,A    | R0,A    | W0+d8,A    | A,R0    | @RW0+d8  | R0    | @RW0+d8  | R0,A    | W0+d8,A  | R0,A    | W0+d8,A    | R0,A    | W0+d8,A  | 8     | @RW0+d8  |
| -              | ADD     | ADD @R     | SUB     | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      | AND     | AND @R   | OR      | OR @R      | XOR     | XOR @R   | NOT   | NOT      |
| -<br>+         | R1,A    | : W1+d8,A  | R1,A    | : W1+d8,A  | A,R1    | @RW1+d8  | æ     | @RW1+d8  | R1,A    | W1+d8,A  | R1,A    | W1+d8,A    | R1,A    | W1+d8,A  | 뜐     | @RW1+d8  |
| -              | ADD     | ADD @R     | SUB     |            | SUBC    | SUBC A,  | NEG   | NEG      | AND     | AND @R   | OR      | OR @R      | XOR     | XOR @R   | NOT   | NOT      |
| 7 + 7          | R2,A    | W2+d8,A    | R2,A    | W2+d8,A    | A,R2    | @RW2+d8  | R2    | @RW2+d8  | R2,A    | W2+d8,A  | R2,A    | W2+d8,A    | R2,A    | W2+d8,A  | R2    | @RW2+d8  |
| -              | ADD     | ADD @R     | SUB     |            | SUBC    | SUBC A,  | NEG   | NEG      |         | AND @R   | OR      | OR @R      | XOR     | XOR @R   | NOT   | NOT      |
| + 3            | R3,A    | W3+d8,A    | R3,A    | W3+d8,A    | A,R3    | @RW3+d8  | R3    | @RW3+d8  | R3,A    | W3+d8,A  | R3,A    | W3+d8,A    | R3,A    | W3+d8,A  | R3    | @RW3+d8  |
|                | ADD     | ADD @R     | SUB     | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      | AND     | AND @R   | OR      | OR @R      | XOR     | XOR @R   | NOT   | NOT      |
| + 4            | R4,A    | W4+d8,A    | R4,A    | W4+d8,A    | A,R4    | @RW4+d8  | R4    | @RW4+d8  | R4,A    | W4+d8,A  | R4,A    | W4+d8,A    | R4,A    | W4+d8,A  | R4    | @RW4+d8  |
|                | ADD     | ADD @R     | SUB     | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      |         | AND @R   | OR      | OR @R      | XOR     | XOR @R   | NOT   | NOT      |
| 4 9            | R5,A    | W5+d8,A    | R5,A    |            | A,R5    | @RW5+d8  | R5    | @RW5+d8  | R5,A    | W5+d8,A  | R5,A    | W5+d8,A    | R5,A    | W5+d8,A  | R5    | @RW5+d8  |
|                | ADD     | ADD @R     | SUB     | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      | AND     | AND @R   | OR      | OR @R      | XOR     | XOR @R   | NOT   | NOT      |
| + 6            | R6,A    | . W6+d8,A  | R6,A    | : W6+d8,A  | A,R6    | @RW6+d8  | R6    | @RW6+d8  | R6,A    | W6+d8,A  | R6,A    | W6+d8,A    | R6,A    | W6+d8,A  | R6    | @RW6+d8  |
|                | ADD     |            | SUB     |            | SUBC    | SUBC A,  | NEG   | NEG      |         | AND @R   | OR      | OR @R      | XOR     | XOR @R   | NOT   | NOT      |
| + /            | R7,A    | W7+d8,A    | R7,A    | W7+d8,A    | A,R7    | @RW7+d8  | R7    | @RW7+d8  | R7,A    | W7+d8,A  | R7,A    | W7+d8,A    | R7,A    | W7+d8,A  | R7    | @RW7+d8  |
| -              | ADD     | ADD @R     | SUB     | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      |         | AND @R   | OR      | OR @R      | XOR     | XOR @R   | NOT   | NOT      |
| + 8            | @RW0,A  | W0+d16,A   | @RW0,A  | W0+d16,A   | A,@RW0  | @RW0+d16 | @RW0  | @RW0+d16 | @RW0,A  | W0+d16,A | @RW0,A  | W0+d16,A   | @RW0,A  | W0+d16,A | @RW0  | @RW0+d16 |
| -              | ADD     | ADD @R     | SUB     | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      | AND     | AND @R   | OR      | OR @R      | XOR     | XOR @R   | NOT   | NOT      |
| 6 <del>+</del> | @RW1,A  | W1+d16,A   | @RW1,A  | : W1+d16,A | A,@RW1  | @RW1+d16 | @RW1  | @RW1+d16 | W1,A    | W1+d16,A | @RW1,A  | W1+d16,A   | @RW1,A  | W1+d16,A | @RW1  | @RW1+d16 |
|                | ADD     | ADD @R     | SUB     | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      | AND     | AND @R   | OR      | OR @R      | XOR     | XOR @R   | NOT   | NOT      |
| +              | @RW2,A  | 6,A        | @RW2,A  | W2+d16,A   | A,@RW2  | @RW2+d16 | @RW2  | @RW2+d16 | 2,A     | W2+d16,A | @RW2,A  | W2+d16,A   | @RW2,A  | W2+d16,A | @RW2  | @RW2+d16 |
|                | ADD     |            | SUB     | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      | AND     | AND @R   | OR      | OR @R      | XOR     | XOR @R   | NOT   | NOT      |
| + B            | @RW3,A  | W3+d16,A   | @RW3,A  | W3+d16,A   | A,@RW3  | @RW3+d16 | @RW3  | @RW3+d16 | ×,      | W3+d16,A | @RW3,A  | W3+d16,A   | @RW3,A  | W3+d16,A | @RW3  | @RW3+d16 |
|                | ADD     | ADD @R     | SUB     | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      | AND     | AND @R   | OR      | OR @R      | XOR     | XOR @R   | NOT   | NOT      |
| с<br>+         | @RW0+,A | : W0+RW7,A | @RW0+,A | : W0+RW7,A | A,@RW0+ | @RW0+RW7 | @RW0+ | @RW0+RW7 | @RW0+,A | W0+RW7,A | @RW0+,A | : W0+RW7,A | @RW0+,A | W0+RW7,A | @RW0+ | @RW0+RW7 |
|                | ADD     | ADD @R     | SUB     | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      | AND     | AND @R   | OR      | OR @R      | XOR     | XOR @R   | NOT   | NOT      |
| с<br>+         | @RW1+,A | : W1+RW7,A | @RW1+,A | : W1+RW7,A | A,@RW1+ | @RW1+RW7 | @RW1+ | @RW1+RW7 | @RW1+,A | W1+RW7,A | @RW1+,A | : W1+RW7,A | @RW1+,A | W1+RW7,A | @RW1+ | @RW1+RW7 |
|                | ADD     | ADD @P     | SUB     | SUB @P     | SUBC    | SUBC A,  | NEG   | NEG      | AND     | AND @P   | OR      | OR @P      | XOR     | XOR @P   | NOT   | NOT      |
| н<br>+         | @RW2+,A |            | @RW2+,A |            | A,@RW2+ | @PC+d16  | @RW2+ | @PC+d16  | @RW2+,A | C+d16,A  | @RW2+,A | C+d16,A    | @RW2+,A | C+d16,A  | @RW2+ | @PC+d16  |
|                | ADD     | ADD        | SUB     | SUB        | SUBC    | SUBC A,  | NEG   | NEG      | AND     | AND      | OR      | B          | XOR     | XOR      | NOT   | NOT      |
| ц<br>+         | @RW3+,A | addr16,A   | @RW3+,A | addr16,A   | A,@RW3+ | addr16   | @RW3+ | addr16   | @RW3+,A | addr16,A | @RW3+,A | addr16,A   | @RW3+,A | addr16,A | @RW3+ | addr16   |

### Table B.9-11 ea Instruction 6 (first byte = $75_{H}$ )

| ADDW A,<br>@RW0+d8<br>ADDW A,<br>@RW1+d8<br>ADDW A,<br>@RW2+d8<br>ADDW A,<br>@RW3+d8<br>ADDW A,<br>@RW3+d8<br>ADDW A,<br>@RW4+d8<br>ADDW A,<br>@RW4+d8<br>ADDW A,<br>@RW7+d8<br>ADDW A,<br>@RW7+d16<br>ADDW A,<br>@RW1+d16<br>ADDW A,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | SUBW<br>A,RW0<br>SUBW<br>A,RW1<br>SUBW<br>A,RW2<br>SUBW<br>A,RW2<br>SUBW<br>A,RW6<br>A,RW6<br>SUBW | SUBW A,<br>@RW0+d8<br>SUBW A,<br>@RW1+d8<br>SUBW A,<br>@RW2+d8 | ADDCW   |          |         | ſ        |         |          |         |          |         |          |         |          |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|----------------------------------------------------------------|---------|----------|---------|----------|---------|----------|---------|----------|---------|----------|---------|----------|
| C         A,RW0         @RW0+48           1         A,DW         A,DW         A,           2         A,DW         A, A,         A,           3         A,DW         A, A,         A,           4         A,DW         A,DW         A,           5         A,RW3         B,RW1+48         A,           4         A,DW         A,DW         A,           5         A,DW         A,DW         A,           6         A,RW3         B,RW3+48         A,           6         A,DW         A,         A,           6         A,DW         A,         A,           6         A,RW4         B,RW4+48         A,           6         A,RW5         B,RW4+48         A,           7         A,DW         A,         A,           7         A,RW7         B,RW7+48         A,           9         A, B,W1         A,         A,           4         A,         A,         A,           4         A,         A,         A,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                    |                                                                | •       | ADDCW A, | CMPW :: | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @  |
| 1         ADDW         A,<br>A,RW1         B,RW1+d8           2         A,DW         A,RW1         6,RW1+d8           3         ADW         A,RW2         6,RW2+d8           4         A,DW         A,DW         A,<br>A,DW           5         A,DW         A,DW           6         A,DW         A,<br>A,DW         A,RM3           6         A,DW         A,DW         A,RM4           7         A,DW         A,DW         A,<br>A,DW           7         A,DW         A,DW         A,<br>A,0W           8         A,0W         A, A,<br>A,0W         A, A,<br>A,0W           9         A,0W         A, A,<br>A,0W         A, A,<br>A, A, A,<br>A, A, A, A,<br>A, A, A, A, A, A,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                    |                                                                | A,RW0   | @RW0+d8  | RW0,r   | RW0+d8,r |
| ADDW         A.R.M.1         CR.M.1+d8           2         ADDW         A.R.M2         CR.W2+d8           3         ADDW         A.R.M3         CR.W3+d8           4         ADDW         A.R.M3         CR.W3+d8           5         ADW         ADDW         A.           6         ADW         ADDW         A.           7         ADDW         ADDW         A.           7         ADDW         ADDW         A.           8         A.R.W5         CR.W4-d8         A.           7         ADDW         A.DDW         A.           9         A.C.W1         CR.W1+d16         A.           4         ADDW         A.         A.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                    |                                                                | ADDCW   | ADDCW A, | CMPW    | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @  |
| 2         ADDW         A,<br>A,RW2         B, ADW         A,<br>A,RW2         B, ADW         A,<br>A,RW3         B, ADW         A,<br>A,RW3         A,<br>B, A,RW3         A,RW3         B, A,RW3         A,RW4         B, A,RW3         A,RW3         B, A,RW3         A,RW3         B, A,RW3         A,RW3         B, A,RW3         A,RW3 <td>•••••••••••••••••••••••••••••••••••••••</td> <td></td> <td>A,RW1</td> <td>@RW1+d8</td> <td>A,RW1</td> <td>@RW1+d8</td> <td>A,RW1</td> <td>@RW1+d8</td> <td>A,RW1</td> <td>@RW1+d8</td> <td>A,RW1</td> <td>@RW1+d8</td> <td>RW1,r</td> <td>RW1+d8,r</td> | •••••••••••••••••••••••••••••••••••••••                                                            |                                                                | A,RW1   | @RW1+d8  | RW1,r   | RW1+d8,r |
| Z         A,RW2         @RW2+d8           3         ADDW         A,           4         ADDW         A,           5         ADDW         A,           6         ADDW         A,           7         ADDW         A,           8         ADDW         A,           6         ADDW         A,           7         ADDW         A,           8         ADDW         A,           7         A,         ADDW           8         A,         ADDW           9         A,         B,           A,         ADW         ADW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                    |                                                                | ADDCW   | ADDCW A, | CMPW    |          | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @  |
| 3         ADDW         A,<br>A,RW3         B,RW3+d8           4         A,DW         A,<br>A,RW4         B,RW3+d8           5         A,DW         A,<br>A,RW4         B,RW4+d8           6         A,DW         A,<br>A,DW         A,<br>A,DW         A,<br>A,DW           7         A,DW         A,<br>A,BW7         B,RW1+d8           8         A,0DW         A,<br>A,0DW         A,<br>A,<br>A,0DW           9         A,0DW         A,<br>A,0DW         A,<br>A,0DW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | •••••••••••••••••••••••••••••••••••••••                                                            | Ì                                                              | A,RW2   | @RW2+d8  | RW2,r   | RW2+d8,r |
| 3         A,R,W3         @RW3+d8           4         ADDW         A,           5         A,RW4         @RW4+d8           5         A,RW5         @RW5+d8           6         A,RW6         @RW6+d8           7         ADDW         A,           8         A,RW7         @RW6+d8           4         ADW         A,           7         ADW         A,           8         A, @RW6         @RW6+d8           4         ADW         A,           9         A, @RW1         @RW0+d16           4         ADW         ADW           9         A, @RW1         @RW1+d16           4         ADW         ADW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | •••••••••••••••••••••••••••••••••••••••                                                            |                                                                | ADDCW   | ADDCW A, | CMPW    | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @  |
| 4         ADDW         A,<br>A,RW4         B,RW4+d8           5         A,DW         8,RW5+d8         A,<br>A,RW5         8,RW5+d8           6         A,RW6         8,RW6+d8         A,<br>A,RW6         A,DW         A,<br>A,DW         A,DW         A,DW         A,DW                                                                      |                                                                                                    | @RW3+d8                                                        | A,RW3   | @RW3+d8  | A,RW3   | @RW3+d8  | A,RW3   | @RW3+d8  | A,RW3   | @RW3+d8  | A,RW3   | @RW3+d8  | RW3,r   | RW3+d8,r |
| 4         A,R.W4         @RW4+d8           5         ADDW         A,           6         A,R.W5         @RW5+d8           7         ADDW         A,           7         ADDW         A,           8         A, BDW         A,           8         A, BDW         A,           9         A, @RW1-d16         MDW           4         ADDW         A,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                    | SUBW A,                                                        | ADDCW   | ADDCW A, | CMPW    |          | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @  |
| 5         ADDW         A,<br>A,RWIS         BDW         A,<br>B           6         A,RWIS         @RWIS-468         A           7         ADDW         A,<br>A,RWIS         @RWIS-468         A           7         ADDW         A,<br>A,RWIS         @RWIS-468         A           8         A, B, MUT         @RWIS-416         A           9         A, @RWI         @RWIS-416         A           4         ADDW         A         A         A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                    | @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 |
| D         A,R.W5         @RW5+d8           6         A,DW         A,           7         A,DW         A,           7         A,DW         A,           8         A,DW         A,           8         A,00W         A,           9         A,00W         A,           4         A,0W         @RW0+d16           9         A,00W         A,           4         ADW         A,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | A,RW5<br>SUBW<br>A.RW6                                                                             | SUBW A,                                                        | ADDCW   | ADDCW A, | CMPW    | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @  |
| 6 ADDW A,<br>ARW6 @RW6+d8<br>ARW7 @RW7+d8<br>ADDW A,<br>B ADDW A,<br>ADDW A,<br>ADDW A,<br>ADDW A,<br>ADDW A,<br>ADDW A,<br>ADDW A,<br>ADDW A,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | SUBW                                                                                               | @RW5+d8                                                        | A,RW5   | @RW5+d8  | A,RW5   | @RW5+d8  | A,RW5   | @RW5+d8  | A,RW5   | @RW5+d8  | A,RW5   | @RW5+d8  | RW5,r   | RW5+d8,r |
| 6         A,RW6         @RW6+d8           7         ADDW         A,           7         A,RW7         @RW7+d8           8         ADDW         A,           9         A, @RW1         @RW1+d16           ADDW         A,         ADDW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | A.RW6                                                                                              | SUBW A,                                                        | ADDCW   | ADDCW A, | CMPW    | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @  |
| 7 ADDW A,<br>ARW7 @RW7+48<br>B ADDW A,<br>B A,@RW0 @RW0+416<br>9 A,@RW1 @RW1+416<br>ADDW A,<br>ADDW A,<br>ADDW A,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                    | @RW6+d8                                                        | 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 |
| /         A,RW/         @RW/748           8         ADDW         A,           8         A,@RW0         @RW0-416           9         A,@RW1         @RW1416           ADDW         A,         MOW         A,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | SUBW                                                                                               | SUBW A,                                                        | ADDCW   | ADDCW A, | CMPW    | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @  |
| 8         ADDW         ADW         A,           8         A,@RW0         @RW0+d16         0           9         ADDW         A,         0           4         MM1         @RW1+d16         0           ADDW         ADDW         A,         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | A,RW7                                                                                              | @RW7+d8                                                        | A,RW7   | @RW7+d8  | A,RW7   | @RW7+d8  | A,RW7   | @RW7+d8  | A,RW7   | @RW7+d8  | A,RW7   | @RW7+d8  | RW7,r   | RW7+d8,r |
| B         A,@RW0-d16           ADDW         @RW1-d16           9         A,@RW1         @RW1+d16           ADDW         ADDW         A,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | SUBW                                                                                               | SUBW A,                                                        | ADDCW   | ADDCW A, | CMPW    | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @R |
| 9 ADDW ADDW A,<br>9 A,@RW1 @RW1+d16<br>ADDW A,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 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 |
| 9 A,@RW1 @RW1+d16<br>ADDW ADDW A,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | SUBW                                                                                               | SUBW A,                                                        | ADDCW   | ADDCW A, | CMPW    | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @R |
| ADDW ADDW A,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 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 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | SUBW                                                                                               | SUBW A,                                                        | ADDCW   | ADDCW A, | CMPW    | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @R |
| A,@RW2 : @RW2+d16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | A,@RW2                                                                                             | @RW2+d16                                                       | A,@RW2  | @RW2+d16 | A,@RW2  | @RW2+d16 | A,@RW2  | @RW2+d16 | A,@RW2  | @RW2+d16 | A,@RW2  | @RW2+d16 | @RW2,r  | W2+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 @R |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 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 : ADDW A,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | SUBW                                                                                               | SUBW A,                                                        | ADDCW   | ADDCW A, | CMPW    | CMPW A,  | ANDW    | ANDW A,  | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @R |
| @RW0+RW7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | A,@RW0+                                                                                            |                                                                |         | @RW0+RW7 | A,@RW0+ |          | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 | @RW0+,r | W0+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 @R |
| + D A,@RW1+ E @RW1+RW7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | A,@RW1+                                                                                            | @RW1+RW7                                                       | A,@RW1+ | @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 @  |
| W2+ @PC+d16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | +                                                                                                  | @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+ 🗄 addr16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | A,@RW3+                                                                                            | addr16                                                         | A,@RW3+ | addr16   | A,@RW3+ | addr16   | A,@RW3+ | addr16   | A,@RW3+ | addr16   | A,@RW3+ | addr16   | @RW3+,r | addr16,r |

### Table B.9-12 ea Instruction 7 (first byte = $76_{H}$ )

| APPENDIX B | Instructions |
|------------|--------------|
|------------|--------------|

### Table B.9-13 ea Instruction 8 (first byte = $77_{H}$ )

|        | 00              | 10            | 20            | 30            | 40      | 50       | 60    | 20       | 80      | 06       | AO      | B0       | S        | DO       | EO    | FO       |
|--------|-----------------|---------------|---------------|---------------|---------|----------|-------|----------|---------|----------|---------|----------|----------|----------|-------|----------|
| 4      | ADDW            | ADDW @R       | SUBW          | SUBW @R       | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW @R  | ORW     | ORW @R   | XORW     | XORW @R  | NOTW  | NOTW     |
| 5<br>F | RW0,A           | W0+d8,A       | RW0,A W0+d8,A | W0+d8,A       | A,RW0   | @RW0+d8  | RWO   | @RW0+d8  | RW0,A   | W0+d8,A  | RW0,A   | W0+d8,A  | RW0,A    | W0+d8,A  | RWO   | @RW0+d8  |
| -      | ADDW            | ADDW @R       | SUBW          | SUBW @R       | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW @R  | ORW     | ORW @R   | XORW     | XORW @R  | NOTW  | NOTW     |
| -      | RW1,A : W1+d8,A | W1+d8,A       | RW1,A         | W1+d8,A       | A,RW1   | @RW1+d8  | RW1   | @RW1+d8  | RW1,A   | W1+d8,A  | RW1,A   | W1+d8,A  | RW1,A    | W1+d8,A  | RW1   | @RW1+d8  |
| -      | ADDW            | ADDW @R       | SUBW          | SUBW @R       | SUBCW   | SUBCW A, | NEGW  |          |         | ANDW @R  | ORW     | ORW @R   | XORW     | XORW @R  | NOTW  | NOTW     |
| N +    | RW2,A           | W2+d8,A       | RW2,A         | W2+d8,A       | A,RW2   | @RW2+d8  | RW2   | @RW2+d8  | RW2,A   | W2+d8,A  | RW2,A   | W2+d8,A  | RW2,A    | W2+d8,A  | RW2   | @RW2+d8  |
| -      | ADDW            |               |               |               | SUBCW   | SUBCW A, | NEGW  |          |         | ANDW @R  | ORW     | ORW @R   | XORW     | XORW @R  | NOTW  | NOTW     |
| n<br>+ | RW3,A           | : W3+d8,A     | RW3,A         | W3+d8,A       | A,RW3   | @RW3+d8  | RW3   | @RW3+d8  | RW3,A   | W3+d8,A  | RW3,A   | W3+d8,A  | RW3,A    | W3+d8,A  | RW3   | @RW3+d8  |
| -      | ADDW            | ADDW @R       |               | SUBW @R       | SUBCW   | SUBCW A, | NEGW  |          |         | ANDW @R  | ORW     | ORW @R   | XORW     | XORW @R  | NOTW  | NOTW     |
| + 4    | RW4,A           | RW4,A W4+d8,A | RW4,A         | W4+d8,A       | A,RW4   | @RW4+d8  | RW4   | @RW4+d8  | RW4,A   | W4+d8,A  | RW4,A   | W4+d8,A  | RW4,A    | W4+d8,A  | RW4   | @RW4+d8  |
|        | ADDW            | ADDW @R       | SUBW          | SUBW @R       | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW @R  | ORW     | ORW @R   | XORW     | XORW @R  | NOTW  | NOTW     |
| ი<br>+ | RW5,A           | W5+d8,A       | RW5,A         | W5+d8,A       | A,RW5   | @RW5+d8  | RW5   | @RW5+d8  | RW5,A   | W5+d8,A  | RW5,A   | W5+d8,A  | RW5,A    | W5+d8,A  | RW5   | @RW5+d8  |
| -      | ADDW            | ADDW @R       | SUBW          | SUBW @R       | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW @R  | ORW     | ORW @R   | XORW     | XORW @R  | NOTW  | NOTW     |
| 9+     | RW6,A           | : W6+d8,A     | RW6,A         | W6+d8,A       | A,RW6   | @RW6+d8  | RW6   | @RW6+d8  | RW6,A   | W6+d8,A  | RW6,A   | W6+d8,A  | RW6,A    | W6+d8,A  | RW6   | @RW6+d8  |
|        | ADDW            |               | SUBW          | SUBW @R       | SUBCW   | SUBCW A, | NEGW  |          | ANDW    | ANDW @R  | ORW     | ORW @R   | XORW     | XORW @R  | NOTW  | NOTW     |
| × +    | RW7,A           | W7+d8,A       | RW7,A         | RW7,A W7+d8,A | A,RW7   | @RW7+d8  | RW7   | @RW7+d8  | RW7,A   | W7+d8,A  | RW7,A   | W7+d8,A  | RW7,A    | W7+d8,A  | RW7   | @RW7+d8  |
|        | ADDW            | ADDW @R       | SUBW          | SUBW @R       | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW @R  | ORW     | ORW @R   | XORW     | XORW @R  | NOTW  | NOTW     |
| 8+     | @RW0,A          | W0+d16,A      | @RW0,A        | W0+d16,A      | A,@RW0  | @RW0+d16 | @RW0  | @RW0+d16 | @RW0,A  | W0+d16,A | @RW0,A  | W0+d16,A | @RW0,A   | W0+d16,A | @RW0  | @RW0+d16 |
| -      | ADDW            | ADDW @R       | SUBW          | SUBW @R       | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW @R  | ORW     | ORW @R   | XORW     | XORW @R  | NOTW  | NOTW     |
| 6<br>+ | @RW1,A          |               |               | W1+d16,A      | A,@RW1  | @RW1+d16 | @RW1  | d16      | 1,A     | W1+d16,A | @RW1,A  | W1+d16,A | @RW1,A   | W1+d16,A | @RW1  | @RW1+d16 |
| -      | ADDW            | ADDW @R       | SUBW          | SUBW @R       | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW @R  | ORW     | ORW @R   | XORW     | XORW @R  | NOTW  | NOTW     |
| + +    | @RW2,A          |               | @RW2,A        | W2+d16,A      | A,@RW2  | @RW2+d16 | @RW2  | @RW2+d16 | @RW2,A  | W2+d16,A | @RW2,A  | W2+d16,A | @RW2,A   | W2+d16,A | @RW2  | @RW2+d16 |
|        | ADDW            | : ADDW @R     | SUBW          | SUBW @R       | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW @R  | ORW     | ORW @R   | XORW     | XORW @R  | NOTW  | NOTW     |
| я<br>+ | @RW3,A          | W3+d16,A      | @RW3,A        | W3+d16,A      | A,@RW3  | @RW3+d16 | @RW3  | @RW3+d16 | @RW3,A  | W3+d16,A | @RW3,A  | W3+d16,A | @RW3,A   | W3+d16,A | @RW3  | @RW3+d16 |
|        | ADDW            | ADDW @R       | SUBW          | SUBW @R       | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW @R  | ORW     | ORW @R   | XORW     | XORW @R  | NOTW  | NOTW     |
| ပ<br>+ | @RW0+,A         |               | @RW0+,A       | W0+RW7,A      | A,@RW0+ | @RW0+RW7 | @RW0+ | @RW0+RW7 | @RW0+,A | W0+RW7,A | @RW0+,A | W0+RW7,A | @ RW0+,A | W0+RW7,A | @RW0+ | @RW0+RW7 |
| -      | ADDW            | : ADDW @R     | SUBW          | SUBW @R       | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW @R  | ORW     | ORW @R   | XORW     | XORW @R  | NOTW  | NOTW     |
| с<br>Н | @RW1+,A         |               | @RW1+,A       | W1+RW7,A      | A,@RW1+ | @RW1+RW7 | @RW1+ | @RW1+RW7 | @RW1+,A | W1+RW7,A | @RW1+,A | W1+RW7,A | @RW1+,A  | W1+RW7,A | @RW1+ | @RW1+RW7 |
|        | ADDW            | ADDW @P       | SUBW          | SUBW @P       | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW @P  | ORW     | ORW @P   | XORW     | XORW @P  | NOTW  | NOTW     |
| ш<br>+ | @RW2+,A         |               | @RW2+,A       | C+d16,A       | A,@RW2+ | @PC+d16  | @RW2+ | 16       | <       |          | @RW2+,A | C+d16,A  | @RW2+,A  | C+d16,A  | @RW2+ | @PC+d16  |
| -      | ADDW            | ADDW          | SUBW          | SUBW          | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW     | ORW     | ORW      | XORW     | XORW     | NOTW  | NOTW     |
| ⊥<br>+ | @RW3+,A         | addr16,A      | @RW3+,A       | addr16,A      | A,@RW3+ | addr16   | @RW3+ | addr16   | @RW3+,A | addr16,A | @RW3+,A | addr16,A | @RW3+,A  | addr16,A | @RW3+ | addr16   |

|        | 00      | 10        | 20      | 30         | 40      | 50       | 60      | 70       | 80      | 06        | AO      | BO         | õ       | DO       | EO      | FO       |
|--------|---------|-----------|---------|------------|---------|----------|---------|----------|---------|-----------|---------|------------|---------|----------|---------|----------|
|        | MULU    | : MULU A, | MULUW   | MULUW A,   | MUL     | MUL A,   | MULW    | MULW A,  | DIVU    | DIVU A,   | DIVUW   | DIVUW A,   | DIV     | DIV A,   | DIVW    | DIVW A,  |
| ⊃<br>+ | A,R0    | @RW0+d8   | A,RW0   | @ RW0+d8   | A R0    | @ RW0+d8 | A,RW0   | @ RW0+d8 | A,R0    | @RW0+d8   | A,RW0   | @RW0+d8    | A,R0    | @RW0+d8  | A,RW0   | @RW0+d8  |
| -      | MULU    | MULU A,   | MULUW   | MULUW A,   | MUL     | MUL A,   | MULW    | MULW A,  | DIVU    | DIVU A,   | DIVUW   | DIVUW A,   | DIV     | DIV A,   | MVID    | DIVW A,  |
| +      | A,R1    | @RW1+d8   | A,RW1   | @RW1+d8    | A,R1    | @RW1+d8  | A,RW1   | @RW1+d8  | A,R1    | @RW1+d8   | A,RW1   | @RW1+d8    | A,R1    | @RW1+d8  | A,RW1   | @RW1+d8  |
|        | MULU    | MULU A,   | MULUW   | MULUW A,   | MUL     | MUL A,   | MULW    | MULW A,  | DIVU    | DIVU A,   | DIVUW   | DIVUW A,   | DIV     | DIV A,   | DIVW    | DIVW A,  |
| ~<br>+ | A,R2    | @RW2+d8   | A,RW2   | @RW2+d8    | A,R2    | @RW2+d8  | A RW2   | @ RW2+d8 | A,R2    | @RW2+d8   | A,RW2   | @RW2+d8    | A,R2    | @RW2+d8  | A,RW2   | @RW2+d8  |
| -      | MULU    | MULU A,   | MULUW   | MULUW A,   | MUL     | MUL A,   | MULW    | MULW A,  | DIVU    | DIVU A,   | DIVUW   | DIVUW A,   | DIV     | DIV A,   | DIVW    | DIVW A,  |
| + 3    | A,R3    | @RW3+d8   | A,RW3   | @RW3+d8    | A,R3    | @RW3+d8  | A RW3   | @RW3+d8  | A,R3    | @RW3+d8   | A,RW3   | @RW3+d8    | A,R3    | @RW3+d8  | A,RW3   | @RW3+d8  |
| -      | MULU    | : MULU A, | MULUW   | MULUW A,   | MUL     | MUL A,   | MULW    | MULW A,  | DIVU    | DIVU A,   | DIVUW   | DIVUW A,   | DIV     | DIV A,   | DIVW    | DIVW A,  |
| + 4    | A,R4    | @RW4+d8   | A,RW4   | @RW4+d8    | A,R4    | @RW4+d8  | A RW4   | @RW4+d8  | A,R4    | @RW4+d8   | A,RW4   | @RW4+d8    | A,R4    | @RW4+d8  | A,RW4   | @RW4+d8  |
|        | MULU    | MULU A,   | MULUW   | MULUW A,   | MUL     | MUL A,   | MULW    | MULW A,  | DIVU    | DIVU A,   | DIVUW   | DIVUW A,   | DIV     | DIV A,   | DIVW    | DIVW A,  |
| ۹<br>+ | A,R5    | @RW5+d8   | A,RW5   | @RW5+d8    | A,R5    | @RW5+d8  | A RW5   | @RW5+d8  | A,R5    | @RW5+d8   | A,RW5   | @RW5+d8    | A,R5    | @RW5+d8  | A,RW5   | @ RW5+d8 |
|        | MULU    | : MULU A, | MULUW   | MULUW A,   | MUL     | WUL A,   | MULW    | MULW A,  | DIVU    | DIVU A,   | DIVUW   | DIVUW A,   | DIV     | DIV A,   | DIVW    | DIVW A,  |
| 9+     | A,R6    | @RW6+d8   | A,RW6   |            | A R6    | @RW6+d8  | A,RW6   | @RW6+d8  | A,R6    | @RW6+d8   | A,RW6   | @RW6+d8    | A,R6    | @RW6+d8  | A,RW6   | @RW6+d8  |
|        | MULU    | MULU A,   | MULUW   | MULUW A,   | MUL     | WUL A,   | MULW    | MULW A,  | DIVU    | DIVU A,   | DIVUW   | DIVUW A,   | DIV     | DIV A,   | DIVW    | DIVW A,  |
| + 7    | A,R7    | @RW7+d8   | A,RW7   | @RW7+d8    | A,R7    | @RW7+d8  | A,RW7   | @RW7+d8  | A,R7    | @RW7+d8   | A,RW7   | @RW7+d8    | A,R7    | @RW7+d8  | A,RW7   | @RW7+d8  |
|        | MULU    | : MULU A, | MULUW   | : Muluw A, | MUL     | MUL A,   | MULW    | MULW A,  | DIVU    | DIVU A,   | DIVUW   | DIVUW A,   | DIV     | DIV A,   | DIVW    | DIVW A,  |
| +      | A,@RW0  | @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 | A,@RW0  | @RW0+d16 |
|        | MULU    | MULU A,   | MULUW   | MULUW A,   | MUL     | WUL A,   | MULW    | MULW A,  | DIVU    | DIVU A,   | DIVUW   | DIVUW A,   | DIV     | DIV A,   | DIVW    | DIVW A,  |
| 6+     | A,@RW1  | @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 | A,@RW1  | @RW1+d16 |
|        | MULU    | MULU A,   | MULUW   | MULUW A,   | MUL     | WUL A,   | MULW    | MULW A,  | DIVU    | DIVU A,   | DIVUW   | : DIVUW A, | DIV     | DIV A,   | DIVW    | DIVW A,  |
| +      | A,@RW2  | @RW2+d16  | A,@RW2  | @RW2+d16   | A,@RW2  | @RW2+d16 | A,@RW2  | @RW2+d16 | A,@RW2  | @RW2+d16  | A,@RW2  | @RW2+d16   | A,@RW2  | @RW2+d16 | RW2     | @RW2+d16 |
|        | MULU    | MULU A,   | MULUW   | MULUW A,   | MUL     | WUL A,   | MULW    | MULW A,  | DIVU    | : DIVU A, | DIVUW   | : DIVUW A, | DIV     | DIV A,   |         | DIVW A,  |
| + 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 | A,@RW3  | @RW3+d16 |
|        | MULU    | MULU A,   | MULUW   | MULUW A,   | MUL     | WUL A,   | MULW    | MULW A,  | DIVU    | DIVU A,   | DIVUW   | DIVUW A,   | DIV     | DIV A,   | DIVW    | DIVW A,  |
| с<br>+ | A,@RW0+ | @RW0+RW7  | A,@RW0+ | @RW0+RW7   | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7  | A,@RW0+ | @RW0+RW7   | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 |
|        | MULU    | MULU A,   | MULUW   | MULUW A,   | MUL     | MUL A,   | MULW    | MULW A,  | DIVU    | DIVU A,   | DIVUW   | DIVUW A,   | DIV     | DIV A,   | DIVW    | DIVW A,  |
| 0<br>+ | A,@RW1+ | @RW1+RW7  | A,@RW1+ | @RW1+RW7   | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7  | A,@RW1+ | @RW1+RW7   | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 |
|        | MULU    | MULU A,   | MULUW   | MULUW A,   | MUL     | MUL A,   | MULW    | MULW A,  | DIVU    | DIVU A,   | DIVUW   | DIVUW A,   | DIV     | DIV A,   | DIVW    | DIVW A,  |
| ш<br>+ | A,@RW2+ | @PC+d16   |         | @PC+d16    | A @RW2+ | @PC+d16  | A,@RW2+ | @PC+d16  | A,@RW2+ | @PC+d16   | A,@RW2+ | @PC+d16    | A,@RW2+ | @PC+d16  | {W2+    | @PC+d16  |
|        | MULU    | MULU A,   | MULUW   | : MULUW A, | MUL     | WUL A,   | MULW    | MULW A,  | DIVU    | : DIVU A, | DIVUW   | : DIVUW A, | DIV     | DIV A,   | DIVW    | DIVW A,  |
| ц<br>+ | A,@RW3+ | addr16    | A,@RW3+ | addr16     | A,@RW3+ | addr16   | A,@RW3+ | addr16   | A,@RW3+ | addr16    | A,@RW3+ | addr16     | A,@RW3+ | addr16   | A,@RW3+ | addr16   |

### Table B.9-14 ea Instruction 9 (first byte = $78_{H}$ )

|        | 00       | 10        | 20       | 30        | 40       | 50        | 60       | 70        | 80       | 06        | AO       | BO          | CO       | DO        | EO       | FO        |
|--------|----------|-----------|----------|-----------|----------|-----------|----------|-----------|----------|-----------|----------|-------------|----------|-----------|----------|-----------|
| -      | MOVEA    | MOVEA RW0 | MOVEA    | MOVEA RW1 | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA    | MOVEA RW5   | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA RW7 |
|        | 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   |
| -      | MOVEA    |           |          | MOVEA RW1 | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA    | MOVEA RW5   | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA 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   |
|        | MOVEA    |           |          | MOVEA RW1 | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA    | MOVEA RW5   | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA RW7 |
| х<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   |
|        | MOVEA    | _         |          | MOVEA RW1 | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA    | MOVEA RW5   | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA RW7 |
| ۶<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  |
|        | MOVEA    |           | MOVEA    | MOVEA RW1 | MOVEA    | MOVEA RW2 | ≥        | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA    | MOVEA RW5   | 2        | MOVEA RW6 | MOVEA    | MOVEA RW7 |
| +<br>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   |
|        | MOVEA    |           |          | MOVEA RW1 | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA    | MOVEA RW5   | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA RW7 |
| ი<br>+ | 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   |
|        | MOVEA    |           |          | MOVEA RW1 | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA    | MOVEA RW5   | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA 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   |
|        | MOVEA    | MOVEA RW0 | MOVEA    | MOVEA RW1 | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA    | MOVEA RW5   | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA RW7 |
| + 2    | 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  |
|        | MOVEA    |           |          | MOVEA RW1 | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA    | MOVEA RW5   | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA RW7 |
| ∞<br>+ | 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 |
|        | MOVEA    |           |          | MOVEA RW1 | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA    | MOVEA RW5   | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA RW7 |
| 6+     | 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 |
|        | MOVEA    | MOVEA RW0 | MOVEA    | MOVEA RW1 | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA    | MOVEA RW5   | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA RW7 |
| +      | 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 |
|        | MOVEA    | MOVEA RW0 | MOVEA    | MOVEA RW1 | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA    | MOVEA RW5   | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA 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 |
|        | MOVEA R  | MOVEA RW0 | MOVEA R  | MOVEA RW1 | MOVEA R  | MOVEA RW2 | MOVEA R  | MOVEA RW3 | MOVEA R  | MOVEA RW4 | MOVEA R  | MOVEA RW5   | MOVEA R  | MOVEA RW6 | MOVEA R  | MOVEA RW7 |
| ပ<br>+ | W0,@RW0+ |           | 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  |
|        | MOVEA R  | MOVEA RW0 | MOVEA R  | MOVEA RW1 | MOVEA R  | MOVEA RW2 | MOVEA R  | MOVEA RW3 | MOVEA R  | MOVEA RW4 | MOVEA R  | MOVEA RW5   | MOVEA R  | MOVEA RW6 | MOVEA R  | MOVEA 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 |
|        | MOVEA R  | MOVEA RW0 | MOVEA R  | MOVEA RW1 | MOVEA R  | MOVEA RW2 | MOVEA R  | MOVEA RW3 | MOVEA R  | MOVEA RW4 | MOVEA R  | MOVEA RW5   | MOVEA R  | MOVEA RW6 | MOVEA R  | MOVEA RW7 |
| н<br>Н | W0,@RW2+ |           | 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  |
|        | MOVEA R  | MOVEA RW0 | MOVEA R  | MOVEA RW1 | MOVEA R  | MOVEA RW2 | MOVEA R  | MOVEA RW3 | MOVEA R  | MOVEA RW4 | MOVEA R  | : MOVEA RW5 | MOVEA R  | MOVEA RW6 | MOVEA R  | MOVEA RW7 |
| ш<br>+ | W0,@RW3+ | ,addr16   | W1,@RW3+ | ,addr16   | W2,@RW3+ | ,addr16   | W3,@RW3+ | ,addr16   | W4,@RW3+ | ,addr16   | W5,@RW3+ | ,addr16     | W6,@RW3+ | ,addr16   | W7,@RW3+ | ,addr16   |

### Table B.9-15 MOVEA RWi, ea Instruction (first byte = $79_H$ )

|        | 00      | 10              | 20      | 30              | 40      | 50       | 60      | 70        | 80      | 06       | AO      | BO       | c       | D0       | EO      | FO       |
|--------|---------|-----------------|---------|-----------------|---------|----------|---------|-----------|---------|----------|---------|----------|---------|----------|---------|----------|
| -      | MOV     | MOV R0,         | MOV     | MOV R1,         | MOV     | MOV R2,  | MOV     | : MOV R3, | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,  | MOV     | MOV R7,  |
| o +    | R0,R0   | @RW0+d8         | R1,R0   | @RW0+d8         | 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     | MOV R0,         | MOV     | MOV R1,         | MOV     | MOV R2,  | MOV     | MOV R3,   | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,  | MOV     | MOV R7,  |
| -+     | R0,R1   | @RW1+d8         | R1,R1   | @RW1+d8         | R2,R1   | @RW1+d8  | R3,R1   | @RW1+d8   | R4,R1   | @RW1+d8  | R5,R1   | @RW1+d8  | R6,R1   | @RW1+d8  | R7,R1   | @RW1+d8  |
|        | MOV     | MOV R0,         | MOV     |                 | MOV     | MOV R2,  | MOV     | MOV R3,   | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,  | MOV     | MOV R7,  |
| х<br>+ | R0,R2   | @RW2+d8         | R1,R2   | @RW2+d8         | R2,R2   | @RW2+d8  | R3,R2   | @RW2+d8   | R4,R2   | @RW2+d8  | R5,R2   | @RW2+d8  | R6,R2   | @RW2+d8  | R7,R2   | @RW2+d8  |
| -      | MOV     |                 | MOV     |                 | MOV     | MOV R2,  | MOV     | MOV R3,   | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,  | MOV     | MOV R7,  |
| ۶<br>+ | R0,R3   | @RW3+d8         | R1,R3   | @RW3+d8         | 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 R0,         |         | MOV R1,         | MOV     | MOV R2,  | MOV     | MOV R3,   | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,  | MOV     | MOV R7,  |
| + 4    | R0,R4   | @RW4+d8         | 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  |
|        | MOV     | MOV R0,         | MOV     | MOV R1,         | MOV     | MOV R2,  | MOV     | MOV R3,   | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,  | MOV     | MOV R7,  |
| ¢<br>4 | R0,R5   | @RW5+d8         | 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  |
|        | MOV     | MOV R0,         | MOV     | MOV R1,         | MOV     | MOV R2,  | MOV     | MOV R3,   | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,  | MOV     | MOV R7,  |
| 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  |
|        | MOV     | MOV R0,         | MOV     | MOV R1,         | MOV     | MOV R2,  | MOV     | MOV R3,   | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,  | MOV     | MOV R7,  |
| L +    | R0,R7   | @RW7+d8         | R1,R7   |                 | R2,R7   | @RW7+d8  | R3,R7   | @RW7+d8   | R4,R7   | @RW7+d8  | R5,R7   | @RW7+d8  | R6,R7   | @RW7+d8  | R7,R7   | @RW7+d8  |
|        | MOV     | MOV R0,         | MOV     | MOV R1,         | MOV     | MOV R2,  | MOV     | MOV R3,   | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,  | MOV     | MOV R7,  |
| 8+     | R0,@RW0 | @RW0+d16        | R1,@RW0 | @RW0+d16        | R2,@RW0 | @RW0+d16 | R3,@RW0 | @RW0+d16  | R4,@RW0 | @RW0+d16 | R5,@RW0 | @RW0+d16 | R6,@RW0 | @RW0+d16 | R7,@RW0 | @RW0+d16 |
|        | MOV     | MOV R0,         | MOV     | MOV R1,         | MOV     | MOV R2,  | MOV     | MOV R3,   | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,  | MOV     | MOV R7,  |
| 6+     | 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 |
|        | MOV     | MOV R0,         | MOV     | MOV R1,         | MOV     | MOV R2,  | MOV     | MOV R3,   | NOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,  | NOM     | MOV R7,  |
| +      | R0,@RW2 | @RW2+d16        | 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 |
|        | MOV     | MOV R0,         | MOV     | MOV R1,         | MOV     | MOV R2,  | MOV     | : MOV R3, | NOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,  | NOV     | MOV R7,  |
| 9<br>+ | R0,@RW3 | @RW3+d16        | R1,@RW3 | @RW3+d16        | R2,@RW3 | @RW3+d16 | R3,@RW3 | @RW3+d16  | R4,@RW3 | @RW3+d16 | R5,@RW3 | @RW3+d16 | R6,@RW3 | @RW3+d16 | R7,@RW3 | @RW3+d16 |
|        | MOV R0, | MOV R0,         | MOV R1, | MOV R1,         | MOV R2, | MOV R2,  | MOV R3, | MOV R3,   | MOV R4, | MOV R4,  | MOV R5, | MOV R5,  | MOV R6, | MOV R6,  | MOV R7, | MOV R7,  |
| ပ<br>+ | @RW0+   | @RW0+RW7        | _       | @RW0+RW7        | @RW0+   | @RW0+RW7 | @RW0+   | @RW0+RW7  | @RW0+   | @RW0+RW7 | @RW0+   | @RW0+RW7 | @RW0+   | @RW0+RW7 | @RW0+   | @RW0+RW7 |
|        | MOV R0, | MOV R0, MOV R0, | MOV R1, | MOV R1,         | MOV R2, | MOV R2.  | MOV R3, | MOV R3,   | MOV R4, | MOV R4,  | MOV R5, | MOV R5,  | MOV R6, | MOV R6,  | MOV R7, | MOV R7,  |
| 0<br>+ | @RW1+   | @RW1+RW7        | @RW1+   |                 | @RW1+   | @RW1+RW7 | @RW1+   | @RW1+RW7  | @RW1+   | @RW1+RW7 | @RW1+   | @RW1+RW7 | @RW1+   | @RW1+RW7 | @RW1+   | @RW1+RW7 |
|        | MOV R0, | MOV R0,         | MOV R1, | MOV R1,         | MOV R2, | MOV R2,  | MOV R3, | MOV R3,   | MOV R4, | MOV R4,  | MOV R5, | MOV R5,  | MOV R6, | MOV R6,  | MOV R7, | MOV R7,  |
| ш<br>+ | @RW2+   | @PC+d16         |         | @PC+d16         | @RW2+   | @PC+d16  | @RW2+   |           | @RW2+   | @PC+d16  | @RW2+   | @PC+d16  | @RW2+   |          | -       | @PC+d16  |
|        | MOV R0, | MOV R0, MOV R0, |         | MOV R1, MOV R1, | MOV R2, | MOV R2,  | MOV R3, | MOV R3,   | MOV R4, | MOV R4,  | MOV R5, | MOV R5,  | MOV R6, | MOV R6,  | MOV R7, | MOV R7,  |
| ц<br>+ | @RW3+   | addr16          | @RW3+   | addr16          | @RW3+   | addr16   | @RW3+   | addr16    | @RW3+   | addr16   | @RW3+   | addr16   | @RW3+   | addr16   | @RW3+   | addr16   |

### Table B.9-16 MOV Ri, ea Instruction (first byte = $7A_H$ )

| 00 10 20 30 | MOVW : MOVW RWO MOVW | T 0 RW0,RW0 @RW0+d8 RW1,RW0 @RV | MOVW RW0 MOVW | + 1 RW0,RW1 ; ,@RW1+d8 RW1,RW1 ; ,@RV | MOVW RW0 MOVW : 1 | + 2 RW0,RW2 @RW2+d8 RW1,RW2 @RV | MOVW RW0 MOVW | + 3 RW0,RW3 @RW3+d8 RW1,RW3 @RV | MOVW RW0 MOVW : N | + 4 RW0,RW4 ; ,@RW4+d8 RW1,RW4 ; ,@RV | MOVW BW0 MOVW | + 5 RW0,RW5 @RW5+d8 RW1,RW5 @RV | MOVW RW0 MOVW | + 6 RW0,RW6 @RW6+d8 RW1,RW6 @RV | MOVW RW0 MOVW : 1 | + 7 RW0,RW7 8 (@RW7+d8 RW1,RW7 6 (@RV | MOVW :MOVW RWO, MOVW N | + 8 RWO,@RW0 : @RW0+d16 RW1,@RW0 : @RW0 | MOVW MOVW RWO, MOVW | @RW1+d16 RW1,@RW1 | MOVW MOVW RWO, MOVW | + A RWO,@RW2 @RW2+d16 RW1,@RW2 @RW2 | MOVW RWO, MOVW | + B RWO,@RW3 @RW3+d16 RW1,@RW3 @RW3 | MOVW R MOVW RWO, MOVW R | @RW0+RW7 W1,@RW0+ : | MOVW R MOVW RWO, MOVW R | + D W0,@RW1+ :@RW1+RW7 W1,@RW1+ :@RW1+ | MOVW R MOVW RWO MOVW R | W1,@RW2+         | MOVW R : MOVW RW MOVW R : MOVW RW |             |
|-------------|----------------------|---------------------------------|---------------|---------------------------------------|-------------------|---------------------------------|---------------|---------------------------------|-------------------|---------------------------------------|---------------|---------------------------------|---------------|---------------------------------|-------------------|---------------------------------------|------------------------|-----------------------------------------|---------------------|-------------------|---------------------|-------------------------------------|----------------|-------------------------------------|-------------------------|---------------------|-------------------------|----------------------------------------|------------------------|------------------|-----------------------------------|-------------|
| 30 4        | MOVW RW1 MOVW        | @RW0+d8 RW2                     | ~             | ,@RW1+d8 RW2                          | ~                 | @RW2+d8 RW2                     | ~             | ,@RW3+d8 RW2                    | MOVW RW1 MOVW     | @RW4+d8 RW2                           |               |                                 | 2             | ,@RW6+d8 RW2                    | MOVW RW1 MOVW     | ,@RW7+d8 RW2                          | MOVW RW1, MOVW         | @RW0+d16 RW2, (                         | MOVW RW1, MOVW      |                   | MOVW RW1, MOVW      | @RW2+d16 RW2, (                     | MOVW RW1, MOVW | @RW3+d16 RW2, (                     | MOVW RW1, MOVW          | @RW0+RW7 W2,@       | MOVW RW1, MOVW          | @RW1+RW7 W2,@                          | MOVW RW1 MOVW          |                  | W RW MOVW                         |             |
| 40          |                      | RW2,RW0 ,6                      |               | RW2,RW1 ,6                            |                   | RW2,RW2 : .6                    |               | RW2,RW3 .                       | . <del>.</del> .  | RW2,RW4 : .(                          |               | RW2,RW5 .(                      | ž             | RW2,RW6 : ,@                    | -                 | RW2,RW7 : ,@                          | 2                      | RW2,@RW0 : @F                           | -                   | RW2,@RW1 🗍 @F     | <                   | RW2,@RW2 @F                         | 2              | RW2,@RW3 6                          |                         | W2,@RW0+ ┊@R'       | Ē                       | W2,@RW1+ : @R                          | œ                      | W2,@RW2+         | Е                                 |             |
| 50          | MOVW RW2 MOVW        | @RW0+d8 RW                      | NOVW RW2 MOVW | @RW1+d8 RW                            | MOVW RW2 MOVW     | @RW2+d8 RW                      | ~             | @RW3+d8 RW                      | MOVW RW2 MOVW     | @RW4+d8 RW                            | MOVW RW2 MOVW | @RW5+d8 RW                      |               | @RW6+d8 RW                      | AOVW RW2 MOVW     | @RW7+d8 RW                            | AOVW RW2, MOVW         | @RW0+d16 RW3                            | AOVW RW2, MOVW      | @RW1+d16 RW3      | AOVW RW2, MOVW      | @RW2+d16 RW3                        | 10VW RW2, MOVW | @RW3+d16 RW3                        | MOVW RW2, MOVW          | @RW0+RW7 W3, @      | MOVW RW2, MOVW          | @RW1+RW7 W3, @                         | MOVW RW2 MOVW          | @PC+d16 W3, @    | NOVW RW MOVW                      |             |
| 60          |                      | RW3,RW0                         |               | RW3,RW1                               | ž                 | RW3,RW2                         |               | RW3,RW3                         | .2.               | RW3,RW4                               |               | RW3,RW5                         | Σ             | RW3,RW6                         | . <del>-</del> .  | RW3,RW7                               | <                      | RW3,@RW0 : @                            | <u> </u>            | RW3,@RW1 = @      | -                   | RW3,@RW2 6                          |                | RW3,@RW3 🗧 @                        | Ē                       | W3,@RW0+ 🗄 @I       | -<br>-                  | W3,@RW1+ : @I                          | Ē                      | W3,@RW2+         | Ē                                 |             |
| 70          | AOVW RW3 N           | @RW0+d8                         | NOVW RW3 N    | @RW1+d8                               | _                 | @RW2+d8                         | _             | @RW3+d8                         | 10VW RW3 N        | @RW4+d8                               | MOVW RW3 N    | @RW5+d8                         |               | @RW6+d8                         | AOVW RW3 N        | @RW7+d8                               | AOVW RW3, N            | @RW0+d16 R                              | AOVW RW3, N         | @RW1+d16 R        | AOVW RW3, N         | @RW2+d16 R                          | AOVW RW3, M    | @RW3+d16 R                          | MOVW RW3, N             | @RW0+RW7            | MOVW RW3, N             | @RW1+RW7                               | MOVW RW3 N             | @PC+d16 W        | MOVW RW N                         |             |
| 80          | MOVW                 | RW4,RW0                         | MOWW          | RW4, RW1                              | MOVW              | RW4,RW2                         | Movw          | RW4,RW3                         | Movw              | RW4,RW4                               | MOVW          | RW4,RW5                         | MOVW          | RW4,RW6                         | MOVW              | RW4,RW7                               | MOVW                   | RW4,@RW0                                | MOVW                | RW4,@RW1          | MOW                 | RW4,@RW2                            | MOVW :         | RW4,@RW3                            | MOVW R 1                | W4,@RW0+            | MOVW R 1                | W4,@RW1+                               | MOVW R                 | W4,@RW2+         | MOVW R 1                          |             |
| 06          | MOVW RW4             | @RW0+d8                         | MOVW RW4      | ,@RW1+d8                              |                   | @RW2+d8                         |               | ,@RW3+d8                        | MOVW RW4          | ,@RW4+d8                              | MOVW RW4      | ,@RW5+d8                        | MOVW RW4      | @RW6+d8                         | MOVW RW4          | ,@RW7+d8                              | MOVW RW4,              | @RW0+d16                                | MOVW RW4,           | @RW1+d16          | MOVW RW4,           | @RW2+d16                            | MOVW RW4,      | @RW3+d16                            | MOVW RW4,               | @RW0+RW7            | MOVW RW4,               | @RW1+RW7                               | MOVW RW4               | ,@PC+d16         | MOVW RW                           | 0 1 1 1 1 1 |
| AO          | MOVW                 | RW5,RW0                         | MOW           | RW5,RW1                               | MOVW              | RW5,RW2                         | MOVW          | RW5,RW3                         | MOVW              | RW5,RW4                               | MOVW          | RW5,RW5                         | MOVW          | RW5,RW6                         | MOVW              | RW5,RW7                               | MOVW                   | RW5,@RW0                                | MOVW                | RW5,@RW1          | MOVW                | RW5,@RW2                            | MOVW           | RW5,@RW3                            | MOVW R                  | W5,@RW0+            | MOVW R                  | W5,@RW1+                               | MOVW R                 | @PC+d16 W5,@RW2+ | MOVW R                            |             |
| BO          | MOVW RW5             | @RW0+d8                         | MOVW RW5      | ,@RW1+d8                              |                   | ,@RW2+d8                        |               | ,@RW3+d8                        | MOVW RW5          | ,@RW4+d8                              | MOVW RW5      | @RW5+d8                         | MOVW RW5      | ,@RW6+d8                        | MOVW RW5          | @RW7+d8                               | MOVW RW5,              | @RW0+d16                                |                     | @RW1+d16          | MOVW RW5,           | @RW2+d16                            |                | @RW3+d16                            | MOVW RW5,               | @RW0+RW7            | MOVW RW5,               | @RW1+RW7                               | MOVW RW5               | ,@PC+d16         | MOVW RW                           |             |
| CO          | MOVW                 | RW6,RW0                         | MOVW          | RW6,RW1                               | _                 | RW6,RW2                         | ~             | RW6,RW3                         | ~                 | RW6,RW4                               | _             | RW6,RW5                         | -             | RW6,RW6                         | _                 | RW6,RW7                               | MOVW                   | RW6,@RW0                                | MOVW                | RW6,@RW1          | MOVW                | RW6,@RW2                            | MOVW           | RW6,@RW3                            | MOVW R                  | W6,@RW0+            | MOVW R                  | W6,@RW1+                               | MOVW R                 | @PC+d16 W6,@RW2+ | MOVW R                            |             |
| DO          | MOVW RW6             | @RW0+d8                         | MOVW RW6      | ,@RW1+d8                              | MOVW RW6          | ,@RW2+d8                        | MOVW RW6      | ,@RW3+d8                        | MOVW RW6          | @ RW4+d8                              | MOVW RW6      | ,@RW5+d8                        | MOVW RW6      | ,@RW6+d8                        | MOVW RW6          | ,@RW7+d8                              | MOVW RW6,              | @RW0+d16                                | MOVW RW6,           | @RW1+d16          | MOVW RW6,           | @RW2+d16                            | MOVW RW6,      | @RW3+d16                            | MOVW A@R                | @RW0+RW7            | MOVW RW6,               | @RW1+RW7                               | MOVW RW6               | ,@PC+d16         | MOVW RW                           | :           |
| EO          | MOVW                 | RW7,RW0                         | 2             | RW7,RW1                               | 2                 | RW7,RW2                         | 2             | RW7,RW3                         | MOVW              | RW7,RW4                               | 2             | RW7,RW5                         | ~             | RW7,RW6                         | MOVW              | RW7,RW7                               | MOVW                   | RW7,@RW0                                | MOVW                | RW7,@RW1          | MOVW                | RW7,@RW2                            | MOVW           | RW7,@RW3                            | MOVW R                  | W7,@RW0+            | MOVW R                  | W7,@RW1+                               | MOVW R                 | W7,@RW2+         | MOVW R                            |             |
| FO          | MOVW RW7             | @RW0+d8                         | MOVW RW7      | @RW1+d8                               | MOVW RW7          | @ RW2+d8                        | MOVW RW7      | ,@RW3+d8                        | MOVW RW7          | @RW4+d8                               | MOVW RW7      | ,@RW5+d8                        | MOVW RW7      | @RW6+d8                         | MOVW RW7          | ,@RW7+d8                              | MOVW RW7,              | @RW0+d16                                | MOVW RW7,           | @RW1+d16          | MOVW RW7,           | @RW2+d16                            | MOVW RW7,      | @RW3+d16                            | MOVW Å@R                | @RW0+RW7            | MOVW RW7,               | @RW1+RW7                               | MOVW RW7               | ,@PC+d16         | MOVW RW                           | -<br>-<br>- |

### Table B.9-17 MOVW RWi, ea Instruction (first byte = 7B<sub>H</sub>)

|        | 00               | 10                 | 20               | 30             | 40       | 50       | 60       | 70         | 80       | 06         | AO       | BO         | CC       | OQ       | EO       | FO       |
|--------|------------------|--------------------|------------------|----------------|----------|----------|----------|------------|----------|------------|----------|------------|----------|----------|----------|----------|
| -      | MOV              | : MOV @R           | MOV              | : MOV @R       | MOV      | MOV @R   | MOV      | MOV @R     | MOV      | MOV @R     | MOV      | MOV @R     | MOV      | MOV @R   | MOV      | MOV @R   |
| o<br>+ | R0,R0            | R0,R0 W0+d8,R0     | 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      |            | MOV      | MOV @R     | MOV      |            | MOV      | MOV @R   | MOV      | MOV @R   |
| -<br>+ | 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      |            | MOV      | MOV @R     | MOV      |            | MOV      | MOV @R   | MOV      | MOV @R   |
| х<br>+ | R2,R0            | R2,R0 : W2+d8,R0   | R2,R1 : W2+d8,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 |
| c<br>- | 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>+ | R3,R0            | R3,R0 W3+d8,R0     | R3,R1 W3+d8,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      | 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   |
| 9+     | R6,R0            | R6,R0 : W6+d8,R0   | 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 |
|        | 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>+ | R7,R0            | R7,R0 W7+d8,R0     | R7,R1            | W7+d8,R1       | R7,R2    | W7+d8,R2 | R7,R3    | W7+d8,R3   | R7,R4    | W7+d8,R4   | R7,R5    | W7+d8,R5   | R7,R6    | W7+d8,R6 | R7,R7    | W7+d8,R7 |
| c<br>- | MOV              | MOV @RW            | MOV              | MOV @RW        | MOV      | MOV @RW  | MOV      | MOV @RW    | MOV      | MOV @RW    | MOV      | MOV @RW    | MOV      | MOV @RW  | MOV      | MOV @RW  |
| 0<br>+ | @RW0,R0          | @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       | @RW1,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 |
| <<br>+ | MOV              | MOV @RW            | MOV              | MOV @RW        | MOV      | MOV @RW  | MOV      | MOV @RW    | MOV      | MOV @RW    | MOV      | MOV @RW    | MOV      | MOV @RW  | MOV      | 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>+ | MOV              | MOV @RW            | MOV              | MOV @RW        | MOV      | MOV @RW  | MOV      | MOV @RW    | MOV      | V          | MOV      | >          | MOV      | MOV @RW  | MOV      | MOV @RW  |
|        | @RW3,R0 3+d16,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      | MOV      | MOV @RW  | MOV      | MOV @RW    | MOV      | MOV @RW    | MOV      | MOV @RW    | MOV      | MOV @RW  | NOV      | 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 |
| 4      | 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+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 |
|        | MOV              | MOV P              | MOV              |                | MOV      | MOV P    | MOV      | MOV P      | MOV      | MOV P      | MOV      | MOV P      | MOV      | MOV P    | MOV      | MOV P    |
| ⊔<br>+ | @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>+ | MOV              | MOV a              | MOV              | MOV a          | MOV      | MOV a    | MOV      | MOV a      | MOV      | MOV a      | MOV      | 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 B.9-18 MOV ea, Ri Instruction (first byte = 7C<sub>H</sub>)

|   |          |           | ;        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          | 1         | :        | 1         |          |           |          |            | ġ        |           | i        | i         |
|---|----------|-----------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----------|----------|-----------|----------|-----------|----------|------------|----------|-----------|----------|-----------|
|   | 8        | 10        | 20       | 00<br>Official definition of the second s | 40       | 20        | 60       | 20        | 80       | 06        | AO       | BO         | 8        | 8         | EO       | 6         |
|   | MOVW     | MOVW @RW  | MOVW     | MOVW @RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | MVOM     | MOVW @RW  | MOVW     | MOVW @RW  | MVOM     | MOVW @RW  | WOW      | MOWN @RW   | MOVW     | MOWW @RW  | MOVW     | MOVW @RW  |
|   | RW0,RW0  | 0+d8,RW0  | RW0,RW1  | 0+d8,RW1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW0,RW2  | 0+d8,RW2  | RW0,RW3  | 0+d8,RW3  | RW0,RW4  | 0+d8,RW4  | RW0,RW5  | 0+d8,RW5   | RW0,RW6  | 0+d8,RW6  | RW0,RW7  | 0+d8,RW7  |
|   | MOVW     |           | MOVW     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | MOW      |           | MOVW     | MOVW @RW  | MOVW     | MOVW @RW  | MOVW     | MOVW @RW   | MOVW     | MOWV @RW  | MOVW     | MOVW @RW  |
|   | RW1,RW0  | 1+d8,RW0  | RW1,RW1  | 1+d8,RW1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW1,RW2  | 1+d8,RW2  | RW1,RW3  | 1+d8,RW3  | RW1,RW4  | 1+d8,RW4  | RW1,RW5  | 1+d8,RW5   | RW1,RW6  | 1+d8,RW6  | RW1,RW7  | 1+d8,RW7  |
|   | MOVW     | MOVW @RW  | MOVW     | MOVW @RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | MOVW     |           | MOVW     | MOVW @RW  | MOVW     | MOVW @RW  | MOVW     | MOVW @RW   | MOVW     | MOVW @RW  | MOVW     | MOVW @RW  |
|   | RW2,RW0  | 2+d8,RW0  | RW2,RW1  | 2+d8,RW1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW2,RW2  | 2+d8,RW2  | RW2,RW3  | 2+d8,RW3  | RW2,RW4  | 2+d8,RW4  | RW2,RW5  | 2+d8,RW5   | RW2,RW6  | 2+d8,RW6  | RW2,RW7  | 2+d8,RW7  |
|   | MOVW     | <u> </u>  | MOVW     | MOVW @RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | MOVW     | MOVW @RW  | MOVW     | MOVW @RW  | MOVW     | MOVW @RW  | MOW      | MOWW @RW   | MOW      | MOWW @RW  | MOVW     | MOVW @RW  |
|   | RW3,RW0  | 3+d8,RW0  | 3,RW1    | 3+d8,RW1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW3,RW2  | 3+d8,RW2  | RW3,RW3  | 3+d8,RW3  | RW3,RW4  | 3+d8,RW4  | RW3,RW5  | : 3+d8,RW5 | RW3,RW6  | 3+d8,RW6  | RW3,RW7  | 3+d8,RW7  |
|   | MOWW     | AOVW @RW  | MOVW     | MOVW @RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | MOVW     | MOWW @RW  | MOW      | MOVW @RW  | MOVW     | MOVW @RW  | MOVW     | MOWW @RW   | MOVW     | MOVW @RW  | MOVW     | MOVW @RW  |
|   | RW4,RW0  | 4+d8,RW0  | RW4,RW1  | 4+d8,RW1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW4, RW2 | 4+d8,RW2  | RW4,RW3  | 4+d8,RW3  | RW4,RW4  | 4+d8,RW4  | RW4, RW5 | 4+d8,RW5   | RW4,RW6  | 4+d8,RW6  | RW4,RW7  | 4+d8,RW7  |
|   | MOVW     | MOVW @RW  | MOVW     | MOVW @RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | MOVW     | MOWW @RW  | MOW      | MOVW @RW  | MOVW     | MOVW @RW  | MOVW     | MOVW @RW   | MOVW     | MOVW @RW  | MOVW     | MOVW @RW  |
|   | RW5,RW0  | 5+d8,RW0  |          | 5+d8,RW1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW5,RW2  | 5+d8,RW2  | RW5,RW3  | 5+d8,RW3  | RW5,RW4  | 5+d8,RW4  | RW5,RW5  | 5+d8,RW5   | RW5,RW6  | 5+d8,RW6  | RW5,RW7  | 5+d8,RW7  |
|   | MOVW     | MOVW @RW  | MOVW     | MOVW @RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | MOVW     | MOWW @RW  | MOW      | MOVW @RW  | MOVW     | MOVW @RW  | MOVW     | MOVW @RW   | MOVW     | MOVW @RW  | MOVW     | MOVW @RW  |
|   | RW6,RW0  | 6+d8,RW0  | RW6,RW1  | 6+d8,RW1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW6,RW2  | 6+d8,RW2  | RW6,RW3  | 6+d8,RW3  | RW6,RW4  | 6+d8,RW4  | RW6,RW5  | 6+d8,RW5   | RW6,RW6  | 6+d8,RW6  | RW6,RW7  | 6+d8,RW7  |
|   | MOVW     | MOVW @RW  |          | MOVW @RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | MOVW     | MOWW @RW  | MOW      | MOVW @RW  | WOW      | MOVW @RW  | WOW      | MOVW @RW   | WOW      | MOVW @RW  | WOW      | MOVW @RW  |
|   | RW7,RW0  | 7+d8,RW0  | RW7,RW1  | 7+d8,RW1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW7,RW2  | 7+d8,RW2  | RW7,RW3  | 7+d8,RW3  | RW7,RW4  | 7+d8,RW4  | RW7,RW5  | 7+d8,RW5   | RW7,RW6  | 7+d8,RW6  | RW7,RW7  | 7+d8,RW7  |
|   | MOVW     | MOVW @RW0 | MOVW     | MOVW @RW0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | MOVW     | MOVW @RW0 | MOVW     | MOVW @RW0 | MOVW     | MOVW @RW0 | MOVW     | MOVW @RW0  | MOVW     | MOVW @RW0 | MOVW     | MOVW @RW0 |
|   | @RW0,RW0 | +d16,RW0  | @RW0,RW1 | +d16,RW1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | @RW0,RW2 | +d16,RW2  | @RW0,RW3 | +d16,RW3  | @RW0,RW4 | +d16,RW4  | @RW0,RW5 | +d16,RW5   | @RW0,RW6 | +d16,RW6  | @RW0,RW7 | +d16,RW7  |
|   | MOW      | MOVW @RW1 | MOVW     | MOVW @RW1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | MOVW     | MOVW @RW1 | MOVW     | MOVW @RW1 | MOW      | MOVW @RW1 | MOVW     | MOVW @RW1  | MOVW     | MOVW @RW1 | MOVW     | MOVW @RW1 |
|   | @RW1,RW0 | +d16,RW0  | @RW1,RW1 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | @RW1,RW2 |           | @RW1,RW3 | +d16,RW3  | @RW1,RW4 | +d16,RW4  | @RW1,RW5 | +d16,RW5   | @RW1,RW6 | +d16,RW6  | @RW1,RW7 | +d16,RW7  |
|   | MOVW     | MOVW @RW2 | MOVW     | MOVW @RW2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | MOVW     | MOVW @RW2 | MOVW     | MOVW @RW2 | MOVW     | MOVW @RW2 | MOVW     | MOWW @RW2  | MOVW     | MOWW @RW2 | MOVW     | MOVW @RW2 |
|   | @RW2,RW0 | +d16,RW0  | łW1      | +d16,RW1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | @RW2,RW2 | +d16,RW2  | @RW2,RW3 | +d16,RW3  | @RW2,RW4 | +d16,RW4  | @RW2,RW5 | +d16,RW5   | @RW2,RW6 | +d16,RW6  | @RW2,RW7 | +d16,RW7  |
| l | MOW      | MOVW @RW3 | MOVW     | MOVW @RW3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | MOVW     | MOWW @RW3 | MOW      | MOVW @RW3 | MOVW     | MOVW @RW3 | MOVW     | MOVW @RW3  | MOVW     | MOVW @RW3 | MOVW     | MOVW @RW3 |
|   | @RW3,RW0 | +d16,RW0  | @RW3,RW1 | +d16,RW1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | @RW3,RW2 | +d16,RW2  | @RW3,RW3 | +d16,RW3  | @RW3,RW4 | +d16,RW4  | @RW3,RW5 | +d16,RW5   | @RW3,RW6 | +d16,RW6  | @RW3,RW7 | +d16,RW7  |
|   | MOVW @   | MOVW @RW0 | MOVW @   | MOVW @RW0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | MOVW @   | MOWW @RW0 | MOVW @   | MOVW @RW0 | MOVW @   | MOVW @RW0 | MOVW @   | MOVW @RW0  | MOVW @   | MOVW @RW0 | MOVW @   | MOVW @RW0 |
|   | RW0+,RW0 | +RW7,RW0  | RW0+,RW1 | +RW7,RW1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW0+,RW2 | +RW7,RW2  | RW0+,RW3 | +RW7,RW3  | RW0+,RW4 | +RW7,RW4  | RW0+,RW5 | +RW7,RW5   | RW0+,RW6 | +RW7,RW6  | RW0+,RW7 | +RW7,RW7  |
| 1 | MOVW @   | MOVW @RW1 | MOVW @   | MOVW @RW1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | MOWV @   | MOWV @RW1 | MOVW @   | MOVW @RW1 | MOVW @   | MOVW @RW1 | MOWV @   | MOVW @RW1  | MOVW @   | MOWV @RW1 | MOVW @   | MOVW @RW1 |
|   | RW1+,RW0 | +RW7,RW0  | RW1+,RW1 | +RW7,RW1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW1+,RW2 | +RW7,RW2  | RW1+,RW3 | +RW7,RW3  | RW1+,RW4 | +RW7,RW4  | RW1+,RW5 | +RW7,RW5   | RW1+,RW6 | +RW7,RW6  | RW1+,RW7 | +RW7,RW7  |
| 1 | MOVW @   | MOVW @PC+ | MOVW @   | MOVW @PC+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | MOVW @   | MOWW @PC+ | MOVW @   | MOWW @PC+ | MOVW @   | MOVW @PC+ | MOVW @   | :MOVW @PC+ | MOVW @   | MOWW @PC+ | MOVW @   | MOVW @PC+ |
|   | RW2+,RW0 |           | RW2+,RW1 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW2+,RW2 | d16,RW2   | RW2+,RW3 | d16,RW3   | RW2+,RW4 | d16,RW4   | RW2+,RW5 | d16,RW5    | RW2+,RW6 | d16,RW6   | RW2+,RW7 | d16,RW7   |
|   | MOVW @   | MOVW addr | MOVW @   | MOVW addr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | @ MVOM   | MOVW addr | MOVW @   | MOVW addr | MOVW @   | MOVW addr | MOWV @   | MOVW addr  | MOVW @   | MOVW addr | MOVW @   | MOVW addr |
|   | RW3+,RW0 | 16,RW0    | RW3+,RW1 | 16,RW1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RW3+,RW2 | 16,RW2    | RW3+,RW3 | 16,RW3    | RW3+,RW4 | 16,RW4    | RW3+,RW5 | 16,RW5     | RW3+,RW6 | 16,RW6    | RW3+,RW7 | 16,RW7    |

### Table B.9-19 MOVW ea, Rwi Instruction (first byte = 7D<sub>H</sub>)

|    |         |          |          |         |         |          | -        |          | -        |         | :       |         | -       |         | :       |         | :       |          | :       |          | :       |                  | :       |          | :       |          |         |          | :       |          | :       |          |
|----|---------|----------|----------|---------|---------|----------|----------|----------|----------|---------|---------|---------|---------|---------|---------|---------|---------|----------|---------|----------|---------|------------------|---------|----------|---------|----------|---------|----------|---------|----------|---------|----------|
| Ъ  | 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 | XCH R7, | W2+d16,A         | XCH R7, | @RW3+d16 | XCH R7, | @RW0+RW7 | XCH R7, | ÷        | XCH R7, | @PC+d16  | XCH R7, | addr16   |
| EO | ХСН     | R7,R0    | ХСН      | R7,R1   | XCH     | R7,R2    | XCH      | R7,R3    | ХСН      | R7,R4   | XCH     | R7,R5   | XCH     | R7,R6   | XCH     | R7,R7   | XCH     | R7,@RW0  | XCH     | R7,@RW1  | хсн     | R7,@RW2          | XCH     | R7,@RW3  | XCH     | R7,@RW0+ | XCH     | R7,@RW1+ | XCH     | R7,@RW2+ | XCH     | R7,@RW3+ |
| DO | 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, | @RW7+d8 | XCH R6, | @RW0+d16 | XCH R6, | @RW1+d16 | XCH R6, | W2+d16,A         | XCH R6, | @RW3+d16 | XCH R6, | @RW0+RW7 | XCH R6, | @RW1+RW7 | XCH R6, | @PC+d16  | XCH R6, | addr16   |
| C0 | хсн     | R6,R0    | хсн      | R6,R1   | хсн     | R6,R2    | XCH      | R6,R3    | хсн      | R6,R4   | XCH     | R6,R5   | ХСН     | R6,R6   | ХСН     | R6,R7   | ХСН     | R6,@RW0  | XCH     | R6,@RW1  | XCH     | @RW2             | XCH     | @RW3     | XCH     | R6,@RW0+ | XCH     | R6,@RW1+ | XCH     | R6,@RW2+ | XCH     | R6,@RW3+ |
| BO | 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, | @RW6+d8 | XCH R5, | @RW7+d8 | XCH R5, | @RW0+d16 | XCH R5, | @RW1+d16 | XCH R5, |                  | XCH R5, | @RW3+d16 | XCH R5, |          | XCH R5, | @RW1+RW7 | XCH R5, | @PC+d16  | XCH R5, | addr16   |
| AO | хсн     | R5,R0    | хсн      | R5,R1   | хсн     | R5,R2    | хсн      | R5,R3    | хсн      | R5,R4   | XCH     | R5,R5   | хсн     | R5,R6   | хсн     | R5,R7   | XCH     | R5,@RW0  | XCH     | R5,@RW1  | хсн     | @RW2             | хсн     | R5,@RW3  | хсн     | R5,@RW0+ | XCH     | R5,@RW1+ | XCH     | R5,@RW2+ | XCH     | R5,@RW3+ |
| 06 | XCH R4, | @ RW0+d8 | XCH R4,  | @RW1+d8 | XCH R4, | @RW2+d8  | XCH R4,  | @RW3+d8  | XCH R4,  | @RW4+d8 | XCH R4, | @RW5+d8 | XCH R4, | @RW6+d8 | XCH R4, | @RW7+d8 | XCH R4, | @RW0+d16 | XCH R4, | @RW1+d16 | XCH R4, | W2+d16,A         | XCH R4, | @RW3+d16 | XCH R4, | @RW0+RW7 | XCH R4, | @RW1+RW7 | XCH R4, | @PC+d16  | XCH R4, | addr16   |
| 80 | XCH     | R4,R0    | хсн      | R4,R1   | XCH     | R4,R2    | XCH      | R4,R3    | хсн      | R4,R4   | XCH     | R4,R5   | XCH     | R4,R6   | XCH     | R4,R7   | XCH     | R4,@RW0  | XCH     | R4,@RW1  | XCH     | R4,@RW2          | XCH     | R4,@RW3  | XCH     | R4,@RW0+ | XCH     | R4,@RW1+ | XCH     | R4,@RW2+ | XCH     | R4,@RW3+ |
| 70 | XCH R3, | @ RW0+d8 | XCH R3,  | @RW1+d8 | XCH R3, | @ RW2+d8 | XCH R3,  | @RW3+d8  | 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, | @RW3+d16 | XCH R3, | @RW0+RW7 | 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, | @RW0+RW7 | XCH R2, | @RW1+RW7 | XCH R2, | @PC+d16  | XCH R2, | addr16   |
| 40 | хсн     | R2,R0    | хсн      | R2,R1   | хсн     | R2,R2    | XCH      | R2,R3    | хсн      | R2,R4   | XCH     | R2,R5   | 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+d8  | XCH R1,  | @ RW3+d8 | XCH R1,  | @RW4+d8 | XCH R1, | @RW5+d8 | XCH R1, | @RW6+d8 | XCH R1, | @RW7+d8 | XCH R1, | @RW0+d16 | XCH R1, | @RW1+d16 | XCH R1, | W2+d16,A         | XCH R1, | @RW3+d16 | XCH R1, | @RW0+RW7 | XCH R1, | @RW1+RW7 | XCH R1, | @PC+d16  | XCH R1, | addr16   |
| 20 | хсн     | R1,R0    | ХСН      | R1,R1   | хсн     | R1,R2    | хсн      | R1,R3    | хсн      | R1,R4   | XCH     | R1,R5   | хсн     | R1,R6   | XCH     | R1,R7   | XCH     |          | XCH     | @RW1     | XCH     | R1,@RW2 W2+d16,A | XCH     |          | XCH     | R1,@RW0+ | XCH     | R1,@RW1+ | XCH     | R1,@RW2+ | 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 RO, | @RW0+d16 | XCH R0, |          | XCH R0, | W2+d16,A         | XCH R0, | @RW3+d16 | XCH R0, | @RW0+RW7 | XCH R0, | @RW1+RW7 | XCH R0, | @PC+d16  | XCH R0, | addr16   |
| 00 | хсн     | R0,R0    | хсн      | R0,R1   | хсн     | R0,R2    | хсн      | R0,R3    | хсн      | R0,R4   | хсн     | R0,R5   | хсн     | R0,R6   | хсн     |         | ХСН     |          | XCH :   | @RW1     | XCH     | @RW2             | XCH     |          | XCH     |          | XCH :   | R0,@RW1+ | XCH ::  | +        | XCH     | R0,@RW3+ |
|    | -       | ><br>+   | -        | -<br>+  | -       | 7<br>+   |          | ი<br>+   |          | + 4     |         | ი<br>+  |         | 9+      |         | \<br>+  |         | 8<br>+   |         | 6<br>+   |         | ₹                |         | а<br>+   |         | ပ<br>+   |         | ∩<br>+   |         | ш<br>+   |         | ш<br>+   |

Table B.9-20 XCH Ri, ea Instruction (first byte = 7E<sub>H</sub>)

|         | 00       | 10               | 20                  | 30        | 40       | 50        | 09       | 02        | 08       | 06        | AO       | BO        | CO       | DO          | EO       | FO        |
|---------|----------|------------------|---------------------|-----------|----------|-----------|----------|-----------|----------|-----------|----------|-----------|----------|-------------|----------|-----------|
| -       | XCHW     | XCHW RW0,        | XCHW                | XCHW RW1, | XCHW     | XCHW RW2, | WHX      | XCHW RW3, | хснм     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6,   | XCHW     | XCHW RW7, |
|         | RW0.RW0  | @RW0+d8          | RW1, RW0. : @RW0+d8 | @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     | XCHW RW2, | XCHW     | XCHW RW3, | XCHW     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6,   | XCHW     | XCHW RW7, |
| +       | RW0,RW1  | @RW1+d8          | RW1,RW1 @RW1+d8     | @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   |
| -       | XCHW     |                  |                     | ÷.        | 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+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   |
| -       | 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+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, |
| + +     | 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 RW0,        | XCHW                | XCHW RW1, | XCHW     | XCHW RW2, | XCHW     | XCHW RW3, | XCHW     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6,   | XCHW     | XCHW RW7, |
| م<br>+  | RW0,RW5  | RW0,RW5 @RW5+d8  | RW1,RW5 @RW5+d8     | @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 RW0,        |                     | Ļ,        | XCHW     | XCHW RW2, | XCHW     |           | XCHW     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6,   | XCHW     | XCHW RW7, |
| 9+      | RW0,RW6  | @RW6+d8          | RW1, RW6 @RW6+d8    | @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 RW5, | 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, |
| 80<br>+ | 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                | XCHW RW1, | XCHW     | XCHW RW2, | XCHW     |           | 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 RW0,        | XCHW                | XCHW RW1, | XCHW     | XCHW RW2, | XCHW     | XCHW RW3, | XCHW     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6,   | XCHW     | XCHW RW7, |
| + +     | 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, |
| 20<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 RW0,        | XCHW R              | XCHW RW1, | XCHW R   | XCHW RW2, | XCHW R   |           |          | XCHW RW4, | XCHW R   | XCHW RW5, | XCHW R   | XCHW RW6,   | XCHW R   | XCHW RW7, |
| ပ<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  |
|         | 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 +     | 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+ | 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 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 B.9-21 XCHW RWi, ea Instruction (first byte = 7F<sub>H</sub>)

# **APPENDIX C** Index of Registers

This section provides an index for finding the page containing the description of an MB90M405 series register from the register address, peripheral resource name, abbreviation, or register name.

#### Index of Registers

Table C-1 Index of Registers

| Address             | Abbreviation        | Register                                         | Peripheral resource       | Page<br>number |
|---------------------|---------------------|--------------------------------------------------|---------------------------|----------------|
| 000008 <sub>H</sub> | PDR8                | Port 8 data register                             | Port 8                    | 158            |
| 000009 <sub>H</sub> | PDR9                | Port 9 data register                             | Port 9                    | 163            |
| 00000A <sub>H</sub> | PDRA                | Port A data register                             | Port A                    | 168            |
| 00000B <sub>H</sub> | PDRB                | Port B data register                             | Port B                    | 174            |
| 000018 <sub>H</sub> | DDR8                | Port 8 direction register                        | Port 8                    | 158            |
| 000019 <sub>H</sub> | DDR9                | Port 9 direction register                        | Port 9                    | 163            |
| 00001A <sub>H</sub> | DDRA                | Port A direction register                        | Port A                    | 168            |
| 00001B <sub>H</sub> | DDRB                | Port B direction register                        | Port B                    | 174            |
| 00001E <sub>H</sub> | ADER0               | Analog input enable register 0                   | Port A, A/D               | 168            |
| 00001F <sub>H</sub> | ADER1               | Analog input enable register 1                   | Port B, A/D               | 174            |
| 000020 <sub>H</sub> | SMR(0)              | Mode register ch0                                |                           | 275            |
| 000021 <sub>H</sub> | SCR(0)              | Control register ch0                             |                           | 272            |
| 000022 <sub>H</sub> | SIDR(0)/<br>SODR(0) | Input data register ch0/Output data register ch0 | UART ch0                  | 280, 280       |
| 000023 <sub>H</sub> | SSR(0)              | Status register ch0                              |                           | 277            |
| 000024 <sub>H</sub> | SMR(1)              | Mode register ch1                                |                           | 275            |
| 000025 <sub>H</sub> | SCR(1)              | Control register ch1                             | UART ch1                  | 272            |
| 000026 <sub>H</sub> | SIDR(1)/<br>SODR(1) | Input data register ch0/Output data register ch1 |                           | 280, 280       |
| 000027 <sub>H</sub> | SSR(1)              | Status register ch1                              |                           | 277            |
| 000028 <sub>H</sub> | CDCR(0)             | Communication prescaler control register ch0     | Communication prescaler 0 | 282            |
| 000029 <sub>H</sub> | CDCR(1)             | Communication prescaler control register ch1     | Communication prescaler 1 | 282            |

| Table C-1 Index of Registers (Continued) |
|------------------------------------------|
|------------------------------------------|

| Address             | Abbreviation | Register                                     | Peripheral resource           | Page<br>number |
|---------------------|--------------|----------------------------------------------|-------------------------------|----------------|
| 00002A <sub>H</sub> | IBSR         | I <sup>2</sup> C status register             |                               | 336            |
| 00002B <sub>H</sub> | IBCR         | I <sup>2</sup> C control register            |                               | 338            |
| 00002C <sub>H</sub> | ICCR         | I <sup>2</sup> C clock control register      | I <sup>2</sup> C interface    | 341            |
| 00002D <sub>H</sub> | IADR         | I <sup>2</sup> C address register            | I-C Interface                 | 344            |
| 00002E <sub>H</sub> | IDAR         | I <sup>2</sup> C data register               |                               | 345            |
| 00002F <sub>H</sub> | ISEL         | I <sup>2</sup> C port selection register     |                               | 346            |
| 000030 <sub>H</sub> | ENIR         | DTP/Interrupt enable register                |                               | 319            |
| 000031 <sub>H</sub> | EIRR         | DTP/interrupt cause register                 | DTP/external<br>interrupt     | 316            |
| 000032 <sub>H</sub> | ELVR         | Request level setting register               |                               | 321            |
| 000034 <sub>H</sub> | ADCS0        |                                              |                               | 365            |
| 000035 <sub>H</sub> | ADCS1        | A/D control status register                  |                               | 363            |
| 000036 <sub>H</sub> | ADCR0        | A/D data register                            | A/D converter                 | 207            |
| 000037 <sub>H</sub> | ADCR1        | A/D data register                            |                               | 367            |
| 000039 <sub>H</sub> | ADMR         | A/D conversion channel setting register      | -                             | 369            |
| 000040 <sub>H</sub> | TCCS         | Timer counter control status register        |                               | 250            |
| 000042 <sub>H</sub> | торт         | Timer counter data register                  | 16-bit free-<br>running timer | 240            |
| 000043 <sub>H</sub> | TCDT         | Timer counter data register                  |                               | 249            |
| 000044 <sub>H</sub> | IPC(0)       | Input conturo data register ch0              |                               | 255            |
| 000045 <sub>H</sub> |              | Input capture data register ch0              | Input capture                 | 255            |
| 000046 <sub>H</sub> | IPC(1)       | Input capture data register ch1              |                               | 255            |
| 000047 <sub>H</sub> |              |                                              |                               | 200            |
| 000048 <sub>H</sub> | ICSO1        | Input capture control status register        | -                             | 256            |
| 00004A <sub>H</sub> | 00000        | Output compore register ch0                  |                               | 252            |
| 00004B <sub>H</sub> | OCCP0        | Output compare register ch0                  | Output compare                |                |
| 00004C <sub>H</sub> | OCS0         | Output compare control status register ch0   | -                             | 253            |
| 000050 <sub>H</sub> |              | Timor control status register ab0            |                               | 220 to 221     |
| 000051 <sub>H</sub> | TMCSR(0)     | Timer control status register ch0            | 16-bit reload                 | 229 to 231     |
| 000052 <sub>H</sub> | TMR(0)/      | 16-bit timer register/16-bit reload register | timer ch0                     | 233 to 234     |
| 000053 <sub>H</sub> | TMRLR(0)     | ch0                                          |                               |                |

| Address                                          | Abbreviation      | Register                                  |                 | Peripheral resource                              | Page<br>number |
|--------------------------------------------------|-------------------|-------------------------------------------|-----------------|--------------------------------------------------|----------------|
| 000054 <sub>H</sub>                              | TMCSR(1)          | Timor control status register (           | <b>b</b> 1      |                                                  | 229 to 231     |
| 000055 <sub>H</sub>                              |                   | Timer control status register of          |                 | 16-bit reload                                    | 229 10 231     |
| 000056 <sub>H</sub>                              | TMR(1)/           | 16-bit timer register/16-bit rel          | oad register    | timer ch1                                        | 233 to 234     |
| 000057 <sub>H</sub>                              | TMRLR(1)          | ch1                                       |                 |                                                  | 200 10 204     |
| 000058 <sub>H</sub>                              | TMCSR(2)          | Timer control status register of          | -h2             |                                                  | 229 to 231     |
| 000059 <sub>H</sub>                              |                   |                                           | /IZ             | 16-bit reload                                    | 229 10 231     |
| 00005A <sub>H</sub>                              | TMR(2)/           | 16-bit timer register/16-bit rel          | oad register    | timer ch2                                        | 222 to 224     |
| 00005B <sub>H</sub>                              | TMRLR(2)          | ch2                                       | -               |                                                  | 233 to 234     |
| 000060 <sub>H</sub>                              |                   | Sorial mode control status ra             | riotor ob 2     |                                                  | 101            |
| 000061 <sub>H</sub>                              | SMCR(2)           | Serial mode control status reg            | JISTEL CUZ      | Serial I/O ch2                                   | 184            |
| 000062 <sub>H</sub>                              | SDR(2)            | Serial shift data register ch2            |                 |                                                  | 188            |
| 000064 <sub>H</sub>                              |                   |                                           | riotor ob 2     |                                                  | 404            |
| 000065 <sub>H</sub>                              | SMCR(3)           | Serial mode control status reg            | gister ch3      | Serial I/O ch3                                   | 184            |
| 000066 <sub>H</sub>                              | SDR(3)            | Serial shift data register ch3            |                 |                                                  | 188            |
| 000068 <sub>H</sub>                              | FLC1              | Display control register 1                |                 |                                                  | 385            |
| 000069 <sub>H</sub>                              | FLC2              | Display control register 2                |                 |                                                  | 387            |
| 00006A <sub>H</sub>                              | FLDG              | Digit setting register                    |                 | FL control<br>circuit                            | 389            |
| 00006B <sub>H</sub>                              | FLDC              | Digit count register                      |                 |                                                  | 391            |
| 00006D <sub>H</sub>                              | FLST              | Status/settlement register                |                 |                                                  | 394            |
| 00006F <sub>H</sub>                              | ROMM              | ROM mirroring function selection register |                 | ROM mirroring<br>function<br>selection<br>module | 425            |
| 000070 <sub>H</sub><br>to<br>000070 <sub>H</sub> | SEGD0 to<br>SEGD7 | Segment dimmer setting register           |                 | _                                                | 397            |
| 000078 <sub>H</sub>                              | FLPD0             | FIP36 to 43                               |                 | FL control                                       |                |
| 000079 <sub>H</sub>                              | FLPD1             | Port register                             |                 |                                                  | 393            |
| 00007A <sub>H</sub>                              | FLPD2             |                                           | FIP52 to 59     | 1                                                |                |
| 00009E <sub>H</sub>                              | PACSR             | Program address detection corregister     | ontrol status   | Address match detection circuit                  | 417            |
| 00009F <sub>H</sub>                              | DIRR              | Delayed interrupt cause gene<br>register  | eration/release | Delayed<br>interrupt                             | 409            |

Table C-1 Index of Registers (Continued)

| Table C-1 Index of Registers (Contin | ued) |
|--------------------------------------|------|
|--------------------------------------|------|

| Address                                                                    | Abbreviation      | Register                                    | Peripheral resource     | Page<br>number |
|----------------------------------------------------------------------------|-------------------|---------------------------------------------|-------------------------|----------------|
| 0000A0 <sub>H</sub>                                                        | LPMCR             | Low power consumption mode control register | Low power consumption   | 86             |
| 0000A1 <sub>H</sub>                                                        | CKSCR             | Clock selection register                    | control circuit         | 75             |
| 0000A8 <sub>H</sub>                                                        | WDTC              | Watchdog timer control register             | Watchdog timer          | 215            |
| 0000A9 <sub>H</sub>                                                        | TBTC              | Timebase timer control register             | Timebase timer          | 204            |
| 0000AE <sub>H</sub>                                                        | FMCS              | Flash memory control status register        | 1M-bit flash<br>memory  | 430            |
| 0000AF <sub>H</sub>                                                        | TMCS              | Watch clock output control register         | Watch clock<br>division | 406            |
| 0000B0 <sub>H</sub><br>to<br>0000BF <sub>H</sub>                           | ICR00 to<br>ICR15 | Interrupt control register ch0 to ch15      | Interrupt<br>controller | 108            |
| 000100 <sub>H</sub><br>to<br>0010FF <sub>H</sub>                           | RAM area          | RAM memory                                  | RAM                     |                |
| 001100 <sub>H</sub><br>to<br>0011FF <sub>H</sub>                           | FL000 to<br>FL255 | Display data RAM                            | FL control circuit      | 396            |
| 001FF0 <sub>H</sub>                                                        |                   | Program address detection register (lower)  |                         |                |
| 001FF1 <sub>H</sub>                                                        | PADR0             | Program address detection register (middle) |                         |                |
| 001FF2 <sub>H</sub>                                                        |                   | Program address detection register (upper)  | Address match           | 416            |
| 001FF3 <sub>H</sub>                                                        |                   | Program address detection register (lower)  | detection<br>function   | 410            |
| 001FF4 <sub>H</sub>                                                        | PADR1             | Program address detection register (middle) |                         |                |
| 001FF5 <sub>H</sub>                                                        |                   | Program address detection register (upper)  | ]                       |                |
| FE0000 <sub>H</sub><br>(FE8000 <sub>H</sub> )<br>to<br>FFFFFF <sub>H</sub> | ROM area          | ROM                                         | ROM                     |                |

# **APPENDIX D** Index of Pin Functions

This section provides an index for finding the page containing a block diagram and description from the MB90M405 series package pin number, pin name, circuit type, or peripheral resource name.

#### ■ Index of Pin Functions

| Table D-1 Index of Index of Pin Function | ons |
|------------------------------------------|-----|
|------------------------------------------|-----|

| Pin<br>number                    | Pin name          | Circuit<br>type | Peripheral resource name and function name | Functional description | Block<br>diagram |
|----------------------------------|-------------------|-----------------|--------------------------------------------|------------------------|------------------|
| 82, 83                           | X0, X1            | A               | Oscillation pin                            | 10                     | 14               |
| 77                               | RST               | В               | Reset input                                | 10                     | 14               |
| 85 to 100                        | FIP0 to<br>FIP16  |                 |                                            | 383                    | 383              |
| 1                                | LED0 to<br>LED16  | С               | FL control circuit                         | 383                    | 383              |
| 2 to 10<br>12 to 19              | FIP17 to<br>FIP33 |                 |                                            | 383                    | 383              |
| 20 to 22<br>24 to 41<br>43 to 47 | FIP34 to<br>FIP59 | D               | FL control circuit                         | 384                    | 384              |
|                                  | P80               |                 | General-purpose I/O port 8 bit 0           | 158                    | 159              |
| 52                               | IC0               | -               | Input capture ch0                          | 158                    | 159              |
|                                  | INT0              |                 | External interrupt input ch0               | 314                    | 314              |
|                                  | P81               | -               | General-purpose I/O port 8 bit 1           | 158                    | 159              |
| 53                               | IC1               | -               | Input capture ch0                          | 158                    | 159              |
|                                  | INT1              |                 | External interrupt input ch1               | 314                    | 314              |
| 54                               | P82               | E               | General-purpose I/O port 8 bit 2           | 158                    | 159              |
| 54                               | SI0               |                 | UART data input ch0                        | 269                    | 270              |
| 55                               | P83               |                 | General-purpose I/O port 8 bit 3           | 158                    | 159              |
|                                  | SC0               |                 | UART clock I/O ch0                         | 269                    | 270              |
|                                  | P84               |                 | General-purpose I/O port 8 bit 4           | 158                    | 159              |
| 56                               | SO0               |                 | UART data output ch0                       | 269                    | 270              |
| 57                               | P85               |                 | General-purpose I/O port 8 bit 5           | 158                    | 159              |
| 57 -                             | SI1               |                 | UART data input ch1                        | 269                    | 270              |

| Table D-1 | Index of Index of Pin Functions ( | (Continued) | ) |
|-----------|-----------------------------------|-------------|---|
|-----------|-----------------------------------|-------------|---|

| Pin<br>number | Pin name        | Circuit<br>type | Peripheral resource name and function name | Functional description | Block<br>diagram |
|---------------|-----------------|-----------------|--------------------------------------------|------------------------|------------------|
| 58            | P86             |                 | General-purpose I/O port 8 bit 6           | 158                    | 159              |
| 20            | SC1             | F               | UART clock I/O ch1                         | 269                    | 270              |
| 50            | P87             | E               | General-purpose I/O port 8 bit 7           | 158                    | 159              |
| 59            | SO1             |                 | UART data output ch1                       | 269                    | 270              |
|               | P90             |                 | General-purpose I/O port 9 bit 0           | 163                    | 164              |
| 60            | SDA             |                 | l <sup>2</sup> C                           | 333                    | 333              |
|               | SO3             | 0               | Serial I/O data output ch3                 | 163                    | 164              |
|               | P91             | G               | General-purpose I/O port 9 bit 1           | 163                    | 164              |
| 61            | SCL             |                 | l <sup>2</sup> C                           | 333                    | 333              |
|               | SC3             |                 | Serial I/O clock I/O ch3                   | 163                    | 164              |
|               | PA0             |                 | General-purpose I/O port A bit 0           | 168                    | 169              |
| 64            | AN0             |                 | A/D converter analog input ch0             | 360                    | 361              |
|               | TMCK            |                 | Watch clock output pin                     | -                      | 169              |
|               | PA1 to PA7      |                 | General-purpose I/O port A bit 1 to bit 7  | 168                    | 169              |
| 65 to 71      | AN1 to AN7      |                 | A/D converter analog input ch1 to ch7      | 360                    | 361              |
|               | PB0 to PB2      |                 | General-purpose I/O port B bit 0 to bit 2  | 172                    | 172              |
| 72 to 74      | AN8 to AN10     |                 | A/D converter analog input ch8 to ch10     | 358                    | 359              |
|               | PB3             |                 | General-purpose I/O port B bit 3           | 174                    | 175              |
| 75            | AN11 F          | F               | A/D converter analog input ch11            | 360                    | 361              |
|               | SI2             |                 | Serial I/O data input ch2                  | 174                    | 175              |
|               | PB4             |                 | General-purpose I/O port B bit 4           | 174                    | 175              |
|               | AN12            |                 | A/D converter analog input ch12            | 360                    | 361              |
| 76            | SC2             |                 | Serial I/O clock I/O ch2                   | 174                    | 175              |
|               | TIN0            |                 | Reload timer event input ch0               | 227                    | 227              |
|               | PB5             |                 | General-purpose I/O port B bit 5           | 174                    | 175              |
| 78            | AN13            |                 | A/D converter analog input ch13            | 360                    | 361              |
|               | SO2             |                 | Serial I/O data output ch2                 | 174                    | 175              |
|               | PB6 to PB7      |                 | General-purpose I/O port B bit 6 to bit 7  | 174                    | 175              |
| 79, 80        | AN14 to<br>AN15 | F               | A/D converter analog input ch14 to ch15    | 360                    | 361              |
|               | INT2 to INT3    |                 | External interrupt input ch2 to ch3        | 314                    | 314              |

| Pin<br>number | Pin name             | Circuit<br>type | Peripheral resource name and function name        | Functional description | Block<br>diagram |
|---------------|----------------------|-----------------|---------------------------------------------------|------------------------|------------------|
| 62            | AV <sub>CC</sub>     | н               | Analog V <sub>CC</sub> power input pin            | 10                     | 15               |
| 63            | AV <sub>SS</sub>     |                 | Analog V <sub>SS</sub> power input pin            | 10                     | 15               |
| 48            | V <sub>KK</sub>      | -               | High withstand voltage output pull-down power pin | 10                     | -                |
| 49            | MD0                  | -               | Power mode specification input pin 0              | 10                     | -                |
| 50            | MD1                  | -               | Power mode specification input pin 1              | 10                     | -                |
| 51            | MD2                  | -               | Operating mode specification input pin 2          | 10                     | -                |
| 11, 42        | V <sub>SS</sub> -IO  | -               | I/O power (GND) input pin                         | 10                     | -                |
| 23            | V <sub>DD</sub> -FIP | -               | FIP power (3V) input pin                          | 10                     | -                |
| 81            | V <sub>SS</sub> -CPU | -               | Control circuit power (GND) input pin             | 10                     | -                |
| 84            | V <sub>CC</sub> -CPU | -               | Control circuit power (3V) input pin              | 10                     | -                |

Table D-1 Index of Index of Pin Functions (Continued)

**APPENDIX D** Index of Pin Functions

# INDEX

The index follows on the next page. This is listed in alphabetic order.

# Index

#### Numerics

| 16-bit free-running timer (one channel)      | 246   |
|----------------------------------------------|-------|
| 16-bit Free-running timer count timing       | 259   |
| 16-bit free-running timer operation          | 258   |
| 16-bit I/O timer block diagram               | 247   |
| 16-bit I/O timer register                    | 248   |
| 16-bit input capture operation               | 261   |
| 16-bit output compare operation              | 260   |
| 16-bit reload register (TMRLR)               | 234   |
| 16-bit reload timer interrupt                |       |
| 16-bit reload timer interrupt and EI2OS224   | , 235 |
| 16-bit reload timer operating mode           |       |
| 16-bit reload timer pin                      | 227   |
| 16-bit reload timer pin, block diagram of    | 227   |
| 16-bit reload timer register                 | 228   |
| 16-bit reload timer setting                  |       |
| 16-bit reload timer, block diagram of        | 225   |
| 16-bit reload timer, EI2OS function of       | 235   |
| 16-bit reload timer, usage note on           |       |
| 16-bit timer register (TMR)                  | 233   |
| 1M-bit flash memory, feature of              | 428   |
| 24-bit operand specification, linear         |       |
| addressing by                                |       |
| 8/10-bit A/D converter interrupt             | 371   |
| 8/10-bit A/D converter interrupt and         |       |
| EI2OS                                        |       |
| 8/10-bit A/D converter pin                   |       |
| 8/10-bit A/D converter pin, block diagram of |       |
| 8/10-bit A/D converter register              |       |
| 8/10-bit A/D converter, block diagram of     |       |
| 8/10-bit A/D converter, EI2OS function of    |       |
| 8/10-bit A/D converter, function of          |       |
| 8/10-bit A/D converter, usage note on        | 318   |
|                                              |       |

# Α

| A/D control status register 0 (ADCS0)            |
|--------------------------------------------------|
| A/D control status register 1 (ADCS1)            |
| A/D conversion channel select register (ADMR)369 |
| A/D conversion data protection function          |
| A/D converter power supply analog input,         |
| power-on sequence for17                          |
| A/D data register (ADCR0/ADCR1)                  |
| access to low power consumption mode control     |
| register87                                       |

| accumulator (A)                                | 37  |
|------------------------------------------------|-----|
| acknowledgement                                | 348 |
| address field, effective 466,                  | 481 |
| address match detection function, block        |     |
| diagram of                                     | 414 |
| address match detection function, list of      |     |
| registers of                                   | 415 |
| address match detection function, operation of |     |
| addressing 347, 436,                           |     |
| addressing, direct                             | 467 |
| addressing, indirect                           |     |
| arbitration                                    | 348 |
| asynchronous mode, operation in                | 298 |
| automatic fluorescent tube display digits and  |     |
| segments and automatic LED display pin,        |     |
| assignment of                                  | 398 |
| automatic fluorescent tube display function    | 380 |
| automatic fluorescent tube display, start and  |     |
| stop timings of                                | 401 |
| automatic LED display function                 | 381 |
| automatic LED display pin                      | 398 |
| automatic LED display, start and stop          |     |
| timing of                                      | 402 |
|                                                |     |

#### В

| bank addressing                          | 28  |
|------------------------------------------|-----|
| bank addressing and default space        | 31  |
| bank register (PCB, DTB, USB, SSB, ADB)  | 49  |
| bank register and access space           | 30  |
| bank select prefixe (PCB, DTB, ADB, SPB) | 53  |
| bidirectional communication function     | 302 |
| block diagram                            | 7   |
| block diagram of low power consumption   |     |
| control circuit                          | 84  |
| buffer address pointer (BAP)             | 133 |
| bus error                                | 348 |
| bus mode                                 | 148 |
| bus mode setting bit                     | 150 |
|                                          |     |

# С

| calculating execution cycle count        | . 479 |
|------------------------------------------|-------|
| clock                                    | 72    |
| clock generation block, block diagram of | 73    |
| clock mode                               | 83    |
| clock mode transition                    | 77    |

| clock selection register (CKSCR),                     |
|-------------------------------------------------------|
| configuration of75                                    |
| clock supply function 200, 208                        |
| clock supply map19                                    |
| command sequence table 433                            |
| common register bank prefix (CMR)55                   |
| communication prescaler control register              |
| (CDCR0/CDCR1)189, 282                                 |
| competition among SCC, MSS and INT bit,               |
| note on                                               |
| condition code register (CCR) configuration           |
| configuration of extended intelligent I/O service     |
| (EI2OS) descriptor (ISD)129                           |
| configuration of interrupt control register (ICR) 110 |
| consecutive prefix code58                             |
| continuous conversion mode, operation in              |
| control register (SCR0/SCR1)272                       |
| conversion using EI2OS 375                            |
| correspondence between reset cause flag bit 67        |
| counter operating status 237                          |
| counter operation 223                                 |
| CPU                                                   |
| CPU intermittent operation mode                       |
| CPU operating mode and current consumption 82         |
| crystal oscillation circuit                           |
| cycle count, execution                                |
| -,                                                    |

# D

| data counter (DCT) 131                                      |
|-------------------------------------------------------------|
| dedicated baud rate generator, baud rate                    |
| determined using291                                         |
| dedicated register and general-purpose register $\ldots 34$ |
| dedicated register, configuration of35                      |
| delayed interrupt cause/cancel register (DIRR) 409          |
| delayed interrupt generator module,                         |
| operation of410                                             |
| delayed interrupt generator module, block                   |
| diagram of 408                                              |
| delayed interrupt generator module, precautions             |
| to follow when using411                                     |
| digit count register (FLDC)                                 |
| digit setting register (FLDG)                               |
| direct addressing 467                                       |
| direct page register (DPR) 48                               |
| display control register 1 (FLC1)                           |
| display control register 2 (FLC2)                           |
| display RAM 396                                             |
| DTP function, operation of 327                              |
| DTP/external interrupt circuit and EI2OS,                   |
| interrupt of 311                                            |

| DTP/external interrupt circuit pin               | .314 |
|--------------------------------------------------|------|
| DTP/external interrupt circuit pin, block        |      |
| diagram of                                       | .314 |
| DTP/external interrupt circuit register          | .315 |
| DTP/external interrupt circuit, block diagram of | .312 |
| DTP/external interrupt circuit, usage note on    | .328 |
| DTP/external interrupt function                  | .310 |
| DTP/interrupt cause register (EIRR)              | .316 |
| DTP/interrupt enable register (ENIR)             | .319 |

# Ε

| E2PROM memory map                             | 419       |
|-----------------------------------------------|-----------|
| effective address field                       | .466, 481 |
| event count mode                              | 242       |
| event count mode (external clock mode)        | 223       |
| exception processing                          | 139       |
| execution cycle count                         | 478       |
| execution cycle count, calculating            | 479       |
| extended intelligent I/O service (EI2OS)      | 127       |
| extended intelligent I/O service (EI2OS) stat | tus       |
| register (ISCS)                               | 132       |
| extended intelligent I/O service (EI2OS),     |           |
| processing specification of sample            |           |
| program for                                   | 144       |
| external clock, baud rate determined using.   | 295       |
| external clock, note on                       | 17        |
| external interrupt function                   | 326       |
| external reset pin, block diagram of          |           |
| external shift clock mode                     | 192       |
|                                               |           |

## F

| F2MC-16LX instruction list                      | 485 |
|-------------------------------------------------|-----|
| FL control circuit pin                          | 383 |
| FL control circuit pin, block diagram of        | 383 |
| FL control circuit, reading from/writing to     |     |
| registers or display RAM in                     | 399 |
| FL control circuit                              | 382 |
| FL control circuit, block diagram of            | 382 |
| flag change suppression prefix (NCC)            | 56  |
| flash memory (chip deletion), deleting all data |     |
| item from                                       | 438 |
| flash memory (sector deletion), deleting a data |     |
| item from                                       | 439 |
| flash memory control status register (FMCS)     | 430 |
| flash memory sector deletion, resuming          | 442 |
| flash memory writing and deletion, detailed     |     |
| description of                                  | 434 |
| flash memory, register of                       | 429 |
| flash memory, writing data to                   | 436 |
|                                                 |     |

#### INDEX

| flash memory, writing data to or deleting  |      |
|--------------------------------------------|------|
| data from                                  | 428  |
| flash memory, writing to and deletion from | .428 |
| flash microcomputer programmer (when power |      |
| supplied by user), example of minimum      |      |
| connection with                            | .450 |
| flash microcomputer programmer (when power |      |
| supplied from programmer), example of      |      |
| minimum connection with                    | 452  |
| FPT-100P-M06 Dimension                     | 8    |

# G

| general-purpose register                     |
|----------------------------------------------|
| general-purpose register area and register   |
| bank pointer45                               |
| general-purpose register, configuration of50 |

# н

| hardware interrupt                                | 113 |
|---------------------------------------------------|-----|
| hardware interrupt activation                     | 116 |
| hardware interrupt disable                        | 114 |
| hardware interrupt operation                      | 117 |
| hardware interrupt processing time                | 123 |
| hardware interrupt structure                      | 114 |
| high dielectric output pin                        | 380 |
| high dielectric output pin (circuit type C or D), |     |
| output of                                         | 18  |

#### I

| I2C status register (IBSR)                      | 336      |
|-------------------------------------------------|----------|
| index of pin function                           | 525      |
| index of register                               | 521      |
| indirect addressing                             | 472      |
| indirect specification with 32-bit register,    |          |
| addressing by                                   |          |
| initial state                                   |          |
| input capture (two channel)                     |          |
| input capture control status register (ICS01)   |          |
| input capture data register (IPC0/IPC1)         | 255      |
| input capture input timing                      | 262      |
| input data register (SIDR0/SIDR1)               | 280      |
| instruction map, structure of                   | 499      |
| instruction presentation item and symbol,       |          |
| description of                                  |          |
| instruction type                                |          |
| INT9 interrupt                                  |          |
| internal clock mode                             | 222      |
| internal clock mode (reload mode),              |          |
| operation in                                    |          |
| internal clock mode (single-shot mode)          |          |
| internal peripheral function (resources)        |          |
| internal shift clock mode                       | 192      |
| internal timer (16-bit reload timer), baud rate |          |
| determined using                                | 293      |
| interrupt cause and interrupt vector/interrupt  | 405      |
| control register                                |          |
| interrupt control register                      |          |
| interrupt control register (ICR00 to ICR15)     |          |
| interrupt control register function             |          |
| interrupt control registers (ICR)               |          |
| interrupt level mask register (ILM)             |          |
| interrupt operation                             |          |
| interrupt suppression instruction               |          |
| interrupt type and function                     |          |
| interrupt vector 104,                           |          |
| interval timer function                         | 200      |
| interval timer function (timebase timer),       | <u> </u> |
| operation of                                    | 207      |
|                                                 |          |

#### L

| linear addressing and bank addressing          | 28 |
|------------------------------------------------|----|
| low power consumption mode control register    |    |
| (LPMCR)                                        | 86 |
| low power consumption mode, operating state in | 97 |

#### Μ

| machine clock                      | . 78 |
|------------------------------------|------|
| main clock mode and PLL clock mode | . 77 |

| master-slave communication function         | 4  |
|---------------------------------------------|----|
| maximum rated voltage (latchup prevention), |    |
| strict observation of1                      | 6  |
| MB90M405 series features                    | 2  |
| memory map 2                                | :6 |
| memory space2                               | 3  |
| mode control register (SMR0/SMR1)27         | '5 |
| mode data 15                                | 0  |
| mode data fetch 6                           | 5  |
| mode pin 6                                  | 54 |
| mode pin (MD2 to MD0)14                     | 9  |
| mode setting14                              | 8  |
| multibyte data access 3                     | 3  |
| multibyte data in RAM, storage of 3         | 52 |
| multibyte data in stack, storage of 3       | 3  |
| multibyte operand, storage of 3             | 32 |
| multiple interrupt                          |    |
| •                                           |    |

## 0

| operating mode                                                    | 148 |
|-------------------------------------------------------------------|-----|
| operating status during standby mode                              | 90  |
| operation flow of extended intelligent I/O service<br>(EI2OS)     | 134 |
| operation in synchronous mode (operation<br>mode 2)               | 300 |
| operation of DTP/external interrupt circuit                       | 324 |
| operation of extended intelligent I/O service<br>(EI2OS)          | 128 |
| oscillation stabilization wait reset status                       | 62  |
| oscillation stabilization wait time 62, 79,                       | 100 |
| oscillation stabilization wait time timer function                | 207 |
| oscillator or external clock to microcontroller,<br>connection of | 80  |
| output compare (one channel)                                      | 246 |
| output compare control status register (OCS0)                     | 253 |
| output compare register (OCCP0)                                   | 252 |
| output data register (SODR0/SODR1)                                | 281 |
|                                                                   |     |

#### Ρ

| pin after mode data being read, status of6  | 39  |
|---------------------------------------------|-----|
| pin assignment                              | . 9 |
| pin during reset, status of6                | 39  |
| pin function1                               | 10  |
| placing flash Memory in read/reset status   | 35  |
| PLL clock mode                              | 77  |
| PLL clock mode, note on during operation of | 18  |
| PLL clock multiplier, selection of          | 77  |
| port 8 configuration15                      | 58  |
| port 8 pin                                  | 58  |
|                                             |     |

| port 8 pin, block diagram of                      | 159    |
|---------------------------------------------------|--------|
| port 8 register                                   | 159    |
| Port 8 Register, function of                      | 160    |
| port 8, operation of                              | 161    |
| port 9 configuration                              | 163    |
| port 9 pin                                        | 163    |
| port 9 pin, block diagram of                      | 164    |
| Port 9 register                                   | 164    |
| port 9 register, function of                      | 165    |
| port 9, operation of                              | 166    |
| port A configuration                              | 168    |
| port A pin16                                      | 8, 169 |
| port A pin, block diagram of                      | 169    |
| port A register                                   | 169    |
| port A register, function of                      | 170    |
| port A, operation of                              | 172    |
| port B configuration                              | 174    |
| port B pin17                                      | 4, 175 |
| port B pin, block diagram of                      | 175    |
| port B register                                   | 175    |
| port B register, function of                      | 176    |
| port B, operation of                              | 178    |
| port register                                     | 393    |
| port register (FLPD)                              |        |
| power supply pin                                  | 17     |
| power-on, note on                                 | 16     |
| prefix code                                       | 52     |
| prefix code and interrupt suppression instruction | n57    |
| procedure for using extended intelligent I/O      |        |
| service (EI2OS)                                   | 135    |
| procedure for using hardware interrupt            | 119    |
| processing for interrupt operation                | 118    |
| processing time (one transfer time) of extended   | b      |
| intelligent I/O service (EI2OS)                   | 136    |
| processor status (PS) configuration               | 42     |
| product lineup                                    | 5      |
| program address detection control status          |        |
| register (PACSR)                                  | 417    |
| program address detection register for upper,     |        |
| middle and lower part of address (PADR0/PADR1)    | 110    |
| · · · · · · · · · · · · · · · · · · ·             |        |
| program counter (PC)                              | 47     |

# R

| RAM area24                                             |
|--------------------------------------------------------|
| reception interrupt generation and flag set timing 286 |
| register bank51                                        |
| register bank pointer45                                |
| register bank pointer (RP)45                           |

| relationship between mode pin and mode data 151        |
|--------------------------------------------------------|
| relationship between operation mode and power20        |
| release of sleep mode91                                |
| release of stop mode94                                 |
| release of timebase timer mode93                       |
| request level setting register (ELVR)                  |
| reset cause60, 67                                      |
| reset cause and oscillation stabilization wait time 62 |
| reset cause bit66                                      |
| reset cause bit, note about68                          |
| reset operation, overview of64                         |
| returning from hardware interrupt116                   |
| returning from software interrupt125                   |
| ROM area24                                             |
| ROM mirroring function selection module, block         |
| diagram of424                                          |
| ROM mirroring function selection register              |
| (ROMM)425                                              |
|                                                        |

# S

| sample I/O port program                                                                | . 180 |
|----------------------------------------------------------------------------------------|-------|
| sample programs for interrupt processing                                               | .142  |
| sector configuration                                                                   | .429  |
| segment dimmer setting register (SEGD)                                                 | . 397 |
| segment gradation display (segment dimmer)                                             | . 397 |
| serial data I/O timing                                                                 | .196  |
| serial data register, R/W wait state of                                                | .193  |
| serial I/O unit, block diagram of                                                      | .182  |
| serial I/O unit, interrupt function of                                                 | . 197 |
| serial I/O unit, operation of                                                          | .191  |
| serial I/O unit, overview of                                                           | .182  |
| serial I/O unit, registers of                                                          | . 183 |
| serial mode control status register lower<br>(SMCR)                                    | . 186 |
| serial mode control status register, higher<br>(SMCR)                                  | . 184 |
| serial programming (when power supplied by                                             | 440   |
| user), example of connection for                                                       | .440  |
| serial programming (when power supplied from<br>programmer), example of connection for | .448  |
| serial programming connection to MB90MF408/                                            |       |
| MF408A, standard configuration for                                                     | .444  |
| serial shift data register (SDR)                                                       | .188  |
| setting DTP/external interrupt circuit                                                 | .323  |
| shift operation, start/stop timing of                                                  | . 195 |
| single conversion mode, operation in                                                   | .372  |
| software interrupt activation                                                          | . 125 |
| software interrupt operation                                                           | .126  |
| software pull-up resistor                                                              | 98    |

| specifying more than one sector, note on         | 439   |
|--------------------------------------------------|-------|
| specifying sector                                | 439   |
| stack area                                       | 141   |
| stack operation at start of interrupt processing | 140   |
| stack operation on return from interrupt         |       |
| processing                                       |       |
| stack selection                                  |       |
| standby mode                                     |       |
| standby mode by interrupt, release of            |       |
| start condition                                  | 347   |
| start condition generation instruction while     |       |
| SDA=LOW and SCL=LOW, execution of                |       |
| status change diagram                            |       |
| status of pin in single-chip mode                |       |
| status register (SSR0/SSR1)                      |       |
| status/authorization register (FLST)             |       |
| stop condition                                   |       |
| stop conversion mode, operation in               |       |
| stop mode and sleep mode, operation in           |       |
| stop mode by external interrupt, release of      |       |
| STOP state                                       | . 193 |
| stopped state                                    | 193   |
| STP, SLP and TMD bit, priority of                | 88    |
| structure of instruction map                     | 499   |
| supply voltage, stabilization of                 | 16    |
| switching to sleep mode                          | 91    |
| switching to standby mode and interrupt          | 99    |
| switching to stop mode                           | 94    |
| switching to timebase timer mode                 |       |
| system configuration                             |       |
| system stack pointer (SSP)                       | 41    |
|                                                  |       |

#### т

| temporarily stopping sector deletion            | 441 |
|-------------------------------------------------|-----|
| timebase timer control register (TBTC)          | 204 |
| timebase timer interrupt                        | 206 |
| timebase timer interrupt and EI2OS              | 206 |
| timebase timer operation status                 | 209 |
| timebase timer usage note                       | 210 |
| timebase timer, block diagram of                | 202 |
| timer control status register, higher (TMCSR)   | 229 |
| timer control status register, low part (TMCSR) | 231 |
| timer counter control status register (TCCS)    | 250 |
| timer counter data register (TCDT)              | 249 |
| transfer state                                  | 194 |
| transmission interrupt output and flag set      |     |
| timing                                          | 288 |
| treating pin when the A/D converter is not used | 17  |
| type of instruction                             | 464 |
|                                                 |     |

#### U

| UART baud rate selection       |          |
|--------------------------------|----------|
| UART EI2OS function            |          |
| UART function                  |          |
| UART interrupt                 |          |
| UART interrupt and EI2OS       | 265, 285 |
| UART pin                       |          |
| UART pin, block diagram of     |          |
| UART register                  |          |
| UART, block diagram of         |          |
| UART, note on using            | 307      |
| UART, operation of             |          |
| unused input pin, treatment of | 16       |

#### W

| watch clock output circuit                      | 404 |
|-------------------------------------------------|-----|
| watch clock output control register (TMCS)      | 406 |
| watch clock selection circuit, block diagram of | 405 |
| watchdog timer control register (WDTC)          | 215 |
| watchdog timer function                         | 212 |
| watchdog timer operation                        | 217 |
| watchdog timer, block diagram of                | 213 |
| watchdog timer, usage note on                   | 219 |
| writing data, note on                           | 436 |
|                                                 |     |

INDEX

CM44-10116-2E

# FUJITSU SEMICONDUCTOR •CONTROLLER MANUAL

F<sup>2</sup>MC-16LX 16-BIT MICROCONTROLLER MB90M405 Series HARDWARE MANUAL

October 2001 the second edition

Published FUJITSU LIMITED Electronic Devices

Edited Technical Information Dept.