# F $^{2}$ MC-16LX <br> 16-BIT MICROCONTROLLER MB90580 SERIES HARDWARE MANUAL 

## PREFACE

Thank you for selecting FUJITSU Semiconductor Devices.
The FUJITSU MB90580 series has been developed as one general-application version of the $\mathrm{F}^{2} \mathrm{MC}^{® *} 16 \mathrm{LX}$ series of original 16 -bit one-chip microcontrollers for ASIC (application specific IC) applications. This manual describes the functions and operations of the MB90580 series, and is intended for use by engineers actually designing products using these semiconductors. Please be sure to read it carefully.
*: $\quad F^{2} M C$ is an abbreviation for FUJITSU Flexible Microcontroller, and is a registered trademark of Fujitsu.

This document is organized as follows.
Chapter 1 OVERVIEW
This section presents an overview of MB90580 series features and functions.
Chapter 2 CPU
This section describes the functions of the $\mathrm{F}^{2} \mathrm{MC}-16 \mathrm{LX}$ series CPU .

## Chapter 3 MEMORY

This section describes the functions of the $\mathrm{F}^{2} \mathrm{MC}$-16LX series memory.

## Chapter 4 CLOCK AND RESET

This section describes the functions of the MB90580 series clocks and resets.

## Chapter 5 WATCHDOG TIMER, TIME BASE TIMER, AND WATCH TIMER FUNCTION

This section describes the functions and operation of the MB90580 series watchdog timer, timebase timer and watch timer function.

## Chapter 6 LOW POWER CONTROL CIRCUIT

This section describes the MB90580 series low power control circuits (CPU intermittent operation function, oscillator stabilization wait time, PLL clock multiplier function).

## Chapter 7 INTERRUPT

This section describes the functions of each MB90580 each interrupt and interrupt source.

## Chapter 8 PARALLEL PORTS

This section describes the functions of the MB90580 series parallel port.

## Chapter 9 DTP/EXTERNAL INTERRUPT

This section describes the function and operation of the MB90580 series DTP and external interrupts.

## Chapter 10 DELAY INTERRUPT MODULE

This section describes the functions and operation of the MB90580 series delay interrupt module.

## Chapter 12 COMMUNICATION PRESCALER

This section describes the MB90580 series communication prescaler.

## Chapter 13 UART

This section describes the function and operation of the MB90580 UART.

## Chapter 14 IE BUS

This section describes the functions and operation of the MB90580 series IE Bus.

## Chapter 15 8/16-BIT PPG

This section describes the functions and operation of the MB90580 series $8 / 16$-bit PPG.
Chapter 16 16-BIT RELOAD TIMER (WITH EVENT COUNT FUNCTION)
This section describes the functions and operation of the MB90580 series 16-bit reload timer.

## Chapter 17 A/D CONVERTERr

This section describes the functions and oeration of the MB90580 series A/D converter.
Chapter 18 D/A CONVERTER
This section describes the functions and oeration of the MB90580 series D/A converter
Chapter 19 PULSE WIDTH COUNTER (PWC) TIMER
This section describes the functions and oeration of the MB90580 series pulse width counter (PWC) timer.

## Chapter 20 CLOCK MONITOR FUNCTION

This section describes the functions of the MB90580 series clock monitor function.
Chapter 21 16-bit I/O Timers
This section describes the functions and operation of the MB90580 series 16-bit I/O timers which consists of 16 -bit free-run timer, 2 output compare regsiters and 4 input capture registers.

Chapter 22 ROM CORRECTION module
This section describes the function and operation of the MB90580 series rom correction module.

## Chapter 23 ROM MIRRORING MODULE

This section describes the function of the MB90580 series ROM mirrorling module.

## Appendix A I/O MAP

The appendix A provides I/O maps, and low power mode status transition charts.
Appendix B INSTRUCTION
The appendix B describes addressing in the $\mathrm{F}^{2} \mathrm{MC}^{\circledR \star *}$ - 16 LX series, and provides instruction lists and instruction maps.

Appendix C PROGRAMMING THE FLASH MEMORY ON THE MB90F584
The appendix C provides programming method of the flash memory on the MB90F584.

## CONTENTS

Chapter 1 Overview ..... 1
1.1 Features ..... 1
1.2 Product Lineup ..... 3
1.3 Block Diagram ..... 4
1.4 Pin Assignment ..... 5
1.4.1 SQFP-100 Pin Assignment ..... 5
1.4.1 QFP-100 Pin Assignment ..... 6
1.5 Pin Functions ..... 7
1.6 Handling the Device ..... 14
Chapter 2 CPU ..... 15
2.1 CPU ..... 15
2.1.1 Memory space ..... 16
2.1.2 Registers ..... 20
2.1.3 Prefix codes ..... 28
Chapter 3 Memory ..... 31
3.1 Memory Access Modes ..... 31
3.1.1 Mode pins ..... 32
3.1.2 Mode data ..... 33
3.1.3 Bus Mode ..... 34
3.2 External Memory Access ..... 36
3.2.1 Block diagram ..... 36
3.2.2 Registers and Register details ..... 37
3.2.1 Operations ..... 42
Chapter 4 Clock and Reset ..... 47
4.1 Clock Generator ..... 47
4.2 Reset Causes ..... 48
4.3 Operation after reset release ..... 50
Chapter 5 Watchdog Timer, Timebase Timer, and Watch Timer Functions ..... 51
5.1 Outline ..... 51
5.2 Block diagram ..... 52
5.3 Registers and register details ..... 53
5.3.1 WDTC (Watch-Dog Timer Control Register) ..... 54
5.3.2 TBTC (Time Base Timer Control Register) ..... 56
5.3.3 Watch Timer Control Register (WTC) ..... 57
5.4 Operation ..... 59
5.4.1 Watch-Dog Timer ..... 59
5.4.2 Time Base Timer ..... 60
5.4.3 Watch Timer ..... 60
Chapter 6 Low Power Control Circuit ..... 61
6.1 Outline ..... 61
6.2 Block Diagram ..... 62
6.3 Registers and register details ..... 63
6.3.1 LPMCR (Low power mode control register) ..... 63
6.3.2 CKSCR (Clock selection register) ..... 65
6.4 Operations ..... 67
6.4.1 Sleep mode ..... 68
6.4.2 Pseudo-watch mode ..... 68
6.4.3 Watch mode ..... 69
6.4.4 Stop mode ..... 69
6.4.5 Hardware standby mode ..... 70
6.4.6 CPU intermittent operation function ..... 70
6.4.7 Setting the main clock oscillation stabilization waiting period ..... 71
6.4.8 Switching the machine clock ..... 71
6.4.9 State transition ..... 73
Chapter 7 Interrupt ..... 81
7.1 Outline ..... 81
7.2 Causes of Interrupt ..... 82
7.3 Interrupt Vector ..... 83
7.4 Hardware Interrupt ..... 84
7.4.1 Overview ..... 84
7.4.2 Structure ..... 84
7.4.3 Operation ..... 84
7.4.4 Hardware Interrupt Ocurrence When Internal Resource Is Being Accessed ..... 87
7.4.5 Interrupt Inhibit Instruction ..... 87
7.4.6 Multiple Interrupts ..... 87
7.4.7 Register Saving In Stack Upon Interrupt ..... 87
7.4.8 Precaution in Using Hardware Interrupt ..... 87
7.5 Software Interrupt ..... 88
7.5.1 Overview ..... 88
7.5.2 Structure ..... 88
7.5.3 Operation ..... 89
7.5.4 Others ..... 89
7.6 Extended intelligent I/O service (EI2OS) ..... 90
7.6.1 Overview ..... 90
7.6.2 Structure ..... 91
7.6.3 Operation ..... 97
7.6.4 EI2OS Execution Time ..... 99
7.7 Exceptions ..... 100
7.7.1 Exception due to execution of an undefined instruction ..... 100
Chapter 8 Parallel Ports ..... 101
8.1 Outline ..... 101
8.2 Block Diagram ..... 102
8.3 Registers and register details ..... 103
8.3.1 Port data register ..... 104
8.3.2 Port direction registers ..... 105
8.3.3 Output pin register ..... 106
8.3.4 Input resistor register ..... 106
8.3.5 Analogue Input Enable Register ..... 107
8.3.6 Low Noise Output Select Register ..... 107
Chapter 9 DTP/External Interrupt ..... 109
9.1 Outline ..... 109
9.2 Block Diagram ..... 109
9.3 Registers and Register Details ..... 110
9.3.1 Interrupt/DTP enable register (ENIR: Enable interrupt request register) ..... 110
9.3.2 Interrupt/DTP cause register (EIRR: External interrupt request register) ..... 111
9.3.3 Request level setting register (ELVR: External level register) ..... 111
9.4 Operations ..... 112
9.4.1 External interrupts ..... 112
9.4.2 DTP operation ..... 113
9.4.3 Switching between external interrupt and DTP requests ..... 114
9.5 Notes on use ..... 115
9.5.1 Conditions on the externally connected peripheral when DTP is used ..... 115
9.5.2 Recovery from standby ..... 115
9.5.3 External interrupt/DTP operation procedure ..... 115
9.5.4 External interrupt request level ..... 115
Chapter 10 Delayed Interrupt Generation Module ..... 117
10.1 Outline ..... 117
10.2 Block Diagram ..... 117
10.3 Registers and Register Details ..... 117
10.4 Operations ..... 118
10.4.1 Delayed interrupt occurrence ..... 118
10.5 Notes on operation ..... 118
10.5.1 Delayed interrupt request lock ..... 118
Chapter 11 Communication Prescaler ..... 119
11.1 Outline ..... 119
11.2 Block Diagram ..... 119
11.3 Register and Register Details ..... 120
11.3.1 Clock Division Control Registers ..... 120
11.4 Operations ..... 121
Chapter 12 UART ..... 123
12.1 Outline ..... 123
12.2 Block Diagram ..... 124
12.3 Register and Register Details ..... 125
12.3.1 Serial Mode Register (SMR0/1/2/3/4) ..... 126
12.3.2 Serial Control Register (SCR0/1/2/3/4) ..... 128
12.3.3 Serial Input Data Register (SIDR0/1/2/3/4)/ Serial Ouput Data Register (SODR0/1/2/3/4) ..... 130
12.3.4 Serial Status Register (SSR0/1/2/3/4) ..... 130
12.4 Operations ..... 132
12.4.1 Operation modes ..... 132
12.4.2 UART clock selection ..... 132
12.4.3 Asynchronous mode ..... 134
12.4.4 CLK synchronous mode ..... 135
12.4.5 Interrupt occurrence and flag set timing ..... 137
12.4.6 I2OS (Intelligent I/O service) ..... 139
12.4.7 Notes on use ..... 139
12.4.8 Application ..... 139
Chapter 13 IE Bus ..... 141
13.1 Outline ..... 141
13.2 Block Diagram ..... 142
13.3 Registers and Register Details ..... 143
13.3.1 Command register upper byte (CMRH) ..... 146
13.3.2 Command register lower byte (CMRL) ..... 148
13.3.3 Unit address register (MAWH, MAWL) ..... 150
13.3.4 Slave address register (SAWH, SAWL) ..... 150
13.3.5 Mutliaddress, control bit set register (DCWR) ..... 151
13.3.6 Telegraph length set register (DEWR) ..... 152
13.3.7 Status register upper byte (STRH) ..... 153
13.3.8 Status register lower byte (STRL) ..... 155
13.3.9 Lock read register (LRRH, LRRL) ..... 157
13.3.10 Master address read register (MARH, MARL) ..... 158
13.3.11 Multiaddress, control bit read register (DCRR) ..... 159
13.3.12 Telegraph length read register (DERR) ..... 160
13.3.13 Read data buffer (RDB) ..... 161
13.3.14 Write data buffer (WDB) ..... 162
13.4 IEBus Communication Protocol ..... 163
13.4.1 Overview ..... 163
13.4.2 Determining bus mastership (arbitration) ..... 164
13.4.3 Communication mode ..... 164
13.4.4 Communication address ..... 165
13.4.5 Multiaddress communication ..... 165
13.4.6 Transfer protocol ..... 166
13.4.7 Transmit data ..... 170
13.4.8 Bit format ..... 173
13.5 Operation ..... 174
13.5.1 IEBus control ..... 174
13.5.2 Communication status ..... 177
13.5.3 Program flow example for IEBus controller ..... 179
13.5.4 Timing Diagram of Multiple Frame Transmission ..... 186
13.5.5 Timing diaram of transmission data when an error is generated ..... 188
Chapter 14 8/16-Bit PPG ..... 191
14.1 Outline ..... 191
14.2 Block Diagram ..... 192
14.3 Registers and Register Details ..... 194
14.3.1 PPG0 operation mode control register (PPGC0) ..... 195
14.3.2 PPG1 operation mode control register (PPGC1) ..... 197
14.3.3 PPGO, 1 output pin control register (PPGOE) ..... 199
14.3.4 Reload register (PRLL/PRLH ) ..... 200
14.4 Operations ..... 201
Chapter 15 16-Bit Reload Timer (with Event Count Function) ..... 207
15.1 Outline ..... 207
15.2 Block Diagram ..... 208
15.3 Registers and Register Details ..... 209
15.3.1 Timer control status register (TMCSR) ..... 210
15.3.2 TMR (16-bit timer register)/TMRLR (16-bit reload register) ..... 213
15.4 Operation ..... 214
15.4.1 Internal clock operation ..... 214
15.4.2 Underflow operation ..... 215
15.4.3 Input pin functions (for internal clock mode) ..... 216
15.4.4 External event counter ..... 216
15.4.5 Output pin functions ..... 217
15.4.6 Intelligent I/O service (I2OS) function and interrupts ..... 217
15.4.7 Counter operation state ..... 218
Chapter 16 A/D Converter ..... 219
16.1 Outline ..... 219
16.2 Block Diagram ..... 220
16.3 Registers and Register Details ..... 221
16.3.1 Control status registers (ADCS1 and ADCS2) ..... 222
16.3.2 ADCR1 and ADCR0 (Data registers) ..... 226
16.4 Operations ..... 228
16.5 Notes on use ..... 234
16.5.1 Other considerations ..... 234
Chapter 17 D/A Converter ..... 235
17.1 Outline ..... 235
17.2 Block Diagram ..... 236
17.3 Registers and Register Details ..... 237
17.3.1 DAT0/1 ( D/A data register) ..... 238
17.3.2 DACRO/1 ( D/A control register) ..... 238
17.4 Operations ..... 239
Chapter 18 Pulse Width Counter (PWC) Timer ..... 241
18.1 Outline ..... 241
18.2 Block Diagram ..... 242
18.3 Regiaters and Register Details ..... 243
18.3.1 PWC control status register (PWCSR) ..... 244
18.3.2 PWC data buffer register (PWCR) ..... 249
18.3.3 Divide Ratio Control Register (DIVR) ..... 250
18.3.4 PWC noise cancelling register (RNCR) ..... 251
18.4 Operations ..... 252
18.5 Precautions ..... 265
Chapter 19 Clock Monitor Function ..... 267
19.1 Outline ..... 267
19.2 Block Diagram ..... 267
19.3 Registers and Register Details ..... 268
19.3.1 Clock output enable register (CLKR) ..... 268
Chapter 20 16-Bit I/O Timer ..... 269
20.1 Outline ..... 269
20.2 Block Diagram ..... 271
20.2.1 Overall Block Diagram of 16-bit I/O Timer ..... 271
20.2.2 Block Diagram of 16-bit free-run timer ..... 272
20.2.3 Block Diagram of Output Comparison ..... 272
20.2.4 Block Diagram of Input Capture ..... 273
20.3 Registers and Register Details ..... 274
20.3.1 16-bit free-run timer ..... 274
20.3.2 Output comparison ..... 278
20.3.3 Input capture ..... 282
20.4 Operations ..... 285
20.4.1 16-bit free-run timer ..... 285
20.4.2 16-bit output compare ..... 286
20.4.3 16-bit input capture ..... 287
20.5 Timing ..... 288
20.5.1 16 -bit free-run timer count timing ..... 288
20.5.2 Output compare timing ..... 289
20.5.3 Input capture input timing ..... 290
Chapter 21 ROM Correction Module ..... 291
21.1 Outline ..... 291
21.2 Block Diagram ..... 291
21.3 Registers and Register Details ..... 292
21.3.1 Program Address Detect Register 0/1 (PADR0/PADR1) ..... 292
21.3.2 Program Address detect Control Status Register (PACSR) ..... 293
21.4 Operations ..... 294
21.5 Application Example ..... 295
Chapter 22 ROM Mirroring Module ..... 299
22.1 Outline ..... 299
22.2 Block Diagram ..... 299
22.3 Registers and Register Details ..... 300
22.3.1 ROM Mirror Function Select Register ..... 300
Appendix A I/O Map ..... 303
A. 1 I/O Map ..... 303
Appendix B Instructions ..... 309
B. 1 Addressing ..... 309
B.1.1 Effective address field ..... 309
B.1.2 Addressing Details ..... 310
B. 2 Instruction Set ..... 314
B.2.1 $\quad \mathrm{F}^{2} \mathrm{MC}$-16LX Instruction Set (351 Instructions) ..... 320
B. 3 Instruction Map ..... 334
B.3.1 Basic Page Map ..... 336
Appendix C The Flash Memory in the MB90F583 ..... 357
C. 1 Outline ..... 357
C. 2 Sector Structure of 1M Bit Flash Memory ..... 358
C. 3 Flash Control Register (FMCS) ..... 359
C. 4 Automatic Algorithm Initiation Method ..... 361
C. 5 Automatic Algorithm Execution Status ..... 362
C.5.1 Data polling flag (DQ7) ..... 363
C.5.2 Toggle bit flag (DQ6) ..... 364
C.5.3 Exceeded timing limits flag (DQ5) ..... 365
C.5.4 Sector erase timer flag (DQ3) ..... 366
C. 6 Notes on Flash Memory Program/Erase ..... 367
C.6.1 Read/reset status ..... 367
C.6.2 Data Programming ..... 368
C.6.3 Chip Erase ..... 370
C.6.4 Sector Erase ..... 370
C.6.5 Suspend Sector Erase ..... 372
C.6.6 Resume Sector Erase ..... 372

## FIGURES

Chapter 1 Overview ..... 1
Figure 1.3a Block Diagram of MB90580 Series ..... 4
Figure 1.4a Pin Assignment of MB90580 (LQFP-100) ..... 5
Figure 1.4b Pin Assignment of MB90580 (QFP-100) ..... 6
Figure 1.6a Using external clock ..... 14
Figure 1.6b Connection of Power pins ..... 14
Chapter 2 CPU ..... 15
Figure 2.1.1a Sample relationship between F2MC-16LX system and memory map ..... 16
Figure 2.1.1b Sample linear addressing ..... 17
Figure 2.1.1c Physical addresses of each space ..... 18
Figure 2.1.1d Sample allocation of multi-byte data in memory ..... 19
Figure 2.1.1e Execution of MOVW A, 080FFFFH ..... 19
Figure 2.1.2a Special registers ..... 20
Figure 2.1.2b General-purpose registers ..... 21
Figure 2.1.2c Program counter. ..... 21
Figure 2.1.2d 32-bit data transfer ..... 22
Figure 2.1.2e AL-AH transfer ..... 22
Figure 2.1.2f Stack manipulation instruction and stack pointer ..... 23
Figure 2.1.2g PS structure ..... 24
Figure 2.1.2h Condition code register configuration ..... 24
Figure 2.1.2i Register bank pointer ..... 25
Figure 2.1.2j Interrupt level register ..... 25
Figure 2.1.2k Generating a physical address in direct addressing mode ..... 27
Figure 2.1.3a Interrupt disable instruction ..... 29
Figure 2.1.3b Interrupt disable instructions and prefix codes ..... 30
Figure 2.1.3c Consecutive prefix codes ..... 30
Chapter 3 Memory ..... 31
Figure 3.1.3a Access areas and physical addresses in each bus mode ..... 34
Figure 3.2.1a External bus pin control circuit ..... 36
Figure 3.2.1a External memory access timing chart ..... 42
Figure 3.2.1b External memory access timing chart ..... 43
Figure 3.2.1c Ready timing chart ..... 44
Figure 3.2.1d Hold timing ..... 45
Chapter 4 Clock and Reset ..... 47
Figure 4.1a Clock generator circuit block diagram ..... 47
Figure 4.2a Reset cause bit block diagram ..... 49
Figure 4.2b WDTC (watch-dog timer control register) ..... 49
Figure 4.3a Source and destination of reset vector and mode data ..... 50
Chapter 5 Watchdog Timer, Timebase Timer, and Watch Timer Functions ..... 51
Figure 5.2a Watchdog Timer, Timebase Timer, and Watch Timer Block Diagram ..... 52
Figure 5.4.1a Watch-dog timer operation ..... 59
Chapter 6 Low Power Control Circuit ..... 61
Figure 6.2a Low-power consumption control circuit and clock generator ..... 62
Figure 6.4.8a Clock Selection State Transition Diagram (1) ..... 72
Figure 6.4.8b Clock Selection State Transition Diagram (2) ..... 73
Figure 6.4.9a Low Power Consumption Mode Transition Diagram A ..... 77
Figure 6.4.9b Low Power Consumption Mode Transition Diagram B ..... 78
Figure 6.4.9c Low Power Consumption Mode Transition Diagram C ..... 79
Figure 6.4.9d Low Power Consumption Mode Transition Diagram D ..... 80
Chapter 7 Interrupt ..... 81
Figure 7.4.3a Occurrence and release of hardware interrupt ..... 85
Figure 7.4.3b Hardware interrupt operation flow ..... 86
Figure 7.4.7a Registers saved in stack ..... 87
Figure 7.5.3a Occurrence and release of software interrupt ..... 89
Figure 7.6.1a Outline of extended intelligent I/O service ..... 90
Figure 7.6.2a Extended intelligent I/O service descriptor configuration ..... 94
Figure 7.6.3a EI2OS operation flow ..... 97
Figure 7.6.3b EI2OS use flow ..... 98
Chapter 8 Parallel Ports ..... 101
Figure 8.2a Block diagram of I/O port ..... 102
Figure 8.2b Block diagram of input resistor register ..... 102
Figure 8.2c Block diagram of Output pin register ..... 102
Figure 8.3a Registers of Parallel Ports ..... 103
Chapter 9 DTP/External Interrupt ..... 109
Figure 9.2a Block diagram of DTP/External Interrupt ..... 109
Figure 9.4.1a External interrupt ..... 112
Figure 9.4.2a Timing to cancel the external interrupt at the end of DTP operation ..... 113
Figure 9.4.2b Sample interface to the external peripheral ..... 113
Figure 9.4.3a Switching between external interrupt and DTP requests ..... 114
Figure 9.5.4a Clearing the cause hold circuit upon level set ..... 115
Figure 9.5.4b Interrupt cause and interrupt request to the interrupt controller while interrupts are enabled ..... 115
Chapter 10 Delayed Interrupt Generation Module ..... 117
Figure 10.2a Block diagram of Delayed Interrupt Generation Module ..... 117
Figure 10.4.1a Delayed interrupt issuance ..... 118
Chapter 11 Communication Prescaler ..... 119
Figure 11.2a Block diagram of Communication Prescaler ..... 119
Chapter 12 UART ..... 123
Figure 12.2a Block diagram of UART ..... 124
Figure 12.3a Registers of UART ..... 125
Figure 12.4.3a Transfer data format (modes 0 and 1) ..... 134
Figure 12.4.4a Transfer data format (mode 2) ..... 135
Figure 12.4.5a Timing to set PE, ORE, FRE, and RDRF (mode 0) ..... 137
Figure 12.4.5b Timing to set ORE, FRE, and RDRF (mode 1) ..... 137
Figure 12.4.5c Timing to set ORE and RDRF (mode 2). ..... 138
Figure 12.4.5d Timing to set TDRE (modes 0 and 1) ..... 138
Figure 12.4.5e Timing to set TDRE (mode 2) ..... 138
Figure 12.4.8a Sample system configuration in mode 1 ..... 139
Figure 12.4.8b Flow chart of communication in mode 1 ..... 140
Chapter 13 IE Bus ..... 141
Figure 13.2a Block Diagram of IE Bus ..... 142
Figure 13.3a Registers of IE BUS (1/3) ..... 143
Figure 13.3b Registers of IE BUS (2/3) ..... 144
Figure 13.3c Registers of IE BUS (3/3) ..... 145
Figure 13.5.4a When setting ' 1 ' on WDBC (Master side of master transmission) ..... 186
Figure 13.5.4b When setting ' 0 ' on WDBC (Master side of master transmission) ..... 187
Figure 13.5.5a Error happened on the Slave side when master transmission ..... 188
Figure 13.5.5b Error happened on the Master side when master transmission ..... 189
Chapter 14 8/16-Bit PPG ..... 191
Figure 14.2a 8-bit PPG ch0 block diagram ..... 192
Figure 14.2b 8-bit PPG ch1 block diagram ..... 193
Figure 14.3a Registers of 8/16-bit PPG ..... 194
Figure 14.4a PPG output operation, output waveform ..... 202
Figure 14.4b 8+8 PPG output operation waveform ..... 203
Figure 14.4c Write timing chart ..... 205
Figure 14.4d PRL write operation block diagram ..... 205
Chapter 15 16-Bit Reload Timer (with Event Count Function) ..... 207
Figure 15.2a Block Diagram of 16-Bit Reload Timer ..... 208
Figure 15.3a Registers of 16-Bit Reload Timer ..... 209
Figure 15.3.1a Timer Control Status Register ..... 210
Figure 15.3.2a 16-Bit Timer Register and 16-Bit Reload Register ..... 213
Figure 15.4.1a Counter Activation and Operation ..... 214
Figure 15.4.2a Underflow Operation ..... 215
Figure 15.4.3a Trigger Input Operation ..... 216
Figure 15.4.3b Gate Input Operation ..... 216
Figure 15.4.5a Output Pin Functions (1) ..... 217
Figure 15.4.5b Output Pin Functions (2) ..... 217
Figure 15.4.7a Counter State Transitions ..... 218
Chapter 16 A/D Converter ..... 219
Figure 16.2a Block Diagram of $A / D$ converter ..... 220
Figure 16.3a Registers of A/D Converter ..... 221
Figure 16.3.1a Control Status Registers ..... 222
Figure 16.3.2a Data Registers ..... 226
Figure 16.4a Flow chart of A/D Conversion ..... 229
Figure 16.4b Flow Chart of Data Protection Function ..... 233
Chapter 17 D/A Converter ..... 235
Figure 17.2a Block Diagram of D/A Cobverter ..... 236
Figure 17.3a Register of D/A Converter ..... 237
Chapter 18 Pulse Width Counter (PWC) Timer ..... 241
Figure 18.2a lock Diagram of Pulse Width Counter Timer ..... 242
Figure 18.3a Register of Pulse Width Counter Timer ..... 243
Figure 18.4a Timer Operation (Single-Shot Mode) ..... 252
Figure 18.4b Timer Operation (Reload Mode) ..... 252
Figure 18.4c Pulse Width Count Operation (Single-Shot Count Mode, "H" Width Count Mode) ..... 253
Figure 18.4d Pulse Width Count Operation (Continuous Count Mode, "H" Width Count Mode) ..... 253
Figure 18.4e Operation Mode Selection ..... 255
Figure 18.4f Flowchart of Timer Mode Operation ..... 259
Figure 18.4g Flowchart of Operation in Pulse Width Count Mode ..... 264
Chapter 19 Clock Monitor Function ..... 267
Figure 19.2a Block Diagram of Clock Monitor Function ..... 267
Figure 19.3a Registers of Clock Monitor Function ..... 268
Chapter 20 16-Bit I/O Timer ..... 269
Figure 20.2.1a Overall Block diagram of 16-bit I/O Timer ..... 271
Figure 20.2.2a Block diagram of 16-bit free-run timer ..... 272
Figure 20.2.3a Block diagram of Output Comparison ..... 272
Figure 20.2.4a Block diagram of Input Capture ..... 273
Figure 20.3.1a Registers of 16-bit free-run timer ..... 274
Figure 20.3.2a Registers of output comparsion ..... 278
Figure 20.3.3a Register of input capture ..... 282
Chapter 21 ROM Correction Module ..... 291
Figure 21.2a Block Diagram of ROM Correction Module ..... 291
Figure 21.3a Registers of ROM Correction Module ..... 292
Figure 21.5a System Structure Example ..... 295
Figure 21.5b ROM Correction Processing Example ..... 296
Figure 21.5c ROM Correction Processing Flow Diagram ..... 297
Chapter 22 ROM Mirroring Module ..... 299
Figure 22.2a Block Diagram of ROM Mirroring Module ..... 299
Figure 22.3a Register of ROM Mirroring Module ..... 300
Figure 22.3b Memory in Single Chip Mode ..... 301
Figure 22.3c Memory in Internal ROM External Bus Mode ..... 301
Appendix A I/O Map ..... 303
Appendix B Instructions ..... 309
Fig. B.1.2a Register List Configuration ..... 312
Fig. B.3a Structure of $\mathrm{F}^{2}$ MC-16LX Instruction Map ..... 334
Fig. B.3b Correspondence between Actual Instructions and the Instruction Maps ..... 335
Appendix C The Flash Memory in the MB90F583 ..... 357
Figure C.2a Sector structure of 1M bit flash memory ..... 358
Figure C.3a Timing of RDYINT and RDY ..... 360
Figure C.6.2a Example flowchart of progamming the flash memory ..... 369
Figure C.6.4a Example flowchart of erasing flash memory ..... 371

## TABLES

Chapter 1 Overview ..... 1
Table 1.2a MB90580 series product lineup ..... 3
Table 1.5a Pin functions (1/4) (STBC: With standby control) ..... 7
Table 1.5b Pin functions (2/4) ..... 8
Table 1.5c Pin functions (3/4) ..... 9
Table 1.5d Pin functions (4/4) ..... 10
Table 1.5e I/O circuit format (1) ..... 11
Table 1.5f I/O circuit format (2) ..... 12
Table $1.5 \mathrm{~g} \quad \mathrm{I} / \mathrm{O}$ circuit format (3) ..... 13
Chapter 2 CPU ..... 15
Table 2.1.1a Default space ..... 18
Table 2.1.2a Levels indicated by the interrupt level mask (ILM) register ..... 25
Table 2.1.2b Register functions ..... 26
Table 2.1.2c Relationship between registers ..... 26
Table 2.1.3a Bank select prefix ..... 28
Chapter 3 Memory ..... 31
Table 3.1a Memory Access Mode ..... 31
Table 3.1.1a Mode pins and modes ..... 32
Table 3.1.3a Sample recommended setting of mode pins and mode data ..... 35
Table 3.1.3b Modes and related external pin operations ..... 35
Table 3.2.0a Selecting the high-order address bit output control ..... 39
Chapter 4 Clock and Reset ..... 47
Table 4.2a Reset causes ..... 48
Table 4.2b Reset cause bits ..... 49
Chapter 5 Watchdog Timer, Timebase Timer, and Watch Timer Functions ..... 51
Table 5.3.1a Reset cause registers ..... 54
Table 5.3.1b Watchdog Timer Interval Selection Bits ..... 55
Table 5.3.2a Selecting the time base timer interval ..... 56
Table 5.3.3a Watch Timer Interval Selection ..... 58
Chapter 6 Low Power Control Circuit ..... 61
Table 6.3.1a CG Bit Setting ..... 64
Table 6.3.2a WS Bit Settings ..... 65
Table 6.3.2b CS Bit Settings ..... 66
Table 6.4a Low Power Consumption Mode Operating Statuses ..... 67
Table 6.4.9a List of Transition Conditions ..... 74
Chapter 7 Interrupt ..... 81
Table 7.2a Interrupt causes, interrupt vectors, and interrupt control registers ..... 82
Table 7.3a MB90580 interrupt assignment table (1/2) ..... 83
Table 7.4.3a Compensation values for interrupt processing cycle count ..... 86
Table 7.6.2a ICS bits, channel numbers, and descriptor addresses ..... 92
Table 7.6.2b $S$ bits and end conditions ..... 92
Table 7.6.2c Interrupt level setting bits and interrupt levels ..... 93
Table 7.6.4a Execution time when the extended I2OS continues ..... 99
Table 7.6.4b Data transfer compensation values for extended I2OS execution time ..... 99
Chapter 8 Parallel Ports ..... 101
Chapter 9 DTP/External Interrupt ..... 109
Chapter 10 Delayed Interrupt Generation Module ..... 117
Chapter 11 Communication Prescaler ..... 119
Chapter 12 UART ..... 123
Table 12.4.1a UART operation modes ..... 132
Table 12.4.2a Baud rate (f indicates the machine clock.) ..... 132
Table 12.4.2b Baud rates and reload values ..... 133
Chapter 13 IE Bus ..... 141
Table 13.3.1a Transmission mode ..... 146
Table 13.3.1b Setting for GOTM and GOTS ..... 147
Table 13.3.2a Interval for the occurrence of data transmit interrupt ..... 148
Table 13.3.2b Interval for the occurrence of data transmit interrupt ..... 148
Table 13.3.2c Interval for the occurrence of data transmit interrupt ..... 148
Table 13.3.2d Internal clock frequency ..... 149
Table 13.3.5a Control bits setting ..... 151
Table 13.3.6a Number of transmit data bytes setting ..... 152
Table 13.3.8a Status flag ..... 156
Table 13.3.13a Time Required for next data receive after receive buffer full interrupt occurred ..... 161
Table 13.3.14a Data write time after WDB empty interrupt ..... 162
Table 13.4.1a IEBus transfer rates ..... 163
Table 13.4.3a Transfer rate and maximum number of transfer byte in each communication mode ..... 164
Table 13.4.6a Number of transmit data bytes setting ..... 167
Table 13.4.7a Control bits setting ..... 170
Table 13.4.7b The control command that can be executed by a locked slave unit ..... 170
Table 13.4.7c Meaning of Slave Status ..... 171
Table 13.5.1a Time required to write transmit data to WDB after transmit interrupt has occurred ..... 175
Table 13.5.2a Meaning of status code ST3-0 for master, slave transmit ..... 177
Table 13.5.2b Meaning of status code ST3-0 for master receive ..... 177
Table 13.5.2c Meaning of status code ST3-0 for slave receive ..... 178
Table 13.5.2d Meaning of status code ST3-0 for multiaddress receive ..... 178
Chapter 14 8/16-Bit PPG ..... 191
Table 14.4a Reload operation and pulse output ..... 201
Chapter 15 16-Bit Reload Timer (with Event Count Function) ..... 207
Chapter 16 A/D Converter ..... 219
Chapter 17 D/A Converter ..... 235
Table 17.4a Theoretical values of D/A converter output voltages ..... 239
Chapter 18 Pulse Width Counter (PWC) Timer ..... 241
Table 18.4a Count Clock Selection ..... 254
Table 18.4b Start and Stop Bit Functions ..... 256
Table 18.4c Operating State Indicator Bit Functions ..... 256
Table 18.4d Count Clock and Period ..... 258
Table 18.4e Count Input Pin Selection ( $\mathrm{n}=3$ to 0 ) ..... 260
Table 18.4f Count Modes ..... 261
Table $18.4 \mathrm{~g} \quad$ Pulse Width Count Range ..... 263
Chapter 19 Clock Monitor Function ..... 267
Chapter 20 16-Bit I/O Timer ..... 269
Chapter 21 ROM Correction Module ..... 291
Chapter 22 ROM Mirroring Module ..... 299
Appendix A I/O Map ..... 303
Table A.1a I/O map ..... 303
Appendix B Instructions ..... 309
Table B.1.1a Effective Address Field ..... 309
Table B.2a Explanation of Items in Table of Instructions ..... 314
Table B.2b Explanation of Symbols in Table of Instructions ..... 316
Table B.2c Effective Address Fields ..... 317
Table B.2d Number of Execution Cycles for Each Form of Addressing ..... 318
Table B.2e Compensation Values for Number of Cycles Used to Calculate Number of Actual Cycles ..... 318
Table B.2f Compensation Values for Number of Cycles Used to Calculate Number of Program Fetch Cycles ..... 319
Table B.2.1a Transfer Instructions (Byte) (41 Instructions) ..... 320
Table B.2.1b Transfer Instructions (Word/Long-Word) (38 Instructions) ..... 321
Table B.2.1c Addition and Subtraction Instructions (Byte/Word/Long-Word) (42 Instructions) ..... 322
Table B.2.1d Increment and Decrement Instructions (Byte/Word/Long-Word) (12 Instructions) ..... 323
Table B.2.1e Compare Instructions (Byte/Word/Long-Word) (11 Instructions) ..... 323
Table B.2.1f Unsigned Multiplication and Division Instructions (Word/Long-Word) (11 Instructions) 324
Table B.2.1g Signed Multiplication and Division Instructions (Word/Long-Word) (11 Instructions) 325
Table B.2.1h Logical 1 Instructions (Byte/Word) (39 Instructions) ..... 326
Table B.2.1i Logical 2 Instructions (Long-Word) (6 Instructions) ..... 327
Table B.2.1j Sign Inversion Instructions (Byte/Word) (6 Instructions) ..... 327
Table B.2.1k Normalize Instruction (Long-Word) (1 Instruction) ..... 327
Table B.2.1I Shift Instructions (Byte/Word/Long-Word) (18 Instructions) ..... 328
Table B.2.1m Branch 1 Instructions (31 Instructions) ..... 329
Table B.2.1n Branch 2 Instructions (19 Instructions) ..... 330
Table B.2.10 Other Control Instructions (Byte/Word/Long-Word) (36 Instructions) ..... 331
Table B.2.1p Bit Manipulation Instructions (22 Instructions) ..... 332
Table B.2.1q Accumulator Manipulation Instructions (Byte/Word) (6 Instructions) ..... 333
Table B.2.1r String Instructions (10 Instructions) ..... 333
Table B.3.1a Basic Page Map ..... 336
Table B.3.1b Bit Manipulation Instruction Map (First byte $=6 \mathrm{CH}$ ) ..... 337
Table B.3.1c Character String Manipulation Instruction Map (First byte $=6 \mathrm{EH}$ ) ..... 338
Table B.3.1d Two-byte Instruction Map (First byte $=6 \mathrm{FH}$ ) ..... 339
Table B.3.1e "ea" Instructions 1 (First byte $=70 \mathrm{H}$ ) ..... 340
Table B.3.1f "ea" Instructions 22 (First byte = 71H) ..... 341
Table B.3.1g "ea" Instructions 3 (First byte $=72 \mathrm{H}$ ) ..... 342
Table B.3.1h "ea" Instructions 4 (First byte = 73H) ..... 343
Table B.3.1i "ea" Instructions 5 (First byte $=74 \mathrm{H}$ ) ..... 344
Table B.3.1j "ea" Instructions 6 (First byte $=75 \mathrm{H}$ ) ..... 345
Table B.3.1k "ea" Instructions 7 (First byte $=76 \mathrm{H}$ ) ..... 346
Table B.3.1I "ea" Instructions 8 (First byte $=77 \mathrm{H}$ ) ..... 347
Table B.3.1m "ea" Instructions 9 (First byte = 78H) ..... 348
Table B.3.1n MOVEA RWi, ea (First byte $=79 \mathrm{H}$ ) ..... 349
Table B.3.1o MOV Ri, ea (First byte = 7AH) ..... 350
Table B.3.1p MOVW RWi, ea (First byte $=7 B H$ ) ..... 351
Table B.3.1q MOV ea, Ri (First byte $=7 \mathrm{CH}$ ) ..... 352
Table B.3.1r MOVW ea, RWi (First byte = 7DH) ..... 353
Table B.3.1s CH Ri, ea (First byte $=7 \mathrm{EH}$ ) ..... 354
Table B.3.1t XCHW RWi, ea (First byte $=7 \mathrm{FH}$ ) ..... 355
Appendix C The Flash Memory in the MB90F583 ..... 357
Table C.4a Command Sequence Definitions ..... 361
Table C.5a Hardware sequence flag's bit assignment ..... 362
Table C.5b Hardware Sequence Flag ..... 362
Table C.5.1a Status Change of data polling flag (DQ7) ..... 363
Table C.5.2a Status Change of toggle bit flag (DQ6) ..... 364
Table C.5.3a Status Change of exceeded timing limits flag (DQ5) ..... 365
Table C.5.4a Status Change of sector erase tomer flag (DQ3) ..... 366

## Chapter 1: Overview

The MB90580 series 16-bit microcontrollers are designed for applications that require high-speed real-time processing. These microcontrollers feature functions that are suitable for controlling car audio and electronic appliances.

### 1.1 Features

- Clock

Embedded PLL Clock Multiplication Circuit
Operating clock (PLL clock) can e selected from divided-by-2 of oscillation or one to four times the oscillation (at oscillation of $4 \mathrm{MHz}, 4 \mathrm{MHz}$ to 16 MHz ).
Minimum instruction execution time of 83.3 ns (at oscillation of 4 MHz , three times the PLL clock, operation at Vcc of 5.0 V )

- CPU addressing space of 16 Mbytes

Internal addressing of 24-bit
External accessing can be performed by selecting 8/16-bit bus width (external bus mode)

- Instruction set optimized for controller applications

Rich data types (bit, byte, word, long word)
Rich addressing mode (23 types)
High code efficiency
Enhanced precision calculation realized by the 32-bit accumulatorInstruction set designed for high level language (C) and multi-task operations
Adoption of system stack pointer
Enhanced pointer indirect instructions
Barrel shift instructions

- Enhanced execution speed

4-byte instruction queue

- Enhanced interrupt function

8 levels, 32 factors

- Automatic data transmission function independent of CPU operation

Extended intelligent I/O service function (EI ${ }^{2} \mathrm{OS}$ )

- Low-power consumption (stand-by) mode

Sleep mode (mode in which CPU operating clock is stopped)
Timebase timer mode (mode in which other than oscillation and timebase timer are stopped)
Stop mode (mode in which oscillation is stopped)
CPU intermittent operation mode
Hardware stand-by mode

- I/O port

Maximum of 77 ports

- IE Bus :1 channels
small scale two-line serial bus interface for automotive and general industrial application
Maximium transfer rate is 27 Kbps
- Timers

18-bit Timebase counter/watchdog timer: 1 channel
Watch-dog timer : 1 channel
15-bit Watch timer : 1 channel
$8 / 16$-bit PPG timer: 8 -bit $\times 2$ channels or 16 -bit $\times 1$ channel
16-bit re-load timer: 3 channels
16-bit PWC timer (with noise filter) : 1 channel
16-bit I/O timer (16-bit free-run timer): 1 channel

- Input capture (ICU) : 4 channels

Generates an interrupt request by latching a 16-bit free-run timer counter value upon detection of an edge input to the pin.

- Output compare (OCU) : 2 channels

Generates an interrupt request and reverse the output level upon detection of a match between the 16-bit free-run timer counter value and the compare setting value.

- UART : 5 channels

With full-duplex double buffer (8-bit length)
Clock asynchronized or clock synchronized transmission (with start and stop bits) can be selectively used.
-TP/external interrupt circuit : 8 channels
A module for starting extended intelligent $I / O$ service ( $E I^{2} \mathrm{OS}$ ) and generating an external interrupt triggered by an external input.

- Delayed interrupt generation module

Generates an interrupt request for switching tasks.

- Clock monitor function

Output the clock to I/O port (Dividing the machine clock by 2 to $2^{8}$.

- ROM correction module

Replace the internal ROM code by small external circuit.

- ROM mirroring module

Used to increase the coding efficiency.
-10-bit A/D converter : 8 channels
10-bit resolution can be selectively used.
Starting by an external trigger input.
-8-bit D/A converter : 2 independent channels
8 -bit resolution.
R-2R typet.

- Package

LQFP-100, QFP-100

- Process

CMOS technology

### 1.2 Product Lineup

Internal Configuration
Table 1.2a lists the product lineup of the MB90580 series. All products are functionally identical except for ROM and RAM sizes.

Table 1.2a MB90580 series product lineup

|  | MB90V580 | MB90583 | MB90F583 |
| :---: | :---: | :---: | :---: |
| ROM size | - | Mask ROM <br> 128 Kbytes | Flash ROM <br> 128 Kbytes |
| RAM size | 6kByte | $6 k$ 6yye | $6 k$ Byte |
| Others |  |  |  |

Note: MB90V580 is the evaluation device of MB90580 series, that has no internal ROM incorporated. However it has 6Kbytes of internal RAM and the internal resources. The package of MB90V580 is PGA-256C-A02.

### 1.3 Block Diagram



Figure 1.3a Block Diagram of MB90580 Series

### 1.4 Pin Assignment

### 1.4.1 LQFP-100 Pin Assignment



Figure 1.4a Pin Assignment of MB90580 (LQFP-100)

### 1.4.1 QFP-100 Pin Assignment



Figure 1.4b Pin Assignment of MB90580 (QFP-100)

### 1.5 Pin Functions

Table 1.5 a to Table 1.5 d lists the functions. Table 1.5 e to Table 1.5 g list the $\mathrm{I} / \mathrm{O}$ circuit formats.
Table 1.5a Pin functions (1/4) (STBC: With standby control)

| QFP | LQFP | Pin name | I/O Circuit |  |
| :---: | :---: | :---: | :---: | :--- | :--- |
| 82 | 80 | X0 | A | Oscillator pin |
| 83 | 81 | X1 | A | Oscillator pin |
| 52 | 50 | HSTX | C | Hardware standby input pin |
| 77 | 75 | RSTX | B | Reset input pin |

### 1.5 Pin Functions

Table 1.5b Pin functions (2/4)

| QFP | LQFP | Pin name | I/O Circuit | Function |
| :---: | :---: | :---: | :---: | :---: |
| 19 | 17 | P41 | E <br> (CMOS/H) | General-purpose I/O port <br> SOTO pin when the SOE bit of the UMC register is ' 1 ' <br> Open drain output port when OD41 of the open drain control setting regis- <br> ter (ODR4) is set to '1' (D41=' 0 ': Invalid when set as input) |
|  |  | SOTO |  | UART0 serial data output (SOTO) pin |
| 20 | 18 | P42 | $\begin{gathered} \text { E } \\ \text { (CMOS/H) } \end{gathered}$ | General-purpose I/O port <br> SOTO pin when the SOE bit of the UMC register is ' 1 ' <br> Open drain output port when OD41 of the open drain control setting register (ODR4) is set to ' 1 ' (D41 = 0 ': Invalid when set as input) |
|  |  | SCK0 |  | UART0 serial clock I/O (SCK0) pin |
| 21 | 19 | P43 | $\begin{gathered} \text { E } \\ (\mathrm{CMOS} / \mathrm{H}) \end{gathered}$ | General-purpose I/O port <br> Serial input (SIN1) during extended I/O serial operation <br> Open drain output port when OD43 of the open drain control setting regis- <br> ter (ODR4) is set to '1' (D43=' 0 ': Invalid when set as input) |
|  |  | SIN1 |  | UART1 serial data input (SIN1) pin |
| 22 | 20 | P44 | $\begin{gathered} \text { E } \\ (\text { CMOS/H }) \end{gathered}$ | General-purpose I/O port <br> SOT1 pin when the SOE bit of the UMC register is ' 1 ' <br> Open drain output port when OD44 of the open drain control setting register (ODR4) is set to ' 1 ' (D44=' 0 ': Invalid when set as input) |
|  |  | SOT1 |  | UART1 serial data output (SOT1) pin |
| 24 | 22 | P45 | $\begin{gathered} \text { E } \\ (\mathrm{CMOS} / \mathrm{H}) \end{gathered}$ | General-purpose I/O port <br> Clock input (SCK1) during extended I/O serial operation in external shift clock mode SCK1 pin when the SOE bit of the UMC register is '1' <br> Open drain output port when OD45 of the open drain control setting register (ODR4) is set to '1' (D45=' 0 ': Invalid when set as input) |
|  |  | SCK1 |  | UART1 serial clock I/O (SCK1) pin |
| 25 | 23 | P46 | E <br> (CMOS/H) | General-purpose I/O port <br> Open drain output port when OD46 of the open drain control setting register (ODR4) is set to ' 1 ' (D46=' 0 ': Invalid when set as input) |
|  |  | ADTG |  | A/D converter external trigger input pin |
| 26 | 24 | P47 | $\begin{gathered} \mathrm{E} \\ (\mathrm{CMOS} / \mathrm{H}) \end{gathered}$ | General-purpose I/O port <br> Open drain output port when OD47 of the open drain control setting register (ODR4) is set to '1 ' (D47='0': Invalid when set as input) |
| 38 | 36 | P50 | $\begin{gathered} \mathrm{G} \\ (\mathrm{CMOS} / \mathrm{H}) \end{gathered}$ | General-purpose I/O port |
|  |  | AN0 |  | Analog input pin (ANO) during A/D converter operation |
|  |  | SIN3 |  | UART3 serial data input (SIN3) pin |
| 39 | 37 | P51 | $\begin{gathered} \mathrm{G} \\ (\mathrm{CMOS} / \mathrm{H}) \end{gathered}$ | General-purpose I/O port |
|  |  | AN1 |  | Analog input pin (AN1) during A/D converter operation |
|  |  | SOT3 |  | UART3 serial data output (SOT3) pin |
| 40 | 38 | P52 | G <br> (CMOS/H) | General-purpose I/O port |
|  |  | AN2 |  | Analog input pin (AN2) during A/D converter operation |
|  |  | SCK3 |  | UART3 serial data output (SOT3) pin |
| 41 | 39 | P53 |  | General-purpose I/O port |
|  |  | AN3 | (CMOS/H) | Analog input pins (AN3) during A/D converter operation |
| 43 | 41 | P54 | $\begin{gathered} \mathrm{G} \\ (\mathrm{CMOS} / \mathrm{H}) \end{gathered}$ | General-purpose I/O port |
|  |  | AN4 |  | Analog input pin (AN4) during A/D converter operation |
|  |  | SIN4 |  | UART4 serial data input (SIN4) pin |
| 44 | 42 | P55 | G <br> (CMOS/H) | General-purpose I/O port |
|  |  | AN5 |  | Analog input pin (AN5) during A/D converter operation |
|  |  | SOT4 |  | UART4 serial data output (SOT4) pin |

Table 1.5c Pin functions (3/4)

| QFP | LQFP | Pin name | I/O Circuit | Function |
| :---: | :---: | :---: | :---: | :---: |
| 45 | 43 | P56 | G <br> (CMOS/H) | General-purpose I/O port |
|  |  | AN6 |  | Analog input pin (AN6) during A/D converter operation |
|  |  | SCK4 |  | UART4 serial data output (SOT4) pin |
| 46 | 44 | P57 | G <br> (CMOS/H) | General-purpose I/O port |
|  |  | AN7 |  | Analog input pins (AN7) during A/D converter operation |
| 27 | 25 | C |  | 0.1 uf capacitor connection pin for voltage supply stabilization. |
| 28 | 26 | P71 | (CMÓS/H) | General-purpose I/O port <br> SOT3 pin when the SOE bit of the UMC register is ' 1 ' |
| 29 | 27 | P72 | $(\mathrm{CMOS} / \mathrm{H})$ | General-purpose I/O port <br> Clock input (SCK3) during UART1 operation in external shift clock mode SCK3 pin when the SOE bit of the UMC register is ' 1 ' |
| 32 | 30 | P73 | H <br> (CMOS/H) | General-purpose I/O port <br> D/A output pin when the DAE0 bit of the D/A control register (DACR) is '1' |
|  |  | DAOO |  | D/A output '0' pin during D/A converter operation |
| 33 | 31 | P74 | $(\mathrm{CMOS} / \mathrm{H})$ | General-purpose I/O port <br> D/A output pin when the DAE1 bit of the D/A control register (DACR) is ' 1 ' |
|  |  | DAO1 |  | D/A output '1' pin during D/A converter operation |
| 47 | 45 | P80 | $\stackrel{F}{\text { (CMOS/H) }}$ | General-purpose I/O port |
|  |  | IRQ0 |  | External interrupt request I/O 0 |
| 48 | 46 | P81 | $\stackrel{\text { F }}{(\mathrm{CMOS} / \mathrm{H})}$ | General-purpose I/O port |
|  |  | IRQ1 |  | External interrupt request I/O 1 |
| 53 | 51 | P82 | $\stackrel{\text { F }}{(\mathrm{CMOS} / \mathrm{H})}$ | General-purpose I/O port |
|  |  | IRQ2 |  | External interrupt request I/O 2 |
| 54 | 52 | P83 | $\stackrel{\text { F }}{(\mathrm{CMOS} / \mathrm{H})}$ | General-purpose I/O port |
|  |  | IRQ3 |  | External interrupt request I/O 3 |
| 55 | 53 | P84 | $(\mathrm{CMOS} / \mathrm{H})$ | General-purpose I/O port |
|  |  | IRQ4 |  | External interrupt request I/O 4 |
| 56 | 54 | P85 | $(\mathrm{CMOS} / \mathrm{H})$ | General-purpose I/O port |
|  |  | IRQ5 |  | External interrupt request I/O 5 |
| 57 | 55 | P86 | $(\mathrm{CMOS} / \mathrm{H})$ | General-purpose I/O port Always enabled (STBC) |
|  |  | IRQ6 |  | External interrupt request I/O 6 |
| 58 | 56 | P87 | $(\mathrm{CMOS} / \mathrm{H})$ | General-purpose I/O port Always enabled (STBC) |
|  |  | IRQ7 |  | External interrupt request I/O 7 |
| 59 | 57 | P60 | D <br> (CMOS/H) | General-purpose I/O port <br> A pull-up resistor can be assigned (RD60='1') by using the pull-up resistor setting register (RDR6). (D60='1': Invalid when set as output) |
|  |  | SIN2 |  | UART2 serial data input (SIN2) pin |
| 60 | 58 | P61 | $\begin{gathered} D \\ (\mathrm{CMOS} / \mathrm{H}) \end{gathered}$ | General-purpose I/O port <br> SOT1 pin when the SOE bit of the UMC register is ' 1 ' <br> A pull-up resistor can be assigned (RD61='1') by using the pull-up resistor setting register (RDR6). (D61-'1': Invalid when set as output) |
|  |  | SOT2 |  | UART2 serial data output (SOUT2) pin |
| 61 | 59 | P62 | $\begin{gathered} D \\ (\mathrm{CMOS} / \mathrm{H}) \end{gathered}$ | General-purpose I/O port <br> Clock input (SCK2) during UART1 operation in external shift clock mode SCK1 pin when the SOE bit of the UMC register is ' 1 ' <br> A pull-up resistor can be assigned (RD62=1') by using the pull-up resistor setting register (RDR6). (D62='1': Invalid when set as output) |
|  |  | SCK2 |  | UART2 serial clock I/O (SCK2) pin |

### 1.5 Pin Functions

Table 1.5d Pin functions (4/4)

| QFP | LQFP | Pin name | 1/O Circuit | Function |
| :---: | :---: | :---: | :---: | :---: |
| 62 | 60 | P63 | D <br> (CMOS/H) | General-purpose I/O port <br> A pull-up resistor can be assigned (RD63='1') by using the pull-up resistor setting register (RDR6). (D63='1': Invalid when set as output) |
|  |  | PPG00 |  | PPG00 output when PPG is enabled |
| 63 | 61 | P64 | $\begin{gathered} \text { D } \\ (\text { CMOS/H) } \end{gathered}$ | General-purpose I/O port <br> A pull-up resistor can be assigned (RD64='1') by using the pull-up resistor setting register (RDR6). (D64='1': Invalid when set as output) |
|  |  | PPG01 |  | PPG01 output when PPG is enabled |
| 64 | 62 | P65 | $\begin{gathered} \text { D } \\ \text { (CMOS/H) } \end{gathered}$ | General-purpose I/O port <br> A pull-up resistor can be assigned (RD65='1') by using the pull-up resistor setting register (RDR6). (D65='1': Invalid when set as output) |
|  |  | CKOT |  | CKOT output during CKOT operation |
| 65 | 63 | TX | 1 | IEBus output when IEBus is enabled |
| 66 | 64 | RX | J | IEBus input when IEBus is enabled |
| 67 to 69 | 65 to 67 | P90 to P92 | F <br> (CMOS/H) | General-purpose I/O port |
|  |  | TIN0 to TIN2 |  | Event input pins for reload timers 0,1 and 2 . As these inputs are used continuously during reload timer input operation, outputs to these pins from other functions must be avoided unless performed intentionally. |
|  |  | IN0 to IN2 |  | Input capture channels 0-2 trigger inputs |
| 70 | 68 | P93 | $\begin{gathered} \text { F } \\ (\text { CMOS/H) } \end{gathered}$ | General-purpose I/O port |
|  |  | TOT0 |  | Output pins for reload timer 0 . This function applies when the output for reload timers 0 is enabled. |
|  |  | IN3 |  | Input capture channel 3 trigger input |
| 71 to 72 | 69 to 70 | P94 to P95 | F <br> (CMOS/H) | General-purpose I/O port |
|  |  | TOT1, TOT2 |  | Output pins for reload timers 1 and 2. This function applies when the outputs for reload timers 1 and 2 are enabled. |
|  |  | OUT0, OUT1 |  | Output comparison channels 0-1 event outputs |
| 73 | 71 | P96 | $\begin{gathered} \text { F } \\ (\text { CMOS/H) } \end{gathered}$ | General-purpose I/O port |
|  |  | PWC |  | PWC input |
| 74 | 72 | P97 | (CMOS/H) | General-purpose I/O port |
| 75, 76 | 73, 74 | PA0, PA1 | (CMOS/H) | General-purpose I/O port |
| 78 | 76 | PA2 | (CMOS/H) | General-purpose I/O port |
| 79 | 77 | X1A | A | Oscillator input |
| 80 | 78 | X0A | A | Oscillator input |
| 34 | 32 | $\mathrm{AV}_{\mathrm{CC}}$ | - | A/D converter power supply pin |
| 37 | 35 | $\mathrm{AV}_{\text {SS }}$ | - | A/D converter power supply pin |
| 35 | 33 | AVRH | - | A/D converter external reference power supply pin |
| 36 | 34 | AVRL | - | A/D converter external reference power supply pin |
| 30 | 28 | DVRH | - | D/A converter external reference power supply pin |
| 31 | 29 | DVSS | - | D/A converter power supply pin |
| 49 to 51 | 47 to 49 | MD0 to MD2 | C | Operation mode specification input pin Connect directly to Vcc or Vss. |
| 23, 84 | 21, 82 | $\mathrm{V}_{\mathrm{CC}}$ | - | Power supply ( 5 V ) input pin |
| 11,42, 81 | $9,40,$ | VSS | - | Power supply (0 V) input pin |

Table 1.5e I/O circuit format (1)

| Class | Circuit | Remarks |
| :---: | :---: | :---: |
| A |  | - Oscillation feedback resistor: $1 \mathrm{M} \Omega$ approx. |
| B |  | - Hysteresis input with pull-up Resistor: $50 \mathrm{k} \Omega$ approx. |
| C | HYS | - Hysteresis input port |
| D | Standby control signal | - With input pull-up resistor control <br> - CMOS level output <br> - Hysteresis input with standby control Resistor: $50 \mathrm{k} \Omega$ approx. |

Table 1.5f I/O circuit format (2)

| Class | Circuit | Remarks |
| :---: | :---: | :---: |
| E |  | - CMOS level output <br> - With open drain control <br> - Hysteresis input with standby contro |
| F | Standby control signal | - CMOS level output <br> - Hysteresis input with standby control |
| G | Standby control signal | - CMOS level output <br> - Hysteresis input with standby control <br> - Analog input |

Table 1.5g I/O circuit format (3)

| Class | Circuit | Remarks |
| :---: | :---: | :---: |
| H | Standby control signal | - CMOS level output <br> - Hysteresis input with standby control <br> - Analog output <br> - Shared with DA output |
| I |  | - CMOS level output |
| J |  | - Hysteresis input |

### 1.6 Handling the Device

(1) Preventing latch-up

CMOS IC chips may suffer latch-up under the following conditions:
A voltage higher than Vcc or lower than Vss is applied to an input or output pin.
A voltage higher than the rated voltage is applied between Vcc and Vss.
The AVcc power supply is applied before the Vcc voltage.
Latch-up may increase the power supply current drastically, causing thermal damage to the device.
(2) Handling unused input pins

Do not leave unused input pins open, as doing so may cause misoperation of the device. Use a pull-up or pull-down resistor.
(3) Using external clock

To use external clock, drive the X 0 and X 1 pins in reverse phase.
Figure 1.6a is a diagram of how to use external clock..


Figure 1.6a Using external clock
(4) Power supply pins (Vcc/Vss)

Ensure that all Vcc-level power supply pins are at the same potential. In addition, ensure the same for all Vss-level power supply pins. (See the figure below.) If there are more than one Vcc or Vss system, the device may operate incorrectly even within the guaranteed operating range.


Figure 1.6b Connection of Power pins

## Chapter 2: <br> CPU

### 2.1 CPU

The $\mathrm{F}^{2} \mathrm{MC}$-16LX CPU core is a 16 -bit CPU designed for applications that require high-speed real-time processing, such as home-use or vehicle-mounted electronic appliances. The $\mathrm{F}^{2} \mathrm{MC}-16 \mathrm{LX}$ instruction set is designed for controller applications, and is capable of high-speed, highly efficient control processing.
In addition to 16 -bit data, the $\mathrm{F}^{2} \mathrm{MC}$-16LX CPU core can process 32 -bit data by using an internal 32 -bit accumulator. (32-bit data can be processed with some instructions.) Up to 16 Mbytes of memory space (expandable) can be used, which can be accessed by either the linear pointer or bank method. The instruction system, based on the $\mathrm{F}^{2} \mathrm{MC}-8 \mathrm{~A}-\mathrm{T}$ architecture, has been reinforced by adding instructions compatible with high-level languages, expanding addressing modes, reinforcing multiplication and division instructions, and enhancing bit processing. The features of the $\mathrm{F}^{2} \mathrm{MC}-16 \mathrm{LX}$ CPU are explained below.

- Minimum instruction execution time: 62.5 ns (at $4-\mathrm{MHz}$ oscillation, 4 times multiplication)
- Maximum memory space: 16 Mbytes, accessed in linear or bank mode
- Instruction set optimized for controller applications

Rich data types: Bit, byte, word, long word
Extended addressing modes: 23 types
High-precision operation (32-bit length) based on 32-bit accumulator Signed multiply and division, enhanced RETI instruction

- Powerful interrupt functions Eight priority levels (programmable)
- CPU-independent automatic transfer Up to 16 channels of extended intelligent I/O service
- Instruction set compatible with high-level language (C)/multitasking System stack pointer/instruction set symmetry/barrel-shift instructions
- Improved execution speed: 4-byte queue
2.1 CPU


### 2.1.1 Memory space

- Outline of CPU memory space

An $F^{2}$ MC-16LX CPU has a 16-Mbyte memory space. All data program input and output managed by the $\mathrm{F}^{2} \mathrm{MC}$-16LX CPU are located in this 16-Mbyte memory space. The CPU accesses the resources by indicating their addresses using a 24 -bit address bus. (See Figure 2.1.1a.).


Figure 2.1.1a Sample relationship between $\mathrm{F}^{2} \mathrm{MC}$-16LX system and memory map

Address generation types
The $\mathrm{F}^{2} \mathrm{MC}$-16LX CPU has two address generation methods. One is the linear method in which an entire 24 -bit address is specified by an instruction. The other method is the bank method in which the high-order eight bits of an address is specified by an appropriate bank register while the low-order 16 bits of the same address is specified by an instruction.

There are two types of linear method. One specifies a 24 -bit address directly by using operands. The other method cites the low-order 24 bits of a 32 -bit general-purpose register value as an address. (See Figure 2.1.1b.)


Figure 2.1.1b Sample linear addressing
Bank addressing types
In the bank method, the 16-Mbyte space is divided into 256 64-Kbyte banks. The following five bank registers are used to specify the banks corresponding to each space:

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

The 64-Kbyte bank specified by the PCB is called a program (PC) space. The PC space contains instruction codes, vector tables, and immediate value data, for example.
The 64-Kbyte bank specified by the DTB is called a data (DT) space. The DT space contains readable/ writable data, and control/data registers for internal and external resources.
The 64-Kbyte bank specified by the USP or SSP is called a stack (SP) space. The SP space is accessed when a stack access occurs during a push/pop instruction or interrupt register saving. The S flag in the condition code register determines the stack space to be accessed.
The 64-Kbyte bank specified by the ADB is called an additional (AD) space. The AD space, for example, contains data that cannot fit into the DT space.

Table 2.1.1a lists the default spaces used in each addressing mode, which are pre-determined to improve instruction coding efficiency. To use a non-default space for an addressing mode, specify a prefix code corresponding to a bank before the instruction. This enables access to the bank space corresponding to the specified prefix code.
After reset, the DTB, USB, SSB, and ADB are initialized to 00 H . The PCB is initialized to a value specified by the reset vector. After reset, the DT, SP, and AD spaces are allocated in bank $00 \mathrm{H}(000000 \mathrm{H}$ to 00 FFFFH), and the PC space is allocated in the bank specified by the reset vector.

Table 2.1.1a Default space

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

Figure 2.1.1c is an example of a memory space divided into register banks.


Figure 2.1.1c Physical addresses of each space

Multi-byte data allocation in memory space
Figure 2.1.1d is a diagram of multi-byte data configuration in memory. The low-order eight bits of a data item are stored at address $n$, then address $n+1$, address $n+2$, address $n+3$, etc.


Figure 2.1.1d Sample allocation of multi-byte data in memory
Data is written to memory from the low-order addresses. Therefore, for a 32-bit data item, the low-order 16 bits are transferred before the high-order 16 bits.
If a reset signal is input immediately after the low-order bits are written, the high-order bits might not be written.

Accessing multi-byte data
Fundamentally, accesses are made within a bank. For an instruction accessing a multi-byte data item, address FFFFH is followed by address 0000 H of the same bank. Figure 2.1.1e is an example of an instruction accessing multi-byte data.


Figure 2.1.1e Execution of MOVW A, 080FFFFH

### 2.1.2 Registers

The $\mathrm{F}^{2} \mathrm{MC}$-16LX registers are largely classified into two types: special registers in the CPU and general-purpose registers in memory. The special registers are dedicated internal hardware of the CPU, and their applications are limited by the CPU architecture. The general-purpose registers share the CPU address space with RAM. The general-purpose registers are the same as the special registers in that they can be accessed without using an address. The applications of the general-purpose registers can be specified by the user however, as is ordinary memory space.

- Special registers

The $\mathrm{F}^{2} \mathrm{MC}$-16LX has the following 13 special registers:

- Accumulator (A=AH:AL): Two 16-bit accumulators (Can be used as a single 32-bit accumulator.)
- User stack pointer (USP): 16-bit pointer indicating the user stack area
- System stack pointer (SSP): 16-bit pointer indicating the system stack area
- Processor status (PS): 16-bit register indicating the system status
- Program counter: 16-bit register holding the address of the program
- Program bank register: 8 -bit register indicating the PC space
- Data bank register: 8-bit register indicating the DT space
- User stack bank register (USB): 8-bit register indicating the user stack space
- System stack bank register (SSB): 8-bit register indicating the system stack space
- Additional bank register (ADB): 8-bit register indicating the AD space
- Direct page register (DPR): 8-bit register indicating a direct page


Figure 2.1.2a Special registers

General-purpose registers
The $F^{2}$ MC-16LX general-purpose registers are located from addresses 000180 H to 00037 FH (maximum configuration) of main storage. The register bank pointer (RP) indicates which of the above addresses are currently being used as a register bank. Each bank has the following three types of registers. These registers are mutually dependent as described in Figure 2.1.2b.

- R0 to R7: 8-bit general-purpose register
- RW0 to RW7: 16-bit general-purpose register
- RL0 to RL3: 32-bit general-purpose register


Figure 2.1.2b General-purpose registers

The relationship between the high-order and low-order bytes of a byte or word register is expressed as follows:

$$
\operatorname{RW}_{(\mathrm{i}+4)}=\mathrm{R}_{\left(\mathrm{i}^{*} 2+1\right)^{*} 256+\mathrm{R}_{\left(\mathrm{i}^{*} 2\right)}[\mathrm{i}=0 \text { to } 3]}
$$

The relationship between the high-order and low-order bytes of Rli and RW can be expressed as follows:

$$
\operatorname{RL}_{(\mathrm{i})}=\mathrm{RW}_{\left(\mathrm{i}^{*} 2+1\right)^{*} 65536+\mathrm{RW}}^{\left(\mathrm{i}^{*} 2\right)}[\mathrm{i}=0 \text { to } 3]
$$

Program counter (PC)
The PC register is a 16 -bit counter that indicates the low-order 16 bits of the memory address of an instruction code to be executed by the CPU. The high-order eight bits of the address are indicated by the PCB. The PC register is updated by a conditional branch instruction, subroutine call instruction, interrupt, or reset.
The PC register can also be used as a base pointer for operand access.


Figure 2.1.2c Program counter

Accumulator (A)
The A register consists of two 16-bit arithmetic operation registers (AH and AL). The A register is used as a temporary storage for operation results and transfer data. During 32-bit data processing, AH and AL are used together. Only AL is used for word processing in 16-bit data processing mode or for byte processing in 8 -bit data processing mode (see Figures 2.1.9 and 2.1.10). The data stored in the A register can be operated upon with the data in memory or registers (Ri, Rwi, or Rli). In the same manner as with the $\mathrm{F}^{2} \mathrm{MC}-8 \mathrm{~L}$, when a word or shorter data item is transferred to $A L$, the previous data item in AL is automatically sent to AH (data preservation function). The data preservation function and operation between AL and AH help improve processing efficiency.

When a byte or shorter data item is transferred to AL, the data is sign-extended or zero-extended and stored as a 16-bit data item in AL. The data in AL can be handled either as word or byte long.
When a byte-processing arithmetic operation instruction is executed on AL, the high-order eight bits of AL before operation are ignored. The high-order eight bits of the operation result all become zeroes.
The A register is not initialized by a reset. The A register holds an undefined value immediately after a reset.


Figure 2.1.2d 32-bit data transfer


Figure 2.1.2e AL-AH transfer

User stack pointer (USP) and system stack pointer (SSP)
USP and SSP are 16-bit registers that indicate the memory addresses for saving and restoring data in the event of a push/pop instruction or subroutine execution. The USP and SSP registers are used by stack instructions. The USP register is enabled when the $S$ flag in the processor status register is '0,' and the SSP register is enabled when the S flag is '1' (see Figure 2.1.2f). Since the S flag is set when an interrupt is accepted, register values are always saved in the memory area indicated by SSP during interrupt processing. SSP is used for stack processing in an interrupt routine, while USP is used for stack processing outside an interrupt routine. If the stack space is not divided, use only the SSP.

During stack processing, the high-order eight bits of an address are indicated by SSB (for SSP) or USB (for USP). USP and SSP are not initialized by a reset. Instead, they hold undefined values.


Figure 2.1.2f Stack manipulation instruction and stack pointer

Note: Specify an even-numbered address in the stack pointer whenever possible.
2.1 CPU

Processor status (PS)
The PS register consists of the bits controlling the CPU Operation and the bits indicating the CPU status.
As shown in Figure 2.1.2g, the high-order byte of the PS register consists of a register bank pointer (RP) and an interrupt level mask register (ILM). The RP indicates the start address of a register bank. The low-order byte of the PS register is a condition code register (CCR), containing the flags to be set or reset depending on the results of instruction execution or interruptoccurrences.


Figure 2.1.2g PS structure
(1)Condition code register (CCR)


Figure 2.1.2h Condition code register configuration

| I:Interrupt enable flag: | Interrupts other than software interrupts are enabled when the I flag is 1 and are masked when the Iflag is 0 . The I flag is cleared by a reset. |
| :---: | :---: |
| S :Stack flag: | When the $S$ flag is 0, USP is enabled as the stack manipulation pointer. When the $S$ flag is 1, SSP is enabled as the stack manipulation pointer. The $S$ flag is set by an interrupt reception or a reset. |
| T:Sticky bit flag: | 1 is set in the $T$ flag when there is at least one ' 1 ' in the data shifted out from the carry after execution of a logical right/arithmetic right shift instruction. Otherwise, 0 is set in the T flag. In addition, '0' is set in the T flag when the shift amount is zero. |
| $N$ :Negative flag: | The N flag is set when the MSB of the operation result is ' 1 ,' and is otherwise cleared. |
| Z:Zero flag: | The Z flag is set when the operation result is all zeroes, and is otherwise cleared. |
| V :Overflow flag: | The V flag is set when an overflow of a signed value occurs as a result of operation execution and is otherwise cleared. |
| C:Carry flag: | The C flag is set when a carry-up or carry-down from the MSB occurs as a result of operation execution and is otherwise cleared. |

## (2) Register bank pointer (RP)

The RP register indicates the relationship between the general-purpose registers of the F2MC-16LX and the internal RAM addresses. Specifically, the RP register indicates the first memory address of the currently used register bank in the following conversion expression: [00180H + (RP)*10H] (see Figure 2.1.2i). The RP register consists of five bits, and can take a value between 00 H and 1 FH . Register banks can be allocated at addresses from 000180H to 000370H in memory.
Even within that range, however, the register banks cannot be used as general-purpose registers if the banks are not in internal RAM. The RP register is initialized to all zeroes by a reset. An instruction may transfer an eight-bit immediate value to the RP register; however, only the low-order five bits of that data are used.

| Initial valueB4 B3 B2 B1 B0 <br> 0 0 0 0 0 |
| :---: | :---: | :---: | :---: | :---: | :---: |

Figure 2.1.2i Register bank pointer
(3) Interrupt level mask register (ILM)

The ILM register consists of three bits, indicating the CPU interrupt masking level. An interrupt request is accepted only when the level of the interrupt is higher than that indicated by these three bits. Level 0 is the highest priority interrupt, and level 7 is the lowest priority interrupt (see Table 2.1.2a). Therefore, for an interrupt to be accepted, its level value must be smaller than the current ILM value. When an interrupt is accepted, the level value of that interrupt is set in ILM. Thus, an interrupt of the same or lower level cannot be accepted subsequently. ILM is initialized to all zeroes by a reset. An instruction may transfer an eight-bit immediate value to the ILM register, but only the low-order three bits of that data are used.
Initial value

| ILM2 | ILM1 | ILM0 |
| :---: | :---: | :---: |
| 0 | 0 | 0 |
| $0 y y y y$ |  |  |

Figure 2.1.2j Interrupt level register
Table 2.1.2a Levels indicated by the interrupt level mask (ILM) register

| ILM2 | ILM1 | ILM0 | Level <br> value | Acceptable interrupt level |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | Interrupt disabled |
| 0 | 0 | 1 | 1 | 0 only |
| 0 | 1 | 0 | 2 | Level value smaller than 1 |
| 0 | 1 | 1 | 3 | Level value smaller than 2 |
| 1 | 0 | 0 | 4 | Level value smaller than 3 |
| 1 | 0 | 1 | 5 | Level value smaller than 4 |
| 1 | 1 | 0 | 6 | Level value smaller than 5 |
| 1 | 1 | 1 | 7 | Level value smaller than 6 |

A register bank consists of eight words. The register bank can be used as the following general-purpose registers for arithmetic operations: byte registers R0 to R7, word registers RW0 to RW7, and long word registers RL0 to RL3. In addition, the register bank can be used as instruction pointers.
Table 2.1.2b lists the functions of the registers. Table 2.1.2c indicates the relationship between the registers.
In the same manner as for an ordinary RAM area, the register bank values are not initialized by a reset. The status before a reset is maintained. When the power is turned on, however, the register bank will have an undefined value.

Table 2.1.2b Register functions

| R0 to R7 | Used as operands of instructions. <br> Note: R0 is also used as a counter for barrel shift or normalization instructions. |
| :---: | :--- |
| RW0 to RW7 | Used as pointers. <br> Used as operands of instructions. <br> Note: RW0 is used as a counter for string instructions. |
| RL0 to RL3 | Used as long pointers. <br> Used as operands of instructions. |

Table 2.1.2c Relationship between registers

|  | RW0 | RL0 |
| :--- | :--- | :--- |
|  | RW1 |  |
|  | RW2 | RL1 |
| R0 | RW3 |  |
| R1 | RW4 | RL2 |
| R2 | RW5 |  |
| R3 |  |  |
| R4 | RL3 |  |
| R5 |  |  |
| R6 |  |  |
| R7 |  |  |

Program counter bank register $(\mathrm{PCB})$ <Initial value: Value in reset vector>
Data bank register(DTB) <Initial value: $00 \mathrm{H}>$
User stack bank register(USB) <Initial value: 00H>
System stack bank register(SSB) <Initial value: $00 \mathrm{H}>$
Additional data bank register(ADB) <Initial value: $00 \mathrm{H}>$
Each bank register indicates the memory bank where the PC, DT, SP (user), SP (system), or AD space is allocated. All bank registers are one byte long. PCB is initialized to 00 H by a reset. Bank registers other than PCB can be read or written to. PCB can be read but cannot be written to.

PCB is updated when the JMPP, CALLP, RETP, RETI, or RETF instruction branching to the entire $16-\mathrm{Mbyte}$ space is executed or when an interrupt occurs. For operation of each register, see Chapter 2, Section 2.1.1, "Memory space."

Direct page register (DPR) <Initial value: $01 \mathrm{H}>$
DPR specifies addr8 to addr15 of the instruction operands in direct addressing mode as shown in Figure 2.1.2k. DPR is eight bits long, and is initialized to 01 H by a reset. DPR can be read or written to by an instruction.


Figure 2.1.2k Generating a physical address in direct addressing mode

### 2.1.3 Prefix codes

Placing a prefix code before an instruction partially changes the operation of the instruction. Three types of prefix codes can be used: bank select prefix, common register bank prefix, and flag change disable prefix.

- Bank select prefix

The memory space used for accessing data is determined for each addressing mode.
When a bank select prefix is placed before an instruction, the memory space used for accessing data by that instruction can be selected regardless of the addressing mode.

Table 2.1.3a Bank select prefix

| Bank select prefix | Space selected |
| :---: | :---: |
| PCB | PC space |
| DTB | Data space |
| ADB | AD space |
| SPB | Either the SSP or USP space is used according to <br> the stack flag value. |

Use the following instructions with care:
(1) String instructions (MOVS, MOVSW, SCEQ, SCWEQ, FILS, FILSW)

The bank register specified by an operand is used regardless of the prefix.
(2)Stack manipulation instructions (PUSHW, POPW)

SSB or USB is used according to the $S$ flag regardless of the prefix.
(3)//O access instructions

MOV A, io / MOV io, A /MOVX A, io / MOVW A, io /MOVW io, A / MOV io, \#imm8 MOVW io, \#imm16 / MOVB A, io:bp / MOVB io:bp, A /SETB io:bp / CLRB io:bp BBC io:bp, rel / BBS io:bp, rel WBTC, WBTS

The IO space of the bank is used regardless of the prefix.
(4)Flag change instructions (AND CCR,\#imm8, OR CCR,\#imm8)

The instruction is executed normally, but the prefix affects the next instruction.
(5)POPW PS

SSB or USB is used according to the $S$ flag regardless of the prefix. The prefix affects the next instruction.
(6)MOV ILM,\#imm8

The instruction is executed normally, but the prefix affects the next instruction.
(7)RETI

SSB is used regardless of the prefix.

Common register bank prefix (CMR)
To simplify data exchange between multiple tasks, the same register bank must be accessed relatively easily regardless of the RP value. When CMR is placed before an instruction that accesses a register bank, that instruction accesses the common bank (the register bank selected when $\mathrm{RP}=0$ ) at addresses from 000180 H to 00018 FH regardless of the current RP value. Use the following instructions with care:
(1)String instructions (MOVS, MOVSW, SCEQ, SCWEQ, FILS, FILSW)

If an interrupt request occurs during execution of a string instruction with a prefix code, the prefix code becomes invalid when the string instruction is resumed after the interrupt is processed. Thus, the string instruction is executed falsely after the interrupt is processed. Do not prefix any of the above string instructions with CMR.
(2)Flag change instructions (AND CCR,\#imm8, OR CCR,\#imm8, POPW PS)

The instruction is executed normally, but the prefix affects the next instruction.
(3)MOV ILM, \#imm8

The instruction is executed normally, but the prefix affects the next instruction.

- Flag change disable prefix

To disable flag changes, use the flag change disable prefix code (NCC). Placing NCC before an instruction disables flag changes associated with that instruction. Use the following instructions with care:
(1) String instructions (MOVS, MOVSW, SCEQ, SCWEQ, FILS, FILSW)

If an interrupt request occurs during execution of a string instruction with a prefix code, the prefix code becomes invalid when the string instruction is resumed after the interrupt is processed. Thus, the string instruction is executed incorrectly after the interrupt is processed. Do not prefix any of the above string instructions with NCC.
(2) Flag change instructions (AND CCR,\#imm8, OR CCR,\#imm8, POPW PS)

The instruction is executed normally, but the prefix affects the next instruction.
(3)Interrupt instructions (INT \#vct8, INT9, INT addr16, INTP addr24, RETI)

CCR changes according to the instruction specifications regardless of the prefix.
(4)JCTX @A

CCR changes according to the instruction specifications regardless of the prefix.
(5)MOV ILM,\#imm8

The instruction is executed normally, but the prefix affects the next instruction.

- Interrupt disable instructions

Interrupt requests are not sampled for the following ten instructions:
$\left.\begin{array}{lllll}\bullet \text { MOV ILM,\#imm8 } & \bullet \text { PCB } & \bullet \text { SPB } & \bullet \text { OR CCR,\#imm8 } & \bullet \text { NCC } \\ \bullet \text { AND CCR,\#imm8 } & \bullet \text { ADB } & \bullet \text { CMR } & \bullet P O P W ~ P S ~ & \bullet \text { DTB }\end{array}\right)$

If a valid interrupt request occurs during execution of any of the above instructions, the interrupt can be processed only when an instruction other than the above is executed. For details, see Figure 2.1.3a.


Figure 2.1.3a Interrupt disable instruction

- Restrictions on interrupt disable instructions and prefix instructions

When a prefix code is placed before an interrupt disable instruction, the prefix code affects the first instruction after the code other than the interrupt disable instruction.


Figure 2.1.3b Interrupt disable instructions and prefix codes
Consecutive prefix codes
When competitive prefix codes are placed consecutively, the latter becomes valid.


Figure 2.1.3c Consecutive prefix codes

In the figure above, competitive prefix codes are PCB, ADB, DTB, and SPB.

## Chapter 3: <br> Memory

### 3.1 Memory Access Modes

In the $F^{2} M C-16 L X$, there are several modes for access methods, access areas, and test methods. In this module, the following classifications apply:

Table 3.1a Memory Access Mode

| Operation Mode | Bus Mode | Access Mode <br> (External data bus width) |
| :---: | :---: | :---: |
| RUN | Single Chip | - |
|  | Internal ROM, external bus | 8 bit |
|  |  | 16 bit |
|  | External ROM, external bus | 8 bit |
|  |  | 16 bit |
| EPROM Write | - | - |
| Test Functions | - | - |

Operation mode
Operation mode means the mode for controlling the device operation status. The operation mode is specified by the MDx mode setting pin and the Ex bit in mode data. By selecting an operation mode, normal operation, internal test program activation, or special test function activation can be performed.
■ Bus mode
Bus mode means the mode for controlling the internal ROM operation and external access function. The bus mode is specified by the MDx mode setting pin and the Mx bit in mode data. The MDx mode setting pin specifies the bus mode for reading the reset vector and mode data, and the Mx bit in mode data specifies the bus mode for normal operation.

## Access mode

Access mode means the mode for controlling the external data bus width. The access mode is specified by the MDx mode setting pin and the Sx bit in mode data. By selecting an access mode, an 8 - or 16 -bit external data bus is specified.

### 3.1.1 Mode pins

Table 3.1.1a describes the operations specified by combinations of the MD2 to MD0 external pins.
Table 3.1.1a Mode pins and modes

| Mode pin setting <br> MD2 MD1 MD0 | Mode name | Reset vector <br> access area | External <br> data bus <br> width | Remarks |
| :---: | :--- | :---: | :---: | :---: |
| $\mathbf{0 0 0}$ | External vector mode 0 | External | 8 bits |  |
| $\mathbf{0 0 1}$ | External vector mode 1 | External | 16 bits | Reset vector, 16-bit bus width <br> access |
| $\mathbf{0 1 0}$ | (Specification inhibited) |  |  |  |
| $\mathbf{0 1 1}$ | Internal vector mode | Internal | (Mode data) | Reset sequence are based on <br> mode data. |
| $\mathbf{1 0 0}$ |  |  |  |  |
| $\mathbf{1 0 1}$ | (Specification inhibited) |  |  |  |
| $\mathbf{1 1 0}$ |  |  |  |  |

Note: When using internal vector mode 0 , the initial value of IOBS and LMBS are ' 0 '. If IOBS and LMBS are set afterwards, the address range $0000 \mathrm{C} 0 \mathrm{H} . .0000 \mathrm{FFH}$ and 002000H..7FFFFFH will use 16-bit data bus.

### 3.1.2 Mode data

Mode data is stored at FFFFDF $_{H}$ of main memory and used for controlling the CPU operation. This data is fetched during a reset sequence and stored in the mode register inside the device. The mode register value can be changed only by a reset sequence.

The setting of this register is valid after the reset sequence.
Always set the reserved bits to ' 0 .'
Here is a diagram of the setting of the bits.

| Mode data | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\leadsto$ Bit No. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $\mathrm{FFFFDF}_{\mathrm{H}}$ | M1 | M0 | - | - | S0 | - | - | - |  |

[bit 7, 6] : Bus mode setting bits
These bits are used to specify the operation mode after the reset sequence is completed. Here shows the relationship between the bits and the functions.

| M1 | M0 | Function | Remarks |
| :---: | :---: | :--- | :---: |
| 0 | 0 | Single chip mode |  |
| 0 | 1 | Internal ROM and external bus mode |  |
| 1 | 0 | External ROM and external bus mode |  |
| 1 | 1 | (Inhibited) |  |

[bit 3] : Mode setting bits
These bits are used to specify the bus mode or access mode after the reset sequence is completed. The following table shows the relationship between the bits and the functions.

| S0 | Function | Remarks |
| :---: | :--- | :---: |
| 0 | External data bus, 8-bit mode |  |
| 1 | External data bus, 16-bit mode |  |

### 3.1.3 Bus Mode

Figure 3.1.3a shows correspondence between the access areas and physical addresses for each bus mode.


Note: If ROM mirroring function is not wanted, please refer to Chapter 22, ROM Mirroring Module.
Note: The high-order portion of bank 00 gives the image of the FF bank ROM to make the small model of the C compiler effective. Since the low-order 16 bits are the same, the table in ROM can be referenced without using the far specification in the pointer declaration.For example, an attempt to access $00 \mathrm{C} 000_{\mathrm{H}}$ accesses the value at $\mathrm{FFCOOO}_{\mathrm{H}}$ in ROM.
Note: The ROM area in bank FF exceeds 48 Kbytes, and its entire image cannot be shown in bank 00.
Note: With the MB90F583 and MB90583, the image between FF4000H and FFFFFFF ${ }_{H}$ is visible in bank 00, while the image between $\mathrm{FE}_{\mathrm{F}} 0000_{\mathrm{H}}$ and $\mathrm{FF}_{\mathrm{F}} \mathrm{FFF}_{\mathrm{H}}$ is visible only in bank FE or FF

Figure 3.1.3a Access areas and physical addresses in each bus mode

Recommended setting
Table 3.1.3a lists a sample recommended setting of mode pins and mode data.
Table 3.1.3a Sample recommended setting of mode pins and mode data

| Sample setting | MD2 | MD1 | MD0 | M1 | M0 | S0 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Single chip | 0 | 1 | 1 | 0 | 0 | $\times$ |
| Internal ROM and external bus mode, 16-bit bus | 0 | 1 | 1 | 0 | 1 | 1 |
| Internal ROM and external bus mode, 8-bit bus | 0 | 1 | 1 | 0 | 1 | 0 |
| External ROM and external bus mode, 16-bit bus, vector 16 bus width | 0 | 0 | 1 | 1 | 0 | 1 |
| External ROM and external bus mode, 8-bit bus | 0 | 0 | 0 | 1 | 0 | 0 |

Note: I/O signals appearing on an external pin connected to this module vary with the mode.
Table 3.1.3b lists the external pin function in each modes

Table 3.1.3b Modes and related external pin operations

| Pin name | Function |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | Single chip | External bus extension |  | EPROMwrite |
|  |  | 8 bits | 16 bits |  |
| P07 to P00 | Port | AD07 to 00 |  | D07 to 00 |
| P17 to P10 |  | A15 to 08 | AD15 to 08 | A15 to 08 |
| P27 to P20 |  | A23 to 16 |  | A07 to 00 |
| P30 |  | ALE |  | A16 |
| P31 |  | RDX |  | CEX |
| P32 |  | WRX | WRLX | OEX |
| P33 |  | Port | WRHX | PGMX |
| P34 |  | HRQ |  |  |
| P35 |  | HAKX |  |  |
| P36 |  | RDY |  | Unused |
| P37 |  | CLK |  |  |

Note: The high-order bits of an address and WRX, WRLX, WRHX, HAKX, HRQ, RDY, and CLK can be used as ports depending on function selection.

### 3.2 External Memory Access

To access external memory and peripherals, the $\mathrm{F}^{2} \mathrm{MC}-16 \mathrm{LX}$ supplies the following address, data, and control signals:

| $\triangle$ CLK | (P37) | Machine cycle clock (KBP) |
| :---: | :---: | :---: |
| $\triangle$ RDY | (P36) | External ready input pin |
| $\triangle$ WRHX | (P33) | Write signal for high-order 8 bits of data bus |
| $\triangle$ WRLX | (P32) | Write signal for low-order 8 bits of data bus |
| $\triangle$ RDX | (P31) | Read signal |
| $\triangle$ ALE | (P30) | Address latch enable signal |

The external bus pin control circuit controls the external bus pins for externally extending the CPU address/data bus.

### 3.2.1 Block diagram



Figure 3.2.1a External bus pin control circuit

### 3.2.2 Registers and Register details

Automatic ready function selection register

| Address: $0000 \mathrm{~A}_{\mathrm{H}}$ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $\leadsto$ Bit No. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | IOR1 | IOR0 | HMR1 | HMR0 | - | - | LMR1 | LMR0 | ARSR |
| Read/write $\quad \Rightarrow$ |  | (W) | (W) | (W) | (-) | (-) | (W) | (W) |  |
| Initial value $\Rightarrow$ | (0) | (0) | (1) | (1) | (-) | (-) | (0) | (0) |  |

External address output control register

| Address: $0000 \mathrm{~A} 6_{\mathrm{H}}$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $<$ Bit No. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | E23 | E22 | E21 | E20 | E19 | E18 | E17 | E16 | HACR |
| Read/write $\Rightarrow$ | (W) | (W) | (W) | (W) | (W) | (W) | (W) | (W) |  |
| Initial value $\Rightarrow$ | (0) | (0) | (0) | (0) | (0) | (0) | (0) | (0) |  |

Bus control signal selection register

| Address: $0000 \mathrm{~A} 7_{\mathrm{H}}$ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $<$ Bit No. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | CKE | RYE | HDE | IOBS | HMBS | WRE | LMBS | - | ECSR |
| Read/write $\Rightarrow$ |  | (W) | (W) | (W) | (W) | (W) | (W) | (-) |  |
| Initial value $\Rightarrow$ | (0) | (0) | (0) | (0) | (1/0) | (0) | (0) | $(-)$ |  |

### 3.2.2.1 Automatic ready function selection register

| Address: $0000 \mathrm{~A}^{\mathrm{H}}$ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $<$ Bit No. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | IOR1 | IOR0 | HMR1 | HMRO | - | - | LMR1 | LMR0 | ARSR |
| Read/write $\Rightarrow$ |  | (W) | (W) | (W) | (-) | (-) | (W) | (W) |  |
| Initial value $\Rightarrow$ |  | (0) | (1) | (1) | (-) | (-) | (0) | (0) |  |

[bits 15 and 14]: IOR1 and IOR0
These bits specify the automatic wait function for external access to the area between $000000_{\mathrm{H}}$ and $0000 \mathrm{FF}_{\mathrm{H}}$.

| IOR1 | IOR0 |  |
| :---: | :---: | :--- |
| 0 | 0 | Automatic wait disabled |
| 0 | 1 | One machine cycle of automatic wait for external access |
| 1 | 0 | Two machine cycles of automatic wait for external access |
| 1 | 1 | Three machine cycles of automatic wait for external access |

The initial value is '00B.'
[bits 13 and 12]: HMR1 and HMR0
These bits specify the automatic wait function for external access to the area between $800000_{\mathrm{H}}$ and FFFFFF $_{\mathrm{H}}$.

| HMR1 | HMR0 | Setting |
| :---: | :---: | :--- |
| 0 | 0 | Automatic wait disabled |
| 0 | 1 | One machine cycle of automatic wait for external access |
| 1 | 0 | Two machine cycles of automatic wait for external access |
| 1 | 1 | Three machine cycles of automatic wait for external access |

The initial value is '11B.'
[bits 9 and 8]: LMR1 and LMR0
These bits specify the automatic wait function for external access to the area between $002000_{\mathrm{H}}$ and $7 \mathrm{FFFFF}_{\mathrm{H}}$.

| LMR1 | LMR0 | Setting |
| :---: | :---: | :--- |
| 0 | 0 | Automatic wait disabled |
| 0 | 1 | One machine cycle of automatic wait for external access |
| 1 | 0 | Two machine cycles of automatic wait for external access |
| 1 | 1 | Three machine cycles of automatic wait for external access |

The initial value is '00B.'

### 3.2.2.2 External address output control register

| Address: 0000A6H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\begin{array}{r} <\text { Bit No. } \\ \quad \text { HACR } \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | E23 | E22 | E21 | E20 | E19 | E18 | E17 | E16 |  |
| Read/write $\Rightarrow$ | (W) | (W) | (W) | (W) | (W) | (W) | (W) | (W) |  |
| Initial value $\Rightarrow$ | (0) | (0) | (0) | (0) | (0) | (0) | (0) | (0) |  |

This register controls the external output of addresses (A19 to A16). The bits corresponds to addresses A19 to A16, controlling the address output pins as described below.

Table 3.2.0a Selecting the high-order address bit output control

| 0 | The corresponding pin is used as an address output (Axx). |
| :--- | :--- |
| 1 | The corresponding pin is used as an I/O port (Pxx). |

This register cannot be accessed when the device is in single chip mode. In that case, all pins are used as I/O ports regardless of the value of this register.

All bits of this register are write-only bits. ' 1 ' is always read from these bits.
These bits are initialized to ' 0 ' upon a reset.

### 3.2.2.3 Bus control signal selection register

| Bus control signal selection register |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $<$ Bit No. |
| Address: $0000 \mathrm{~A} 7_{\mathrm{H}}$ | CKE | RYE | HDE | IOBS | HMBS | WRE | LMBS | - | ECSR |
| Read/write $\Rightarrow$ |  | (W) | (W) | (W) | (W) | (W) | (W) | (-) |  |
| Initial value $\Rightarrow$ | (0) | (0) | (0) | (0) | (0) | (0) | (0) | (-) |  |

This register is used to set the bus control function in external bus mode.
This register cannot be accessed when the device is in single chip mode. In that case, all pins are used as I/O ports regardless of the value of this register.
All bits of this register are write-only bits. ' 1 ' is always read from these bits.
[bit 15]: CKE
This bit controls the external clock (CLK) output as described below.

| 0 | I/O port (P37) operation (clock output disabled) |
| :--- | :--- |
| 1 | Clock signal (CLK) output enabled |

This bit is initialized to ' 0 ' upon a reset.
[bit 14]: RYE
This bit controls the external ready (RDY) input as described below.

| 0 | I/O port (P36) operation (external RDY input disabled) [default] |
| :---: | :--- |
| 1 | External ready (RDY) input enabled |

This bit is initialized to ' 0 ' upon a reset.
[bit 13]: HDE
This bit specifies whether to enable I/O of hold-related pins. This bit controls the hold request input (HRQ) and hold acknowledge output (HAKX) pins as described below.

| 0 | I/O port (P35 and P34) operation (Hold function I/O disabled) [default] |
| :---: | :---: |
| 1 | Hold request (HRQ) input/hold acknowledge (HAKX) output enabled |

This bit is initialized to ' 0 ' upon a reset.
[bit 12]: IOBS
This bit specifies the bus size when an area between 0000 COH and 0000 FFH is externally accessed in 16 -bit external data bus mode. The size is controlled as described below.

| 0 | 16 -bit bus size access [default] |
| :--- | :--- |
| 1 | 8 -bit bus size access |

This bit is initialized to ' 0 ' upon a reset.
[bit 11]: HMBS
This bit specifies the bus size when an area between $800000_{H}$ and FFFFFF ${ }_{H}$ is externally accessed in 16 -bit external data bus mode. The size is controlled as described below.

| 0 | 16 -bit bus size access [default in mode other than external vector mode 2] |
| :---: | :--- |
| 1 | 8 -bit bus size access [default in external vector mode 2] |

This bit is initialized to ' 1 ' upon a reset in external vector mode 2. In any other mode, this bit is initialized to '0' upon a reset.
[bit 10]: WRE
This bit controls the output of the external write signal pin (WRHX and WRLX pins in 16-bit bus mode and WRX pin in 8 -bit bus mode) as described below.

| 0 | I/O port (P33 and P32) operation (write signal output disabled) [default] |
| :---: | :--- |
| 1 | Write strobe signal (WRHX/WRLX or WRX) output enabled |

In 8-bit external data bus mode, P33 is used as an I/O port regardless of the value of this register.
This bit is initialized to ' 0 ' upon a reset.
[bit 9]: LMBS
This bit specifies the bus size when an area between $002000_{H}$ and $7 F F F F F_{H}$ is externally accessed in 16 -bit external data bus mode. The size is controlled as described below.

| 0 | 16 -bit bus size access [default] |
| :--- | :--- |
| 1 | 8 -bit bus size access |

This bit is initialized to ' 1 ' upon a reset.
Note: In 16-bit bus mode, set P33 and P32 in input mode (set '0' in bits 3 and 2 of DDR3) when enabling the WRHX and WRLX functions by the WRE bit. In 8 -bit bus mode, set P32 in input mode (set ' 0 ' in bit 2 of DDR3) when enabling the WRX function by the WRE bit. Even if RDY or HRQ input is enabled by the RYE or HDE bit, the I/O port function of the port is valid. Therefore, ensure that ' 0 ' (input mode) is written to the DDR3 bit corresponding to the port.

### 3.2.1 Operations

MB90580 has a variety of access method and access area modes. See Section 3.1 ,"Memory Access Modes"
(1) External memory access control signals

External memory is accessed in three cycles while the ready function is not used. Figure 3.2.4 shows the concept of external access timing.
The 8 -bit bus width access in external 16 -bit bus mode is used to read or write to an 8 -bit peripheral chip when both 8 - and 16 -bit peripheral chips are connected to the external bus. Sine the 8 -bit bus width access is executed using the low-order 8 bits of the data bus, ensure that the 8 -bit peripheral chips are connected to the low-order 8 bits of the data bus.

Use the HMBS, LMBS, and IOBS bits of EPCR to specify whether to perform 16- or 8-bit bus width access in external 16 -bit bus mode.
If only an address and ALE assert signal are output and RDX, WRX, WRLX, and WRHX are not asserted, the bus operation may not be actually performed. Ensure that a peripheral chip is not accessed by only an ALE signal.
■ External 8-bit bus mode


Figure 3.2.1a External memory access timing chart

External 16-bit bus mode


Figure 3.2.1b External memory access timing chart
(2) Ready function

When the RYE bit of the bus control signal selection register (EPCR) is set to '1,' a wait cycle is inserted while an L level signal appears at the R36/RDY pin in the event of an access to an external area. Thus, the access cycle can be extended.


Figure 3.2.1c Ready timing chart
The $\mathrm{F}^{2} \mathrm{MC}$-16LX has two types of automatic ready functions for external memory. The automatic ready function automatically inserts one to three wait cycles without an external circuit under the following conditions. The function inserts the wait cycles when an access is made to a low-order address external area located between addresses $002000_{\mathrm{H}}$ and $7 \mathrm{FFFFF}_{\mathrm{H}}$ or to a high-order address external area located between addresses $800000_{H}$ and FFFFFFF $_{H}$. This function extends the access cycle. The automatic ready function is activated by setting the LMR1/LMR0 bits (low-order address external area) or the HMR1/HMR0 bits (high-order address external area) of ARSR. In addition, the $\mathrm{F}^{2} \mathrm{MC}$-16LX has another built-in automatic ready function for external I/O. This automatic ready function automatically inserts one to three wait cycles without an external circuit when an access is made to an external area located between addresses $0000 \mathrm{CO}_{\mathrm{H}}$ and $0000 \mathrm{FF} \mathrm{F}_{\mathrm{H}}$. This function extends the access cycle. This automatic ready function is activated by setting the IOR1/IORO bits of ARSR.

When the RYE bit of EPCR is set to '1,' the wait cycle continues if an L level signal appears at the R36/RDY pin at the end of either automatic ready cycle.
(3) Hold function

When the HDE bit of EPCR is set to ' 1 ,' the external bus hold function by the P34/HRQ and P35/HAKX pins is enabled. When an H level signal is input to the P34/HRQ pin, the hold state starts at the end of the CPU instruction (at the end of processing for one element data item in the case of a string instruction), an L level signal is output from the P35/HAKX pin, and the following pins are set to high impedance:

- Address output P27/A23 to P20/A16
- Address/data I/O P17/D15 to P00/D00
- Bus control signal P30/ALE, P31/RDX, P32/WRLX, P33/WRHX

The above function enables the use of an external bus by a device external circuit.
When an L level signal is input to the $\mathrm{P} 34 / \mathrm{HRQ}$ pin, an H level signal is output from the $\mathrm{P} 35 / \mathrm{HAKX}$ pin, the external pin status is restored, and the CPU resumes operation.
In the STOP state, no hold request input is accepted.

- Hold timing (in external bus 16-bit mode)


Figure 3.2.1d Hold timing

## Chapter 4: <br> Clock and Reset

### 4.1 Clock Generator

The clock generator controls internal clock operation, including such functions as sleep, timer, stop, and PLL multiplication. This internal clock is called the machine clock, and one cycle of the machine clock is called a machine cycle. A clock based on the source oscillation is called the main clock, and a clock based on the internal VCO oscillation is called the PLL clock.
Note: When the operating voltage is 5 V , the OSC source oscillation can be between 3 MHz and 16 MHz . The highest operating frequency for the CPU and peripheral resource circuits is 16 MHz , however. Normal operation is not guaranteed if a multiplication factor resulting in a higher frequency than 16 MHz is specified. For example, if the source oscillation is 16 MHz , only 1 can be specified as the multiplication factor.

The lowest operating frequency of the VCO oscillation is 4 MHz , and an oscillation below 4 MHz must not be specified.


Figure 4.1a Clock generator circuit block diagram

### 4.2 Reset Causes

When a reset cause occurs, $\mathrm{F}^{2} \mathrm{MC}$-16LX terminates the currently executing processing and waits for the release of reset signal. A reset can be caused by the following factors:
O Power-on reset
O Hardware standby release
O Watch-dog timer overflow
O External reset request via RSTX pin
O Reset request by software
Right after stop mode release or power on reset, the MCU will wait for the stabilization time before resumption of any activities.
When reset occurs, $\mathrm{F}^{2} \mathrm{MC}$-16LX will stop all operation at once and wait for the release of reset.
The content of watchdog timer control register will change according to the reset cause. Thus, the cause of previous reset can be known.
Note: While an external bus is used, the address generated by the device is undefined when a reset cause occurs. All external bus access signals, including RDX and WRX, become inactive.

Table 4.2a Reset causes

| Reset | Cause | Machine clock | Watch-dog timer | Oscillation <br> stabilization <br> wait |
| :---: | :---: | :---: | :---: | :---: |
| Power-on | When the power is turned <br> on | Main clock | Stop | Yes |
| Hardware <br> standby | 'L' level input to HSTX pin | Main clock | Stop | Yes |
| Watch-dog timer | Watch-dog timer overflow | Main clock | Stop | Yes |
| External pin | 'L' level input to RSTX pin | Previous status <br> maintained | Previous status <br> maintained | No |
| Software | '0' written to RST bit of | Previous status <br> STBYC | Previous status <br> maintained | No |

* In stop or hardware standby mode, a reset input allows for oscillation stabilization time regardless of the reset cause.
* The oscillation stabilization time for a power-on reset is fixed to $2^{18}$ cycles of source oscillation. For other types of reset, the oscillation stabilization wait time is determined by CS1 and CS0 of the clock selection register.
As shown in Figure 4.2a, each reset cause has a corresponding flip-flop. The contents of the flip-flop can be obtained by reading the watch-dog timer control register. If identifying the reset cause is required after the reset is released, ensure that the value read from the watch-dog timer control register is processed by software and processing branches to an appropriate program.


Figure 4.2a Reset cause bit block diagram

| Address: $0000 \mathrm{AB}_{\mathrm{H}}$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\propto \text { Bit No. }$ <br> WDTC |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | PONR | STBR | WRST | ERST | SRST | WTE | WT1 | WT0 |  |
| Read/write $\qquad$ Initial value $\qquad$ | $\begin{aligned} & \text { (R) } \\ & (\mathrm{X}) \end{aligned}$ | $\begin{aligned} & \text { (R) } \\ & \text { (X) } \end{aligned}$ | $\begin{aligned} & \text { (R) } \\ & (\mathrm{X}) \end{aligned}$ | $\begin{aligned} & \text { (R) } \\ & \text { (X) } \end{aligned}$ | $\begin{aligned} & \text { (R) } \\ & (\mathrm{X}) \end{aligned}$ | (W) <br> (1) | (W) <br> (1) | (W) <br> (1) |  |

Figure 4.2b WDTC (watch-dog timer control register)

When there are multiple reset causes, the corresponding reset cause bits in the watch-dog timer control register are set. Therefore, if an external reset request and a watch-dog reset occur at the same time, both the ERST and WRST bits are set to 1.
A power-on reset is an exception; while the PONR bit is 1, the values of other bits do not indicate the correct reset causes. Therefore, design software so that the other reset cause bit values are ignored while the PONR bit is set to 1 .

Table 4.2b Reset cause bits

| Reset cause | PONR | STBR | WRST | ERST | SRST |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power-on | 1 | - | - | - | - |
| Hardware standby | ${ }^{*}$ | 1 | ${ }^{*}$ | ${ }^{*}$ | ${ }^{*}$ |
| Watch-dog timer | ${ }^{*}$ | ${ }^{*}$ | 1 | ${ }^{*}$ | ${ }^{*}$ |
| External pin | ${ }^{*}$ | ${ }^{*}$ | ${ }^{*}$ | 1 | ${ }^{*}$ |
| RST bit | ${ }^{*}$ | ${ }^{*}$ | ${ }^{*}$ | ${ }^{*}$ | 1 |

(An asterisk (*) in the table means that the previous value is maintained.)
Note: A reset cause bit is cleared only by reading the watch-dog timer control register. Thus, once a reset occurs, the corresponding reset cause bit remains 1 even if another reset cause occurs.

### 4.3 Operation after reset release

When a reset cause is removed, the $\mathrm{F}^{2} \mathrm{MC}$-16LX immediately outputs the address in which the reset vector is stored, then fetches the reset vector and mode data. The reset vector and mode data are assigned to the four bytes between FFFFDC $_{H}$ and FFFFDF $_{H}$. After reset is released, the reset vector and mode data are transferred to the registers by the hardware as described in Figure 4.3a.

Use the mode pin to specify whether to read the reset vector and mode data from internal ROM or from external memory. When the mode pin is set to external vector mode, the $\mathrm{F}^{2} \mathrm{MC}-16 \mathrm{LX}$ reads the reset vector and mode data from external memory. When using the $F^{2}$ MC-16LX in single chip mode or internal ROM external bus mode, Fujitsu recommends specifying internal vector mode.
The bus mode after the reset vector and mode data are read is specified by the mode data.


Figure 4.3a Source and destination of reset vector and mode data

## Chapter 5:

## Watchdog Timer, Timebase Timer, and Watch Timer Functions

### 5.1 Outline

## Watch-Dog Timer

The watchdog timer consists of 2-bit counter that uses to carry signal from the 18 -bit timebase timer or the 15 -bit watch timer as a clock source, a control register, and a watchdog reset controller. The watch-dog timer function enables detection of program surge. If the watch-dog timer is not accessed within the specified time due to, for example, a program surge, the watch-dog timer resets the system.

## Time Base Timer

The timebase timer consists of 18 -bit counter and a circuit that control interval interrupts. The timebase timer also has a function for supplying operating clocks for the timer output for the oscillation stabilization time or the watchdog timer etc.it is counting up in synchronization to the internal count clock (divided-by-2 of oscillation) with an interval timer function for selecting an interval time from four types of $2^{12} / \mathrm{HCLK}$, $2^{14} /$ HCLK, $2^{16} /$ HCLK, and $2^{19} /$ HCLK. (HCLK is the main clock.) Note taht the timebase timer uses the main clock, regardless of the MCS bit and SCS bit in CKSCR.

## Watch Timer

The watch timer consists of 15 -bit counter and a circuit that controls interval interrupts. The watch timer functions as the clock source for the watchdog counter, as the timer for the subclock stabilization wait, and as an interval timer that generates interrupts at a given period. Note that the watch timer uses the sub clock, regardless of the MCS bit and SCS bit in CKSCR.

### 5.2 Block diagram



Figure 5.2a Watchdog Timer, Timebase Timer, and Watch Timer Block Diagram

### 5.3 Registers and register details

Watch-Dog timer control register

| Address : 0000A8H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Bit number <br> WDTC |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | PONR | STBR | WRST | ERST | SRST | WTE | WT1 | WT0 |  |
| Read/write Initial value | $\begin{aligned} & (\mathrm{R}) \\ & (\mathrm{X}) \end{aligned}$ | $\begin{aligned} & (\mathrm{R}) \\ & (\mathrm{X}) \end{aligned}$ | $\begin{aligned} & \text { (R) } \\ & \text { (X) } \end{aligned}$ | (R) (X) | (R) (X) | $\begin{aligned} & (W) \\ & (1) \end{aligned}$ | (W) (1) | (W) |  |

Timer base timer control register

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $\checkmark$ Bit number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $0000 \mathrm{A9}{ }_{\mathrm{H}}$ | Reserved | - | - | TBIE | TBOF | TBR | TBC1 | TBC0 | TBTC |
| Read/write Initial value $\Rightarrow$ | $(-)$ $(1)$ | $(-)$ $(-)$ | $(-)$ $(-)$ | $\underset{(0)}{(R / W)}$ | (R/W) $(0)$ | (W) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ |  |

Watch timer control register

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Bit number WTC |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $0000 \mathrm{AA}_{\mathrm{H}}$ | WDCS | SCE | WTIE | WTOF | WTR | WTC2 | WTC1 | WTC0 |  |
| Read/write $\Rightarrow$ Initial value $\Rightarrow$ | (R/W) (1) | $\begin{aligned} & \text { (R) } \\ & \text { (X) } \end{aligned}$ | (R/W) (0) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} \text { (R/W) } \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (R / W) \\ (0) \end{gathered}$ | (R/W) <br> (0) |  |

### 5.3.1 WDTC (Watch-Dog Timer Control Register)

Watch-Dog timer control register

| Address : 0000A8 ${ }_{\text {H }}$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Bit number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | PONR | STBR | WRST | ERST | SRST | WTE | WT1 | WT0 | WDTC |
| Read/write $\Rightarrow$ | (R) | (R) | (R) | (R) | (R) | (W) | (W) | (W) |  |
| Initial value $\Rightarrow$ | (X) | (X) | (X) | (X) | (X) | (1) | (1) | (1) |  |

Don't use read-modify-write command to access this register, otherwise malfunction will occur.
[bits 7 to 3] PONR, STBR, WRST, ERST, and SRST
These flags indicate the reset causes. The flags are set upon a reset as described in Table 5.3.1a.
All bits are cleared to ' 0 ' after the WDTC register is read. The WDTC register is a read-only register. This is a read-only register. Note that during power-on only, the contents of the bits that indicate sources other than power-on are not guaranteed. Therefore, software should be designed to ignore the other bits when the PONR bit is " 1 ".

Table 5.3.1a Reset cause registers

| Reset cause | PONR | STBR | WRST | ERST | SRST |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power-on | 1 | - | - | - | - |
| Hardware standby | ${ }^{*}$ | 1 | ${ }^{*}$ | ${ }^{*}$ | ${ }^{*}$ |
| Watch-dog timer | ${ }^{*}$ | ${ }^{*}$ | 1 | ${ }^{*}$ | ${ }^{*}$ |
| External pin | ${ }^{*}$ | ${ }^{*}$ | ${ }^{*}$ | 1 | ${ }^{*}$ |
| RST bit | ${ }^{*}$ | ${ }^{*}$ | ${ }^{*}$ | ${ }^{*}$ | 1 |

(*: The previous value is maintained.)
[bit 2] WTE
While the watch-dog timer is stopped, writing '0' to this bit activates the watch-dog timer. Subsequently, writing ' 0 ' clears the watch-dog timer counter. Writing ' 1 ' has no effect.

The watch-dog timer is stopped by power-on, hardware standby, or reset by watch-dog timer. ' 1 ' is always read from this bit.
[Bits 1, 0] WT1, WT0
These bits select the watchdog interval time. Only the data written when the watchdog timer is started up is valid. Data written to these bits at any time other than watchdog startup is ignored. Note that the clock that is input to the watchdog timer is selected according to the result of ANDing the WDCS bit of the WTC and the SCM bit of the LPMCR. In other words, if WDCS is set to " 1 ", then the timebase timer output can be selected if the main clock and the PLL clock are selected, and the watch timer output can be selected if the subclock is selected.

The interval time settings are shown in Table 5.3.1a.
These bits are write-only bits.

Table 5.3.1b Watchdog Timer Interval Selection Bits

| WDCS/ SCM | WT1 | WTO | Interval Time(Source oscillation: 4 MHz )Minimum |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Maximum |
| 1 | 0 | 0 | Approx. 3.58 ms | Approx. 4.61 ms |
| 1 | 0 | 1 | Approx. 14.33 ms | Approx. 18.43 ms |
| 1 | 1 | 0 | Approx. 57.23 ms | Approx. 73.73 ms |
| 1 | 1 | 1 | Approx. 458.75 ms | Approx. 589.82 ms |
| 0 | 0 | 0 | Approx. 0.109 s | Approx. 0.141 s |
| 0 | 0 | 1 | Approx. 0.875 s | Approx. 1.125 s |
| 0 | 1 | 0 | Approx. 1.75 s | Approx. 2.25 s |
| 0 | 1 | 1 | Approx. 3.5 s | Approx. 4.5 s |

Note: The maximum interval value is the value when the time base counter or the clock counter are not reset during watchdog operation.

### 5.3.2 TBTC (Time Base Timer Control Register)

Timer base timer control register

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | - Bit number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: 0000A9 ${ }_{\text {H }}$ | Reserved | - | - | TBIE | TBOF | TBR | TBC1 | TBC0 | TBTC |
| Read/write Initial value $\Rightarrow$ | $(-)$ $(1)$ | $(-)$ $(-)$ | $(-)$ $(-)$ | $\underset{(0)}{(R / W)}$ | (R/W) $(0)$ | (W) | $\begin{gathered} (R / W) \\ (0) \end{gathered}$ | $\begin{gathered} (R / W) \\ (0) \end{gathered}$ |  |

Note: Don't use read-modify-write command to access this register, otherwise malfunction will occur.
[bit 15] Reserved
This is a reserved bit. When writing data to this register, ensure that ' 1 ' is written to this bit.
[bit 12] TBIE
This bit is used to enable interval interrupts based on the time base timer. Writing ' 1 ' to this bit enables interrupts, and writing ' 0 ' disables interrupts. This bit is initialized to ' 0 ' upon a reset. This bit is readable and writable.
[bit 11] TBOF
This is an interrupt request flag for the time base timer. While the TBIE bit is '1,' an interrupt request is issued when ' 1 ' is written to TBOF. This bit is set to ' 1 ' for each interval specified with the TBC1 and TBCO bits.
This bit is cleared by writing ' 0 ,' by switching to stop or hardware standby mode, or by a reset. Writing '1' has no effect.

1 ' is always read by a read-modify-write instruction.
[bit 10] TBR
This bit clears all bits of the time base timer counter to ' 0 .'
Writing ' 0 ' clears the time base counter.
Writing '1' has no effect.
' 1 ' is always read from this bit.
Note: Time base timer interrupt should be masked by either TBIE bit or ILM bit of CPU before clearing the TBOF bit.
[bits 9 and 8] TBC1 and TBC0
These bits are used to set the time base timer interval.

Table 5.3.2a Selecting the time base timer interval

| TBC1 | TBC0 | Interval at 4 MHz <br> source oscillation | Machine Clock Cycle |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 1.024 ms | $2^{12}$ cycle |
| 0 | 1 | 4.096 ms | $2^{14}$ cycle |
| 1 | 0 | 16.384 ms | $2^{16}$ cycle |
| 1 | 1 | 131.072 ms | $2^{19}$ cycle |

### 5.3.3 Watch Timer Control Register (WTC)

| Watch timer control register |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\checkmark$ Bit number |
| Address: $0000 \mathrm{AA}_{H}$ | WDCS | SCE | WTIE | WTOF | WTR | WTC2 | WTC1 | WTC0 | WTC |
| Read/write Initial value | $(R / W)$ <br> (1) | $\begin{aligned} & (\mathrm{R}) \\ & (\mathrm{X}) \end{aligned}$ | (R/W) <br> (0) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\underset{(0)}{(\mathrm{R} / \mathrm{W})}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ |  |

[Bit 7] WDCS
This bit selects whether to use the clock signal from the watch timer or from the timebase timer for the watchdog timer input clock when the main clock and PLL clock are selected. When this bit is " 0 ", the clock signal from the watch timer is selected; when this bit is "1", the clock signal from the timebase timer is selected. In short, if WDCS is set to "1", then the timebase timer output can be selected if the main clock and the PLL clock are selected, and the watch timer output can be selected if the subclock is selected.
This bit is initialized to "1" by a power-on reset.
Note: When WDCS is set to "1", because the timebase timer output and the watch timer output are asynchronous, there is a possibility that the watchdog timer count may advance. Therefor, when WDCS is set to "1", it is necessary to clear the watchdog timer before and after changing the clock mode.
[Bit 6] SCE
This bit indicates that the subclock oscillation stabilization waiting period has elapsed. When this bit is " 0 ", it indicates that the oscillation stabilization period is currently in progress. The oscillation stabilization period is fixed at $2{ }^{14}$ cycles (subclock). This bit is initialized to " 0 " by a power-on reset and by stopping.
[Bit 5] WTIE
This bit enables interval interrupts by the watch timer. When this bit is set to " 1 ", interrupts are enabled; when set to " 0 ", interrupts are disabled. This bit is initialized to " 0 " by a reset. This bit can be read and written.
[Bit 4] WTOF
This bit is the watch timer interrupt request flag. When the WTIE bit is "1", an interrupt request is generated if WTOF is set to "1". This bit is set to "1" at the intervals set by the WTC1 and WTC0 bits. This bit is cleared by writing a " 0 ", by switching to stop mode or hardware standby mode, and by a reset. Writing "1" to this bit has no meaning.
When this bit is read by a read-modify-write instruction, a "1" is read.
[Bit 3] WTR
This bit clears all of the watch timer counter bits to " 0 ". The clock counter is cleared by writing a " 0 " to this bit. Writing " 1 " to this bit has no meaning. Reading this bit returns a " 1 ".
[Bits 2, 1, 0] WTC2, WTC1, WTC0
These bits set the watch timer interval. The interval settings are shown in Table 5.3.3a. These bits are initialized to "000" by a reset. These bits can be read and written.
When writing these bits, clear bit 4 (WTOF) at the same time.
5.3 Registers and register details

Table 5.3.3a Watch Timer Interval Selection

| WTC2 | WTC1 | WTC0 | Interval time when <br> subclock is 32 kHz |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 15.625 ms |
| 0 | 0 | 1 | 31.25 ms |
| 0 | 1 | 0 | 62.5 ms |
| 0 | 1 | 1 | 0.125 s |
| 1 | 0 | 0 | 0.250 s |
| 1 | 0 | 1 | 0.500 s |
| 1 | 1 | 0 | 1.000 s |
| 1 | 1 | 1 | - |

### 5.4 Operation

### 5.4.1 Watch-Dog Timer

The watch-dog timer function enables detection of program surge.
If the watch-dog timer is not accessed within the specified time due to, for example, a program surge, the watch-dog timer resets the system.
(1) Activation

The watch-dog timer is activated by writing '0' to the WTE bit of the WTC register while the watch-dog timer is stopped. At the same time, the WT1 and WT0 bits are used to set the watch-dog timer reset interval. Only the interval setting specified during activation is valid.
(2) Watch-dog counter

Once the watch-dog timer is activated, the watch-dog timer counter must be periodically cleared within the program. Writing ' 0 ' to the WTE bit of the WTC register clears the watch-dog counter. The watch-dog counter consists of a two-bit counter which uses the carry signals of the time base counter as a clock source. Therefore, the watch-dog reset time may become shorter than the setting if the time base counter is cleared.

Figure 5.4.1a is a diagram of the watch-dog timer operation.


Figure 5.4.1a Watch-dog timer operation
(3) Watch-dog stop

Once activated, the watch-dog timer is initialized and stopped only by power-on, hardware standby, or reset by watch-dog. Reset by an external pin or software merely clears the watch-dog counter without stopping the watch-dog function.
(4) Others

The watch-dog counter is cleared by a reset, transition to sleep or stop mode, or hold acknowledgment signal in addition to writing the WTE bit.

### 5.4.2 Time Base Timer

The time base timer functions as a watch-dog timer clock source, timer for waiting for the oscillation to stabilize, and interval timer for generating interrupts at specified intervals.
(1) Time base counter

The time base counter consists of an 18-bit counter for a clock generated by dividing the source oscillation input by two. This clock is used to generate the machine clock. While the source oscillation is input, the time base counter keeps counting. The time base counter is cleared by a power-on reset, transition to stop or hardware standby mode, shifting from the main clock to the PLL clock through the setting of the MCS bit in the CKSCR register, shifting from the main clock to the subclock through the setting of the SCS bit in the CKSCR register, or writing '0' to the TBR bit of the TBTC register.
(2) Interval interrupt function

Interrupts are generated at specified intervals according to the carry signals of the time base counter. The TBOF flag is set at the intervals specified with the TBC1 and TBC0 bits of the TBTC register. The flag is written to reference to the time at which the time base timer is cleared last.
If a shift is made from the main clock mode to the PLL clock mode, the timebase timer is cleared, since it is used as the timer for the PLL clock oscillation stabilization waiting period.

In addition, if a shift is made from the main clock mode to the subclock mode, the timebase timer is cleared, since it is used as the timer for the main clock oscillation stabilization waiting period.
Upon transition to stop or hardware standby mode, the time base timer is used as a timer for waiting for the oscillation to stabilize upon recovery. Therefore, the TBOF flag is immediately cleared upon mode transition.

### 5.4.3 Watch Timer

The watch timer functions as the clock source for the watchdog counter, as the timer for the subclock stabilization wait, and as an interval timer that generates interrupts at a given period.
(1) Watch timer

The watch timer is a 15-bit counter that counts the source oscillation input which is used to generate the machine clock. The watch timer always continues its counting operation as long as the source oscillation is being input. The watch timer is cleared by: power-on reset, shifting to stop mode or hardware standby mode, and writing " 0 " to the WTR bit in the WTC register.
The watchdog counter and the interval interrupts, both of which utilize the watch timer output, are affected by the watch timer being cleared.
(2) Interval interrupt function

This function generates interrupts at a given period based on the clock counter carry signal. This function sets the WTOF flag at a regular interval, which is set by the WTC1 and WTC0 bits in the WDTC register. The timing for the setting of this flag is based on the time when the watch timer was last cleared.
If a shift is made to stop mode or hardware standby mode, the WTOF flag is cleared at the same time as the mode shift, since the watch timer is used for the oscillation stabilization waiting period during recovery.

## Chapter 6: <br> Low Power Control Circuit

### 6.1 Outline

The following are the operating modes: PLL clock mode, PLL sleep mode, PLL watch mode, pseudo-watch mode, main clock mode, main sleep mode, main watch mode, main stop mode, subclock mode, sub sleep mode, sub watch mode, sub stop mode, and hardware standby mode. Aside from the PLL clock mode, all of the other operating modes are low power consumption modes.
In main clock mode and main sleep mode, only the main clock (main OSC oscillation clock) and the subclock (sub OSC oscillation clock) operate. In these modes, the main clock divided by two is used as the operation clock, the subclock (sub OSC oscillation clock) is used as the watch clock, and the PLL clock (VCO oscillation clock) is stopped.

In subclock mode and sub sleep mode, only the subclock (sub OSC oscillation clock) operates. The subclock is used as the operation clock, and the main clock and the PLL clock are stopped.
In PLL sleep mode and main sleep mode, only the CPU's operation clock is stopped, all clocks other than the CPU clock operate.
In pseudo-watch mode, only the watch timer and the timebase timer operate.
In PLL watch mode, main watch mode, and sub-watch mode, only the watch timer operates. Only the subclock is in operation in this mode; the main clock and the PLL clock are stopped. (The difference among PLL watch mode, main watch mode, and sub-watch mode is that the operating mode upon recovery from an interrupt is PLL clock mode, main clock mode, or subclock mode, respectively. There are no differences in the watch mode operations.)
The main stop mode, sub stop mode, and hardware standby mode stop oscillation, making it possible to retain data while consuming the least amount of power possible. (The difference between main stop mode and sub stop mode is that the operating mode upon recovery from an interrupt is main clock mode or subclock mode, respectively. There are no differences in the stop mode operations.)
The CPU intermittent operation function intermittently runs the clock supplied to the CPU when accessing registers, on-chip memory, on-chip resources, and the external bus. Processing is possible with lower power consumption by reducing the execution speed of the CPU while supplying a high-speed clock to the on-chip resources.
The PLL clock multiplier can be selected as either 2, 4, 6, or 8 by setting the CS1 and CS0 bits. The selected clock divided by two is used as the machine clock.
The WS1 and WS0 bits can be used to set the main clock oscillation stabilization waiting period for when stop mode and hardware standby mode are released.

### 6.2 Block Diagram



Figure 6.2a Low-power consumption control circuit and clock generator

### 6.3 Registers and register details

Clock selection register

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | $8<\mathrm{Bit}^{\text {No. }}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: 0000A1H | SCM | MCM | WS1 | WS0 | SCS | MCS | CS1 | CSO | CKSCR |
| Read/write Initial value $\Rightarrow$ | $\begin{aligned} & (\mathrm{R}) \\ & (1) \end{aligned}$ | $\begin{aligned} & \text { (R) } \\ & (1) \end{aligned}$ | (R/W) <br> (1) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (1) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (1) \end{gathered}$ | (R/W) (1) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (R / W) \\ (0) \end{gathered}$ |  |

Low power mode control register

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | $0<\mathrm{Bit}^{\text {No. }}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $0000 \mathrm{AO}_{\mathrm{H}}$ | STP | SLP | SPL | RST | TMD | CG1 | CG0 | SSR | LPMCR |
| $\begin{aligned} & \text { Read/write } \Rightarrow \\ & \text { Initial value } \Rightarrow \end{aligned}$ | $\begin{aligned} & \text { (W) } \\ & (0) \end{aligned}$ | $\begin{aligned} & (\mathrm{W}) \\ & (0) \end{aligned}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | (W) <br> (1) | $\begin{gathered} (\mathrm{W}) \\ (1) \end{gathered}$ | $\underset{(0)}{(\mathrm{R} / \mathrm{W})}$ | $\underset{(0)}{(R / W)}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ |  |

### 6.3.1 LPMCR (Low power mode control register)

## Low power mode control register

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | $0<\sim$ Bit No. |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $0000 \mathrm{AO}_{\mathrm{H}}$ | STP | SLP | SPL | RST | TMD | CG1 | CGO | SSR | LPMCR |
| Read/write $\Rightarrow$ | (W) | (W) | (R/W) | (W) | (W) | (R/W) | (R/W) | (R/W) |  |
| Initial value $\Rightarrow$ | (0) | (0) | (0) | (1) | (1) | (0) | (0) | (0) |  |

[Bit 7] STP
Writing a " 1 " to this bit changes the mode to pseudo-watch mode (CKSCR. MCS = 0 and SCS =1) or stop mode (CKSCR. MCS $=1$ or SCS $=0$ ). Writing a " 0 " to this bit has no effect. This bit is cleared to " 0 " by a reset, wake-up from watch or stop mode. This bit is a write-only bit. When this bit is read, " 0 " is always returned.
[Bit 6] SLP
Writing a " 1 ' to this bit changes the mode to sleep mode. Writing a "0" to this bit has no effect. This bit is cleared to " 0 " by a reset, wake-up from sleep or stop mode.
If a " 1 ' is written to both the STP bit and the SLP bit simultaneously, the mode changes to either pseudo-watch mode or to stop mode. This bit is a write-only bit. When this bit is read, " 0 " is always returned.
[Bit 5] SPL
When this bit is " 0 ", the level of external pins in watch mode or stop mode is retained. When this bit is " 1 ", the external pins in watch mode or stop mode go to high-impedance. This bit is cleared to "0" by a reset. This bit can be read and written.
[Bit 4] RST
Writing a " 0 " to this bit generates an internal reset signal in three machine cycles. Writing a " 1 ' to this bit has no effect. When this bit is read, a " 1 " is returned.
[Bit 3] TMD
Writing a " 0 " to this bit changes the mode to watch mode. Writing a "1" to this bit has no effect. This bit is set to "1" by a reset, wake-up from watch or stop mode. This bit is a write-only bit. When this bit is read, " 1 " is always returned.
[Bits 2, 1] CG1, CG0
These bits set the number of clock pause cycles for the CPU intermittent operation function.
These bits are initialized to " 00 " by a reset due to power-on, hardware standby, or a reset by the watchdog timer. These bits are not initialized by resets due to other sources. These bits can be read or written.

Table 6.3.1a CG Bit Setting

| CG1 | CG0 | Number of CPU clock pause cycles |
| :---: | :---: | :---: |
| 0 | 0 | 0 cycles (CPU clock = resource clock) |
| 0 | 1 | 9 cycles (CPU clock: resource clock = 1: approximately 3 to 4) |
| 1 | 0 | 17 cycles (CPU clock: resource clock = 1: approximately 5 to 6) |
| 1 | 1 | 33 cycles (CPU clock: resource clock = 1: approximately 9 to 10) |

[Bit 0] SSR
When this bit is set to "1", DRAMC self-refresh control is performed in sleep (main/PLL) mode, watch mode, and stop mode. This bit is cleared to " 0 " by a refresh. This bit can be read and written.
Note: SSR has no function if there is no DRAMC on chip.

### 6.3.2 CKSCR (Clock selection register)

Clock selection register

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | $8 \leftharpoonup$ Bit No. |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $0000 \mathrm{A1}{ }_{\mathrm{H}}$ | SCM | MCM | WS1 | WSO | SCS | MCS | CS1 | CSO | CKSCR |
| Read/write $\qquad$ Initial value $\Rightarrow$ | (R) <br> (1) | (R) <br> (1) | (R/W) <br> (1) | (R/W) <br> (1) | (R/W) <br> (1) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (1) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | (R/W) (0) |  |

[Bit 15] SCM
This bit indicates whether the main clock or the subclock is selected as the machine clock. When this bit is " 0 ", it indicates that the subclock is selected; when this bit is " 1 ", it indicates that the main clock is selected. If $S C S=0$ and $S C M=1$, it indicates that the main clock oscillation stabilization waiting period is in progress.
[Bit 14] MCM
This bit indicates whether the main clock or the PLL clock is selected as the machine clock. When this bit is " 0 ", it indicates that the PLL clock is selected; when this bit is "1", it indicates that the main clock is selected. If MCS $=0$ and $\mathrm{MCM}=1$, it indicates that the PLL clock oscillation stabilization waiting period is in progress. Note that the PLL clock oscillation stabilization waiting period is fixed at $2^{12}$ main clock cycles.
[Bits 13, 12] WS1, WS0
These bits set the main clock oscillation stabilization waiting period upon wake-up from stop mode or hardware standby mode is released.
These bits are initialized to "11" by a power-on reset; these bits are not initialized by a reset due to other sources. These bits can be read and written.

Table 6.3.2a WS Bit Settings

| WS1 | WS0 | Oscillation stabilization waiting period <br> (source oscillation at $4 \mathbf{M H z}$ ) |
| :---: | :---: | :---: |
| 0 | 0 | No oscillation stabilization waiting period |
| 0 | 1 | Approx. 1.02 ms (count of $2^{14}$ of the source oscillation) |
| 1 | 0 | Approx. 8.19 ms (count of $2^{16}$ of the source oscillation) |
| 1 | 1 | Approx. 65.54 ms (count of $2^{18}$ of the source oscillation) |

## [Bit 11] SCS

This bit selects either the main clock or the subclock as the machine clock. When a " 0 " is written to this bit, the subclock is selected; when a "1" is written to this bit, the main clock is selected. If a "1" is written to this bit while it is "0", the oscillation stabilization waiting period for the main clock is generated; therefore, the timebase timer is automatically cleared. In addition, the subclock (as is) is used for the operation clock when the subclock is selected. (When the source oscillation is 32 kHz , the operation clock is 32 KHz .) When SCS and MCS are both set to " 0 ", SCS takes priority and the subclock is selected.

This bit is initialized to "1" by a reset due to power-on, hardware standby, the watchdog timer, an external source, or software.

## [Bit 10] MCS

This bit selects either the main clock or the PLL clock as the machine clock. When a " 0 " is written to this bit, the PLL clock is selected; when a " 1 " is written to this bit, the main clock is selected. If a " 0 " is written to this bit while it is "1", the oscillation stabilization waiting period for the PLL clock is generated; therefore, the timebase timer is automatically cleared. Note that the PLL clock oscillation stabilization waiting period is fixed at $2^{12}$ main clock cycles. In addition, the main clock divided by two is used for the operation clock when the main clock is selected. (When the source oscillation is 4 MHz , the operation clock is 2 MHz .)
This bit is initialized to "1" by a reset due to power-on, hardware standby, or the watchdog timer.
[Bits 9, 8] CS1, CS0
These bits select the PLL clock multiplier. These bits are not initialized by a reset initiated by an external pin or the RST bit. These bits are initialized to "00" by a reset due to power-on, hardware standby, and the watchdog timer.
Writing to these bits is suppressed when the MCS bit is "0". Set the MCS bit to "1" (main clock mode) first and then overwrite the CS bits.

These bits can be read and written.
Table 6.3.2b CS Bit Settings

| CS1 | CS0 | Machine clock (source oscillation at 4 MHz) |
| :---: | :---: | :---: |
| 0 | 0 | 4 MHz (operation frequency = OSC oscillation frequency) |
| 0 | 1 | 8 MHz (operation frequency = OSC oscillation frequency $\times 2$ ) |
| 1 | 0 | 12 MHz (operation frequency = OSC oscillation frequency $\times 3$ ) |
| 1 | 1 | 12 MHz (operation frequency = OSC $(3 \mathrm{MHz}) \times 4)$ |

### 6.4 Operations

The status of each chip block in each operating mode is shown in Table 6.4a
Table 6.4a Low Power Consumption Mode Operating Statuses

|  | Transition condition | Sub oscillation | Main oscillation | Clock | CPU | $\begin{array}{\|c} \text { Peripheral } \\ \mathrm{s} \end{array}$ | Pins | $\begin{gathered} \text { Exit } \\ \text { method } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Subclock | $\begin{aligned} & \mathrm{SCS}=0 \\ & \mathrm{MCS}=\mathrm{x} \end{aligned}$ | Operating | Stopped | Operating | Operating | Operating | Operating | Reset Interrupt |
| Sub sleep | $\begin{aligned} & \text { SCS }=0 \\ & \text { MCS }=x \\ & \text { SLP }=1 \end{aligned}$ | Operating | Stopped | Operating | Stopped | Operating | Operating | Reset Interrupt |
| Main sleep | $\begin{aligned} & \mathrm{SCS}=1 \\ & \mathrm{MCS}=1 \\ & \mathrm{SLP}=1 \end{aligned}$ | Operating | Operating | Operating | Stopped | Operating | Operating | Reset Interrupt |
| PLL sleep | $\begin{aligned} & \mathrm{SCS}=1 \\ & \mathrm{MCS}=0 \\ & \mathrm{SLP}=1 \end{aligned}$ | Operating | Operating | Operating | Stopped | Operating | Operating | Reset Interrupt |
| Pseudowatch (SPL=0) | $\begin{aligned} & \text { SCS }=1 \\ & \text { MCS }=0 \\ & \text { STP }=1 \end{aligned}$ | Operating | Operating | Stopped | Stopped | Stopped | Maintained | Reset Interrupt |
| Pseudowatch (SPL=1) | $\begin{aligned} & \text { SCS }=1 \\ & \text { MCS }=0 \\ & \text { STP }=1 \end{aligned}$ | Operating | Operating | Stopped | Stopped | Stopped | HI-Z | Reset Interrupt |
| Watch (SPL=0) | $\begin{aligned} & \mathrm{SCS}=\mathrm{x} \\ & \mathrm{MCS}=\mathrm{x} \\ & \mathrm{TMD}=0 \end{aligned}$ | Operating | Stopped | Stopped | Stopped | Stopped | Maintained | Reset Interrupt |
| Watch (SPL=1) | $\begin{aligned} & \mathrm{SCS}=\mathrm{x} \\ & \mathrm{MCS}=\mathrm{x} \\ & \mathrm{TMD}=0 \end{aligned}$ | Operating | Stopped | Stopped | Stopped | Stopped | HI-Z | Reset Interrupt |
| $\begin{gathered} \text { Stop } \\ (\mathrm{SPL}=0) \end{gathered}$ | $\begin{gathered} \text { MCS=1 } \\ \text { or SCS=0 } \\ \text { STP=1 } \end{gathered}$ | Stopped | Stopped | Stopped | Stopped | Stopped | Maintained | Reset Interrupt |
| $\begin{gathered} \text { Stop } \\ (\mathrm{SPL}=1) \end{gathered}$ | $\begin{gathered} \text { MCS=1 } \\ \text { or SCS=0 } \\ \text { STP }=1 \end{gathered}$ | Stopped | Stopped | Stopped | Stopped | Stopped | HI-Z | Reset Interrupt |
| Hardware standby | HSTX=L | Stopped | Stopped | Stopped | Stopped | Stopped | HI-Z | HSTX=H |

### 6.4.1 Sleep mode

- Transition to sleep mode

The standby control circuit is set to sleep mode by writing a "1" to the SLP bit, a "1' to the TMD bit, and a " 0 " to the STP bit in the low power consumption mode control register. In sleep mode, only the clock supplied to the CPU is stopped; in this mode, the CPU stops, but the peripheral circuits continue to operate.

If an interrupt request is generated when the "1" is written to the SLP bit, the standby control circuit does not go into sleep mode. In this case, if the CPU is not accepting interrupts, the next instruction is executed; if the CPU is accepting interrupts, processing branches immediately to the interrupt processing routine.
The contents of the accumulator and other dedicated registers, as well as the contents of RAM, are maintained in sleep mode.

- Releasing sleep mode

The standby control circuit is used for wake-up from sleep mode when a reset signal is input or when an interrupt is generated. If a wake-up from sleep mode was done by a reset source, the device enters the reset state after wake-up from sleep mode is completed.

If an interrupt request higher than level 7 is generated by a peripheral circuit, etc., while the device is in sleep mode, the standby control circuit is used for wake-up from sleep mode. Once wake-up from sleep mode is completed, the interrupt is handled in the normal manner. If the settings of the I flag, ILM bits, and the interrupt control register (ICR) are all set so that the interrupt is accepted, then the CPU executes interrupt processing. If the settings do not permit the interrupt to be accepted, then processing resumes from the instruction that follows the instruction that put the device into sleep mode.

### 6.4.2 Pseudo-watch mode

- Transition to pseudo-watch mode

The standby control circuit is set to pseudo-watch mode by writing a "1" to the SCS bit and a "0" to the MCS bit in the clock selection register, and a "1" to the TMD bit and a "1" to the STP bit in the low power consumption mode control register. In pseudo-watch mode, all clocks stop, except for the source oscillation (main and sub), the watch timer, and the timebase timer. Practically all chip functions cease.
In addition, the SPL bit in the low power consumption mode control register can be used to control whether I/O pins maintain their previous states or go to high impedance state in pseudo-watch mode.
If an interrupt request is generated when the "1" is written to the STP bit, the standby control circuit does not shift to pseudo-watch mode.

The contents of the accumulator and other dedicated registers, as well as the contents of RAM, are hold in pseudo-watch mode.

- Exit from pseudo-watch mode

The standby control circuit is used for exit from pseudo-watch mode when a reset signal is input or when an interrupt is generated. If an exit from pseudo-watch mode was performed by a reset source, the device enters the reset state after exit from pseudo-watch mode.
When recovering from pseudo-watch mode, the standby control circuit is activated first for exit from pseudo-watch mode, and then begins waiting for the PLL clock oscillation stabilization wait time to elapse. Therefore, even if the exit from of pseudo-watch mode is due to a reset source, the main clock is used for the reset sequence.

If an interrupt request higher than level 7 is generated by a peripheral circuit, etc., while the device is in pseudo-watch mode, the standby control circuit is activated for exit from pseudo-watch mode. Once exit from pseudo-watch mode is completed, the interrupt is handled in the normal manner. If the settings of the I flag, ILM bits, and the interrupt control register (ICR) are all set so that the interrupt is accepted, then the CPU executes interrupt processing. If the settings do not permit the interrupt to be accepted, then
processing resumes from the instruction that follows the last instruction that put the device into pseudo-watch mode.

### 6.4.3 Watch mode

- Transition to watch mode

The standby control circuit is set to watch mode by writing a " 0 " to the TMD bit in the low power consumption mode control register. In watch mode, all clocks stop, except for the sub-source oscillation and the watch timer. Practically all chip functions cease.

In addition, the SPL bit in the low power consumption mode control register can be used to control whether I/O pins maintain their previous states or go to high impedance state in watch mode.

If an interrupt request is generated when the "1" is written to the TMD bit, the standby control circuit does not shift to watch mode.
The contents of the accumulator and other dedicated registers, as well as the contents of RAM, are maintained in watch mode.

- Exit from watch mode

The standby control circuit is used for exit from watch mode when a reset signal is input or when an interrupt is generated. If watch mode was released by a reset source, the device enters the reset state after exit from watch mode.

When recovering from sub-watch mode, the standby control circuit is activated first for exit from watch mode, and then immediately enters subclock mode. Therefore, even if the wake-up from sub-watch mode is due to a reset source, the sub-clock is used for the reset sequence.
When recovering from main watch mode or PLL watch mode, the standby control circuit is activated first for exit from watch mode, and then begins waiting for the main clock oscillation stabilization period to elapse. Therefore, even if the exit from watch mode is due to a reset source, the sub-clock is used for the reset sequence.

If an interrupt request higher than level 7 is generated by a peripheral circuit, etc., while the device is in watch mode, the standby control circuit is activated for exit from watch mode. Once exit from watch mode is completed, the interrupt is handled in the normal manner. If the settings of the I flag, ILM bits, and the interrupt control register (ICR) are all set so that the interrupt is accepted, then the CPU executes interrupt processing. If the settings do not permit the interrupt to be accepted, then processing resumes from the instruction that follows the last instruction that put the device into watch mode.

### 6.4.4 Stop mode

- Transition to stop mode

The standby control circuit is set to stop mode by writing a "0" to the SCS bit and a "1" to the MCS bit in the clock selection register, and a "1" to the STP bit in the low power consumption mode control register. In stop mode, all oscillation sources (sub and main) stop. All chip functions cease. As a result, data can be retained with the barest minimum of power consumption.
In addition, the SPL bit in the LPMCR can be used to control whether I/O pins maintain their previous states or go to high impedance state in stop mode.
If an interrupt request is generated when the "1" is written to the STP bit, the standby control circuit does not go into stop mode.

The contents of the accumulator and other dedicated registers, as well as the contents of RAM, are maintained in stop mode.

- Exiting stop mode

The standby control circuit releases stop mode when a reset signal is input or when an interrupt is generated. If stop mode was released by a reset source, the device enters the reset state after stop mode is released.

When recovering from sub-stop mode, the standby control circuit first begins waiting for the sub-clock oscillation stabilization waiting period to elapse, and then exits stop mode. Therefore, even if the exit from stop mode is due to a reset source, the reset sequence is executed after the sub-clock oscillation stabilization waiting period elapses.
When recovering from main stop mode, the standby control circuit first begins waiting for the main clock oscillation stabilization waiting period to elapse, and then exits stop mode. Therefore, even if the exit from stop mode is due to a reset source, the reset sequence is executed after the main clock oscillation stabilization waiting period elapses.

If an interrupt request higher than level 7 is generated by a peripheral circuit, etc., while the device is in stop mode, the standby control circuit exits stop mode. After exit from sub-stop mode, and after the sub-clock oscillation stabilization waiting period has elapsed, the interrupt is handled in the normal manner. If the settings of the I flag, ILM bits, and the interrupt control register (ICR) are all set so that the interrupt is accepted, then the CPU executes interrupt processing. If the settings do not permit the interrupt to be accepted, then processing resumes from the instruction that follows the last instruction that put the device into stop mode.
After exit from main stop mode, and after the main clock oscillation stabilization waiting period (specified by the WS1 and WS0 bits in the CKSCR) has elapsed, the interrupt is handled in the normal manner. If the settings of the I flag, ILM bits, and the interrupt control register (ICR) are all set so that the interrupt is accepted, then the CPU executes interrupt processing. If the settings do not permit the interrupt to be accepted, then processing resumes from the instruction that follows the last instruction that put the device into stop mode.

### 6.4.5 Hardware standby mode

- Transition to hardware standby mode

By setting the HSTX pin to low level, it is possible to set the standby control circuit to hardware standby mode, regardless of the current status. In hardware standby mode, oscillation stops and all I/O pins go to high impedance as long as the HSTX pin is low, regardless of any other statuses, including resets.

Although the contents of internal RAM are maintained in hardware standby mode, the accumulator and other dedicated registers are all initialized.

- Waking up from hardware standby mode

Wake-up from hardware standby mode can only be executed through the HSTX pin. When the HSTX pin goes high, the standby control circuit is activated for wake-up from hardware standby mode and the device begins waiting for oscillation stabilization after the internal reset signal is enabled. After the main clock oscillation stabilization waiting period elapses, the standby control circuit releases the internal reset, after which the CPU begins execution, starting from the reset sequence.

### 6.4.6 CPU intermittent operation function

The CPU intermittent operation function regularly stops the clock supplied to the CPU for a given period of time when accessing registers, on-chip memory, on-chip resources, and the external bus, delaying the start of the internal bus cycle. Processing is possible with lower power consumption by reducing the execution speed of the CPU while supplying a high-speed clock to the on-chip resources. The CG1 and CGO bits select the number of pause cycles in the clock supplied to the CPU.
Note that the same clock is used for external bus operations as for resources.

In addition, the instruction execution time when the CPU intermittent operation function is used can be calculated by adding a compensation factor (the number of register, on-chip memory, on-chip resource, and external bus access multiplied by the number of pause cycles) to the normal execution time.


### 6.4.7 Setting the main clock oscillation stabilization waiting period

The WS1 and WS0 bits can be used to set the main clock oscillation stabilization waiting period for wakeup from stop mode and hardware standby mode. The oscillation stabilization waiting period should be set in accordance with the type and characteristics of the oscillation circuit and oscillator connected to the X0 and X1 pins.
These bits are not initialized in the event of a reset, except for a power-on reset. If a power-on reset is generated, these bits are initialized to "11". Therefore, when power is first applied, the main clock oscillation stabilization waiting period is set to approximately a count of $2^{18}$ pulses of the source oscillation.

### 6.4.8 Switching the machine clock

- Main clock/PLL clock switching

Switching between the main clock and the PLL clock is accomplished by writing to the MCS bit in the CKSCR register.
If the MCS bit is overwritten from a " 1 " to a " 0 ", the machine clock switches from the main clock to the PLL clock, once the PLL clock oscillation stabilization waiting period passes ( $2^{11}$ machine clocks).
If the MCS bit is overwritten from a " 0 " to a " 1 ", the machine clock switches from the PLL clock to the main clock, at the point when the edges of the PLL clock and the main clock match (after 1 to 8 PLL clocks).

Because the machine clock does not switch immediately after the MCS bit is overwritten, when performing operations on resources that depend on the machine clock, always reference the MCM bit and make sure that the machine clock was switched before performing the operation on the resource.

- Main clock/sub-clock switching

Switching between the main clock and the sub-clock is accomplished by writing to the SCS bit in the CKSCR register.
If the SCS bit is overwritten from a "1" to a "0", the machine clock switches from the main clock to the subclock when the sub-clock edge is detected.

If the SCS bit is overwritten from a "0" to a "1", the machine clock switches from the sub-clock to the main clock after the main clock oscillation stabilization waiting period elapses.
Because the machine clock does not switch immediately after the SCS bit is overwritten, when performing operations on resources that depend on the machine clock, always reference the SCM bit and make sure that the machine clock was switched before performing the operation on the resource.

- Machine clock initialization

The MCS bit and the SCS bit are not initialized by a reset caused by an external pin or the RST bit. After other types of resets, these bits are each initialized to "1".

Figure 6.4.8a and Figure 6.4.8b show the clock selection state diagram.


Figure 6.4.8a Clock Selection State Transition Diagram (1)


Figure 6.4.8b Clock Selection State Transition Diagram (2)

### 6.4.9 State transition

Figure 6.4.9a to Figure 6.4.9d show the state transitions in low power consumption mode.
In order to keep the state transition diagrams simple, they depict simultaneously occurring events as occurring in stages. In actuality, however, state transitions occur immediately. For example, when MCS is set to "1" and SLP is set to "1" simultaneously in PLL clock mode, the state transition diagrams show the mode changing once to PM transition mode and then to PM transition sleep, but in actuality, the mode changes immediately from PLL clock mode to PM transition sleep. In addition, when a reset occurs in sub sleep mode, the state transition diagrams show the mode changing once to sub mode and then to the main oscillation stabilization period, but in actuality, the mode shifts immediately from sub sleep mode to the main oscillation stabilization period.

MCS: MCS bit (clock selection register) (PLL clock mode is selected when MCS =0)
SCS: $\quad$ SCS bit (clock selection register) (sub-clock mode is selected when SCS =0)
STP: STP bit (low power consumption mode register) (sleep mode is selected when SLP = 0)
SLP: $\quad$ SLP bit (low power consumption mode register) (sleep mode is selected when SLP = 0)
TMD: TMD bit (low power consumption mode register) (watch mode is selected when TMD $=0$ )
MCM: MCM bit (clock selection register) (PLL clock is in use when MCM = 0)
SCM: SCM bit (clock selection register) (sub-clock is in use when SCM =0)
SCD: Sub-clock oscillation stopped (sub-clock oscillation is stopped when SCD = 1)
MCD: Main clock oscillation stopped (main clock oscillation is stopped when MCD =1)
PCD: PLL clock oscillation stopped (PLL clock oscillation is stopped when PCD =1)

Table 6.4.9a List of Transition Conditions

| State before transition | Transition conditions | State after transition |
| :---: | :---: | :---: |
| Power on | 01 Main oscillation stabilization waiting period completed | Main mode |
| Main oscillation stabilization | 05 Main oscillation stabilization waiting period completed | Main mode |
| Main mode | 06 SCS $=0$ written | MS transition mode |
|  | $07 \mathrm{SCS}=1 \cdot \mathrm{MCS}=0$ written | MP transition mode |
|  | 31 TMD $=1 \cdot$ STP $=0 \cdot \mathrm{SLP}=1$ written | Main sleep |
|  | 32 TMD $=0$ written | Main watch transition |
|  | $33 \mathrm{TMD}=1 \cdot \mathrm{STP}=1$ written | Main stop |
| PLL mode | 21 SCS $=0$ written | PS transition mode |
|  | 20 SCS $=1 \cdot$ MCS $=1$ written | PM transition mode |
|  | 59 TMD $=1 \cdot$ STP $=0 \cdot$ SLP $=1$ written | PLL sleep |
|  | $58 \mathrm{TMD}=0$ written | PLL watch transition P |
|  | $57 \mathrm{TMD}=1 \cdot$ STP $=1$ written | Pseudo-watch transition |
| Sub mode | 10 SCS $=1 \cdot \mathrm{MCS}=1$ written | SM transition mode |
|  | $12 \mathrm{SCS}=1 \cdot \mathrm{MCS}=0$ written | SP transition mode |
|  | 11 Reset initiated | Main oscillation stabilization |
|  | $42 \mathrm{TMD}=1 \cdot \mathrm{STP}=0 \cdot \mathrm{SLP}=1$ written | Sub-sleep |
|  | $43 \mathrm{TMD}=0$ written | Sub-watch |
|  | $44 \mathrm{TMD}=1 \cdot \mathrm{STP}=1$ written | Sub-stop |
| PM transition mode | 13 PLL $\rightarrow$ main switching timing wait completed | Main mode |
|  | 38 TMD $=1 \cdot$ STP $=0 \cdot$ SLP $=1$ written | PM transition sleep |
|  | 39 TMD $=0$ written and $\begin{gathered}\text { PLL } \rightarrow \text { main switching timing wait } \\ \text { completed }\end{gathered}$ | Main watch transition |
|  | 40 TMD $=1$ and STP $=1$ written and PLL $\rightarrow$ main switch- | Main stop |

Table 6.4.9a List of Transition Conditions (Continued)

| State before transition | Transition conditions | State after transition |
| :---: | :---: | :---: |
| SM transition mode | 02 Main oscillation stabilization waiting period completed | Main mode |
|  | 03 Reset initiated or interrupt | Main oscillation stabilization |
|  | 04 SCS $=0$ written | Sub mode |
|  | $27 \mathrm{TMD}=1 \cdot \mathrm{STP}=0 \cdot \mathrm{SLP}=1$ written | SM transition sleep |
|  | 28 TMD $=0$ and main oscillation stabilization waiting period completed | Main watch |
|  | 29 TMD $=1$ and STP = 1 written and main oscillation stabilization waiting period completed | Main stop |
| MP transition mode | 16 PLL oscillation stabilization waiting period completed | PLL mode |
|  | $14 \mathrm{SCS}=1 \bullet$ MCS $=1$ written | Main mode |
|  | 15 SCS $=0$ written | MS transition mode |
|  | $68 \mathrm{TMD}=1 \cdot \mathrm{STP}=0 \cdot \mathrm{SLP}=1 \mathrm{written}$ | MP transition sleep |
|  | 70 TMD $=0$ written | PLL watch transition M |
|  | 69 TMD $=1 \cdot$ STP=1 written | Pseudo-watch mode |
| SP transition mode | 17 Main oscillation stabilization waiting period completed | MP transition mode |
|  | 18 MCS $=1$ written | SM transition mode |
|  | 19 Reset initiated | Main oscillation stabilization |
|  | $75 \mathrm{TMD}=1 \cdot \mathrm{STP}=0 \cdot \mathrm{SLP}=1 \mathrm{written}$ | SP transition sleep |
|  | 76 TMD $=0$ written | PLL watch |
|  | 78 TMD $=1$ and STP $=1$ written and main oscillation stabilization waiting period completed | Pseudo-watch mode |
| MS transition mode | 09 Main $\rightarrow$ sub-clock switching timing wait completed | Sub mode |
|  | 08 Reset initiated | Main mode |
|  | $51 \mathrm{TMD}=1 \cdot \mathrm{STP}=0 \cdot \mathrm{SLP}=1$ written | MS transition sleep |
|  | 52 TMD $=0$ written and main $\rightarrow$ sub switching wait completed | Sub watch |
|  | 53 TMD $=1$ and STP $=1$ written and main $\rightarrow$ sub switching wait completed | Sub mode |
| PS transition mode | 23 PLL $\rightarrow$ main clock switching timing wait completed | MS transition mode |
|  | 22 SCS = 1 written | PM transition mode |
|  | $56 \mathrm{TMD}=1 \cdot \mathrm{STP}=0 \cdot \mathrm{SLP}=1$ written | PS transition sleep |
| Main sleep | 26 Interrupt or reset initiated | Main mode |
| SM transition sleep | 24 Main oscillation stabilization waiting period completed | Main sleep |
|  | 25 Interrupt or reset initiated | SM transition mode |
| PM transition sleep | 34 PLL $\rightarrow$ main clock switching timing wait completed | Main sleep |
|  | 35 Interrupt or reset initiated | PM transition mode |
| PLL sleep | 63 Interrupt or reset initiated | PLL mode |
| MP transition sleep | 66 PLL oscillation stabilization waiting period completed | PLL sleep |
|  | 67 Interrupt or reset initiated | MP transition mode |
| SP transition sleep | 73 Main oscillation stabilization waiting period completed | MP transition sleep |
|  | 74 Interrupt or reset initiated | SP transition mode |
| Sub-sleep | 46 Interrupt or reset initiated | Sub mode |

Table 6.4.9a List of Transition Conditions (Continued)

| State before transition | Transition conditions | State after transition |
| :---: | :---: | :---: |
| MS transition sleep | 49 Main $\rightarrow$ sub-clock switching timing wait completed | Sub-sleep |
|  | 50 Interrupt or reset initiated | MS transition mode |
| PS transition sleep | 54 PLL $\rightarrow$ main clock switching timing wait completed | MS transition sleep |
|  | 55 Interrupt or reset initiated | PS transition mode |
| Main watch | 30 Interrupt or reset initiated | SM transition mode |
| Main watch transition | 36 Main $\rightarrow$ sub-clock switching timing wait completed | Main watch |
|  | 37 Interrupt or reset initiated | Main mode |
| PLL watch | 77 Interrupt or reset initiated | SP transition mode |
| PLL watch transition M | 72 Main $\rightarrow$ sub-clock switching timing wait completed | PLL watch |
|  | 71 Interrupt or reset initiated | MP transition mode |
| PLL watch transition P | 65 PLL $\rightarrow$ main clock switching timing wait completed | PLL watch transition M |
|  | 64 Interrupt or reset initiated | PLL mode |
| Sub watch | 47 Interrupt or reset initiated | Sub mode |
| Main stop | 41 Interrupt or reset initiated | Main oscillation stabilization |
| Pseudo-watch | 62 Interrupt or reset initiated | MP transition mode |
| Pseudo-watch transition | 61 PLL $\rightarrow$ main clock switching timing wait completed | Pseudo-watch mode |
|  | 60 Interrupt or reset initiated | PLL mode |
| Sub stop | 48 Interrupt | Sub oscillation stabilization |
|  | 79 Reset initiated | Main oscillation stabilization |
| Sub oscillation stabilization | 45 Subclock oscillation stabilization waiting period completed | Sub mode |
|  | 80 Reset initiated | Main oscillation stabilization |

State Transition Diagrams


Figure 6.4.9a Low Power Consumption Mode Transition Diagram A


Figure 6.4.9b Low Power Consumption Mode Transition Diagram B


Figure 6.4.9c Low Power Consumption Mode Transition Diagram C


Figure 6.4.9d Low Power Consumption Mode Transition Diagram D

## Chapter 7: <br> Interrupt

### 7.1 Outline

The $\mathrm{F}^{2} \mathrm{MC}$-16LX has interrupt functions that terminate the currently executing processing and transfer control to another specified program when a specified event occurs. There are four types of interrupt functions:

- Hardware interrupt:

Interrupt processing due to an internal resource event

- Software interrupt: Interrupt processing due to a software event occurrence instruction
- Extended intelligent $\mathrm{I} / \mathrm{O}$ service ( $\mathrm{E} \mathrm{I}^{2} \mathrm{OS}$ ):... Transfer processing due to an internal resource event
- Exception:

Termination due to an operation exception

### 7.2 Causes of Interrupt

Table 7.2a Interrupt causes, interrupt vectors, and interrupt control registers

| Interrupt cause | $\begin{aligned} & \text { IIOS } \\ & \text { clear } \end{aligned}$ | Interrupt vector |  | Interrupt control register |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Number | Address | Number | Address |
| Reset | $\times$ | \# 08 | FFFFDC $_{\mathrm{H}}$ | - | - |
| INT9 instruction | $\times$ | \# 09 | FFFFD8 ${ }_{\text {H }}$ | - | - |
| Exception | $\times$ | \# 10 | FFFFD4 ${ }_{\text {H }}$ | - | - |
| A/D converter | $\bigcirc$ | \# 11 | FFFFFD0 $_{\text {H }}$ | ICR00 | $0^{0000 B 0}{ }_{H}$ |
| Time base Timer | $\times$ | \# 12 | $\mathrm{FFFFCCC}_{\mathrm{H}}$ |  |  |
| DTP0 (external 0) / UART3 reception completion | $\bigcirc$ | \# 13 | FFFFC8 ${ }_{\text {H }}$ | ICR01 | $0000 \mathrm{~B} 1_{\mathrm{H}}$ |
| DTP1 (external 1) / UART4 reception completion | $\bigcirc$ | \# 14 | FFFFC4 ${ }_{\text {H }}$ |  |  |
| DTP2 (external 2) / UART3 transmission completion | $\bigcirc$ | \# 15 | $\mathrm{FFFFFC}_{\mathrm{H}}$ | ICR02 | $0000 \mathrm{~B} 2_{\mathrm{H}}$ |
| DTP3 (external 3) / UART4 transmission completion | $\bigcirc$ | \# 16 | FFFFBC $_{\text {H }}$ |  |  |
| DTP4-7 (external 4-7) | $\bigcirc$ | \# 17 | FFFFB8 ${ }_{\text {H }}$ | ICR03 | $0^{0000 B 3}{ }_{H}$ |
| Output compare (channel 1) | $\bigcirc$ | \# 18 | FFFFB4 ${ }_{\text {H }}$ |  |  |
| UART2 reception completion | $\bigcirc$ | \# 19 | $\mathrm{FFFFBO}_{\mathrm{H}}$ | ICR04 | $0000 \mathrm{~B} 4_{\mathrm{H}}$ |
| UART1 reception completion | $\bigcirc$ | \# 20 | $\mathrm{FFFFAC}_{\mathrm{H}}$ |  |  |
| Input capture (channel 3) | $\bigcirc$ | \# 21 | FFFFA88 $_{\text {H }}$ | ICR05 | $0^{0000 B 5}{ }_{H}$ |
| Input capture (channel 2) | $\bigcirc$ | \# 22 | FFFFA4 $_{\text {H }}$ |  |  |
| Input capture (channel 1) | $\bigcirc$ | \# 23 | $\mathrm{FFFFAO}_{\mathrm{H}}$ | ICR06 | $0^{0000 B 6}{ }_{\text {H }}$ |
| Input capture (channel 0) | $\bigcirc$ | \# 24 | FFFFF9C $_{\mathrm{H}}$ |  |  |
| 8/16-bit PPG0 counter borrow | $\times$ | \# 25 | FFFF98 $_{\text {H }}$ | ICR07 | $0000 \mathrm{~B}_{\mathrm{H}}$ |
| 16-bit reload timer 2-0 | $\bigcirc$ | \# 26 | FFFF94 ${ }_{\text {H }}$ |  |  |
| Time prescalar | $\times$ | \# 27 | $\mathrm{FFFF9}^{\text {H }}$ H | ICR08 | $0000 \mathrm{B8}{ }_{\mathrm{H}}$ |
| Output Compare (channel 0) | $\bigcirc$ | \# 28 | FFFF88 ${ }_{\text {H }}$ |  |  |
| UART2 transmission completion | $\bigcirc$ | \# 29 | FFFF88 $_{\text {H }}$ | ICR09 | $0000 \mathrm{B9}{ }_{\mathrm{H}}$ |
| PWC timer | $\bigcirc$ | \# 30 | FFFF84 ${ }_{\text {H }}$ |  |  |
| UART1 transmission completion | $\bigcirc$ | \# 31 | ${\mathrm{FFFF} 80_{\mathrm{H}} \text { }}^{\text {d }}$ | ICR10 | $0^{0000 B A}{ }_{H}$ |
| 16-bit free run timer overflow | $\bigcirc$ | \# 32 | FFFF7C ${ }_{\text {H }}$ |  |  |
| UART0 transmission completion | $\bigcirc$ | \# 33 | FFFFF78 $_{\text {H }}$ | ICR11 | $0000 B^{\text {H }}$ |
| 8/16-bit PPG1 counter borrow | $\times$ | \# 34 | FFFF74 ${ }_{\text {H }}$ |  |  |
| IEBus reception completion | (0) | \# 35 | $\mathrm{FFFF} \mathrm{FO}_{\mathrm{H}}$ | ICR12 | $0000 \mathrm{BC}_{\mathrm{H}}$ |
| IEBus transmission completion | (0) | \# 37 | FFFF68 ${ }_{\text {H }}$ | ICR13 | $0000 \mathrm{BD}_{\mathrm{H}}$ |
| UART0 reception completion | - | \# 39 | FFFF60 $_{\text {H }}$ | ICR14 | $0^{0000 B E}{ }_{H}$ |
| Reserved | $\times$ | \# 41 | FFFF58 ${ }_{\text {H }}$ | ICR15 | $0^{0000 B F}{ }_{H}$ |
| Delayed interrupt | $\times$ | \# 42 | FFFF54 ${ }_{\text {H }}$ |  |  |

O : The interrupt request flag is cleared by the IIOS interrupt clear signal.
© : The interrupt request flag is cleared by the IIOS interrupt clear signal. A stop request is available.
$\times$ : The interrupt request flag is not cleared by the IIOS interrupt clear signal.
Note: For a resource with two interrupt causes for a single interrupt number, both interrupt request flags are cleared by the IIOS interrupt clear signal.

## 7．3 Interrupt Vector

Table 7．3a MB90580 interrupt assignment table（1／2）

| Software interrupt instruction | Vector address L | Vector address M | Vector address H | Mode register | Interrupt No． | Hardware interrupt |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INT 0 | FFFFFFC $_{\text {H }}$ | FFFFFD $_{\mathrm{H}}$ | FFFFFE $_{\mathrm{H}}$ | Unused | \＃0 | None |
| 幺 | ： | 幺 | 幺 | ！ | ： | ： |
| INT 7 | $\mathrm{FFFFFE}_{\mathrm{H}}$ | $\mathrm{FFFFE}^{\text {H }}$ H | FFFFE2 $_{\text {H }}$ | Unused | \＃7 | None |
| INT 8 | $\mathrm{FFFFDC}_{\mathrm{H}}$ | FFFFDD ${ }_{\mathrm{H}}$ | FFFFDE $_{\mathrm{H}}$ | FFFFDF | \＃8 | （RESET vector） |
| INT 9 | FFFFD8 $_{\mathrm{H}}$ | FFFFD9 ${ }_{\text {H }}$ | FFFFDA $_{\mathrm{H}}$ | Unused | \＃9 | None |
| INT 10 | FFFFDD $_{\mathrm{H}}$ | FFFFD5 $_{\text {H }}$ | FFFFD6 $_{\mathrm{H}}$ | Unused | \＃10 | ＜Exception＞ |
| INT 11 | $\mathrm{FFFFFDO}_{\mathrm{H}}$ | FFFFD1 ${ }_{\text {H }}$ | FFFFD2 $_{\text {H }}$ | Unused | \＃11 | A／D |
| INT 12 | $\mathrm{FFFFCC}_{\mathrm{H}}$ | FFFFCD ${ }_{\text {H }}$ | $\mathrm{FFFFCE}_{\mathrm{H}}$ | Unused | \＃12 | Time base Timer |
| INT 13 | FFFFC8 $_{\text {H }}$ | $\mathrm{FFFFC}^{\text {H }}$ H | $\mathrm{FFFFCA}_{\mathrm{H}}$ | Unused | \＃13 | DTP0（External interrupt \＃0）／ UART3 reception completion |
| INT 14 | FFFFC4 ${ }_{\text {H }}$ | $\mathrm{FFFFC}^{\text {H }}$ | FFFFC6 $_{\text {H }}$ | Unused | \＃14 | DTP1（External interrupt \＃1）／ <br> UART4 reception completion |
| INT 15 | $\mathrm{FFFFFCO}_{\mathrm{H}}$ | FFFFC1 ${ }_{\text {H }}$ | $\mathrm{FFFFC}^{\text {H }}$ | Unused | \＃15 | DTP2（External interrupt \＃2）／ UART3 transmission completion |
| INT 16 | $\mathrm{FFFFBC}_{\mathrm{H}}$ | $\mathrm{FFFFBD}_{\mathrm{H}}$ | $\mathrm{FFFFBE}_{\mathrm{H}}$ | Unused | \＃16 | DTP3（External interrupt \＃3）／ UART4 transmission completion |
| INT 17 | FFFFB8 ${ }_{\text {H }}$ | $\mathrm{FFFFB}^{\text {H }}$ H | FFFFBA $_{\text {H }}$ | Unused | \＃17 | DTP4－7（External interrupt \＃4－\＃7） |
| INT 18 | FFFFB34 $_{\text {H }}$ | $\mathrm{FFFFB}^{\text {H }}$ | FFFFB6 ${ }_{\text {H }}$ | Unused | \＃18 | Output compare（channel 1） |
| INT 19 | $\mathrm{FFFFBO}_{\mathrm{H}}$ | FFFFB1 ${ }_{\text {H }}$ | FFFFB2 $_{\text {H }}$ | Unused | \＃19 | UART2 reception completion |
| INT 20 | FFFFAC $_{\mathrm{H}}$ | $\mathrm{FFFFAD}_{\mathrm{H}}$ | FFFFAE $_{\text {H }}$ | Unused | \＃20 | UART1 reception completion |
| INT 21 | FFFFA8 $_{\mathrm{H}}$ | $\mathrm{FFFFA}^{\text {H }}$ H | FFFFAA $_{\text {H }}$ | Unused | \＃21 | Input capture（channel 3） |
| INT 22 | FFFFA4 $_{\mathrm{H}}$ | FFFFA5 $_{\mathrm{H}}$ | FFFFA6 $_{\mathrm{H}}$ | Unused | \＃22 | Input capture（channel 2） |
| INT 23 | $\mathrm{FFFFAO}_{\mathrm{H}}$ | FFFFA1 $_{\text {H }}$ | FFFFA2 $_{\text {H }}$ | Unused | \＃23 | Input capture（channel 1） |
| INT 24 | FFFF9C $_{\mathrm{H}}$ | $\mathrm{FFFF}^{\text {a }}$ H | FFFF9E $_{\text {H }}$ | Unused | \＃24 | Input capture（channel 0） |
| INT 25 | $\mathrm{FFFFF98}_{\mathrm{H}}$ | FFFF999 ${ }_{\text {H }}$ | FFFF9A $_{\text {H }}$ | Unused | \＃25 | 8／16－bit PPG0 counter borrow |
| INT 26 | $\mathrm{FFFFF94}_{\mathrm{H}}$ | FFFFF95 $_{\text {H }}$ | FFFF96 $_{\text {H }}$ | Unused | \＃26 | 16－bit reload timer 2－0 |
| INT 27 | $\mathrm{FFFFF90}_{\mathrm{H}}$ | FFFF91 ${ }_{\text {H }}$ | FFFF92 $_{\text {H }}$ | Unused | \＃27 | Time prescalar |
| INT 28 | $\mathrm{FFFF}^{\text {C }}$ H | FFFF8D $_{\text {H }}$ | FFFF8E $_{\text {H }}$ | Unused | \＃28 | Output compare（channel 0） |
| INT 29 | $\mathrm{FFFFF88}_{\mathrm{H}}$ | FFFF89 $_{\text {H }}$ | $\mathrm{FFFFP}^{\text {A }}$ H | Unused | \＃29 | UART2 transmission completion |
| INT 30 | $\mathrm{FFFFF}^{4}{ }_{\mathrm{H}}$ | FFFF85 ${ }_{\text {H }}$ | FFFF86 ${ }_{\mathrm{H}}$ | Unused | \＃30 | PWC timer |
| INT 31 | $\mathrm{FFFFF80}_{\mathrm{H}}$ | FFFF81 ${ }_{\text {H }}$ | FFFF82 ${ }_{\mathrm{H}}$ | Unused | \＃31 | UART1 transmission completion |
| INT 32 | FFFF7C $_{\mathrm{H}}$ | $\mathrm{FFFF}^{\text {（ }}$ H | FFFF7E $_{\text {H }}$ | Unused | \＃32 | 16－bit free run timer overflow |
| INT 33 | FFFFF78 $_{\text {H }}$ | FFFF79 ${ }_{\text {H }}$ | FFFF7A $_{\text {H }}$ | Unused | \＃33 | UARTO transmission completion |
| INT 34 | FFFFF74 ${ }_{\text {H }}$ | FFFF75 ${ }_{\text {H }}$ | FFFF76 ${ }_{\text {H }}$ | Unused | \＃34 | 8／16 bit PPG 1 counter borrow |
| INT 35 | FFFFF70 ${ }_{\text {H }}$ | FFFF71 ${ }_{\text {H }}$ | FFFF72 ${ }_{\text {H }}$ | Unused | \＃35 | IEBus reception completion |
| INT 36 | FFFF6C $_{\mathrm{H}}$ | FFFF6D ${ }_{\text {H }}$ | FFFF6E $_{\text {H }}$ | Unused | \＃36 | None |
| INT 37 | FFFF68 $_{\text {H }}$ | FFFF69 $_{\text {H }}$ | FFFF6A $_{\mathrm{H}}$ | Unused | \＃37 | IEBus transmission completion |
| INT 38 | FFFF64 ${ }_{\text {H }}$ | FFFF65 $_{\text {H }}$ | FFFF66 ${ }_{\text {H }}$ | Unused | \＃38 | None |
| INT 39 | $\mathrm{FFFFF60}_{\mathrm{H}}$ | FFFF61 ${ }_{\text {H }}$ | FFFF62 ${ }_{\text {H }}$ | Unused | \＃39 | UART0 reception completion |
| INT 40 | FFFF5C $_{\text {H }}$ | $\mathrm{FFFF}^{\text {H }}$ | FFFF5E $_{\text {H }}$ | Unused | \＃40 | None |
| INT 41 | $\mathrm{FFFFF58}_{\mathrm{H}}$ | FFFF59 $_{\text {H }}$ | FFFF5 A $_{\mathrm{H}}$ | Unused | \＃41 | （RESERVED） |
| INT 42 | $\mathrm{FFFFF54}_{\mathrm{H}}$ | FFFF55 $_{\text {H }}$ | FFFF56 ${ }_{\text {H }}$ | Unused | \＃42 | Delayed interrupt |

### 7.4 Hardware Interrupt

### 7.4.1 Overview

In response to an interrupt request signal from an internal resource, the CPU pauses current program execution and transfers control to the interrupt processing program defined by the user. This function is called the hardware interrupt function. A hardware interrupt occurs when relevant conditions are satisfied as a result of two operations: comparison between the interrupt request level and the value in the interrupt level mask register of PS of the CPU, and hardware reference to the I flag value in PS. The CPU performs the following processing when a hardware interrupt occurs:

Saves the values in the PC, PS, AH, AL, PCB, DTB, ADB, and DPR registers of the CPU to the system stack.
$\Delta$ Sets ILM in the PS register. The currently requested interrupt level is automatically set.
$\Delta$ Fetches the corresponding interrupt vector value and branches to the processing indicated by that value.

### 7.4.2 Structure

Hardware interrupts are handled by the following three sections:

$$
\begin{aligned}
& \text { Internal resources ...................Interrupt enable and request bits: Used to control interrupt requests } \\
& \text { from resources. } \\
& \text { Interrupt controller...................ICR:Assigns interrupt levels and determines the priority } \\
& \text { levels of simultaneously requested interrupts. } \\
& \text { CPU ...................................... I and ILM:Used to compare the requested and current interrupt } \\
& \text { levelsand to identify the interrupt enable status. } \\
& \text { Microcode:Interrupt processing step }
\end{aligned}
$$

The status of these sections are indicated by the resource control registers for internal resources, the ICR for the interrupt controller, and the CCR value for the CPU. To use a hardware interrupt, set the three sections beforehand by using software.
The interrupt vector table referenced during interrupt processing is assigned to addresses $\mathrm{FFFC}_{\mathrm{H}}$ to FFFFFF $_{H}$ in memory. These addresses are shared with software interrupts.

### 7.4.3 Operation

An internal resource that has the hardware interrupt request function has an interrupt request flag and interrupt enable flag. The interrupt request flag indicates whether an interrupt request exists, and the interrupt enable flag indicates whether the relevant internal resource requests an interrupt to the CPU. The interrupt request flag is set when an event occurs that is unique to the internal resource. When the interrupt enable flag indicates "enable," the resource issues an interrupt request to the interrupt controller.
When two or more interrupt requests are received at the same time, the interrupt controller compares the interrupt levels (IL) in ICR, selects the request at the highest level (the smallest IL value), then reports that request to the CPU. If multiple requests are at the same level, the interrupt controller selects the request with the lowest interrupt number. The relationship between the interrupt requests and ICRs is determined by the hardware.
The CPU compares the received interrupt level and the ILM in the PS register. If the interrupt level is smaller than the ILM value and the I bit of the PS register is set to 1 , the CPU activates the interrupt processing microcode after the currently executing instruction is completed. The CPU references the ISE bit of the ICR of the interrupt controller at the beginning of the interrupt processing microcode, checks that the ISE bit is 0 (interrupt), and activates the interrupt processing body.
The interrupt processing body saves 12 bytes (PS, PC, PCB, DTB, ADB, DPR, and A) to the memory area indicated by SSB and SSP, fetches three bytes of interrupt vector and loads them onto PC and PCB,
updates the ILM of PS to a level value of the received interrupt, sets the $S$ flag, then performs branch processing. As a result, the interrupt processing program defined by the user is executed next.
Figure 7.4.3a illustrates the flow from the occurrence of a hardware interrupt until there is no interrupt request in the interrupt processing program. Figure 7.4.3b is a diagram of the hardware interrupt operation flow.


Figure 7.4.3a Occurrence and release of hardware interrupt
(1) An interrupt cause occurs in a peripheral.
(2) The interrupt enable bit in the peripheral is referenced. If interrupts are enabled, the peripheral issues an interrupt request to the interrupt controller.
(3) Upon reception of the interrupt request, the interrupt controller determines the priority levels of simultaneously requested interrupts. Then, the interrupt controller transfers the interrupt level of the corresponding interrupt to the CPU.
(4) The CPU compares the interrupt level requested by the interrupt controller with the ILM bit of the processor status register.
(5) If the comparison shows that the requested level is higher than the current interrupt processing level, the I flag value of the same processor status register is checked.
(6) If the check in step (5) shows that the I flag indicates interrupt enable status, the requested level is written to the ILM bit. Interrupt processing is performed as soon as the currently executing instruction is completed, then control is transferred to the interrupt processing routine.
(7)When the interrupt cause of step (1) is cleared by software in the user interrupt processing routine, the interrupt request is completed.

The time required for the CPU to execute the interrupt processing in steps (6) and (7) is shown below.
Interrupt start : $24+6 \times$ Table 7.4.3a machine cycles
Interrupt return : $15+6 \times$ Table 7.4.3a machine cycles (RETI instruction)
Table 7.4.3a Compensation values for interrupt processing cycle count

| Address indicated by the stack pointer | Cycle count compensation value |
| :--- | :---: |
| External area, 8-bit data bus | +4 |
| External area, even-numbered address | +1 |
| External area, odd-numbered address | +4 |
| Internal area, even-numbered address | 0 |
| Internal area, odd-numbered address | +2 |



Figure 7.4.3b Hardware interrupt operation flow

### 7.4.4 Hardware Interrupt Ocurrence When Internal Resource Is Being Accessed

When internal I/O area is being asscessed, the CPU will not response to hardware interrupt immediately, there will be one instruction delay. Please refer to Chapter 2, section 2.1.3 for details.

### 7.4.5 Interrupt Inhibit Instruction

If $F^{2} M C-16 L X$ is executing interrupt inhibit instructions, the CPU will not response to hardware interrupt request immediately, there will be one instruction delay. Please refer to Chapter 2, section 2.1.3 for details.

### 7.4.6 Multiple Interrupts

The $\mathrm{F}^{2} \mathrm{MC}$-16LX CPU supports multiple interrupts. If an interrupt of a higher level occurs while another interrupt is being processed, control is transferred to the high-level interrupt after the currently executing instruction is completed. After processing of the high-level interrupt is completed, the original interrupt processing is resumed. An interrupt of the same or lower level may be generated while another interrupt is being processed. If this happens, the new interrupt request is suspended until the current interrupt processing is completed, unless the ILM value or I flag is changed by an instruction. The extended intelligent I/O service cannot be activated from multiple sources; while an extended intelligent I/O service is being processed, all other interrupt requests or extended intelligent I/O service requests are suspended.

### 7.4.7 Register Saving In Stack Upon Interrupt



Figure 7.4.7a Registers saved in stack

### 7.4.8 Precaution in Using Hardware Interrupt

When there is an hardware interrupt, the interrupt request flag should be cleared before leaving the corresponding interrupt routine to avoid malfunction.
Some of the resources' interrupt request flag will be cleared automatically when certain register(s) is(are) read. In this case, please read those registers to clear the interrupt request flag before leaving the interrupt routine.

### 7.5 Software Interrupt

### 7.5.1 Overview

In response to execution of a special instruction, control is transferred from the program currently executed by the CPU to the interrupt processing program defined by the user. This is called the software interrupt function. A software interrupt occurs always when the software interrupt instruction is executed. The CPU performs the following processing when a software interrupt occurs:
$>$ Saves the values in the PC, PS, AH, AL, PCB, DTB, ADB, and DPR registers of the CPU to the system stack.
$>$ Sets I in the PS register. Interrupts are automatically disabled.
$\triangle$ Fetches the corresponding interrupt vector value, then branches to the processing indicated by that value.

A software interrupt request issued by the INT instruction has no interrupt request or enable flag. A software interrupt request is always issued by executing the INT instruction.
The INT instruction does not have an interrupt level. Therefore, the INT instruction does not update ILM. The INT instruction clears the I flag to suspend subsequent interrupt requests.

### 7.5.2 Structure

Software interrupts are handled within the CPU:
$\triangle \mathrm{CPU}$
Microcode: Interrupt processing step

As shown in Table 7.3a, software interrupts share the same interrupt vector area with hardware interrupts. For example, interrupt request number INT 13 is used for external interrupt \#0 of a hardware interrupt as well as for INT \#13 of a software interrupt. Therefore, external interrupt \#0 and INT \#13 call the same interrupt processing routine.

### 7.5.3 Operation

When the CPU fetches and executes the software interrupt instruction, the software interrupt processing microcode is activated. The software interrupt processing microcode saves 12 bytes (PS, PC, PCB, DTB, ADB, DPR, and A) to the memory area indicated by SSB and SSP. The microcode then fetches three bytes of interrupt vector and loads them onto PC and PCB, resets the I flag, and sets the S flag. Then, the microcode performs branch processing. As a result, the interrupt processing program defined by the user application program is executed next.

Figure 7.5.3a illustrates the flow from the occurrence of a software interrupt until there is no interrupt request in the interrupt processing program.


Figure 7.5.3a Occurrence and release of software interrupt
(1) The software interrupt instruction is executed.
(2) Special CPU registers in the register file are saved according to the microcode corresponding to the software interrupt instruction.
(3)The interrupt processing is completed with the RETI instruction in the user interrupt processing routine.

### 7.5.4 Others

When the program bank register (PCB) is FFH, the CALLV instruction vector area overlaps the table of the INT \#vct8 instruction. When designing software, ensure that the CALLV instruction does not use the same address as that of the \#vct8 instruction.

### 7.6 Extended intelligent $I / O$ service ( $E I^{2} O S$ )

### 7.6.1 Overview

$\mathrm{El}^{2} \mathrm{OS}$ is a type of hardware interrupt operation that automatically transfers data between I/O and memory. Conventionally, data is transferred between I/O and memory by an interrupt processing program. $\mathrm{El}^{2} \mathrm{OS}$, however, enables data to be transferred as if in DMA mode. $\mathrm{EI}^{2} \mathrm{OS}$ has the following advantages over the conventional interrupt processing method:
$\Delta$ Writing a transfer program is unnecessary, thus the entire program size can be small.
$\triangle$ No internal register is used for transfer. Therefore, saving the register values is unnecessary, resulting in a higher transfer speed.

I/O can stop transfer at any time. Therefore, unnecessary data is not transferred.
$\triangle$ The buffer address can be incremented, decremented, or left unupdated.
The I/O address can be incremented, decremented, or left unupdated (when the buffer address is updated).
At the end of $\mathrm{EI}^{2} \mathrm{OS}$ processing, the CPU automatically branches to the interrupt processing routine after setting the end condition. Therefore, the user can identify the end condition type.
Figure 7.6.1a outlines the $\mathrm{El}^{2} \mathrm{OS}$.


Figure 7.6.1a Outline of extended intelligent I/O service
Note: Notes:The area that can be specified by IOA is between $000000_{\mathrm{H}}$ and 00 FFFF ${ }_{\mathrm{H}}$. The area that can be specified by BAP is between $000000_{H}$ and FFFFFF $_{H}$. The maximum transfer count that can be specified by DCT is 65,536 .

### 7.6.2 Structure

$\mathrm{El}^{2} \mathrm{OS}$ is handled by the following four sections:
$\triangle$ Internal resources ................. Interrupt enable and request bits: Used to control interrupt requests
from resources.
ICR:Assigns interrupt levels, determines the priority levels
of simultaneously requested interrupts, and selects the
$\mathrm{EI}^{2} \mathrm{OS}$ operation.

Each register is described below.
(1) Interrupt control register (ICR)

The interrupt control register is in the interrupt controller. This register corresponds to I/Os that have the interrupt function. This register has the following three functions:
$\triangle$ Sets the interrupt level of the corresponding peripheral.
$\triangle$ Selects whether to handle the interrupt of the corresponding peripheral as an ordinary interrupt or as an extended intelligent I/O service.

Selects the extended intelligent I/O service channel.

Do not access this register by a read-modify-write instruction, as doing so causes misoperation. Interrupt control register (ICR)

|  | 15/7 | 14/6 | 13/5 | 12/4 | 11/3 | 10/2 | 9/1 | 8/0 | Bit number <br> when written |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : $\mathrm{BO}_{\mathrm{H}}-\mathrm{BF}_{\mathrm{H}}$ | ICS3 | ICS2 | ICS1 | ICS0 | ISE | IL2 | IL1 | ILO |  |
| Read/write $\Rightarrow$ Initial value $\Rightarrow$ | (W) <br> (0) | (W) <br> (0) | $\begin{aligned} & \text { (W) } \\ & (0) \end{aligned}$ | $\begin{aligned} & (W) \\ & (0) \end{aligned}$ | (W) | (W) | (W) | (W) |  |
|  | 15/7 | 14/6 | 13/5 | 12/4 | 11/3 | 10/2 | 9/1 | 8/0 | マ Bit number |
| Address : $\mathrm{BO}_{\mathrm{H}}-\mathrm{BF}_{\mathrm{H}}$ | - | - | S1 | S0 | ISE | IL2 | IL1 | ILO | when read |


| Read/write $\Rightarrow$ | $(-)$ | $(-)$ | $(\mathrm{R})$ | $(\mathrm{R})$ | $(\mathrm{R})$ | $(\mathrm{R})$ | $(\mathrm{R})$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Initial value $\Rightarrow$ | $(\mathrm{X})$ | $(\mathrm{X})$ | $(0)$ | $(0)$ | $0)$ | $(1)$ | $(1)$ |

Note: - ICS3 to ICSO are valid only when $\mathrm{EI}^{2} \mathrm{OS}$ is activated. Set ISE to ' 1 ' to activate $\mathrm{El}^{2} \mathrm{OS}$, and to ' 0 ' not to activate it. When EI2OS is not to be activated, any value can be written to ICS3 to ICS0.

* ' 1 ' is always read.
- ICS1 and ICS0 are valid for write only. S1 and S0 are valid for read only.
[bits 15 to 12] or [bits 7 to 4] ICS3 to ICS0
These bits are used to select the $\mathrm{EI}^{2} \mathrm{OS}$ channel. These bits are write-only. The value specified in these bits determines the address of the extended intelligent I/O service descriptor in memory, which is explained later. ICS is initialized upon a reset.
Table 7.6.2a shows the correspondence between ICS, channel numbers, and descriptor addresses.
Table 7.6.2a ICS bits, channel numbers, and descriptor addresses

| ICS3 | ICS2 | ICS1 | ICS0 | Selected channel | Descriptor address |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | $000100_{\mathrm{H}}$ |
| 0 | 0 | 0 | 1 | 1 | $000108_{\mathrm{H}}$ |
| 0 | 0 | 1 | 0 | 2 | $000110_{\mathrm{H}}$ |
| 0 | 0 | 1 | 1 | 3 | $000118_{\mathrm{H}}$ |
| 0 | 1 | 0 | 0 | 4 | $000120_{\mathrm{H}}$ |
| 0 | 1 | 0 | 1 | 5 | $000128_{\mathrm{H}}$ |
| 0 | 1 | 1 | 0 | 6 | $000130_{\mathrm{H}}$ |
| 0 | 1 | 1 | 1 | 7 | $000138_{\mathrm{H}}$ |
| 1 | 0 | 0 | 0 | 8 | $000140_{\mathrm{H}}$ |
| 1 | 0 | 0 | 1 | 0 | $000148_{\mathrm{H}}$ |
| 1 | 0 | 1 | 0 | 10 | $000150_{\mathrm{H}}$ |
| 1 | 0 | 1 | 1 | $000158_{\mathrm{H}}$ |  |
| 1 | 1 | 0 | 0 | 11 | $000160_{\mathrm{H}}$ |
| 1 | 1 | 0 | 1 | $000168_{\mathrm{H}}$ |  |
| 1 | 1 | 1 | 0 | 13 | $000170_{\mathrm{H}}$ |
| 1 | 1 | 1 | 1 | 15 | $000178_{\mathrm{H}}$ |

[bits 13 and 12] or [bits 5 and 4] S0 and S1
These are $\mathrm{EI}^{2} \mathrm{OS}$ end status bits. These bits are read-only. When the $\mathrm{EI}^{2} \mathrm{OS}$ is completed, the end condition can be identified by checking the value in these bits. These bits are set to ' 00 ' upon a reset.
Table 7.6.2b shows the relationship between the $S$ bits and end conditions

Table 7.6.2b S bits and end conditions

| $\mathbf{S 1}$ | S0 | End condition |
| :---: | :---: | :--- |
| 0 | 0 | Reserved |
| 0 | 1 | Count completion |
| 1 | 0 | Reserved |
| 1 | 1 | Resource request |

[bit 11] or [bit 3] ISE
This is the $\mathrm{EI}^{2} \mathrm{OS}$ enable bit. This bit can be read or written to. Upon issuance of an interrupt request, $\mathrm{EI}^{2} \mathrm{OS}$ is activated if this bit is set to ' 1 ' and the interrupt sequence is activated if this bit is set to '0.' If the $\mathrm{EI}^{2} \mathrm{OS}$ end condition is satisfied (the S 1 and S 0 bits are not ${ }^{\circ} 00$ '), the ISE bit is cleared to ' 0 .' If the corresponding peripheral does not have the $\mathrm{EI}^{2} \mathrm{OS}$ function, the software must set ISE to '0.'
This bit is initialized to ' 0 ' upon a reset.
[bits 10 to 8] or [bits 2 to 0] ILO, IL1, and IL2
These are interrupt level setting bits. Specify the interrupt level of the corresponding internal resource. These bits can be read and written to. These bits are initialized to level 7 (no interrupt) upon a reset. Table 7.6.2c describes the relationship between the interrupt level setting bits and interrupt levels.

Table 7.6.2c Interrupt level setting bits and interrupt levels

| IL2 | IL1 | ILO | Level |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 (Highest interrupt level) |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 2 |
| 0 | 1 | 1 | 3 |
| 1 | 0 | 0 | 4 |
| 1 | 0 | 1 | 5 |
| 1 | 1 | 0 | 6 (Lowest interrupt level) |
| 1 | 1 | 1 | 7 (No interrupt) |

7.6 Extended intelligent I/O service (EI2OS)
(2)Extended intelligent I/O service descriptor (ISD)

The extended intelligent I/O service descriptor exists between $000100_{\mathrm{H}}$ and $00017 \mathrm{~F}_{\mathrm{H}}$ in internal RAM, and consists of the following items:

Data transfer control data
Status data
Buffer address pointer
Figure 7.6.2a shows the configuration of the extended intelligent I/O service descriptor.

| High-order 8 bits of data counter (DCTH)  <br>  Low-order 8 bits of data counter (DCTL) <br>  High-order 8 bits of I/O address pointer (IOAH) <br>  Low-order 8 bits of I/O address pointer (IOAL) <br>  I $^{2}$ OS status (ISCS) <br>  High-order 8 bits of buffer address pointer (BAPH) <br>  Medium-order 8 bits of buffer address pointer (BAPM) <br>  Low-order 8 bits of buffer address pointer (BAPL) |  |  |  |  |
| :--- | :--- | :---: | :---: | :---: |

Figure 7.6.2a Extended intelligent I/O service descriptor configuration

Data counter (DCT)
This is a 16-bit register that works as a counter corresponding to the number of data items transferred. This counter is decremented by one before data transfer. $\mathrm{El}^{2} \mathrm{OS}$ is terminated when this counter reaches 0.

| Upper byte of data counter | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | > Bit number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | B15 | B14 | B13 | B12 | B11 | B10 | B09 | B08 | DCTH |
| Initial value $\leftrightarrows$ | (X) | (X) | (X) | (X) | (X) | (X) | (X) | (X) |  |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | ৫ Bit number |
| Lower byte of data counter | B07 | B06 | B05 | B04 | B03 | B02 | B01 | B00 | DCTL |
| Initial values ${ }^{\text {a }}$ | (X) | (X) | (X) | (X) | (X) | (X) | (X) | (X) |  |

I/O register address pointer (IOA)
This is a 16-bit register that indicates the low-order address (A15 to A0) of the buffer and I/O register used for data transfer to and from the buffer. The high-order address (A23 to A16) are all zeroes, and any I/O between addresses $000000_{\mathrm{H}}$ and $00 \mathrm{FFFF}_{\mathrm{H}}$ can be specified.

| Upper address pointer | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | Bit number <br> IOAH |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | A15 | A14 | A13 | A12 | A11 | A10 | A09 | A08 |  |
| Initial value $\quad$ ¢ $>$ | (X) | (X) | (X) | (X) | (X) | (X) | (X) | (X) |  |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | > Bit number |
| Lower address pointer | A07 | A06 | A05 | A04 | A03 | A02 | A01 | A00 | IOAL |
| Initial value $¢>$ | (X) | (X) | (X) | (X) | (X) | (X) | (X) | (X) |  |

- $\mathrm{EI}^{2} \mathrm{OS}$ status register (ISCS)

This eight-bit register indicates the update direction (increment/decrement), transfer data format (byte/word), and transfer direction of the buffer address pointer and the I/O register address pointer. This register also indicates whether the buffer address pointer or I/O register address pointer is updated or fixed.

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\checkmark$ Bit number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | - | - | - | IF | BW | BF | DIR | SE |  |
| Read/write $\Rightarrow>$ | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) |  |
| Initial value $\Rightarrow>$ | (X) | (X) | (X) | (X) | (X) | (X) | (X) | (X) |  |

* Always write 0 to bits 7 to 5 of ISCS.

Each bit is described below.
[bit 4] IF: Specify whether the I/O register address pointer is updated or fixed.

| 0 | The I/O register address pointer is updated after data transfer. |
| :---: | :--- |
| 1 | The I/O register address pointer is not updated after data transfer. |

Note: Only increment is allowed.
[bit 3] BW: Specify the transfer data length.

| 0 | Byte |
| :--- | :--- |
| 1 | Word |

[bit 2] BF: Specify whether the buffer address pointer is updated or fixed.

| 0 | The buffer address pointer is updated after data transfer. |
| :---: | :--- |
| 1 | The buffer address pointer is not updated after data transfer. |

Note: Only the low-order 16 bits of the buffer address are updated. Only increment is allowed.
7.6 Extended intelligent I/O service (EI2OS)
[bit 1] DIR: Specify the data transfer direction.

| 0 | I/O $\rightarrow$ Buffer |
| :--- | :--- |
| 1 | Buffer $\rightarrow \mathrm{I} / \mathrm{O}$ |

[bit 0] SE: Control the termination of the extended intelligent I/O service based on resource requests.

| 0 | The extended intelligent I/O service is not terminated by a resource <br> request. |
| :---: | :--- |
| 1 | The extended intelligent I/O service is terminated by a resource request. |

■ Buffer address pointer (BAP)
This 24-bit register holds the address used for the next $\mathrm{El}^{2} \mathrm{OS}$ transfer. BAP exists for each $\mathrm{El}^{2} \mathrm{OS}$ channel. Therefore, each $\mathrm{El}^{2} \mathrm{OS}$ channel can be used for transfer with anywhere in the 16-Mbyte space.
Note: If the BF bit of ISCS is set to '0' (update enabled), only the low-order 16 bits of BAP changes and BAPH does not change.

### 7.6.3 Operation



Figure 7.6.3a $\mathrm{El}^{2} \mathrm{OS}$ operation flow
7.6 Extended intelligent I/O service (EI2OS)


Figure 7.6.3b $\mathrm{EI}^{2} \mathrm{OS}$ use flow

### 7.6.4 $\mathrm{El}^{2} \mathrm{OS}$ Execution Time

(1) When data transfer continues (when the stop condition is not satisfied)

EI2OS Execution Time $=$ (value in Table 7.6.4a + value in Table 7.6.4b) machine cycle

Table 7.6.4a Execution time when the extended I2OS continues

| ISCS SE bit |  | Set to '0' |  | Set to '1' |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
| I/O address pointer |  | Fixed | Updated | Fixed | Updated |
| Buffer address <br> pointer | Fixed | 32 | 34 | 33 | 35 |
|  | Updated | 34 | 36 | 35 | 37 |

(2) When a stop request is issued from a resource

El2OS Execution Time $=(36+6 \times$ value of Table 7.4.3a) machine cycles
(3) When the counting is completed

EI2OS Execution Time = (value of Table 7.6.4a + value of Table $7.6 .4 \mathrm{~b}+(21+6 \times$ value of Table 7.4.3a) machine cycles
Table 7.6.4b Data transfer compensation values for extended I2OS execution time

| I/O address pointer |  |  | Internal access |  | External access |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | B/E | 0 | B/E | 8/0 |
| Buffer address pointer | Internal access | B/E | 0 | +2 | +1 | +4 |
|  |  | $\bigcirc$ | +2 | +4 | +3 | +6 |
|  | External access | B/E | +1 | +3 | +2 | +5 |
|  |  | 8/O | +4 | +6 | +5 | +8 |

B: Byte data transfer
E: Even address word transfer

8 : 8-bit external bus word transfer
O : Odd address word transfer

### 7.7 Exceptions

The $\mathrm{F}^{2} \mathrm{MC}$-16LX performs exception processing when the following event occurs:

- Execution of an undefined instruction

Exception processing is fundamentally the same as interrupt processing. When an exception is detected between instructions, exception processing is performed separately from ordinary processing. In general, exception processing is performed as a result of an unexpected operation. Fujitsu recommends using exception processing only for debugging or for activating emergency recovery software.

### 7.7.1 Exception due to execution of an undefined instruction

The $\mathrm{F}^{2} \mathrm{MC}$-16LX handles all codes that are not defined in the instruction map as undefined instructions. When an undefined instruction is executed, processing equivalent to the INT 10 software interrupt instruction is performed. Specifically, the AL, AH, DPR, DTB, ADB, PCB, PC, and PS values are saved into the system stack, and processing branches to the routine indicated by the interrupt number 10 vector. In addition, the I flag is cleared and the S flag is set. The PC value saved in the stack is the address at which the undefined instruction is stored. Processing can be restored by the RETI instruction, but is of no use, however, because the same exception occurs again.

## Chapter 8: <br> Parallel Ports

### 8.1 Outline

In MB90580 series, there are 10 parallel ports which are as follows:

- Port 0 (8 CMOS I/O pins)
- Port 1 (8 CMOS I/O pins)
- Port 2 (8 CMOS I/O pins)
- Port 3 (8 CMOS I/O pins)
- Port 4 (8 CMOS I/O pins with open-drain control)
- Port 5 (8 CMOS I/O pins)
- Port 6 ( 6 CMOS I/O pins)
- Port 7 (4 CMOS I/O pins)
- Port 8 (8 CMOS I/O pins)
- Port 9 (8 CMOS I/O pins)
- Port A (3 CMOS I/O pins)

Each pin of the ports can be specified as input or output using the direction register if the corresponding peripheral does not use the pin. When a pin is specified as input, the value of the pin level is read from a data register. When a pin is specified as output, the data register latch value is read from the data register. The above also applies to a read operation for a read-modify-write instruction.
When a data register is read while the corresponding port is used as a control output, control output value is read from the data register regardless of the direction register value.
When an input pin is changed into an output pin, care must be taken to use a read-modify-write instruction (such as a bit set instruction) to set output data in the data register beforehand. In this case, the data input from the pin is read instead of the data register latch value.

### 8.2 Block Diagram



Figure 8.2a Block diagram of I/O port


Figure 8.2b Block diagram of input resistor register


Figure 8.2c Block diagram of Output pin register

### 8.3 Registers and register details

| Bit | 15/7 | 14/6 | 13/5 | 12/4 | 11/3 | 10/2 | 9/1 | 8/0 | Port 0 data register (PDR0) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 000000 ${ }_{\mathrm{H}}$ | P07 | P06 | P05 | P04 | P03 | P02 | P01 | P00 |  |
| Address : 000001H | P17 | P17 | P15 | P14 | P13 | P12 | P11 | P10 | Port 1 data register (PDR1) |
| Address : 000002H | P27 | P26 | P25 | P24 | P23 | P22 | P21 | P20 | Port 2 data register (PDR2) |
| Address : 000003 ${ }_{\mathrm{H}}$ | P37 | P36 | P35 | P34 | P33 | P32 | P31 | P30 | Port 3 data register (PDR3) |
| Address : 000004 ${ }_{\mathrm{H}}$ | P47 | P46 | P45 | P44 | P43 | P42 | P41 | P40 | Port 4 data register (PDR4) |
| Address : 000005 ${ }_{\text {H }}$ | P57 | P56 | P55 | P54 | P53 | P52 | P51 | P50 | Port 5 data register (PDR5) |
| Address : 000006H | - | - | P65 | P64 | P63 | P62 | P61 | P60 | Port 6 data register (PDR6) |
| Address : 000007\% | - | - | - | P74 | P73 | P72 | P71 | - | Port 7 data register (PDR7) |
| Address : 000008 ${ }_{\mathrm{H}}$ | P87 | P86 | P85 | P84 | P83 | P82 | P81 | P80 | Port 8 data register (PDR8) |
| Address : 000009 ${ }_{\text {H }}$ | P97 | P96 | P95 | P94 | P93 | P92 | P91 | P90 | Port 9 data register (PDR9) |
| Address : $00000 \mathrm{~A}_{\mathrm{H}}$ | - | - | - | - | - | PA2 | PA1 | PA0 | Port A data register (PDRA) |
| Bit | 15/7 | 14/6 | 13/5 | 12/4 | 11/3 | 10/2 | 9/1 | 8/0 |  |
| Address : 000010 ${ }_{\mathrm{H}}$ | D07 | D06 | D05 | D04 | D03 | D02 | D01 | D00 | Port 0 data register (DDR0) |
| Address : 000011 ${ }_{\text {H }}$ | D17 | D17 | D15 | D14 | D13 | D12 | D11 | D10 | Port 1 data register (DDR1) |
| Address : 000012H | D27 | D26 | D25 | D24 | D23 | D22 | D21 | D20 | Port 2 data register (DDR2) |
| Address : 000013 ${ }_{\mathrm{H}}$ | D37 | D36 | D35 | D34 | D33 | D32 | D31 | D30 | Port 3 data register (DDR3) |
| Address : 000014H | D47 | D46 | D45 | D44 | D43 | D42 | D41 | D40 | Port 4 data register (DDR4) |
| Address : 000015 ${ }_{\text {H }}$ | D57 | D56 | D55 | D54 | D53 | D52 | D51 | D50 | Port 5 data register (DDR5) |
| Address : 000016 ${ }_{\text {H }}$ | - | - | D65 | D64 | D63 | D62 | D61 | D60 | Port 6 data register (DDR6) |
| Address : 000017\% | - | - | - | D74 | D73 | D72 | D71 | - | Port 7 data register (DDR7) |
| Address : 000018H | D87 | D86 | D85 | D84 | D83 | D82 | D81 | D80 | Port 8 data register (DDR8) |
| Address : 000019 ${ }_{\mathrm{H}}$ | D97 | D96 | D95 | D94 | D93 | D92 | D91 | D90 | Port 9 data register (DDR9) |
| Address : $00001 \mathrm{~A}_{\mathrm{H}}$ | - | - | - | - | - | DA2 | DA1 | DA0 | Port A data register (DDRA) |
| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | Port 4 pin register (ODR4) |
| Address : $00001 \mathrm{~B}_{\mathrm{H}}$ | OD47 | OD46 | OD45 | OD44 | OD43 | OD42 | OD41 | OD40 |  |
| Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Port 5 analog input enable register (ADER) |
| Address : 00001C ${ }_{\text {H }}$ | ADE7 | ADE6 | ADE5 | ADE4 | ADE3 | ADE2 | ADE1 | ADE0 |  |
| Bit | 15/7 | 14/6 | 13/5 | 12/4 | 11/3 | 10/2 | 9/1 | 8/0 |  |
| Address : 00008C $\mathrm{H}_{\mathrm{H}}$ | RD07 | RD06 | RD05 | RD04 | RD03 | RD02 | RD01 | RD00 | Port 0 resistor register (RDR0) |
| Address : 00008D ${ }_{\text {H }}$ | RD17 | RD16 | RD15 | RD14 | RD13 | RD12 | RD11 | RD10 | Port 1 resistor register (RDR1) |
| Address : 00008E H | - | - | RD65 | RD64 | RD63 | RD62 | RD61 | RD60 | Port 6 resistor register (RDR6) |
| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |
| Address : 0000A3 ${ }_{\text {H }}$ | - | - | - | - | LNB | LNA | LN9 | LN8 | Low Noise Output Select register (Upper) (LNSRH) |
| Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Low Noise Output Select register (Lower) (LNSRL) |
| Address : 0000A2H | LN7 | LN6 | LN5 | LN4 | LN3 | LN2 | LN1 | LN0 |  |

Figure 8.3a Registers of Parallel Ports

### 8.3.1 Port data register

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Initial value | Access |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PDR0 <br> Address: $000000_{\mathrm{H}}$ | P07 | P06 | P05 | P04 | P03 | P02 | P01 | P00 | xxxxxxxx | R/W |
|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |  |
| PDR1 <br> Address: $000001_{\mathrm{H}}$ | P17 | P16 | P15 | P14 | P13 | P12 | P11 | P10 | xxxxxxxx | R/W |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| PDR2 <br> Address: $000002_{\mathrm{H}}$ | P27 | P26 | P25 | P24 | P23 | P22 | P21 | P20 | xxxxxxxx | R/W |
|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |  |
| PDR3 <br> Address: $000003_{\mathrm{H}}$ | P37 | P36 | P35 | P34 | P33 | P32 | P31 | P30 | xxxxxxxx | R/W |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| PDR4 <br> Address: $000004_{\mathrm{H}}$ | P47 | P46 | P45 | P44 | P43 | P42 | P41 | P40 | xxxxxxxx | R/W |
|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |  |
| PDR5 <br> Address: $000005_{\mathrm{H}}$ | P57 | P56 | P55 | P54 | P53 | P52 | P51 | P50 | xxxxxxxx | R/W |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| PDR6 <br> Address: 000006 ${ }_{\mathrm{H}}$ | - | - | P65 | P64 | P63 | P62 | P61 | P60 | --xxxxxx | R/W |
|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |  |
| PDR7 <br> Address: $000007_{\mathrm{H}}$ | - | - | - | P74 | P73 | P72 | P71 | - | ---xxxx- | R/W |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| PDR8 <br> Address: $000008_{\mathrm{H}}$ | P87 | P86 | P85 | P84 | P83 | P82 | P81 | P80 | Xxxxxxxx | R/W |
|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |  |
| PDR9 <br> Address: 000009 ${ }_{\mathrm{H}}$ | P97 | P96 | P95 | P94 | P93 | P92 | P91 | P90 | xxxxxxxx | R/W |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| PDRA <br> Address: $00000 A_{H}$ | - | - | - | - | - | PA2 | PA1 | PA0 | -----xxx | R/W |

Note: Note that R/W for I/O ports differ from R/W for memory in the following points:
O Input mode
Read: The level of the corresponding pin is read.
Write: Data is written to an output latch.
O Output mode
Read: The data register latch value is read.
Write: The data is output to the corresponding pin.

### 8.3.2 Port direction registers

Address: $\mathbf{0 0 0 0 1 0}_{\mathrm{H}}$

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Initial value Access |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D07 | D06 | D05 | D04 | D03 | D02 | D01 | D00 | $00000000_{\mathrm{B}}$ | R/W |


|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DDR1 | D17 | D16 | D15 | D14 | D13 | D12 | D11 | D10 | $00000000{ }_{B}$ | R/W |


|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DDR2 | D27 | D26 | D25 | D24 | D23 | D22 | D21 | D20 | $00000000{ }_{B}$ | R/W |


|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DDR3 | D37 | D36 | D35 | D34 | D33 | D32 | D31 | D30 | $00000000{ }_{B}$ | R/W |


|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DDR4 <br> Address: 000014 ${ }_{H}$ | D47 | D46 | D45 | D44 | D43 | D42 | D41 | D40 | $00000000{ }_{\text {B }}$ | R/W |


|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DDR5 <br> Address: 000015 | D57 | D56 | D55 | D54 | D53 | D52 | D51 | D50 | $00000000{ }_{B}$ | R/W |


|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DDR6 | - | - | D65 | D64 | D63 | D62 | D61 | D60 | $-{ }^{-000000}{ }_{B}$ | R/W |



DDR8
Address: $000018_{\mathrm{H}}$


DDR9
Address: $000019_{\mathrm{H}}$

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D97 | D96 | D95 | D94 | D93 | D92 | D91 | D90 |  |  |
| $0 y y y y y y y$ | $0000000_{B}$ | R/W |  |  |  |  |  |  |  |



When a pin is used as a port, the corresponding pin is controlled as described below:

| 0 | Input mode |
| :---: | :--- |
| 1 | Output mode |

### 8.3.3 Output pin register

Port 4 pin register

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $<$ Bit number <br> ODR4 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 00001B ${ }_{\text {H }}$ | OD47 | OD46 | OD45 | OD44 | OD43 | OD42 | OD41 | OD40 |  |  |
| Read/write $\qquad$ <br> Initial value $\Rightarrow$ | $\begin{gathered} \mathrm{R} / \mathrm{W} \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ |  |  |

This register controls the open drain in output mode.

| 0 | Standard output port in output mode | [initial value] |
| :---: | :--- | :--- |
| 1 | Open drain output port in output mode |  |

Note: This register is not used in input mode. (Output Hi-z)
Note: Input or output mode is determined by the direction register (DDR).
Note: No pull-up resistor is used during hardware standby and stop (SPL=1). (High impedance)

Note: This function is inhibited when an external bus is used. When using an external bus, do not write data in this register.

### 8.3.4 Input resistor register

Port 0 resistor register

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\begin{aligned} & <\text { Bit number } \\ & \text { RDR0 } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 00008C ${ }_{\mathrm{H}}$ | RD07 | RD06 | RD05 | RD04 | RD03 | RD02 | RD01 | RD00 |  |
| Read/write $\Rightarrow$ Initial value $\Rightarrow$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ |  |

Port 1 resistor register

|  | 15 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | $\prec$ Bit number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 00008D ${ }_{\text {H }}$ | RD17 | RD16 | RD15 | RD14 | RD13 | RD12 | RD11 | RD10 |  |
| Read/write $\Rightarrow$ Initial value $\Rightarrow$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \mathrm{R} / \mathrm{W} \\ 0 \end{gathered}$ | $\begin{gathered} \mathrm{R} / \mathrm{W} \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \hline \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \mathrm{R} / \mathrm{W} \\ 0 \end{gathered}$ | $\begin{gathered} \mathrm{R} / \mathrm{W} \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ |  |

Port 6 resistor register


This register controls whether to use a pull-up resistor in input mode.

| 0 | No pull-up resistor used in input mode. | [initial value] |
| :--- | :--- | :--- |
| 1 | Pull-up resistor used in input mode. |  |

Note: This register has no use in output mode (no pull-up resistor is used).
Note: Input or output mode is determined by the direction register (DDR).
Note: No pull-up resistor is used during hardware standby and stop (SPL=1). (High impedance)
Note: This function is inhibited when an external bus is used. When using an external bus, do not write data in this register.

## 8．3．5 Analogue Input Enable Register

Port 5 analogue enable register

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $<$ Bit number <br> ADER |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address ：00001C $\mathrm{H}_{\mathrm{H}}$ | ADE7 | ADE6 | ADE5 | ADE4 | ADE3 | ADE2 | ADE1 | ADE0 |  |
| Read／write Initial value $\leftrightharpoons$ | $\begin{gathered} \text { R/W } \\ 1 \end{gathered}$ | R/W | $\begin{gathered} \text { R/W } \\ 1 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 1 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 1 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 1 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 1 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 1 \end{gathered}$ |  |

This register controls the ．behaviour of port 5.

| 0 | Port input mode |  |
| :---: | :--- | :--- |
| 1 | Analogue input mode | ［initial value］ |

Note：When an intermediate voltage level is applied to the pin during port input mode，a leakage current will be induced．In this case，configure the pin to analogue input mode instead．

## 8．3．6 Low Noise Output Select Register

Low Noise Output Select register（Upper）

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $\propto \text { Bit number }$ <br> LNSRH |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address ： $0000 \mathrm{Al}_{\mathrm{H}}$ | － | － | － | － | LNB | LNA | LN9 | LN8 |  |
| Read／write $\Rightarrow$ Initial value $\Rightarrow$ | 二 | - | 二 | 二 | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ |  |

Low Noise Output Select register（Lower）

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $<$ Bit number <br> LNSRL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address ：0000A2 ${ }_{\text {H }}$ | LN7 | LN6 | LN5 | LN4 | LN3 | LN2 | LN1 | LN0 |  |
| Read／write $\Rightarrow$ Initial value $\Rightarrow$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ |  |

These two register are used to select the low noise output buffer for Port 0 to Port A and the TX output of IE bus．
［bit 15－12］－unused bits
［bit 11］－LNB controls TX pin of IE bus

| 0 | Normal output buffer |
| :--- | :--- | ［initial value］ | 1 | Low noise output buffer |  |
| :--- | :--- | :--- |

［bit 10］－LNA controls Port A

| 0 | Normal output buffer | ［initial value］ |
| :---: | :--- | :---: |
| 1 | Low noise output buffer |  |

[bit 9] - LN9 controls Port 9

| 0 | Normal output buffer | [initial value] |
| :---: | :--- | :--- |
| 1 | Low noise output buffer |  |

[bit 8] - LN8 controls Port 8

| 0 | Normal output buffer | [initial value] |
| :---: | :---: | :---: |
| 1 | Low noise output buffer |  |

[bit 7] - LN7 controls Port 7

| 0 | Normal output buffer | [initial value] |
| :---: | :--- | :--- |
| 1 | Low noise output buffer |  |

[bit 6] - LN6 controls Port 6

| 0 | Normal output buffer | [initial value] |
| :--- | :--- | :--- |
| 1 | Low noise output buffer |  |

[bit 5] - LN5 controls Port 5

| 0 | Normal output buffer | [initial value] |
| :--- | :--- | :--- |
| 1 | Low noise output buffer |  |

[bit 4] - LN4 controls Port 4

| 0 | Normal output buffer | [initial value] |
| :--- | :--- | :--- |
| 1 | Low noise output buffer |  |

[bit 3] - LN3 controls Port 3

| 0 | Normal output buffer | [initial value] |
| :---: | :--- | :--- |
| 1 | Low noise output buffer |  |

[bit 2] - LN2 controls Port 2

| 0 | Normal output buffer | [initial value] |
| :--- | :--- | :--- |
| 1 | Low noise output buffer |  |

[bit 1] - LN1 controls Port 1

| 0 | Normal output buffer | [initial value] |
| :---: | :--- | :--- |
| 1 | Low noise output buffer |  |

[bit 0] - LNO control Port 0

| 0 | Normal output buffer | [initial value] |
| :---: | :--- | :--- |
| 1 | Low noise output buffer |  |

Note: These two register are not available for MB90V580.
Note: When low noise output buffer is selected, the driving power will be decreased.

## Chapter 9: <br> DTP/External Interrupt

### 9.1 Outline

The DTP (Data Transfer Peripheral) is a peripheral block that interfaces external peripherals to the $\mathrm{F}^{2} \mathrm{MC}-16 \mathrm{LX}$ CPU. The DTP receives DMA and interrupt processing requests from external peripherals and passes requests to the $\mathrm{F}^{2} \mathrm{MC}-16 \mathrm{LX}$ CPU to activate the extended intelligent $\mathrm{I} / \mathrm{O}$ service (EI2 OS ) or interrupt processing. Two request levels ("H" and "L") are provideed for the extended intelligent I/O service ( $\left.\mathrm{E}\right|^{2} \mathrm{OS}$ ). For external interrupt requests, generating interrupts on a rising edge or falling edge as well as "H" and "L" level can be selected, giving a total of four types.

### 9.2 Block Diagram



Figure 9.2a Block diagram of DTP/External Interrupt

### 9.3 Registers and Register Details

Interrupt/DTP enable register

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\diamond$ Bit number ENIR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 000030 ${ }_{\text {H }}$ | EN7 | EN6 | EN5 | EN4 | EN3 | EN2 | EN1 | EN0 |  |
| Read/write $\Rightarrow$ Initial value $\Rightarrow$ | $\begin{gathered} (R / W) \\ (0) \end{gathered}$ | (R/W) (0) | (R/W) (0) | (R/W) <br> (0) | $\begin{gathered} (R / W) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ |  |

Interrupt/DTP cause register

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | > Bit number <br> EIRR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 000031 ${ }_{\text {H }}$ | ER7 | ER6 | ER5 | ER4 | ER3 | ER2 | ER1 | ER0 |  |
| Read/write $\Rightarrow$ Initial value $\Rightarrow$ | (R/W) (X) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ |  |

Request level setting register (Lower Byte)

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\begin{aligned} & \diamond \text { Bit number } \\ & \text { ELVR (LOW) } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 000032 ${ }_{\text {H }}$ | LB3 | LA3 | LB2 | LA2 | LB1 | LA1 | LB0 | LAO |  |
| Read/write Initial value | $\begin{gathered} (\mathrm{R} / \mathrm{W} \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W} \\ (0) \end{gathered}$ | (R/W) <br> (0) | $\begin{array}{r} (\mathrm{R} / \mathrm{V} \\ (0) \end{array}$ | $(\mathrm{R} / \mathrm{V}$ | $\begin{gathered} (R / W) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ |  |

Request level setting register (Higher Byte)

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $\begin{aligned} & \diamond \text { Bit number } \\ & \text { ELVR (HIGH) } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 000033 ${ }_{\mathrm{H}}$ | LB7 | LA7 | LB6 | LA6 | LB5 | LA5 | LB4 | LA4 |  |
| Read/write Initial value | $\begin{array}{r} (\mathrm{R} / \mathrm{M} \\ (0) \end{array}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W} \\ (0) \end{gathered}$ | (R/W) <br> (0) | (R/W $(0)$ | $\begin{gathered} (\mathrm{R} / \mathrm{M} \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | (R/W) <br> (0) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ |  |

### 9.3.1 Interrupt/DTP enable register (ENIR: Enable interrupt request register)

Interrupt/DTP enable register

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | > Bit number ENIR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 000030 ${ }_{\text {H }}$ | EN7 | EN6 | EN5 | EN4 | EN3 | EN2 | EN1 | EN0 |  |
| Read/write $\Rightarrow>$ | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) |  |
| Initial value $\Rightarrow>$ | (0) | (0) | (0) | (0) | (0) | (0) | (0) | (0) |  |

ENIR enables the function to issue a request to the interrupt controller using a device pin as an external interrupt/DTP request input. A pin corresponding to a '1' bit of this register is used as an external interrupt/DTP request input. A pin corresponding to a '0' bit holds the external interrupt/DTP request input cause, but does not issue a request to the interrupt controller.

### 9.3.2 Interrupt/DTP cause register (EIRR: External interrupt request register)

| Interrupt/DTP cause register |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $\checkmark$ Bit number |
| Address : 000031 ${ }_{\text {H }}$ | ER7 | ER6 | ER5 | ER4 | ER3 | ER2 | ER1 | ERO | EIRR |
| Read/write $¢>$ | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) |  |
| Initial value $\Rightarrow$ | (X) | (X) | (X) | (X) | (X) | (X) | (X) | (X) |  |

When read, EIRR indicates the current external interrupt/DTP requests. When written, EIRR clears the flip-flop values indicating those requests. External interrupt/DTP requests exist at the pins corresponding to the ' 1 ' bits of this register. Writing ' 0 ' to a bit of this register clears the corresponding request flip-flop value. Writing ' 1 ' performs no operation. ' 1 ' is always read from this register by a read-modify-write instruction.

### 9.3.3 Request level setting register (ELVR: External level register)

Request level setting register (Lower Byte)

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\diamond$ Bit number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 000032H | LB3 | LA3 | LB2 | LA2 | LB1 | LA1 | LB0 | LA0 | ELVR (LOW) |
| Read/write $\Rightarrow$ Initial value $\Rightarrow$ | (R/W (0) | (R/W) <br> (0) | (R/W) <br> (0) | (R/W $(0)$ | (R/W $(0)$ | $(R / W)$ (0) | (R/W) <br> (0) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ |  |

Request level setting register (Higher Byte)

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | ৫ Bit number <br> ELVR (HIGH) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 000033 ${ }_{\text {H }}$ | LB7 | LA7 | LB6 | LA6 | LB5 | LA5 | LB4 | LA4 |  |
| Read/write Initial value | $\begin{gathered} \hline \text { (R/W) } \\ (0) \end{gathered}$ | (R/W) (0) | (R/W) (0) | $\begin{gathered} \text { (R/W) } \\ (0) \end{gathered}$ | $\begin{gathered} \text { (R/W) } \\ (0) \end{gathered}$ | $\begin{gathered} \text { (R/W) } \\ (0) \end{gathered}$ | $\begin{gathered} \text { (R/W) } \\ (0) \end{gathered}$ | $\begin{gathered} \text { (R/W) } \\ (0) \end{gathered}$ |  |

ELVR is used to select a request detection factor. Each pin is assigned two bits as described in the table below. If a request is to be detected based on a level, the register value is maintained while the input is active even when it is cleared.

| LBx | LAx | Interrupt request detection factor |
| :---: | :---: | :--- |
| 0 | 0 | L level pin input |
| 0 | 1 | H level pin input |
| 1 | 0 | Rising edge pin input |
| 1 | 1 | Falling edge pin input |

### 9.4 Operations

### 9.4.1 External interrupts

Once an external interrupt request is set, this resource issues an interrupt request signal to the interrupt controller when a request specified by the ELVR register is input to the corresponding pin. The interrupt controller identifies the priority levels of the simultaneous interrupts, and issues an interrupt request to the $\mathrm{F}^{2} \mathrm{MC}-16 \mathrm{CPU}$ if the interrupt from this resource has the highest priority level. The $\mathrm{F}^{2} \mathrm{MC}$ - 16 CPU compares the ILM bit of its internal CCR register and the interrupt request. If the interrupt level of the request is higher than that indicated by the ILM bit, the $\mathrm{F}^{2} \mathrm{MC}-16 \mathrm{CPU}$ activates the hardware interrupt processing microprogram as soon as the currently executing instruction is terminated.


Figure 9.4.1a External interrupt
In the hardware interrupt processing microprogram, the CPU reads the ISE bit information from the interrupt controller, identifies that the request is for interrupt processing based on that information, and branches to the interrupt processing microprogram. The interrupt processing microprogram reads the interrupt vector area and issues an interrupt acknowledgment signal for the interrupt controller. Then, the microprogram transfers the jump destination address of the macro instruction generated from the vector to the program counter, and executes the user interrupt processing program.

### 9.4.2 DTP operation

To activate the intelligent I/O service, the user program initially sets the address of a register, assigned between $000000_{\mathrm{H}}$ and $0000 \mathrm{FF}_{\mathrm{H}}$, in the I/O address pointer of the intelligent I/O service descriptor. Then, the user program sets the start address of the memory buffer in the buffer address pointer.

The DTP operation sequence is almost the same as for external interrupts. The operation is identical until the CPU activates the hardware interrupt processing microprogram. Then, for the DTP, control is transferred to the intelligent I/O service processing microprogram, since the ISE bit read by the CPU within the hardware interrupt processing microprogram indicates the DTP. Once the intelligent I/O service is activated, a read or write signal is sent to the addresses external peripheral, and data is transferred between the peripheral and the chip. The external peripheral must cancel the interrupt request to this chip within three machine cycles after the transfer is made. When the transfer is completed, the descriptor is updated, and the interrupt controller generates a signal that clears the transfer cause. Upon receiving the signal to clear the transfer cause, this resource clears the flip-flop holding the cause and prepares for the next request from the pin. For details of the intelligent I/O service processing, refer to the MB90700 Programming Manual.


Figure 9.4.2a Timing to cancel the external interrupt at the end of DTP operation


Figure 9.4.2b Sample interface to the external peripheral

### 9.4.3 Switching between external interrupt and DTP requests

To switch between external interrupt and DTP requests, use the ISE bit in the ICR register corresponding to this resource, which is in the interrupt controller. Each pin is individually assigned ICR. Thus, a pin is used for a DTP request if ' 1 ' is written to the ISE bit of the corresponding ICR, and is used for an external interrupt request if ' 0 ' is written to the bit.


Figure 9.4.3a Switching between external interrupt and DTP requests

### 9.5 Notes on use

### 9.5.1 Conditions on the externally connected peripheral when DTP is used

DTP supports only external peripherals that automatically clear a request once a transfer is completed. The system must be designed so that a transfer request is canceled within three machine cycles (provisional) after transfer operation starts. Otherwise, this resource assumes that a transfer request is issued.

### 9.5.2 Recovery from standby

To use an external interrupt to recover from the standby state in clock stop mode, use an H level request as an input request. A $L$ level request may result in misoperation. If an edge request is used, recovery from the standby state in clock stop mode cannot be performed.

### 9.5.3 External interrupt/DTP operation procedure

To set registers in the external interrupt/DTP, follow the steps below:

1. Disable the bits corresponding to the enable register.
2. Set the bits corresponding to the request level setting register.
3. Clear the bits corresponding to the cause register.
4. Enable the bits corresponding to the enable register.
(Steps 3. and 4. can be simultaneously performed by word specification.)
To set a register in this resource, ensure that the enable register is disabled. Before enabling the enable register, ensure that the cause register is cleared. Clearing the cause register prevents a false interrupt cause from being determined while registers are set or interrupts are enabled.

### 9.5.4 External interrupt request level

(1)To detect an edge for a edge request level, the pulse width must be at least three machine cycles.
(2) If the request input level is related to level setting, the request to the interrupt controller is kept active. Because of the internal hold circuit, the request is kept active even if it is input from the external device and then canceled. To cancel the request to the interrupt controller, clear the cause hold circuit.


Figure 9.5.4a Clearing the cause hold circuit upon level set


Figure 9.5.4b Interrupt cause and interrupt request to the interrupt controller while interrupts are enabled

## Chapter 10: <br> Delayed Interrupt Generation Module

### 10.1 Outline

The delayed interrupt generation module generates interrupts for switching tasks for development on a real-time operating system (REALOS series). The module can be used to generate softwarewise generates hardware interrupt requests to the CPU and cancel the interrupts.
This module does not conform to the extended intelligent $I / O$ service ( $E I^{2} \mathrm{OS}$ ).

### 10.2 Block Diagram



Figure 10.2a Block diagram of Delayed Interrupt Generation Module

### 10.3 Registers and Register Details

Delayed interrupt cause issuance/cancellation register (DIRR: Delayed interrupt request register)

Delayed interrupt cause issuance/cancellation register

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | > Bit number DIRR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : $00009 \mathrm{~F}_{\mathrm{H}}$ | - | - | - | - | - | - | - | R0 |  |
| Read/write $\Rightarrow$ | (-) | (-) | (-) | (-) | (-) | (-) | (-) | (R/W) |  |
| Initial value $\Rightarrow>$ | (-) | (-) | (-) | (-) | (-) | (-) | (-) | (0) |  |

DIRR controls issuance and cancellation of delayed interrupt requests. Writing ' 1 ' to this register issues a delayed interrupt request, and writing ' 0 ' cancels the delayed interrupt request. Upon a reset, the request is canceled. Either ' 0 ' or ' 1 ' can be written to the reserved bit area. To access this register, use the set bit or clear bit instruction for future expansions.

### 10.4 Operations

### 10.4.1 Delayed interrupt occurrence

When the CPU writes '1' to the relevant bit of DIRR by software, the request latch in the delayed interrupt source module is set and an interrupt request is issued to the interrupt controller. If this interrupt has the highest priority or if there is no other interrupt request, the interrupt controller issues an interrupt request to the $\mathrm{F}^{2} \mathrm{MC}-16 \mathrm{CPU}$. The $\mathrm{F}^{2} \mathrm{MC}-16 \mathrm{CPU}$ compares the ILM bit of its internal CCR register and the interrupt request, and starts the hardware interrupt processing microprogram as soon as the current instruction is completed if the interrupt level of the request is higher than that of the ILM bit. The interrupt processing routine for this interrupt is thus executed.


Figure 10.4.1a Delayed interrupt issuance

The interrupt cause is cleared and tasks are switched by writing ' 0 ' to the corresponding bit of DDIR in the interrupt processing routine.

### 10.5 Notes on operation

### 10.5.1 Delayed interrupt request lock

This lock is set by writing ' 1 ' to the corresponding bit of DIRR, and is cleared by writing ' 0 ' to the same bit. Therefore, interrupt processing is reactivated immediately after control returns from interrupt processing, unless the software is designed so that the cause of the interrupt is cleared within the interrupt processing routine.

## Chapter 11: <br> Communication Prescaler

### 11.1 Outline

The operation clock for the UART is obtained by dividing the machine clock. UART is designed so that a constant baud rate can be obtained for a variety of machine clocks by the user of the communication prescaler. The Clock Division Control Register (CDCR) controls the machine clock division.

### 11.2 Block Diagram



Figure 11.2a Block diagram of Communication Prescaler

### 11.3 Register and Register Details

### 11.3.1 Clock Division Control Registers

Clock Division Control Register 0, 1, 2, 3, 4

| $\begin{array}{r} \text { Address : } 00002 \mathrm{C}_{\mathrm{H}} \\ 00002 \mathrm{E}_{\mathrm{H}} \end{array}$ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | < Bit number CDCRO CDCR1 CDCR2 CDCR3 CDCR4 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $000034_{\mathrm{H}}$ | MD | - | - | - | DIV3 | DIV2 | DIV1 | DIV0 |  |
| $\begin{aligned} & 000087_{\mathrm{H}} \\ & 00008 \mathrm{~F}_{\mathrm{H}} \end{aligned}$ |  |  |  |  |  |  |  |  |  |
| Read/write $\Rightarrow$ | (R/W) | (-) | (-) | (-) | (R/W) | (R/W) | (R/W) | (R/W) |  |
| Initial value $\Rightarrow$ | (0) | (-) | (-) | (-) | (1) | (1) | (1) | (1) |  |

[bit 15] MD (Machine clock divide mode select):
This bit is used to control the operation of the communication prescaler.

| 0 | The communication prescaler is disabled. | [initial value] |
| :---: | :--- | :--- |
| 1 | The communication prescaler is enabled. |  |

[bits 11, 10, 9, and 8] DIV3 to DIV0 (Divide 3 to 0):
These bits are used to determine the machine clock division ratio.

| DIV3 | DIV2 | DIV1 | DIV0 |  | Division ratio |
| :---: | :---: | :---: | :---: | :---: | :--- |
| 1 | 1 | 1 | 1 | Reserved | [initial value] |
| 1 | 1 | 1 | 0 | 2 |  |
| 1 | 1 | 0 | 1 | 3 |  |
| 1 | 1 | 0 | 0 | 4 |  |
| 1 | 0 | 1 | 1 | 5 |  |
| 1 | 0 | 1 | 0 | 6 |  |
| 1 | 0 | 0 | 1 | 7 |  |
| 1 | 0 | 0 | 0 | 8 |  |

Note: When the division ratio is changed, allow two cycles for the clock to stabilize before starting communication.
Note: In actual application, please use the values other than '1111'.

### 11.4 Operations

Depending on the machine clock $\phi$ to be used, the communication prescaler register should be set as follows. For details please refer to Chapter 12, UART.

| machine clock $\phi$ | div | DIV3 | DIV2 | DIV1 | DIV0 | ф/div |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 4 MHz | 4 | 1 | 1 | 0 | 0 |  |
| 6 MHz | 6 | 1 | 0 | 1 | 0 | 1 MHz |
| 8 MHz | 8 | 1 | 0 | 0 | 0 |  |
| 6 MHz | 3 | 1 | 1 | 0 | 1 |  |
| 8 MHz | 4 | 1 | 1 | 0 | 0 |  |
| 10 MHz | 5 | 1 | 0 | 1 | 1 | 2 MHz |
| 12 MHz | 6 | 1 | 0 | 1 | 0 |  |
| 14 MHz | 7 | 1 | 0 | 0 | 1 |  |
| 16 MHz | 8 | 1 | 0 | 0 | 0 |  |
| 8 MHz | 2 | 1 | 1 | 1 | 0 | 4 MHz |
| 12 MHz | 3 | 1 | 1 | 0 | 1 |  |
| 16 MHz | 4 | 1 | 1 | 0 | 0 |  |

When using the machine clock and the div at a different setting other than those mentioned above, $\phi /$ div should not exceed 4.25 MHz .

## Chapter 12: <br> UART

### 12.1 Outline

UART is a serial I/O port for asynchronous communications or CLK synchronous communications. UART has the following features:

- Full-duplex double buffers
- Asynchronous or CLK synchronous communications
- Multi-processor mode
- Built-in dedicated baud rate generator

Asynchronous: 9615, 31250, 4808, 2404, 1202 bps CLK synchronous: 1 M, $500 \mathrm{~K}, 250 \mathrm{~K}, 125 \mathrm{~K}, 62.5 \mathrm{Kbps}$
(At an internal machine clock of $6,8,10,12$, or 16 MHz )

- Flexible baud rate setting by external clock
- Error detection (parity, framing, and overrun)
- NRZ sign transfer signals
- Intelligent I/O service


### 12.2 Block Diagram



Figure 12.2a Block diagram of UART

### 12.3 Register and Register Details

Serial mode register

| Address : $\begin{array}{r}000020_{\mathrm{H}} \\ 000024_{\mathrm{H}}\end{array}$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\checkmark$ Bit number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $000028_{\mathrm{H}}$ | MD1 | MD0 | CS2 | CS1 | CS0 | Reserved | SCKE | SOE | SMR0 |
| $\begin{aligned} & 000082_{\mathrm{H}} \\ & 00 \end{aligned}$ |  |  |  |  |  |  |  |  | SMR1 |
| Read/write $\Rightarrow$ | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | SMR2 |
| Initial value $\Rightarrow>$ | (0) | (0) | (0) | (0) | (0) | (0) | (0) | (0) | SMR4 |

Serial control register

| $\text { Address : } 0000021_{\mathrm{H}}$ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | ৫ Bit number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 000029_{\mathrm{H}} \\ & 000083 \end{aligned}$ | PEN | P | SBL | CL | A/D | REC | RXE | TXE | SCR0 |
| $\begin{aligned} & 000083_{\mathrm{H}} \\ & 000089_{\mathrm{H}} \end{aligned}$ | PEN | P | SBL | CL | A/D | REC | RXE | TXE | SCR1 |
| Read/write $\Rightarrow$ | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | SCR3 |
| Initial value $\Rightarrow>$ | (0) | (0) | (0) | (0) | (0) | (1) | (0) | (0) | SCR4 |

Serial input register/Serial output register

| Address: $\begin{array}{r}000022_{\mathrm{H}} \\ 000026_{\mathrm{H}}\end{array}$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\diamond$ Bit number <br> SIDRO/SODR0 SIDR1/SODR1 SIDR2/SODR2 SIDR3/SODR3 SIDR4/SODR4 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $00002 \mathrm{~A}_{\mathrm{H}}$ | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |  |  |
| $0^{000084}{ }_{\text {H }}$ | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |  |  |
| $00008 \mathrm{~A}_{\mathrm{H}}$ |  |  |  |  |  |  |  |  |  |  |
| Read/write $¢>$ | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) |  |  |
| Initial value $\Rightarrow>$ | (X) | (X) | (X) | (X) | (X) | (X) | (X) | (X) |  |  |

Serial status register

| Address : $0000023_{\mathrm{H}}$ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | > Bit number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{000023}{ }^{\text {H }}$ | PE | ORE | FRE | RDRF | TDRE | - | RIE | TIE | SSR0 |
| $85 \mathrm{H}$ | PE | ORE | FRE | RDRF | TDRE |  | RIE | TIE | SSR1 |
| Read/write $\Rightarrow$ | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | SSR2 |
| Initial value $\Rightarrow$ | (0) | (0) | (0) | (0) | (1) | (-) | (0) | (0) | SSR4 |

Figure 12.3a Registers of UART

### 12.3.1 Serial Mode Register (SMR0/1/2/3/4)

Serial mode register

| Address : $\begin{array}{r}000020_{\mathrm{H}} \\ 000024_{\mathrm{H}}\end{array}$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\checkmark$ Bit number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 000028_{\mathrm{H}} \\ & 000088_{\mathrm{H}} \end{aligned}$ | MD1 | MD0 | CS2 | CS1 | CS0 | Reserved | SCKE | SOE | SMR0 |
| $000082_{\mathrm{H}}$ <br> Read/write $\Rightarrow$ | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | SMR2 |
| Initial value $\Rightarrow>$ | (0) | (0) | (0) | (0) | (0) | (0) | (0) | (0) | SMR4 |

The SMR register specifies the UART operation mode. Set the operation mode while the UART is stopped. Do not write data in this register during UART operation.
[bits 7 and 6] MD1 and MD0 (Mode select):
These bits are used to select the UART operation mode.

| Mode | MD1 | MD0 | Operation mode |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | Asynchronous normal mode |
| 1 | 0 | 1 | Asynchronous multi-processor mode |
| 2 | 1 | 0 | CLK synchronous mode |
| - | 1 | 1 | Setting inhibited |

Note: In CLK asynchronous multi-processor mode (mode 1), two or more slave CPUs are connected to a single host CPU. This resource cannot identify the format of the received data.
Therefore, this resource only supports a master in multi-processor mode.
Since the parity check function cannot be used, write '0' to PEN of the SCR register.
[bits 5 to 3] CS2, CS1, and CS0 (Clock select):These bits are used to select the baud rate clock source.
When a dedicated baud rate generator is selected, the baud rate is determined at the same time.

| CS2 | CS1 | CSO | Clock input |
| :---: | :---: | :---: | :--- |
| $000_{\mathrm{B}}$ to $100_{\mathrm{B}}$ |  | Dedicated baud rate generator |  |
| 1 | 0 | 1 | reserved |
| 1 | 1 | 0 | Internal timer |
| 1 | 1 | 1 | External clock |

Note: If an internal timer is selected, timer 0 is used for UART0 and UART3 in the MB90580 series.
Note: If an internal timer is selected, timer 1 is used for UART1 and UART4 in the MB90580 series.
Note: If an internal timer is selected, timer 0 is used for UART2 in the MB90580 series.
[bit 2] Reserved bit
Always write '0' to this bit.
[bit 1] SCKE (SCLK enable):
This bit is used to specify whether to use the SCKO pin as a clock input pin or clock output pin in CLK synchronous mode (mode 2) communication.
Set '0' in this bit in CLK asynchronous mode or external clock mode.

| 0 | The SCK0 pin is used as a clock input pin. | [initial value] |
| :---: | :--- | :---: |
| 1 | The SCK0 pin is used as a clock output pin. |  |

Note: To use the SCKO pin as a clock input pin, an external clock source must have been selected.
[bit 0] SOE (Serial output enable):
This bit is used to specify whether the external pin is used as a serial output pin (SOTO) or I/O port pin.

| 0 | The external pin is used as a general-purpose I/O port pin. | [initial value] |
| :--- | :--- | :--- |
| 1 | The external pin is used as a serial data output (SOTO) pin. |  |

### 12.3.2 Serial Control Register (SCR0/1/2/3/4)

| Serial control register $\text { Address : } 000021_{\mathrm{H}}$ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | > Bit number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 000029_{\mathrm{H}} \\ & 000083_{\mathrm{H}} \end{aligned}$ | PEN | P | SBL | CL | A/D | REC | RXE | TXE | SCRO <br> SCR1 |
| $000089_{\mathrm{H}}$ <br> Read/write Initial value | (R/W) <br> (0) | (R/W) <br> (0) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | (R/W) <br> (0) | (R/W) <br> (1) | (R/W) <br> (0) | (R/W) <br> (0) | SCR2 <br> SCR3 <br> SCR4 |

The SCR register controls the transfer protocol for serial communications.
[bit 15] PEN (Parity enable):
This bit is used to specify whether to perform serial data communication using a parity bit.

| 0 | With parity |
| :---: | :--- | [initial value] 9

Note: A parity bit can be added only in normal asynchronous communication mode (mode 0). No parity bit can be added in multi-processor mode (mode 1) or CLK synchronous communication mode (mode 2).
[bit 14] P (Parity):
This bit is used to specify an even- or odd-numbered parity for data communications with parity.

| 0 | Even-numbered parity |
| :---: | :--- | [initial value]

[bit 13] SBL (Stop bit length)
This bit is used to specify the length of the stop bit, which is used as a frame end mark in asynchronous communications.

| 0 | 1 stop bit | [initial value] |
| :--- | :--- | :--- |
| 1 | 2 stop bits |  |

[bit 12] CL (Character length):
This bit is used to specify the data length of each frame to be sent or received.

| 0 | 7-bit data |
| :---: | :---: | [initial value] 9

Note: 7-bit data can be handled only in normal synchronous communication mode (mode 0). Specify 8 -bit data in multi-processor mode (mode 1) or CLK synchronous communication mode (mode 2).
[bit 11> A/D (Address/data):
This bit is used to specify the data format of the frame to be sent or received in multi-processor asynchronous communication mode (mode 1).

| 0 | Data frame | [initial value] |
| :--- | :--- | :--- |
| 1 | Address frame |  |

[bit 10] REC (Receiver error clear):
This bit is used to clear the SSR register error flags (PE, ORE, and FRE). Writing ' 1 ' to this bit is invalid.
' 1 ' is always read from this bit.
[bit 9] RXE (Receiver enable):
This bit is used to control UART reception.

| 0 | Disables reception. | [initial value] |
| :---: | :--- | :--- |
| 1 | Enables reception. |  |

Note: If reception is disabled while data is being received (being input to the reception shift register), reception is terminated when the reception of that frame is completed and the reception data is stored in the reception data buffer (SIDR register).
[bit 8] TXE (Transmitter enable):
This bit is used to control UART transmission.

| 0 | Disables transmission | [initial value] |
| :---: | :--- | :--- |
| 1 | Enables transmission. |  |

Note: If transmission is disabled while data is being transmitted (being output from the transmission register), transmission is terminated after all data in the transmission data buffer (SODR register) has been output.

### 12.3.3 Serial Input Data Register (SIDR0/1/2/3/4)/ Serial Ouput Data Register (SODR0/1/2/3/4)

## Serial input register/Serial output register



These registers are data buffer registers for transmission and reception.
When a data item is seven bits long, the high-order one bit (D7) is invalid. To write a data item in the SODR register, ensure that ' 1 ' is written to TDRE of the SSR register.
Note: Writing a data item at this address means to write it to the SODR register. Reading this address means to read the SIDR register.

### 12.3.4 Serial Status Register (SSR0/1/2/3/4)

## Serial input register/Serial output register

| Address : $\begin{array}{r}000022_{\mathrm{H}} \\ 000026_{\mathrm{H}}\end{array}$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | « Bit number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 00002 A_{H} \\ & 000084 \mathrm{u} \end{aligned}$ | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | SIDR0/SODR0 SIDR1/SODR1 SIDR2/SODR2 |
| $00008 \mathrm{~A}_{\mathrm{H}}$ |  |  |  |  |  |  |  |  |  |
| Read/write $\Rightarrow$ ¢ | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | SIDR3/SODR3 |
| Initial value $\Rightarrow>$ | (X) | (X) | (X) | (X) | (X) | (X) | (X) | (X) |  |

The SSR register consists of the flags indicating the UART operation.
[bit 15] PE (Parity error)
This interrupt request flag is set when a parity error occurs during reception.
To clear a set flag, write '0' to the REC bit (bit 10) of the SCR register.
When this bit is set, the data in SIDR is invalid.

| 0 | No parity error has occurred. | [initial value] |
| :--- | :--- | :--- |
| 1 | A parity error has occurred. |  |

[bit 14] ORE (Overrun error):
This interrupt request flag is set when an overrun error occurs during reception.
To clear a set flag, write '0' to the REC bit (bit 10) of the SCR register.
When this bit is set, the data in SIDR is invalid.

| 0 | No overrun error has occurred. | [initial value] |
| :--- | :--- | :--- |
| 1 | An overrun error has occurred. |  |

[bit 13] FRE (Framing error)
This interrupt request flag is set when a framing error occurs during reception.
To clear a set flag, write '0' to the REC bit (bit 10) of the SCR register.
When this bit is set, the data in SIDR is invalid.

| 0 | No framing error has occurred. | [initial value] |
| :--- | :--- | :--- |
| 1 | A framing error has occurred. |  |

[bit 12] RDRF (Receiver data register full):
This interrupt request flag indicates that the SIDR register contains received data.
This flag is set when received data is loaded into the SIDR register. This flag is automatically cleared when the SIDR register is read.

| 0 | No received data exists. | [initial value] |
| :--- | :--- | :--- |
| 1 | Received data exists. |  |

[bit 11] TDRE (Transmitter data register empty):
This interrupt request flag indicates that transmission data can be written into the SODR register.
This flag is cleared when transmission data is written into the SODR register. Then, when the written data is loaded into the transmission shifter and transfer starts, this flag is set again, indicating the next transmission data item can be written.

| 0 | Writing transmission data is disabled. |  |
| :--- | :--- | :--- |
| 1 | Writing transmission data is enabled. | [initial value] |

0 : Writing transmission data is disabled.
1: Writing transmission data is enabled.
[bit 9] RIE (Receiver interrupt enable):
This bit is used to control reception interrupts.

| 0 | Interrupts are disabled |
| :--- | :--- | [initial value] 9

Note: Reception interrupt causes include normal reception by RDRF in addition to errors due to PE, ORE, and FRE.
[bit 8] TIE (Transmitter interrupt enable):
This bit is used to control transmission interrupts.

| 0 | Interrupts are disabled |
| :--- | :---: | [initial value] |  |  |  |
| :--- | :--- | :--- |
| 1 | Interrupts are enabled. |  |

Note: Transmission interrupt causes include transmission requests by TDRE.

### 12.4 Operations

### 12.4.1 Operation modes

Table 12.4.1a lists the operation modes of UART. The modes can be switched by setting a value in the SMR or SCR register.

Table 12.4.1a UART operation modes

| Mode | Parity | Data <br> length | Operation mode | Stop bit length |
| :---: | :---: | :---: | :--- | :---: |
| 0 | Yes/No | 7 | Asynchronous normal mode | 1 bit or 2 bits |
|  | Yes/No | 8 |  |  |
| 1 | No | $8+1$ | CLK synchronous mode |  |
|  | No | 8 | No |  |

Note: In asynchronous mode, the stop bit length can be specified for transmission only; the stop bit is always one bit long for reception. If a two-bit stop bit length is specified, the UART does not operate.
Note: When using clock synchronous mode, start bit and stop bit is not attached to the data byte.

### 12.4.2 UART clock selection

(1) Dedicated baud rate generator

When a dedicated baud rate generator is selected, the following baud rates are used:
Table 12.4.2a Baud rate (f indicates the machine clock.)

| CS2 | CS1 | CS0 | Asynchronous | Calculation |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 9615 | $(\varnothing \div$ div $) /(8 \times 13 \times 2)$ |
| 0 | 0 | 1 | 4808 | $(\varnothing \div$ div $) /\left(8 \times 13 \times 2^{2}\right)$ |
| 0 | 1 | 0 | 2404 | $(\varnothing \div$ div $) /\left(8 \times 13 \times 2^{3}\right)$ |
| 0 | 1 | 1 | 1202 | $(\varnothing \div$ div $) /\left(8 \times 13 \times 2^{4}\right)$ |
| 1 | 0 | 0 | 31250 | $(\varnothing \div$ div $) / 2^{6}$ |


| CS2 | CS1 | CS0 | CLK synchronous |  | Calculation |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 1 | M | $(\varnothing \div \operatorname{div}) / 2$ |
| 0 | 0 | 1 | 500 | K | $(\varnothing \div$ div $) / 2^{2}$ |
| 0 | 1 | 0 | 250 | K | $(\varnothing \div \mathrm{div}) / 2^{3}$ |
| 0 | 1 | 1 | 125 | K | $(\varnothing \div \mathrm{div}) / 2^{4}$ |
| 1 | 0 | 0 | 62.5 K | $(\varnothing \div \mathrm{div}) / 2^{5}$ |  |

Note: $\varnothing$ : Machine clock
div: Division ration
Please refer to chaper 11, Communication Prescaler.
(2) Internal timer

When '110' is set in CS2 to CS0 and an internal timer is selected, the 16-bit timer (timer 0 ) is used in reload mode. The baud rate is calculated as described below in this case:
Asynchronous: $\quad(\varnothing \div \mathrm{N}) /(16 \times 2 \times(\mathrm{n}+1))$
CLK synchronous: $\quad(\varnothing \div \mathrm{N}) /(2 \times(\mathrm{n}+1))$
$\varnothing:$ Machine clock
$\mathrm{N}:$ Timer count clock sourc
$\mathrm{n}:$ Timer reload value

Table 12.4.2b lists the baud rates and reload values (decimal) at a machine clock of $7,3728 \mathrm{MHz}$

Table 12.4.2b Baud rates and reload values

|  | $\mathbf{N}=\mathbf{2}^{\mathbf{1}}$ <br> (Machine clock/2) | $\mathbf{N} \mathbf{N O}^{\mathbf{3}}$ <br> (Machine clock/8) |
| :---: | :---: | :---: |
| 38400 | 2 | - |
| 19200 | 5 | - |
| 9600 | 11 | 2 |
| 4800 | 23 | 5 |
| 2400 | 47 | 11 |
| 1200 | 95 | 23 |
| 600 | 191 | 47 |
| 300 | 383 | 95 |

When an internal timer (16-bit timer 0 ) is selected as a baud rate clock source, the 16-bit timer 0 output (TOUTO) is connected inside the controller. Therefore, externally connecting the 16-bit timer 0 external pin (TOTO) to the external clock input pin (SCKO) of the UART is unnecessary. If the timer 0 output pin is not used for other purposes, it can be used as an I/O port pin.
(3) External clock

When '111' is set in CS2 to CS0 and an external clock is selected, the baud rate can be expressed as described below, assuming $f$ to be the external clock frequency:

Asynchronous: f/16
CLK synchronous: f
Note: f is up to 1 MHz .

### 12.4.3 Asynchronous mode

(1) Transfer data format

UART handles NRX (non return to zero) format data only. Figure 12.4.3a gives the data format.


Figure 12.4.3a Transfer data format (modes 0 and 1 )

As shown in Figure 12.4.3a, the transfer data always starts from the start bit ('L' level data), transfer is based on the data bit length specified by the first LSB, and transfer ends at the stop bit ('H' level data). When external clock is selected, ensure that the clock is input.
In normal mode (mode 0 ), the data length can be 7 or 8 bits. In multi-processor mode (mode 1), the data length must be 8 bits. In multi-processor mode, no parity bit can be added. Instead, the A/D bit is always added.

## (2) Reception

Data is always received while ' 1 ' is written to the RXE bit (bit 9 ) of the SCR register.
When the start bit appears in the reception line, one frame of data is received according to the data format determined by the SCR register. Once a frame has been received, an error flag is set if an error has occurred, and the RDRF flag (bit 12 of the SSR register) is set. At that time, if ' 1 ' is written to the RIE bit (bit 9 ) of the same SSR register, a reception interrupt is issued to the CPU. Check the flags of the SSR register. Read the SIDR register if the reception has been normal. If an error has occurred, take appropriate measures.

The RDRF flag is cleared when the SIDR register is read.
(3) Transmission

Transmission data is written into the SODR register when '1' is set in the TXE bit (bit 8) of the SSR register. Then, if ' 1 ' ' is written to the TXE bit (bit 8) of the SCR register, transmission is performed.

When the data set in the SODR register is loaded into the transmission shift register and transmission starts, the TDRE flag is set again and the next transmission data item can be set. At that time, if ' 1 ' is written to the TIE bit (bit 8) of the same SSR register, a transmission interrupt is issued to the CPU, requesting to set the transmission data in the SODR register.
The TDRE flag is cleared when data is written to the SODR register.

### 12.4.4 CLK synchronous mode

(1) Transfer data format

UART handles NRX (non return to zero) format data only. Figure 12.4.4a shows the transmission/reception clock and data.


Figure 12.4.4a Transfer data format (mode 2)

When the internal clock (dedicated baud rate generator or internal timer) is selected, a data reception synchronization clock is automatically generated upon data transmission.
When an external clock is selected, it is necessary to supply precisely one byte of clock after it is confirmed that the transmission data buffer (SODR register) of the transmission UART contains data (the TDRE flag is '0'). Ensure that the signal is at the mark level before and after transmission.
Only 8-bit data can be handled, and no parity bit can be added. Since there is no start or stop bits, no errors are detected except for an overrun error.
(2) Initialization

The control register values for CLK synchronous mode are listed below.
(1) SMR register

MD1 and MD0 : 10
CS2, CS1, and CS0: Clock input
SCKE : Dedicated baud rate generator or internal timer: 1External clock: 0
SOE : Transmission and reception: 1 Reception only: 0
(2) SCR register

PEN : 0
P, SBL, A/D : Invalid
CL : 1
REC : 0 (To be initialized)
RXE and TXE : 1 written to one or both
(3) SSR register

RIE : Interrupts are enabled: 1 Interrupts are disabled: 0
TIE : 0

### 12.4 Operations

(3) Start of communication

Communication is started by writing data in the SODR register. Virtual transmission data must be written to the SODR register even when only reception is to be performed.
(4) End of communication

The end of communication can be checked by '1' written to the RDRF flag of the SSR register. Use the ORE bit of the SSR register to check whether communication has been successful.

### 12.4.5 Interrupt occurrence and flag set timing

UART has five flags and two interrupt causes.
The five flags are PE, ORE, FRE, RDRF, and TDRE. PE indicates a parity error, ORE indicates an overrun error, and FRE indicates a framing error. These three flags are set when the corresponding error occurs during reception, and are cleared when ' 0 ' is written to REC of the SCR register. RDRF is set when the received data is loaded into the SIDR register, and is cleared when the SIDR register is read. The parity detection function is not available in mode 1, and the parity and framing error detection functions are not available in mode 2. TDRE is set when the SODR register becomes empty and can be written to. TDRE is cleared when the SODR register is written to.
The two interrupt causes are for reception and transmission. During reception, an interrupt is requested by PE, ORE, FRE, and RDRF. During transmission, an interrupt is requested by TDRE. The timing to set interrupt flags in each operation mode is described below.
(1) Reception in mode 0

The PE, ORE, FRE, and RDRF flags are set when reception is completed and the last stop bit is detected. Then, an interrupt request is issued to the CPU. If the PE, ORE, and FRE flags are active, the data in SIDR is invalid.


Figure 12.4.5a Timing to set PE, ORE, FRE, and RDRF (mode 0)
(2) Reception in mode 1

The ORE, FRE, and RDRF flags are set when reception is completed and the last stop bit is detected. Then, an interrupt request is issued to the CPU. Since the receivable data length is eight bits, the ninth bit indicating the address and data is invalid. If the ORE and FRE flags are active, the data in SIDR is invalid.


Figure 12.4.5b Timing to set ORE, FRE, and RDRF (mode 1)
(3) Reception in mode 2

The ORE and RDRF flags are set when reception is completed and the last data item (D7) is detected.

Then, an interrupt request is issued to the CPU. If the ORE flag is active, the data in SIDR is invalid.


Figure 12.4.5c Timing to set ORE and RDRF (mode 2)
(4) Transmission in modes 0,1 , and 2

TDRE is cleared when a data item is written into the SODR register. When the data item is transferred to the internal shift register and the next data item can be written, TDRE is set and an interrupt request is issued to the CPU. If ' 0 ' is set in TXE (or additionally RXE in mode 2) of the SCR register during transmission, '1' is set in TDRE of the SSR register. Then, the transmission shifter stops and the transmission by UART is disabled. If ' 0 ' is set in TXE (or additionally RXE in mode 2) of the SCR register during transmission, the data set in the SODR register is transmitted before transmission stops.


Figure 12.4.5d Timing to set TDRE (modes 0 and 1 )


Figure 12.4.5e Timing to set TDRE (mode 2)

### 12.4.6 $\mathrm{I}^{2} \mathrm{OS}$ (Intelligent I/O service)

For $I^{2} O S$, see the section describing $I^{2} O S$.

### 12.4.7 Notes on use

To set a communication mode, ensure that UART is not in operation. The data sent or received during mode setting is not guaranteed.

### 12.4.8 Application

Mode 1 is used when two or more slave CPUs are connected to a single host CPU (see Figure 12.4.8a). This resource only supports the host side communication interface.


Figure 12.4.8a Sample system configuration in mode 1
Communication starts when the host CPU transfers address data. Address data means the data used when ' 1 ' is set in A/D of the SCR register. The address data determines the destination slave CPU and enables communication between the host and slave CPUs. Ordinary data means the data used when ' 0 ' is set in A/D of the SCR register. Figure 12.4.8b shows the flowchart.
In mode 1, the parity check function cannot be used. Therefore, set '0' in the PEN bit of the SCR register.


Figure 12.4.8b Flow chart of communication in mode 1

## Chapter 13: <br> IE Bus

### 13.1 Outline

IEBus (Inter Equipment Bus) is a small-scale two-line serial bus interface intended to transfer data between equipment and equipment. It is designed for use in automotive and general industrial applications.
The communication protocol of the IEBus has the following features:

- Multi-master method

All the units connected to the IEBus can transfer data to the other units.

- Multiaddress communication function (one unit can communicate to two or more units simultaneously) Group communication: multiaddress communication to group unit Broadcasting communication: multiaddress communication to all units
- Three different transfer rates can be selected:

| Mode | IE Bus Internal Frequency <br> at 6 MHz | IE Bus Internal Frequency <br> at 6 MHz |
| :---: | :---: | :---: |
| 0 | Approx. 3.9 Kbps | Approx. 4.1 Kbps |
| 2 | Approx. 17 Kbps | Approx. 18 Kbps |
| 3 | Approx. 26 Kbps | Approx. 27 Kbps |

- Transmit Data Buffer : 8-Byte FIFO
- Receive Data Buffer : 8-Byte FIFO
- CPU internal operation frequency: $12 \mathrm{MHz}, 12.58 \mathrm{MHz}$


### 13.2 Block Diagram



Note: Function of Control Circuitry

1. Control the number of transmit/receive bytes
2. Control max. number of byte transmission
3. Detect arbitration
4. Determine acknowledgement
5. Generate interrupt

Figure 13.2a Block Diagram of IE Bus

### 13.3 Registers and Register Details

| Command register upper byte (CMRH) |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | $8<$ Bit Number |
| Address: $000077_{\mathrm{H}}$ | MD1 | MD0 | PCOM | RIE | TIE | GOTM | GOTS | Reserved CMRH |
| Read/write $\Rightarrow$ Initial value $\Rightarrow$ | (R/W) (0) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\underset{(\mathrm{X})}{(\mathrm{R} / \mathrm{W})}$ |
| Command register lower byte (CMRL) |  |  |  |  |  |  |  |  |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | $0<$ Bit Number. |
| Address: $000076{ }_{\text {H }}$ | RXS | TXS | TIT1 | TITO | CS1 | CSO | RDBC | WDBC CMRL |
| Read/write $\qquad$ Initial value $\qquad$ | $(\mathrm{R} / \mathrm{W})$ <br> (1) | (R/W) <br> (1) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | (R/W) <br> (0) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\underset{(0)}{(\mathrm{R} / \mathrm{W})}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ |
| Unit address register (MAWH, MAWL) |  |  |  |  |  |  |  |  |
|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | $8<$ Bit Number |
| Address: $000071_{\mathrm{H}}$ | Reserved | Reserved | Reserved | Reserved | MA11 | MA10 | MA09 | MA08 MAWH |
| Read/write $\qquad$ Initial value $\Rightarrow$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | $(R / W)$ $(X)$ | (R/W) $(X)^{\prime}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \end{gathered}$ | (R/W) $(X)$ | (R/W) (X) | (R/W) $(X)$ | $(R / W)$ $(X)$ |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | $0<$ Bit Number |
| Address: $000070_{H}$ | MA07 | MA06 | MA05 | MA04 | MA03 | MA02 | MA01 | MA00 MAWL |
| Read/write $\qquad$ Initial value $\Rightarrow$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | (R/W) $(X)$ | (R/W) $(X)$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \end{gathered}$ | (R/W) $(X)$ | (R/W) (X) | (R/W) (X) | $\underset{(\mathrm{X})}{(\mathrm{R} / \mathrm{W})}$ |
| Slave address register (SAWH, SAWL) |  |  |  |  |  |  |  |  |
|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | $8<$ Bit Number |
| Address: $000073_{\mathrm{H}}$ | Reserved | Reserved | Reserved | Reserved | SA11 | SA10 | SA09 | SA08 SAWH |
| Read/write $\qquad$ Initial value $\Rightarrow$ | $(R / W)$ (X) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | $(R / W)$ $(X)$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \end{gathered}$ | (R/W) (X) | $\underset{(\mathrm{X})}{(\mathrm{R} / \mathrm{W})}$ | (R/W) $(X)$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | $0<$ Bit Number |
| Address: $000072_{H}$ | SA07 | SA06 | SA05 | SA04 | SA03 | SA02 | SA01 | SA00 SAWL |
| Read/write $\qquad$ (R/W)$\qquad$ |  | $\underset{(\mathrm{X})}{(\mathrm{R} / \mathrm{W})}$ | $\underset{(X)}{(\mathrm{R} / \mathrm{W})}$ | $\underset{(\mathrm{X})}{(\mathrm{R} / \mathrm{W})}$ | $\underset{(X)}{(R / W)}$ | $\underset{(\mathrm{X})}{(\mathrm{R} / \mathrm{W})}$ | $(R / W)$ $(X)$ | $\underset{(\mathrm{X})}{(\mathrm{R} / \mathrm{W})}$ |

Figure 13.3a Registers of IE BUS (1/3)

| Mutliaddress, control bit set register (DCWR) |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $\triangleleft$ Bit Number |
| Address: $000075_{\mathrm{H}}$ | DO3 | DO2 | DO1 | DOO | C3 | C2 | C1 | C0 | DCWR |
| Read/write $\Rightarrow$ Initial value $\Rightarrow$ | $\underset{(0)}{(\text { R/W })}$ | $\underset{(0)}{(\text { R/W })}$ | $\begin{gathered} \text { (R/W) } \\ (0) \end{gathered}$ | $\begin{gathered} \text { (R/W) } \\ (0) \end{gathered}$ | $\begin{gathered} \text { (R/W) } \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (R / W) \\ (0) \end{gathered}$ | $\underset{(0)}{(\mathrm{R} / \mathrm{W})}$ |  |

Telegraph length set register (DEWR)

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\triangleleft$ Bit Number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: 000074 ${ }_{\text {H }}$ | DE7 | DE6 | DE5 | DE4 | DE3 | DE2 | DE1 | DE0 | DECR |
| Read/write $\qquad$ Initial value $\Rightarrow$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | (R/W) (0) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | (R/W) (0) | (R/W) <br> (0) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ |  |

Status register upper byte (STRH)

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $\leadsto$ Bit Number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: 000079 ${ }_{\text {H }}$ | COM | TE | PEF | ACK | RIF | TIF | TSL | EOD | STRH |
| Read/write $\qquad$ Initial value $\Rightarrow$ | (R) (0) | (R/W) | (R) (X) | (R) (X) | (R/W) $(0)$ | $\underset{(0)}{(R / W)}$ | (R) $(0)$ | $\begin{aligned} & (\mathrm{R}) \\ & (0) \end{aligned}$ |  |

Status register lower byte (STRL)

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $<$ Bit Number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: 000078 | WDBF | RDBF | WDBE | RDBE | ST3 | ST2 | ST1 | ST0 | STRL |
| Read/write $\qquad$ Initial value $\leftrightarrows$ | $\begin{aligned} & (\mathrm{R}) \\ & (0) \end{aligned}$ | (R) (0) | (R) | (R) <br> (1) | (R) (X) | $\begin{aligned} & \text { (R) } \\ & (\mathrm{X}) \end{aligned}$ | $\begin{aligned} & (\mathrm{R}) \\ & (\mathrm{X}) \end{aligned}$ | $\begin{aligned} & \text { (R) } \\ & \text { (X) } \end{aligned}$ |  |

Lock read register (LRRH, LRRL)

| Address: $00007 \mathrm{~B}_{\mathrm{H}}$ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $<$ Bit Number LRRH |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Reserved | Reserved | Reserved | LOC | LD11 | LD10 | LD09 | LD08 |  |
| Read/write $\qquad$ Initial value $\Rightarrow$ | (R) <br> (1) | (R) <br> (1) | (R/W) | (R) $(0)$ | (R) (X) | (R) (X) | (R) (X) | (R) (X) |  |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\leadsto$ Bit Number |
| Address: $00007 \mathrm{~A}_{\mathrm{H}}$ | LD07 | LD06 | LD05 | LD04 | LD03 | LD02 | LD01 | LD00 | LRRL |
| Read/write $\qquad$ Initial value $\Rightarrow$ | (R) $(X)$ | (R) (X) | (R) (X) | (R) (X) | (R) (X) | (R) (X) | (R) (X) | (R) (X) |  |

Figure 13.3b Registers of IE BUS (2/3)

Master address read register (MARH, MARL)

| Address: $00007 \mathrm{D}_{\mathrm{H}}$ | 15 | $14 \quad 13$ |  | $12 \quad 11$ |  | 10 | 9 | 8 | $<$ Bit Number <br> MARH |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Reserved | Reserved | Reserved | Reserved | MA11 | MA10 | MA09 | MA08 |  |
| Read/write $\Rightarrow$ | (R) | (R) | (R) | (R) | (R) | (R) | (R) | (R) |  |
| Initial value $¢$ | (1) | (1) | (1) | (1) | (X) | (X) | (X) | (X) |  |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\Longleftrightarrow$ Bit Number |
| Address: $00007 \mathrm{C}_{\mathrm{H}}$ | MA07 | MA06 | MA05 | MA04 | MA03 | MA02 | MA01 | MA00 | MARL |
| $\begin{aligned} \text { Read/write } & \\ \text { Initial value } & \end{aligned}$ | (R) (X) | (R) (X) | (R) (X) | (R) (X) | (R) (X) | (R) (X) | (R) (X) | (R) (X) |  |

Multiaddress, control bit read register (DCRR)

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $\triangleleft$ Bit Number <br> DCRR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $00007 \mathrm{~F}_{\mathrm{H}}$ | DO3 | DO2 | DO1 | DO0 | C3 | C2 | C1 | C0 |  |
| Read/write $\qquad$ Initial value $\qquad$ | (R) (0) | (R) (0) | (R) $(0)$ | (R) (X) | (R) (X) | (R) (X) | (R) (X) | (R) (X) |  |

Telegraph length read register (DERR)

| Address: $00007 \mathrm{E}_{\mathrm{H}}$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $<$ Bit Number <br> DERR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | DE7 | DE6 | DE5 | DE4 | DE3 | DE2 | DE1 | DE0 |  |
| Read/write $\qquad$ Initial value $\Rightarrow$ | (R) (X) | (R) (X) | (R) (X) | (R) (X) | (R) (X) | (R) (X) | (R) (X) | (R) (X) |  |

Read data buffer (RDB)

| Address: 000081 ${ }_{\text {H }}$ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $\triangleleft$ Bit Number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RD7 | RD6 | RD5 | RD4 | RD3 | RD2 | RD1 | RD0 | RDB |
| Read/write $\qquad$ Initial value $\Rightarrow$ | (R) (X) | (R) (X) | (R) (X) | (R) (X) | (R) (X) | (R) (X) | (R) (X) | (R) (X) |  |

Write data buffer (WDB)

| Address: 000080 ${ }_{\text {H }}$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\longleftarrow$ Bit Number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | WD7 | WD6 | WD5 | WD4 | WD3 | WD2 | WD1 | WD0 | WDB |
| Read/write $\leftrightarrows$ | (W) | (W) | (W) | (W) | (W) | (W) | (W) | (W) |  |
| Initial value $\leftrightarrows$ | (X) | (X) | (X) | (X) | (X) | (X) | (X) | (X) |  |

Figure 13.3c Registers of IE BUS (3/3)

### 13.3.1 Command register upper byte (CMRH)

| Command register upper byte (CMRH) |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $000077_{H}$ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | $8<$ | $\leadsto$ Bit Number |
|  | MD1 | MD0 | PCOM | RIE | TIE | GOTM | GOTS | Reserved | CMRH |
| Read/write $\qquad$ Initial value $\qquad$ | $\begin{gathered} (R / W) \\ (0) \end{gathered}$ | $\begin{gathered} (R / W) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (R / W) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (R / W) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ |  |

[bits 15 and 14] MD1, MD0 (Mode select):
These bits are used to select the IEBus operation mode.
Table 13.3.1a Transmission mode

| MD1 | MD0 | Operation mode |
| :---: | :---: | :--- |
| 0 | 0 | Mode 0 |
| 0 | 1 | Mode 1 |
| 1 | 0 | Mode 2 |
| 1 | 1 | Setting inhibited |

[bit 13] PCOM (Communication enable):
This bit is used to enable IEBus communication. When PCOM is written ' 1 ', the COM flag in status register (STRH) is set and then the communication is enabled. When PCOM is written ' 0 ', the communication is ended. Please set this bit to ' 1 ' if the COM flag in the status register is ' 0 '.
[bit 12] RIE (Receive interrupt enable):
This bit controls receive interrupt as described below.

| 0 | Receive interrupt disabled |
| :--- | :--- |
| 1 | Receive interrupt enabled |

The receive interrupt is occurred under the following condition:

- The eight byte Receive data buffer (RDB) is full.
- Data reception is finished normally.
- The communication has ended without receiving the number of data specified by telegraph length field in one communication frame.
- When arbitration lost, the unit cannot be selected as slave unit.
[bit 11] TIE (Transmit interrupt enable):
This bit controls transmit interrupt as described below.

| 0 | Transmit interrupt disabled |
| :---: | :--- |
| 1 | Transmit interrupt enabled |

The transmit interrupt is occurred under the following condition:

- In master transmit, after master address field has been transmitted, the master unit has won in arbitration.
- In slave transmit, the control bits requesting for data transmit are received from master unit.
- Writing the number of data bytes (controlled by TIT1, TIT0 bits of command register, CMRL) into write data buffer (WDB) is requested.
- Transmission of the number of data specified by telegraph length field has been completed in one communication frame.
- The communication has ended without transmitting the number of data specified by telegraph length field in one communication frame.
[bit 10] GOTM (Master transmit):
This bit indicates the start of transmission. After the communication inhibit state has been released, when GOTM is set to ' 1 ', data transmission begins. This bit is written ' 1 ' only and alwaays read " 0 ". Writing ' 0 ' to this bit has no meaning.


## [bit 9] GOTS (Slave transmit):

This bit indicates the start of transmission. After the communication inhibit state has been released, when GOTS is set to ' 1 ', data transmission begins. This bit is written ' 1 ' only and always read" 0 ". Writing ' 0 ' to this bit has no meaning.

Table 13.3.1b Setting for GOTM and GOTS

| GOTM | GOTS | Abritration | Slave <br> Transmit | Operation |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | none | not allowed | slave receive |
| 0 | 1 | none | allowed | slave transmit |
| 1 | 0 | present | not allowed | after abritration lost, it can change to slave receive |
| 1 | 1 | present | allowed | after abritration lost, it can change to slave transmit |

[bit 8] Reserved bits
Always write ' 1 ' to this bit and the read value is undefined.

### 13.3.2 Command register lower byte (CMRL)

| Command register lower byte (CMRL) |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $000076_{H}$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Bit Number. |
|  | RXS | TXS | TIT1 | TITO | CS1 | CSO | RDBC | WDBC | CMRL |
| Read/write $\qquad$ Initial value $\Rightarrow$ | (R/W) (1) | (R/W) <br> (1) | (R/W) (0) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | (R/W) (0) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | (R/W) (0) |  |

[bit 7] RXS
RX input pin polarity selected for external driver/receiver.
Table 13.3.2a Interval for the occurrence of data transmit interrupt

| RXS | $R X$ input status |
| :---: | :--- |
| 0 | $R X$ pin as postive logic input. Logic ' 1 ' is high level and Logic ' 0 ' is Low level. |
| 1 | $R X$ pin as negative logic input. Logic ' 1 ' is low level and Logic ' 0 ' is high level. |

[bit 6] TXS
TX output pin polarity selected for external driver/receiver.
Table 13.3.2b Interval for the occurrence of data transmit interrupt

| TXS | TX output |
| :---: | :---: |
| 0 | TX pin as postive logic output. Logic ' 1 ' is high level and Logic ' 0 ' ' is Low level. |
| 1 | TX pin as negative logic output. Logic ' 1 ' is low level and Logic 0 ' is high level. |

Note1: For MB90580 series, during reset, TX pin will output 'L'. If the driver/receiver used is in positive logic (Driver/receiver enable at ' $L$ '), TX outputs ' $L$ ' from reset to bit setting that will generate a communication error when there is a communication between other communication units. When it happens, it needs a outside circuit to input ' H ' to the driver/receiver from reset to bit setting.
[bit 5, 4] TIT1, TIT0 (Data transmit interrupt control bits)
These bits control the time interval of the occurrence of interrupt for writing transmit data in write data buffer (WDB).

Table 13.3.2c Interval for the occurrence of data transmit interrupt

| TIT1 | TIT0 | Timing for interrupt occurs |
| :---: | :---: | :--- |
| 0 | 0 | More than one byte data can be written in WDB |
| 0 | 1 | More than two byte data can be written in WDB |
| 1 | 0 | More than four byte data can be written in WDB |
| 1 | 1 | Eight byte data can be written in WDB |

[bit 3, 2] CS1, CS0 (Cycle select):
These bits control both the CPU internal clock cycle and IEBUS controller clock cycle and CS1 and CS0 must be set to ' 0 '. .

Table 13.3.2d Internal clock frequency

| CS1 | CS0 | CPU internal clock $\phi$ | IEBus internal <br> clock | Equation |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | $12 \mathrm{MHz}(12.58 \mathrm{MHz})$ | $6 \mathrm{MHz}(6.29 \mathrm{MHz})$ | $\phi_{\text {IE }}=\phi / 2$ |
| 0 | 1 | Setting inhibited | ---- | ---- |
| 1 | 0 | Setting inhibited | ---- | --- |
| 1 | 1 | Setting inhibited | ---- | --- |

Note1: The CPU and IEBus internal clock frequency are calculated by the above equation provided that the CPU operating frequency is inside the guaranteed range.
Note2: The accuracy of clock cycle calculation for mode 0 and 1 is $\pm 1.5 \%$, and for mode 2 is $\pm 0.5 \%$.
[bit 1] RDBC (Read data buffer clear):
This bit is used to clear the 8 -byte read data buffer, RDB. When this bit is set to ' 1 ', all the eight bytes in RDB are cleared. ( $\mathrm{RDBE}=1$ )
This bit is always read as ' 0 '.
[bit 0] WDBC (Write data buffer clear):
This bit is used to clear the 8 -byte write data buffer, WDB. When this bit is set to ' 1 ', all the eight bytes in WDB are cleared and WDB becomes empty (WDBE $=1$ )
This bit is alwarys read as ' 0 '.
For the communication with no. of byte transfer greater than the maximum transfer byte per frame, the data written in the previous frame will no longer valid if ' 1 ' is written to this bit. The data written in the current frame will be transmitted first. In converse, if ' 0 ' is written to this bit, the unsent data in the previous frame will be prioritized to be sent first.
If the transmission is terminated due to timing error, even thought ' 0 ' is written to this bit, the transmission will be started from the next data and not the last one which has not been sent completely.

### 13.3.3 Unit address register (MAWH, MAWL)

| Unit address register (MAWH, MAWL) |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $000071_{\mathrm{H}}$ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $<$ Bit Number |
|  | Reserved | Reserved | Reserved | Reserved | MA11 | MA10 | MA09 | MA08 | MAWH |
| Read/write $\qquad$ Initial value $\qquad$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | (R/W) <br> (X) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ |  |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $<$ Bit Number |
| Address: $000070_{H}$ | MA07 | MA06 | MA05 | MA04 | MA03 | MA02 | MA01 | MA00 | MAWL |
| Read/write $\qquad$ Initial value $\qquad$ | (R/W) <br> (X) | (R/W) (X) | (R/W) (X) | (R/W) (X) | (R/W) (X) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | (R/W) (X) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ |  |

These two registers MAWH, MAWL are used to set its own unit address (12 bits). When the unit is configured as master, the unit address set in MAWH, MAWL is transmitted as master address. When it is configured as slave mode, this unit address is used to compare with the received slave address.
Bit 15 to 12 are reserved bits and always write ' 1 ' to them. The read values are undefined.
Note:Make sure to set the unit address before the communication inhibit state is released.

### 13.3.4 Slave address register (SAWH, SAWL)

| Slave address register (SAWH, SAWL) |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $000073_{\mathrm{H}}$ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $\leadsto$ Bit Number |
|  | Reserved | Reserved | Reserved | Reserved | SA11 | SA10 | SA09 | SA08 | SAWH |
| Read/write $\qquad$ Initial value $\qquad$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | $\underset{(X)}{(R / W)}$ | $\underset{(\mathrm{X})}{(\mathrm{R} / \mathrm{W})}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | $\underset{(\mathrm{X})}{(\mathrm{R} / \mathrm{W})}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | $\underset{(\mathrm{X})}{(\mathrm{R} / \mathrm{W})}$ |  |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\leadsto$ Bit Number |
| Address: $000072_{H}$ | SA07 | SA06 | SA05 | SA04 | SA03 | SA02 | SA01 | SA00 | SAWL |
| $\begin{array}{ll} \text { Read/write } & \Longrightarrow(R / W) \\ \text { Initial value } & (X) \end{array}$ |  | $\underset{(X)}{(\mathrm{R} / \mathrm{W})}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (\mathrm{X}) \end{gathered}$ | $\underset{(\mathrm{X})}{(\mathrm{R} / \mathrm{W})}$ | $\begin{gathered} \text { (R/W) } \end{gathered}$ |  |

These two registers SAWH, SAWL are used to set the slave address ( 12 bits) for master transmit.
Bit 15 to 12 are reserved bits and always write ' 1 ' to them. The read values are undefined.
Note:Make sure to set the slave address before the communication inhibit state is released.

### 13.3.5 Mutliaddress, control bit set register (DCWR)

| Mutliaddress, control bit set register (DCWR) |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $\leadsto$ Bit Number |
| Address: 000075 ${ }_{\text {H }}$ | DO3 | DO2 | DO1 | DO0 | C3 | C2 | C1 | C0 | DCWR |
| Read/write $\qquad$ Initial value $\Rightarrow$ | $\begin{gathered} (R / W) \\ (0) \end{gathered}$ | (R/W) (0) | (R/W) (0) | (R/W) (0) | (R/W) (0) | (R/W) (0) | (R/W) (0) | (R/W) (0) |  |

[bit 15, 14, 13, 12] DO3, DO2, DO1, DO0 (Multiaddress/normal communication select bits):
These bits are used to select multiaddress (more than one slave) or normal communication (one slave).
For multiaddress communication, DO3-0 is set to '0000' and then the multiaddress bit in communication frame is sent out as ' 0 '.
For normal communication, DO3-0 is set to ' 1000 ' and then the multiaddress bit in communication frame is sent out as ' 1 '.
Always write ' 0 ' to bit 14,13 , and 12 , and when reading, these bits always return ' 0 '.
[bit 11, 10, 9, 8] C3, C2, C1, C0 (Control bits):
These bits are used to control IEBus communication.
Table 13.3.5a Control bits setting

|  | $\mathrm{C}^{\text {Note } 1}$ | C 2 | C 1 | C 0 | Control Operation |
| :--- | :---: | :---: | :---: | :---: | :--- |
| OH | 0 | 0 | 0 | 0 | Slave status read |
| 1 H | 0 | 0 | 0 | 1 | Undefined |
| 2 H | 0 | 0 | 1 | 0 | Undefined |
| 3 H | 0 | 0 | 1 | 1 | Data read and lock |
| 4 H | 0 | 1 | 0 | 0 | Lock address read (Lower 8 <br> bits) |
| 5 H | 0 | 1 | 0 | 1 | Lock address read (Upper 4 <br> bits) |
| 6 H | 0 | 1 | 1 | 0 | Slave status read and unlock |
| 7 H | 0 | 1 | 1 | 1 | Data read |
| 8 H | 1 | 0 | 0 | 0 | Undefined |
| 9 H | 1 | 0 | 0 | 1 | Undefined |
| AH | 1 | 0 | 1 | 0 | Command write and lock |
| BH | 1 | 0 | 1 | 1 | Data write and lock |
| CH | 1 | 1 | 0 | 0 | Undefined |
| DH | 1 | 1 | 0 | 1 | Undefined |
| EH | 1 | 1 | 1 | 0 | Command write |
| FH | 1 | 1 | 1 | 1 | Data write |

Note1: The transfer direction of telegraph length bits in telegraph length field and data bits in data field are controlled by the value of C 3 as follows:
When C 3 is ' 1 ': Transfer from master unit to slave unit
When C3 is ' 0 ': Transfer from slave unit to master unit
Note2: 3H, 6H, AH, BH are the lock and unlock function selection bits.
Note3: When sending the undefined control bits like $1 \mathrm{H}, 2 \mathrm{H}, 8 \mathrm{H}, 9 \mathrm{H}, \mathrm{CH}, \mathrm{DH}$, no acknowledge will be returned.

### 13.3.6 Telegraph length set register (DEWR)

| Telegraph length set register (DEWR) |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\propto$ Bit Number |
| Address: 000074 H | DE7 | DE6 | DE5 | DE4 | DE3 | DE2 | DE1 | DE0 | DECR |
| Read/write $\qquad$ Initial value $\qquad$ | $\begin{gathered} (R / W) \\ (0) \end{gathered}$ | (R/W) (0) | $(\mathrm{R} / \mathrm{W})$ (0) | (R/W) (0) | (R/W) (0) | (R/W) (0) | (R/W) (0) | (R/W) <br> (0) |  |

This register is used to set the number of data bytes to be transmitted and is valid only for data transmission.

Table 13.3.6a Number of transmit data bytes setting

| DE7-0 | Number of transmit data bytes |
| :---: | :---: |
| 01 H | 1 byte |
| 02 H | 2 bytes |
| .. | .. |
| .. | .. |
| FFH | 255 bytes |
| 00 H | 256 bytes |

During slave transmit, make sure to set the transmit data count byte to ' 1 ' when the control frame are OH (Reading Slave Status), 4H (Reading Lock-address of the lower 8-bit), 5H (Reading Lock-address of the upper 8 -bit), 6 H (Reading slave -status and diabling lock).
If the no. of bytes required to transfer is greater than the maximum no of transfer byte per frame, it will result in multiframe communciation. In that case, DEWR should be set using the following formula.

DEWR = DERR - Maximum no. of transfer bytes per frame
Upon the completion of one frame, the remaining number of byte required to transfer can be obtained by deducting the maximum no. of transfer byte per frame from DERR. This value is used to set DEWR for the next frame.

### 13.3.7 Status register upper byte (STRH)

Status register upper byte (STRH)

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $\triangleleft$ Bit Number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $000079{ }_{\text {H }}$ | COM | TE | PEF | ACK | RIF | TIF | TSL | EOD | STRH |
| Read/write $\Rightarrow$ Initial value $\Rightarrow$ | $\begin{aligned} & \text { (R) } \\ & (0) \end{aligned}$ | $\underset{(0)}{\text { (R/W) }}$ | (R) (X) | (R) (X) | $\begin{gathered} \text { (R/W) } \\ (0) \end{gathered}$ | (R/W) | (R) $(0)$ | (R) (0) |  |

[bit 15] COM (Communication status):
This bit indicates the communication status as described below.

| 0 | Communication is prohibited |
| :--- | :--- |
| 1 | Communication is enabled |

When this bit is ' 0 ' and the PCOM bit in command register (CMRH) is written ' 1 ', this bit is set. When communication ends, this bit will be cleared.
[bit 14] TE (Timing error):
This bit is set when timing error has occurred during communication. Writing ' 0 ' will clear this bit. This bit is written ' 0 ' only, there is no meaning for writing ' 1 '.
[bit 13] PEF (Parity error):
This bit is set when parity error has been detected.

| 0 | No parity error |
| :--- | :--- |
| 1 | Parity error |

In receive side, if this bit is set, the acknowledge bit will not be returned. This bit will be cleared after the communication inhibit state is released.
[bit 12] ACK (Acknowledge bit):
This bit indicates

| 0 | The acknowledge bit is ' 0 ' |
| :--- | :--- |
| 1 | The acknowledge bit is ' 1 ' |

During normal communication, acknowlege bit will be returned after each data received correctly. This bit will be cleared after communication inhibit state is released.
This bit has no meaning in multiaddress communication and the read value is indefined.
[bit 11] RIF (Receive interrupt flag):
This bit is set when receive interrupt is occurred.

| 0 | No receive interrupt request |
| :--- | :--- |
| 1 | Have receive interrupt request |

This bit is cleared by writing ' 0 ' to this bit or after the extended intelligent I/O service has been served. This bit is written ' 0 ' only.
[bit 10] TIF (Transmit interrupt flag):
This bit is set when transmit interrupt is occurred.

| 0 | No transmit interrupt request |
| :--- | :--- |
| 1 | Have transmit interrupt request |

This bit is cleared by writing ' 0 ' to this bit or after the extended intelligent I/O service has been served. This bit is written ' 0 ' only.
[bit 9] TSL (Transmit limit):
This bit is set when the maximum number of data bytes that can be transmitted in one communication frame has been reached. And this bit is cleared when next communication frame starts.
[bit 8] EOD (End of data):
This bit is set when the number of data bytes specified by telegraph length field has been transferred completely. It means communication ends normally. This bit is cleared when next communication frame starts.

### 13.3.8 Status register lower byte (STRL)

Status register lower byte (STRL)

| Address: 000078H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $<$ Bit Number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | WDBF | RDBF | WDBE | RDBE | ST3 | ST2 | ST1 | ST0 | STRL |
| Read/write $\Rightarrow$ | (R) | (R) | (R) | (R) | (R) | (R) | (R) | (R) |  |
| Initial value $\Rightarrow$ | (0) | (0) | (1) | (1) | (X) | (X) | (X) | (X) |  |

[bit 7] WDBF (Write data buffer full):
This flag indicates the status of the write data buffer (WDB).

| 0 | Write data buffer is not full |
| :--- | :--- |
| 1 | Write data buffer is full |

This bit is set when WDB is full and cleared when at least one byte of data can be written into WDB.
[bit 6] RDBF (Read data buffer full):
This flag indicates the status of the read data buffer (RDB).

| 0 | Read data buffer is not full |
| :--- | :--- |
| 1 | Read data buffer is full |

This bit is set when RDB is full and cleared when at least one byte of data can be received and stored in RDB.
[bit 5] WDBE (Write data buffer empty):
This flag indicates the status of the write data buffer (WDB).

| 0 | Write data buffer is not empty |
| :--- | :--- |
| 1 | Write data buffer is empty |

This bit is set when WDB is empty and cleared when data is written into WDB. Writing ' 1 ' to WDBC in command register CMRL will set this bit.
[bit 4] RDBE (Read data buffer empty):
This flag indicates the status of the read data buffer (RDB).

| 0 | Read data buffer is not empty |
| :--- | :--- |
| 1 | Read data buffer is empty |

This bit is set when RDB is empty and cleared when data is received and stored in RDB. Writing ' 1 ' to RDBC in command register CMRL will set this bit.
[bit 3-0] ST3, ST2, ST1, ST0 (Operation status bits)
These bits indicates the communication status of the unit and generates the corresponding interrupt during transmission or reception. By reading these bits, the communication status of the unit can be known.

Table 13.3.8a Status flag

| ST3 | ST2 | ST1 | ST0 | Status | State |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | Master/slave transmit | Transmit starts |
| 0 | 0 | 0 | 1 |  | During transmission |
| 0 | 0 | 1 | 0 |  | Transmit ends normally |
| 0 | 0 | 1 | 1 |  | Ends without all data being transmitted |
| 0 | 1 | 0 | 0 | Master receive | Master receive starts |
| 0 | 1 | 0 | 1 |  | Master receive data full |
| 0 | 1 | 1 | 0 |  | Master receive ends normally |
| 0 | 1 | 1 | 1 |  | Ends without all data being received |
| 1 | 0 | 0 | 0 | Slave receive | Slave receive starts |
| 1 | 0 | 0 | 1 |  | Slave receive data buffer full |
| 1 | 0 | 1 | 0 |  | Slave receive ends normally |
| 1 | 0 | 1 | 1 |  | Ends without all data being received |
| 1 | 1 | 0 | 0 | Multiaddress receive | Multiaddress receive starts |
| 1 | 1 | 0 | 1 |  | Multiaddress receive data buffer full |
| 1 | 1 | 1 | 0 |  | Multiaddress receive ends normally |
| 1 | 1 | 1 | 1 |  | Ends without all data being received |

For more detail description on setting these four bits, please refer to Table 13.5.2a.

### 13.3.9 Lock read register (LRRH, LRRL)

| Lock read register (LRRH, LRRL) |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $\leadsto$ Bit Number |
| Address: $00007 \mathrm{~B}_{\mathrm{H}}$ | Reserved | Reserved | Reserved | LOC | LD11 | LD10 | LD09 | LD08 | LRRH |
| Read/write $\Rightarrow$ Initial value $\Rightarrow$ | (R) <br> (1) | $\begin{aligned} & \text { (R) } \\ & \text { (1) } \end{aligned}$ | (R/W) (1) | $\begin{aligned} & \text { (R) } \\ & \text { (0) } \end{aligned}$ | $\begin{aligned} & (\mathrm{R}) \\ & (\mathrm{X}) \end{aligned}$ | $\begin{aligned} & \text { (R) } \\ & \text { (X) } \end{aligned}$ | $\begin{aligned} & \text { (R) } \\ & (\mathrm{X}) \end{aligned}$ | $\begin{aligned} & (\mathrm{R}) \\ & (\mathrm{X}) \end{aligned}$ | $<$ Bit Number |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| Address: $00007 \mathrm{~A}_{\mathrm{H}}$ | LD07 | LD06 | LD05 | LD04 | LD03 | LD02 | LD01 | LD00 | LRRL |
| Read/write $\qquad$ Initial value $\Rightarrow$ | (R) (X) | (R) (X) | $\begin{aligned} & (\mathrm{R}) \\ & (\mathrm{X}) \end{aligned}$ | (R) (X) | (R) (X) | (R) (X) | (R) (X) | (R) (X) |  |

[bit 15-13] Reserved bits:
Always reading ' 1 ' from these bits.
[bit 12] LOC (Lock check):
This bit indicates the status whether the unit is locked or not from other unit.

| 0 | Does not lock |
| :--- | :--- |
| 1 | Locked |

Writing ' 0 ' to this bit will unlock the unit itself. Writing ' 1 ' to this bit has no meaning.

## [bit 11-0] LD11-LD00 (Lock address):

These bits store the lock address, the address of the master that has executed locking to the unit. When the unit is not locked. there is no meaning for these bits.
Note: In IEBus communication, the lock function is used to transmit a message over two or more communication frames. If the master that has executed locking was down before executing the unlocked command, the locked unit cannot receive data anymore. So in order to prevent such condition, the unit in the system that supporting lock function need checking the lock status periodically by reading this lock read register. And the unit can unlock itself by writing ' 0 ' to LOC bit..

### 13.3.10 Master address read register (MARH, MARL)

| Master address read register (MARH, MARL) |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: 00007D ${ }_{\text {H }}$ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $<$ Bit Number |
|  | Reserved | Reserved | Reserved | Reserved | MA11 | MA10 | MA09 | MA08 | MARH |
| $\begin{aligned} \text { Read/write } & \\ \text { Initial value } & \end{aligned}$ | (R) <br> (1) | $\begin{aligned} & (\mathrm{R}) \\ & (1) \end{aligned}$ | $(\mathrm{R})$ (1) | $(\mathrm{R})$ (1) | $\begin{aligned} & (\mathrm{R}) \\ & (\mathrm{X}) \end{aligned}$ | $\begin{aligned} & (\mathrm{R}) \\ & (\mathrm{X}) \end{aligned}$ | $\begin{aligned} & (\mathrm{R}) \\ & (\mathrm{X}) \end{aligned}$ | $\begin{aligned} & \text { (R) } \\ & (\mathrm{X}) \end{aligned}$ |  |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\triangleleft$ Bit Number |
| Address: $00007 \mathrm{C}_{\mathrm{H}}$ | MA07 | MA06 | MA05 | MA04 | MA03 | MA02 | MA01 | MA00 | MARL |
| Read/write $\qquad$ Initial value $\leftrightarrows$ | $\begin{aligned} & (\mathrm{R}) \\ & (\mathrm{X}) \end{aligned}$ | (R) | (R) (X) | (R) | (R) (X) | (R) (X) | (R) (X) | (R) (X) |  |

[bit 15-12] Reserved bits:
Always reading ' 1 ' from these bits.
[bit 11-0] MA11-MA00 (Master address):
In slave mode, these bits store the address of the master that has won the arbitration in master address field.

If the unit itself is the master, then the unit address stored in unit address register (MAWH, MAWL) will be read out.

### 13.3.11 Multiaddress, control bit read register (DCRR)

Multiaddress, control bit read register (DCRR)

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $\triangleleft$ Bit Number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $00007 \mathrm{~F}_{\mathrm{H}}$ | DO3 | DO2 | DO1 | DO0 | C3 | C2 | C1 | C0 | DCRR |
| Read/write $\qquad$ Initial value $\qquad$ | (R) (0) | (R) (0) | (R) (0) | (R) (X) | (R) (X) | (R) (X) | (R) (X) | $\begin{aligned} & \text { (R) } \\ & \text { (X) } \end{aligned}$ |  |

[bit 15-12] DO3, DO2, DO1, DO0 (Multiaddress/normal communication bits):
In slave mode, the received multiaddress bit from the master is stored in bit DOO.
If the unit itself is the master, the multiaddress/normal communication set bits (DO3-0) in multiaddress, control bit set register (DCWR) is read out.

Normal communction: (0001B)
Multiaddress communication: (0000B)
DO3~0 always read as " 0 ".
[bit 11-8] C3, C2, C1, C0 (Control bits)
In slave mode, the received control bits from the master are stored in these bits.
If the unit itself is the master, the control bits (C3-0) in multiaddress, control bit set register (DCWR) is read out. These bits are set after the control field has been received and acknowledge bit was detected.

For more detail description, please refer to Table 13.3.5a.

### 13.3.12 Telegraph length read register (DERR)

| Telegraph length read register (DERR) |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $00007 \mathrm{E}_{\mathrm{H}}$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $<$ Bit Number |
|  | DE7 | DE6 | DE5 | DE4 | DE3 | DE2 | DE1 | DE0 | DERR |
| Read/write $\qquad$ Initial value $\qquad$ | (R) | $\begin{aligned} & (\mathrm{R}) \\ & (\mathrm{X}) \end{aligned}$ | $\begin{aligned} & (\mathrm{R}) \\ & (\mathrm{X}) \end{aligned}$ | $\begin{aligned} & \text { (R) } \\ & (\mathrm{X}) \end{aligned}$ | $\begin{aligned} & (\mathrm{R}) \\ & (\mathrm{X}) \end{aligned}$ | $\begin{aligned} & \text { (R) } \\ & \text { (X) } \end{aligned}$ | $\begin{aligned} & (\mathrm{R}) \\ & (\mathrm{X}) \end{aligned}$ | (R) |  |
|  | (X) |  |  |  |  |  |  | (X) |  |

if the unit itself is the receiver, this register stores the number of data specified by telegraph length field.
If the unit itself is the transmitter, the telegraph length bits in telegraph length set register (DEWR) are read. This register is set after the following.

1. When used as master unit
(a) In transmit mode, the number of transmit data bytes is written into DEWR
(b) In receive mode, the telegraph length field is received
(c) Communication ends
2. When used as slave unit
(a) In transmit mode, the number of transmit data bytes is written into DEWR
(b) In receive mode, the telegraph length field is received
(c) Communication ends

### 13.3.13 Read data buffer (RDB)

| Read data buffer (RDB) |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $000081_{\text {H }}$ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $«$ Bit Number |
|  | RD7 | RD6 | RD5 | RD4 | RD3 | RD2 | RD1 | RD0 | RDB |
| Read/write $\qquad$ Initial value $\Rightarrow$ | $\begin{aligned} & (\mathrm{R}) \\ & (\mathrm{X}) \end{aligned}$ | (R) (X) | (R) (X) | $(\mathrm{R})$ $(\mathrm{X})$ | (R) (X) | $\begin{aligned} & (\mathrm{R}) \\ & (\mathrm{X}) \end{aligned}$ | $\begin{aligned} & \text { (R) } \\ & \text { (X) } \end{aligned}$ | $\begin{aligned} & \text { (R) } \\ & \text { (X) } \end{aligned}$ |  |

This register (internally is a 8-byte FIFO buffer) stores received data in data field of the communication frame. When eight byte data have been received, RDB becomes full and receive interrupt is generated. Then data in RDB should be read out before the next coming byte of data is received as shown in Table 13.3.13a. Otherwise, error will be occurred.

When error occurs in multiaddress reception, the communication ends. But when error occurs in normal reception, the acknowledge bit will not returned to the transmitter. Then the transmitter will resend data again until the maximum number of data transmitted is reached.
Even though RDB is not full, the receive interrupt will be generated when the number of data specified in the telegraph field have been received, or the maximum number of data received in one communication frame is reached. Once the receive interrupt has occurred, the data in RDB should be read out.

Writing ' 1 ' to WDBC in CMRL will clear all data in the buffer and return it as empty state.
This register can only be read when noit empty

Table 13.3.13a Time Required for next data receive after receive buffer full interrupt occurred

|  | Maximum Time (us) | No. of Cycles |
| :---: | :---: | :---: |
| Mode 0 | 1580 | 19000 |
| Mode 1 | 400 | 4800 |
| Mode 2 | 290 | 3400 |

### 13.3.14 Write data buffer (WDB)

| Write data buffer (WDB) |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\triangleleft$ Bit Number |
| Address: $000080_{H}$ | WD7 | WD6 | WD5 | WD4 | WD3 | WD2 | WD1 | WD0 | WDB |
| Read/write $\Longleftrightarrow$ | (W) | (W) | (W) | (W) | (W) | (W) | (W) | (W) |  |
| Initial value $\Longleftrightarrow$ | (X) | (X) | (X) | (X) | (X) | (X) | (X) | (X) |  |

This register (internally is a 8-byte FIFO buffer) stored data to be transmitted in data field of the communication frame. The data write interrupt timing is set by the two bits TIT1, TIT0 in command register (CMRL).
When the write interrupt occurs, next data is requested to write into WDB. When all data has been transmitted (WDB is empty), and the data cannot be writtenin RDB within the time listed in Table 13.3.14a, it will result in an error and the transmission will be terminated. Writing ' 1 ' to WDBC bit in command register CMRL will clear the buffer and return it as empty state.
This register can only be written when not full.

Table 13.3.14a Data write time after WDB empty interrupt

|  | Maximum Time | No. of cycles |
| :---: | :---: | :---: |
| Mode 0 | 1580 | 19000 |
| Mode 1 | 400 | 4800 |
| Mode 2 | 290 | 3400 |

### 13.4 IEBus Communication Protocol

### 13.4.1 Overview

IEBus (Inter Equipment Bus) is a small-scale two-line serial bus interface intended to transfer data between equipment and equipment.

- Communication method

Data are transferred by means of half duplex asynchronous communication.

- Multi-master method

All the units connected to the IEBus can transfer data to the other units.

- Multiaddress communication function (one unit can communicate to two or more units simultaneously) Group communication: multiaddress communication to group units Broadcasting communication: multiaddress communication to all units
- Three transfer rates can be selected:

Table 13.4.1a IEBus transfer rates

| Mode | IEBus internal clock <br> $=6 \mathbf{M H z}$ | IEBus internal clock <br> $=6.29 \mathrm{MHz}$ | Maximum number of transfer bytes <br> (bytes $/$ frame) |
| :---: | :---: | :---: | :---: |
| 0 | approx. 3.9Kbps | approx. 4.1 Kbps | 16 |
| 1 | approx. 17Kbps | approx. 18 Kbps | 32 |
| 2 | approx. 26Kbps | approx. 27 Kbps | 128 |

- Access control: CSMA/CD (Carrier Sense Multiple Access with Collision Detection)
- The priority to occupy the IEBus:
(1) Multiaddress communication takes precedence over normal communication (communication between one unit and another).
(2) The lower master address takes precedence over the higher address.
- Communication scale Note

Number of units: 50 max.
Cable length: 150m max. (when twisted pair cable with resistance less than $0.1 \mathrm{~W} / \mathrm{m}$ is used) loading Capacitance: 8000pF max. (between BUS- and BUS+) when IEBus internal clock is 6 MHz 7100 pF max. (between BUS- and BUS+) when IEBus internal clock is 6.29 MHz
Terminal resistance: 120 W .
Note:The system sacle depends on the IE Bus driver/receiver that is used.

### 13.4.2 Determining bus mastership (arbitration)

The equipment connected to the IEBus performs an operation to occupy the bus when it controls another equipment. This operation is called arbitration.

Arbitration is to grant the bus mastership to one of several units that have simultaneously started transmission. As only one equipment acquires the bus mastership as a result of arbitration, the following priority is used to determine which equipment acquires the bus mastership:

- Priority on type of communication Multiaddress communication takes precedence over normal communication.
- Priority on master address

If the type of communication is the same, the lower master address takes precedence over the higher one.
Example: The master address consists of 12 bits, the unit at 000 H has the highest priority, and the unit at FFFH has the lowest priority.

### 13.4.3 Communication mode

The IEBus provides three communication modes, in which each has a different transfer rate. The transfer rate in each communication mode and the maximum number of transfer bytes in one communication frame are shown as below:

Table 13.4.3a Transfer rate and maximum number of transfer byte in each communication mode

| Mode | Maximum number of transfer bytes <br> (bytes / frame) | Effective transfer rate (bps) Note1 |  |
| :---: | :---: | :---: | :---: |
|  |  | IEBus internal clock <br> $6 \mathrm{MHz} \mathrm{Note2}$ | IEBus internal clock $=$ <br> 6.29 MHz Note2 |
| 0 | 16 | approx. 3.9Kbps | approx. 4.1 Kbps |
| 1 | 32 | approx. 17 Kbps | approx. 18 Kbps |
| 2 | 128 | approx. 26Kbps | approx. 27Kbps |

Note1: Effective transfer rate is measured when the maximum number of data bytes have been transferred.
Note2: The relationship between IEBus internal clock and CPU clock is referred to Table 13.3.2d.

Caution1: The required communication mode should be selected for each equipment connected to the IEBus before communication is started. Also, the communication is not performed correctly unless the communication mode of the master and the slave unit are the same.
Caution2: Be sure that both the communication mode and IEBus internal clock are the same for all units connected to the IEBus. Even though the same communication mode is selected, the communication is still performed incorrectly if the IEBus internal clock frequency is different.

### 13.4.4 Communication address

In IEBus, each equipment is assigned to a specific 12-bit communication address. The communication address is consisted of:

Higher 4 bits:group number (identify which group the equipment belongs to)
Lower 8 bits:unit number (identify each equipment in one group)

### 13.4.5 Multiaddress communication

In normal communication mode, the communication is performed on a one-to-one basis, i.e. only one master and one slave. In contrast, multiaddress communication allows the master transmitting data to more than one slave. As more than one slave exist in the IEBus, none of them returns an acknowledge signal in the communication.

The multiaddress bit is used to select either multiaddress communication or normal communication. For detail description, refer to (6) transfer protocol.
Multiaddress communication has the following two modes:

- Group multiaddress communication

Communicating with equipments having the same group number as specifying in higher 4 bits of the communication address.

- Broadcasting communication

Communicating with all equipments, regardless of the value of the group number
The slave address specified in slave address field is used to identify either group multiaddress or broadcasting communication. For detail description, refer to section Section 13.4.6, "Transfer protocol".

### 13.4.6 Transfer protocol

The signal transmit format of the IEBus is shown as below

| Field Name <br> No. of bits |  | Header |  | $\begin{gathered} \text { Master } \\ \text { address field } \end{gathered}$ |  | Slave field |  |  | Control field |  |  | Telegraph length field |  |  | Data field |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 1 | 1 | 12 | 1 | 12 | 1 | 1 | 4 | 1 | 1 | 8 | 1 | 1 | 8 | 1 | 1 | 8 | 1 | 1 |
| Frame format |  | Start bit | adultiess bit | Master address bits | P | Slave address bits | P | A | Control bits | P | A | Telegraph length bits | P | A | Data bits | P | A | Data bits | P | A |
| Transmit time | Mode 0 | approx. $7330 \mu \mathrm{~s}$ |  |  |  |  |  |  |  |  |  |  |  |  | approx. $1590 \times \mathrm{N} \mu \mathrm{s}$ |  |  |  |  |  |
|  | Mode 1 | approx. $2090 \mu \mathrm{~s}$ |  |  |  |  |  |  |  |  |  |  |  |  | approx. $410 \times \mathrm{N} \mu \mathrm{s}$ |  |  |  |  |  |
|  | Mode 2 | approx. $1590 \mu \mathrm{~s}$ |  |  |  |  |  |  |  |  |  |  |  |  | approx. $300 \times \mathrm{N} \mu \mathrm{s}$ |  |  |  |  |  |

Note1: P: parity bit
$A$ : acknowledge bit where $A=0$ : ACK and $A=1$ : NAK
Note2: The acknowledge bit is ignored in multiaddress communication.
(1) Header

The header field is consisted of start bit and multiaddress bit.

- Start bit

The start bit is a signal used to inform the other units that data transmission starts. The unit initiating the data transmission outputs a low-level signal (start bit) for a specific time and then outputs the multiaddress bit.
When one unit tries to output the start bit, but it found that another unit has already output a start bit, then the unit does not output the start bit. But it waits for the end of the start bit output by the another unit and outputs the multiaddress bit in synchronization with the output end timing of the start bit.
The units other than the one that has started transmission detect this start bit and enters the receive status.

- Multiaddress bit

This bit indicates whether the master selects multiaddress or normal communication. When the multiaddress bit is ' 0 ' for multiaddress communication and is ' 1 ' for normal communication. Moreover, multiaddress communication is divided into two modes, group multiaddress and broadcasting communication. These two modes are identified by the value of the slave address.
In multiaddress communication, since there are two or more slave units, the acknowledge bit for each field following the master field is not returned.
If at the same time, two or more units start transmission of a communication frame, multiaddress communication takes precedence over normal communication and is the winner in arbitration.
(2) Master address field

This field is outputted by the master to identify its address for other units being communicated and is consisted of 12 bit of master address with MSB transmitting first and 1 parity bit.
If at the same time, two or more units starts transmitting the multiaddress bit of the same value, judgement of arbitration is based on the master address field value. Everytime when the unit transmits one bit of its unit address, it compares the data output with the data on the IEbus. If they are found to be different, the unit lost the arbitration and then stops transmission and enters receive status.
Since the IEBus is configured as wired AND, the unit having the least master address among the units participating in arbitration (arbitration masters) wins arbitration. After 12-bit master address is transmitted out, only one unit remains in transmit status as the master. This master then outputs the parity bit and let other units confirming that the transmit master address data contains no error. After that, the slave address field is output.

Note:Even parity is used for parity check. If the total number of ' 1 ' in master address bits is odd, the parity bit will be set as ' 1 '.

## (3) Slave address field

This field outputs the address of the other unit with which the master is to communicate and is consisted of 12 bits of slave address with MSB transmitting first, parity bit and acknowledge bit.
After a 12-bit slave address has been transmitted, a parity bit is output to ensure that the slave address is not received by mistake. Then the master unit detects an acknowledge signal from slave unit to confirm its existence on the IEBus. After the detection of acknowledge signal, the master unit starts outputting the control field. However in multiaddress communication mode, the master starts outputting the control field without detecting the acknowledge bit.

In the slave side, when it detects that the slave address has coincided with its own unit address, and the parity bit in both master address field and slave address field are even, it outputs an acknowledge signal. However, if parity bit is odd, the slave unit judges that either master address or slave address has been received incorrectly, and then acknowledge signal is not returned. At this moment, the master unit enters the standby (monitor) status, and communication ends.
In multiaddress communication mode, the slave address is used to identify whether it is group multiaddress or broadcasting communication as follows:
When slave address is FFFH: Broadcasting communication When slave address is not FFFH: Group multiaddress communication

Note:The group number for group multiaddress communication is identified by the higher 4 bits of the slave address.
(4) Control field

This field is used to control the type of following data field and direction of data transfer between master and slave. This field is consisted of 4 bits of control bit with MSB transmitting first, parity bit and acknowledge bit.
If even parity is checked and the slave can execute the function requested by the master, the slave returns an acknowledge signal and then proceeds to the telegraph length field. Even though the parity is even, but if the slave unit cannot execute the function requested by the master, or if the parity is odd, the slave unit does not output the acknowledge signal and returns to the standby (monitor) status.
After the master confirms the return of acknowledge signal, it proceeds to the telegraph length field. If the master cannot receive the acknowledge signal, it enters the standby status, and communication ends. In multiaddress communication mode, the master unit does not detect the acknowledge signal, but proceeds to the telegraph length field.
(5) Telegraph length field

This field is used to indicate the number of bytes of transmit data from the transmitter to receiver. This field is consisted of 8 bits of telegraph length with MSB transmitting first, parity bit and acknowledge bit. Table 13.4.6a shows the relationship between the telegraph length field and the number of transmit data bytes.

Table 13.4.6a Number of transmit data bytes setting

| Telegraph length bits <br> $(H E X)$ | Number of transmit data bytes |
| :---: | :---: |
| 01 H | 1 byte |
| 02 H | 2 bytes |
| .. | .. |
| .. | .. |
| FFH | 255 bytes |
| 00 H | 256 bytes |

Note:According to the communication mode being set, if the number of transmit data bytes set in telegraph length field is greater than the maximum number of transmit data bytes per frame, then communication with multi-frame is performed. In this
case, the second and following communication frames will transmit the remaining data bytes specified in the telegraph length field.
The function of telegraph length field differs when the master is in transmit mode (bit 3 of control bits is ' 1 ') or receive mode (bit 3 of control bits is ' 0 ') as follow:

- Master transmit mode

The telegraph length bits and parity bit are output by the master unit. If even parity is detected by the slave, it returns the acknowledge signal. Then the master proceeds to the data field. But in multiaddress communication mode, the slave does not return any acknowledge signal.
If odd parity is detected, the slave judges that the telegraph length bits have not been correctly received, and then go into standby (monitor) mode without returning acknowledge signal. At the same time, the master also goes into standby status, and communication ends.

- Master receive mode

The slave outputs the telegraph length bits and parity bit. If even parity is detected by the master, it returns the acknowledge signal. But if odd parity is detected, the master judges that the telegraph length bits have not been correctly received, and goes into the standby status without returning acknowledge signal. Then the slave also goes into standby status, and communication ends.
(6) Data field

This field is used by the master to transmit/receive data to/from the slave. This field is consisted of eight data bits with transmitting MSB first, parity bit and acknowledge bit.
Multiaddress communication can only be performed when the master unit transmits data and the acknowledge signal is ignored. The operations for master transmits and receives data are described as follow:

- Master transmit mode

When the master writes data to a slave, it transmits data bits and parity bit to the slave. Then if even parity is detected by the slave and its receive data buffer is not full, the slave returns the acknowledge signal. If odd parity is detected or the receive buffer is full, the slave rejects accepting the corresponding data, and does not return the acknowledge signal.
If the acknowledge is not detected by the master, it retransmits the same data until the acknowledge bit is detected or the maximum number of transmit bytes is exceeded.
If the parity is even and the acknowledge signal is returned from the slave, the master transmits the next available data if the maximum number of transmit bytes is not exceeded.
In multiaddress communication mode, the slave unit does not return the acknowledge signal, and the master transmits data on a 1-byte-by-1-byte basis.

- Master receive mode

When the master reads data from the slave, the master outputs a synchronous signal corresponding to all the read bits. Then the slave outputs the data and parity bit to the IEBus in response to the synchronous signal output by the master. After that, the master reads these bits and confirm the parity check.
If odd parity is detected or the master's receive buffer is full, it rejects accepting the data and does not return the acknowledge signal. If the maximum number of transmit bytes per frame is not exceeded, the master repeatedly reads the same data.
If even parity is detected and the master's receive buffer is not full, the master accepts the data and returns the acknowledge signal. If the maximum number of transmit bytes per frame is not exceeded, the master reads the next data.
(7) Parity bit

The parity bit is used to confirm that the transmit data contains no error. It is appended to master address bits, slave address bits, control bits, telegraph length bits and data bits.
The parity is an even parity. If the number of ' 1 ' bits in the data is odd, then the parity bit is set to ' 1 '. If the number of ' 1 ' bits in the data is even, then the parity bit is set to ' 0 '.
(8) Acknowledge bit

An acknowledge bit is appended to the following location to confirm whether data has been correctly received in the normal communication mode (communication between one unit and another):

- At the end of slave address field
- At the end of control field
- At the end of telegraph length field
- At the end of data field

The acknowledge bit is defined as:
' 0 ': The transmit data is recognized (ACK)
' 1 ': The transmit data is not recognized (NAK)
The acknowledge bit is ignored in multiaddress communication.

1. Acknowledge bit at the end of slave field

The acknowledge bit at the end of the slave field is treated as NAK in any of the following cases, and then transmission is aborted:

- If the parity of the master address bits or slave address bits is not correct
- If a timing error (error in bit format) occurs
- If the specific slave unit does not exist

2. Acknowledge bit at the end of the control field

The acknowledge bit at the end of the control field is treated as NAK in any of the following cases, and then transmission is aborted:

- If the parity of the control bits is not correct
- If bit 3 of the control bits is ' 1 ' (write operation) but the slave receive buffer ${ }^{\text {Note }}$ is full
- If the control bits indicate data read $(3 \mathrm{H}, 7 \mathrm{H})$ but the slave transmit buffer ${ }^{\text {Note }}$ is empty
- If the slave has been locked, but value of $3 \mathrm{H}, 6 \mathrm{H}, 7 \mathrm{H}, \mathrm{AH}, \mathrm{BH}, \mathrm{EH}$ or FH in the control bits are requested by another unit other than the one has set locking
- If the control bits indicate reading of a lock address $(4 \mathrm{H})$ but the slave has not been locked.
- If a timing error occurs
- If undefined control bit values are set

Note:Refer to slave status (SSR) in (7)
3. Acknowledge bit at the end of the telegraph length field

The acknowledge bit at the end of the telegraph length field is treated as NAK in any of the following cases, and transmission is aborted:

- If the parity of the telegraph length bits is not correct
- If a timing error occurs

4. Acknowledge bit at the end of data field

The acknowledge bit at the end of the data field is treated as NAK in any of the following cases, and then transmission is aborted:

- If the parity of the data bits is not correct Note
- If a timing error occurs after the previous acknowledge bit has been transmitted
- If the receive buffer has become full and thus no more data can be accepted

Note:The same data is retransmitted if the maximum number of transmit data bytes per frame is not exceeded.

### 13.4.7 Transmit data

The content in data field is controlled by the control bits in control field and is shown below:
Table 13.4.7a Control bits setting

|  | Bit $3_{1}^{\text {Note }}$ <br> 1 | Bit 2 | Bit 1 | Bit 0 | Function Note 2 |
| :--- | :---: | :---: | :---: | :---: | :--- |
| OH | 0 | 0 | 0 | 0 | Slave status (SSR) read |
| 1 H | 0 | 0 | 0 | 1 | Undefined |
| 2 H | 0 | 0 | 1 | 0 | Undefined |
| 3 H | 0 | 0 | 1 | 1 | Data read and lock |
| 4 H | 0 | 1 | 0 | 0 | Lock address read (Lower 8 bits) |
| 5 H | 0 | 1 | 0 | 1 | Lock address read (Upper 4 bits) |
| 6 H | 0 | 1 | 1 | 0 | Slave status (SSR) read and <br> unlock |
| 7 H | 0 | 1 | 1 | 1 | Data read |
| 8 H | 1 | 0 | 0 | 0 | Undefined |
| $9 H$ | 1 | 0 | 0 | 1 | Undefined |
| AH | 1 | 0 | 1 | 0 | Command write and lock |
| BH | 1 | 0 | 1 | 1 | Data write and lock |
| CH | 1 | 1 | 0 | 0 | Undefined |
| DH | 1 | 1 | 0 | 1 | Undefined |
| EH | 1 | 1 | 1 | 0 | Command write |
| FH | 1 | 1 | 1 | 1 | Data write |

Note1: The direction in which telegraph length bits in the telegraph length field and data in the data field are transferred is changed depending on the value of Bit 3 as follows:
When Bit 3 is ' 1 ': Transfer from master unit to slave unit
When Bit 3 is ' 0 ': Transfer from slave unit to master unit
Note2: Control bits 3H, 6H, AH, BH are used to lock and unlock the unit.
When those undefined control bits $1 \mathrm{H}, 2 \mathrm{H}, 8 \mathrm{H}, 9 \mathrm{H}, \mathrm{CH}, \mathrm{DH}$ has been received, the acknowledge bit is not returned.
When the slave is locked, it can only execute the following command requesting by other units besides of the master executing the lock command:

Table 13.4.7b The control command that can be executed by a locked slave unit

|  | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Function |
| :--- | :---: | :---: | :---: | :---: | :--- |
| 0 H | 0 | 0 | 0 | 0 | Slave status (SSR) read |
| 4 H | 0 | 1 | 0 | 0 | Lock address read (Lower 8 bits) |
| 5 H | 0 | 1 | 0 | 1 | Lock address read (Upper 4 bits) |

(1) Slave status (SSR) read (control bits: $0 \mathrm{OH}, 6 \mathrm{H}$ )

By reading the slave status, the master can understand why the slave has not returned the acknowledge bit (ACK). The slave status is determined in respect to the result of the last communication performed by the slave unit. Moreover all slaves can supply the information of slave status as configured below:

| MSB |  | LSB |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Slave Status 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|  |  |  |  |  |  |  |  |  |

Table 13.4.7c Meaning of Slave Status

| Bit | Value | Meaning |  |
| :---: | :---: | :---: | :---: |
| Bit 0 | 0 | Slave transmit buffer is empty |  |
|  | 1 | Slave transmit buffer is not empty |  |
| Bit 1 | 0 | Slave receive buffer is not full |  |
|  | 1 | Slave receive buffer is full |  |
| Bit 2 | 0 | Unit is not locked |  |
|  | 1 | Unit is locked |  |
| Bit 3 | 0 | Fixed to '0' |  |
| $\underset{\text { Bote }}{ } 4$ | 0 | Slave transmission is stopped |  |
|  | 1 | Slave transmission is enabled |  |
| Bit 5 | 0 | Fixed to '0' |  |
| $\begin{aligned} & \text { Bit } 6 \\ & \text { Bit } 7 \end{aligned}$ | 00 | Mode 0 | Indicates the highest mode that is supported by the unit Note 4 |
|  | 01 | Mode 1 |  |
|  | 10 | Mode 2 |  |
|  | 11 | Prohibited |  |

Note1: The slave transmit buffer is the buffer accessed when data is read (control bits: 3H, 7 H ). This buffer is same as the write data buffer (WDB).

Note2: The slave receive buffer is the buffer accessed when data is written (control bits: 8 H , $\mathrm{AH}, \mathrm{BH}, \mathrm{EH}, \mathrm{FH}$ ). This buffer is same as the read data buffer (RDB).
Note3: This bit can be selected by the PCOM bit in command register (CMRH).
Note4: For MB90580 series, 10 is fixed.
(2) Data/command transfer (control bits: read (3H, 7H), write ( $\mathrm{AH}, \mathrm{BH}, \mathrm{EH}, \mathrm{FH}$ ))

If the control bits indicate data read $(3 \mathrm{H}, 7 \mathrm{H})$, the data in the data buffer of the slave is read by the master. If the control bits indicate data write ( $\mathrm{BH}, \mathrm{FH}$ ) or command write $(\mathrm{AH}, \mathrm{EH})$, the data received by the slave is processed in accordance with the operation regulation of that slave.

Note1: The data or command can be selected with the user's own decision in the corresponding system.
Note2: The slave is also locked when control bits are 3H, AH and BH.
(3) Read lock address (control bits: 4H,5H)

When the lock address is read (control bits: $4 \mathrm{H}, 5 \mathrm{H}$ ), the address (12-bit) of the master that has issued the lock instruction is configured in 1 -byte units as shown below and is read.

(4) Locking and unlocking

The lock function is used to transmit a message over two or more communication frames. The unit that has been locked cannot receive data from any unit other than the one that has locked it.
A unit is locked or unlocked as follows:

- Locking

When the lock command has been executed (control bits: $3 \mathrm{H}, \mathrm{AH}, \mathrm{BH}$ ) and the acknowledge bit ' 0 ' in the telegraph length field has been transmitted or received, but the number of data bytes specified by the telegraph length bits cannot be transmitted or received successfully within the communication frame, then the slave is locked by the master, and the bit related to locking (bit 2) in the slave status is set.

- Unlocking When the lock command (control bits: $3 \mathrm{H}, \mathrm{AH}, \mathrm{BH}$ ) or unlock command (control bits: 6 H ) has been executed, and the number of data bytes specified by the telegraph length bits can be transmitted or received successful within one communication frame, then the slave is unlocked by the master and the bit related to locking (bit 2 ) in the slave status is cleared.
Furthermore, the slave is not locked or unlocked while multiaddress communication is performed.


### 13.4.8 Bit format

The format of the bits constituting an IEBus communication frame is shown below:


Logic '1': voltage difference between inter-bus wires (BUS+ and BUS-)is below 20 mV (low level)
Logic '0': voltage difference between inter-bus wires (BUS+ and BUS-) is above 120 mV (high level)
Preparation period: First low-level period (logic '1')
Synchronization period: Next high-level period (logic '0')
Data period: Period indicating bit value (logic ' 1 ' = low level, logic'0' = high level)
The length of synchronization period and data period are almost the same.
The IEBus establishes synchronization for each bit. The specifications of the time of the entire bit and the time of the period assigned to the bit differ depending on the type of the transmit bit, and whether the unit is master or slave.
Moreover, the specified interval for every period (preparation, synchronization, data) in the communication are detected by both the master and slave. If data cannot be detected within that specified interval, timing error occurs in both master and slave, and then the communication ends and goes into standby mode.

### 13.5 Operation

### 13.5.1 IEBus control

(1) Master transmit

The unit is set as master transmit to transmit data to the slave by sending data/command control bits as $\mathrm{AH}, \mathrm{BH}, \mathrm{EH}$ or FH . The sequences for operating in master transmit are described as below:

1. The master address is written in unit address register (MAWH, MAWL), the slave address is written in slave address register (SAWH, SAWL), multiaddress bit and control bits are written into multiaddress, control bit set register (DCWR). After that, the command register (CMRH) is set to release communication inhibit mode.
2. When the master has won the arbitration (after the master address field is finished), the state code ( OH ) indicating start of transmission is set in ST3-0 of status register (STRL) and transmit interrupt occurs. At this time, the number of transmitted data byte is required to write into telegraph length set register (DEWR) and transmit data is set in write data buffer (WDB), unless the WDb is not full.
3. When one byte of data is transmitted, the number of data in WDB is deducted by one. According to the setting of TIT1, TITO in command register (CMRL) that control the interval for writing data in WDB, the transmit interrupt occurs. At that time, the state code equals ' 1 H ' indicating data transmission and WDB is not full. Therefore, data should be written in WDB.
4. If the specified number of data or command has been transmitted correctly, the state code (2H) indicating transmission ends normally is set in ST3-0 of status register (STRL), the EOD bit in STRH is set and transmit interrupt occurs.
5. If error occurs during transmission or in multi-frame communication the number of data byte specified in telegraph bit set register (DEWR) cannot be transmitted completely, the state code (3H) indicating transmission ends without all data are transmitted is set in ST3-0, and transmit interrupt occurs. At this time, the content of communication error can be known by checking the status of TSL, PEF, TE in status register (STRH).
When timing error is occurred during the transmission, the data stored in WDB can't be transmitted. If the TE bit is cleared and re-transnit sequence is executed, those data left in WDB, excluding the data byte that has timing error will be re-transmit. In order to perform new data transmission, the bit WDBC in CMRL must be written ' 1 ' to clear the write data buffer.
(2) Slave transmit

Data transmit
This mode is set when the master sends control bits either 3 H or 7 H to slave and requests it to transmit data back to the master. The sequences for operating in slave data transmit are described as below:

1. After receiving master control code 3 H or 7 H , the data code $(\mathrm{OH})$ indicating transmit start is set to ST3-0 of status register and the transmit interrupt is occurred. At this time, set the telegraph length set register (DEWR) with the nunmber of byte of data which are required to be transmitted. The transmit data can be written to WDB, provided that WDB is not full.
2. During the start of telegraph field transmission, the status register bits ST3-0 are set to 1 H indicating data transmission in progress and transmit interrupt occurs. At that moment, transmit data can be written to the WDB, provided that WDB is not full.
3. When one byte of data is transmitted, the number of data in WDB is deducted by one. According to the setting of TIT1, TITO in command register (CMRL) that control the timing for writing data in WDB, the transmit interrupt occurs. Data can be written in WDB if state code is still $(1 \mathrm{H})$ and WDB is not full.
4. If the specified number of data or command has been transmitted correctly, the state code (2H) indicating transmission ends normally is set in ST3-0 of status register (STRL), the EOD bit in STRH is set and transmit interrupt occurs.
5. If error occurs during transmission or in multi-frame communication the number of data byte specified in DEWR cannot be transmitted completely, the state code (3H) indicating transmission terminated without all data transmitted is set in STRL:ST3-0. Transmit interrupt will occur. At this time, the content of communication error can be known by checking the status of TSL, PEF, TE in status register (STRH).

The interval between setting ST3-0 and the first data is transmitted out from WDB is shown below:

Table 13.5.1a Time required to write transmit data to WDB after transmit interrupt has occurred

| Mode | Time $(\mu$ S $)$ | Number of cycles |
| :---: | :---: | :---: |
| 0 | approx. 158 | approx. 1900 |
| 1 | approx. 40 | approx. 480 |
| 2 | approx. 29 | approx. 350 |

## Note :

1. Number of transmit bytes and transmit data can be set during the interrupt generated after the receiving of control bits.
2. As the time between the WDB empty interrupt and the next telegraph bit transmit interrupt is very short, thus it is recommended to take the following precautions when the first transmit data is required to write into WDB.

- Only write data to WDB after the WDB empty confirmation.
- In case of setting the transmit data byte count, it is required to set the value within the time listed in Table 13.5.1a. The default value of the transmit data byte count will transmit 256bytes.
- If at least 1 byte of data is not set within the time listed in below after the transmit interrupt, WDB will be detected as empty. Error will be occurred after the transmission of telegraph field and the communication will be terminated.
- Slave status, lock address transmit

When the control bits $0 \mathrm{H}, 4 \mathrm{H}, 5 \mathrm{H}, 6 \mathrm{H}$ has been received from the master, the slave status, lock address are automatically transmitted to the master. In this way, there is no need to write data into WDB, but it is required to set 1 H to the telegraph bit setting register.
(3) Master receive

The unit is set as master receive for getting data, slave status and lock address from the slave by first sending control bits $0 \mathrm{H}, 3 \mathrm{H}, 4 \mathrm{H}, 5 \mathrm{H}, 6 \mathrm{H}$ or 7 H . The sequences for operating as master receive are described as below:

1. When the slave receives the control bits, it transmits the telegraph length bit. Then after the master receives these telegraph length bits and returns the acknowledge bit, the number of received data byte is written into the telegraph length read register (DERR). At this moment, no interrupt occurs.
2. After the acknowledge bit in telegraph length field is sent by the master, data reception will be started. And for each received data byte, the master stores it in the read data buffer (RDB).
3. After eight bytes of data are received, the state code $(5 \mathrm{H})$ is set in ST3-0 of status register (STRL), receive interrupt occurs.
4. When the last byte of data is received and stored in RDB within one communication frame, the state code $(5 \mathrm{H})$ is set in ST3-0 and receive interrupt occurs. This interrupt will be generated even thought RDB is not full.
5. If error is occurred during reception, or the maximium number of data byte has been received in one communication frame, the master cannot received the number of data byte specified in telegraph field and communication is terminated. The state code $(7 \mathrm{H})$ indicating master receive ends without all data are received is set in ST3-0, and receive interrupt occurs.
(4) Slave receive

This mode is set when the slave unit receive control bits $\mathrm{AH}, \mathrm{BH}, \mathrm{EH}$ or FH from the master. The sequences for operating as slave receive are described as below:

1. After the slave returns the acknowledge bit in telegraph length field, the number of receive data byte is written in the telegraph length read register (DERR). At this moment, no interrupt occurs.
2. Following the telegraph length field is the data field, the master starts transmitting data and each received data byte is stored in the read data buffer (RDB).
3. After eight bytes of data are received, the state code ( 9 H ) indicating slave receive buffer full is set in ST3-0 of status register (STRL), and receive interrupt occurs. If the receive interrupt occurs, the RDB can be read after the confirmation of buffer not empty.
4. When the last byte of data in one communication frame is received and stored in RDB, the state code (AH) indicating slave receive ends normally is set in ST3-0 and receive interrupt occurs. This interrupt will occur even thought the buffer is not full.
5. If error is occurred during reception or the maximium number of data byte has been re3ceived in one commmunication frame, the slave cannot receive the number pf data byte specified in telegraph field and communication is terminated.. The state code (BH) indicating slave receive ends without all data are received is set in ST3-0, and receive interrupt occurs.
(5) Multiaddress receive
6. After the slave has received the telegraph length field, the number of receive data byte is written in the telegraph length read register (DERR). At this moment, no interrupt occurs.
7. After the telegraph lenght field is received, each correctly received data byte is stored in the read data buffer (RDB).
8. After eight bytes of data are received, the state code (DH) indicating multiaddress receive buffer full is set in ST3-0 of status register (STRL), and receive interrupt occurs. If the receive interrupt occurs, the RDB can be read after the confirmation of buffer not empty.
9. When the last byte of data in one communication frame is received and stored in RDB, the state code (EH) indicating multiaddress receive ends normally is set in ST3-0 and receive interrupt occurs. This interrupt will occur even thought the buffer is not full.
10. If error is occurred during reception or the maximium number of data byte has been received in one communication frame, the slave cannot receive the number of data byte specified in telegraph field and communication is terminated. The state code (FH) indicating multiaddress receive ends without all data are received is set in ST3-0, and receive interrupt occurs.
For detail description on ST3-0, please refer to Table 13.5.2a.

### 13.5.2 Communication status

In the status register, there are four bits ST3-0 indicating the status code. After the status code has been set, interrupt request is generated. During the interrupt routine, the communication status can be investigated by reading the status register. But at the beginning of master, slave and multiaddress receive, no interrupt will be generated
(1) Master, slave data transmit (transmit interrupt occurs)

When the unit won the arbitration in multiaddress or master address field, it becomes master unit. Then data/command is transmitted to or data is received from the slave, and the status code ST3-0 is set and shown as below:

Table 13.5.2a Meaning of status code ST3-0 for master, slave transmit

| Code Name | Code ST3-0 | Content |
| :---: | :---: | :--- |
| Transmit starts | 0000 | Indicates start of master/slave transmission. <br> 1) master transmit <br> Indicater the master address field in communication frame has been <br> transmitted, and the unit has won in arbitration as the master. <br> 2) slave transmit <br> Indicates that the unit has received control bits $0 \mathrm{H}, 3 \mathrm{H}, 4 \mathrm{H}, 5 \mathrm{H}, 6 \mathrm{H}, 7 \mathrm{H}$ <br> from the master that requests data transmission, and slave data <br> transmission is started. |
| Transmit data | 0001 | Indicates that data is transmitting by Master unit or Slave unit. This <br> control code will be set after the starting of telegraph length field <br> transmission. |
| Transmit ends <br> normally | 0010 | Indicates that the number of data transmit specified by telegraph length <br> field has been completed within one communication frame |
| Ends without <br> all data being <br> transmitted | 0011 | Indicates that the communication has ended without transmitting the <br> number of data specified by telegraph length field in one communication <br> frame. |

(2) Master receive (receive interrupt occurs)

When the unit won the arbitration in multiaddress or master address field, it becomes master unit. Then data, status or log address are received from slave unit, and the status code ST3-0 is set and shown as below:

Table 13.5.2b Meaning of status code ST3-0 for master receive

| Code Name | Code ST3-0 | Content |
| :---: | :---: | :--- |
| Master <br> receive starts | 0100 | Indicates that the master has received the telegraph field correctly from <br> the slave and master reception is started but receive interrupt does not <br> occur at this moment. |
| Master <br> receive data <br> full | 0101 | Indicates that the receive data buffer RDB for master reception is full <br> (eight byte of data has been received), and the host controller is <br> requested to read data from the RDB. |
| Master <br> receive ends <br> normally | 0110 | Indicates the number of data specified by the telegraph field has been <br> received within one communication frame. |
| Ends without <br> all data being <br> received | 0111 | Indicates that the communication has ended without receiving the <br> number of data specified by telegraph length field in one communication <br> frame. |

### 13.5 Operation

(3) Slave receive (receive interrupt occurs)

When data/command is received from the master unit, the status code ST3-0 is set and shown as below:

Table 13.5.2c Meaning of status code ST3-0 for slave receive

| Code Name | Code ST3-0 | Content |
| :---: | :---: | :--- |
| Slave receive <br> starts | 1000 | Indicates that the slave unit has received the telegraph field correctly from <br> master unit and slave reception is started but receive interrupt does not <br> occur at this moment. |
| Slave receive <br> data full | 1001 | Indicates that the receive data buffer RDB for slave reception is full (eight <br> byte of data has been received), and the host controller is requested to <br> read data from the RDB. |
| Slave receive <br> ends normally | 1010 | Indicates the number of data specified by the telegraph field has been <br> received within one communication frame. |
| Ends without <br> all data being <br> received | 1011 | Indicates that the communication has ended without receiving the num- <br> ber of data specified by telegraph length field in one communication <br> frame. |

(4) Multiaddress receive (receive interrupt occurs)

When the data/command in multiaddress communication are received from the slave unit, the status code ST3-0 is set and shown as below:

Table 13.5.2d Meaning of status code ST3-0 for multiaddress receive

| Code Name | Code ST3-0 | Content |
| :---: | :---: | :--- |
| Multiaddress <br> receive starts | 1100 | Indicates that the slave unit has received the telegraph field correctly from <br> master unit and multiaddress reception is started but receive interrupt <br> does not occur at this moment. |
| Multiaddress <br> receive data <br> full | 1101 | Indicates that the receive data buffer RDB for slave reception is full (eight <br> byyte of data has been received), and the host controller is requested to <br> read data from the RDB. |
| Multiaddress <br> receive ends <br> normally | 1110 | Indicates the number of data specified by the telegraph field has been <br> received within one communication frame. |
| Ends without <br> all data being <br> received | 1111 | Indicates that the communication has ended without receiving the num- <br> ber of data specified by telegraph length field in one communication <br> frame. |

### 13.5.3 Program flow example for IEBus controller

(1) Main routine

(2) Interrupt routine

This routine is executed when start of transmission or end of reception. In interrupt routine, the status code (ST3-0) in status register STRL is read, then the transmit data can be written or receive data can be read.


Note1: Refer to master transmit routine
Note2: Refer to slave transmit routine
Note3: Refer to master receive routine
(3) IEBus initial setup

The initial setup sequence includes setting its unit address, the command register and releasing the communication inhibit state. If the unit is not set as master, there is no need to set the slave address in slave address register. In converse, if the unit is set as master, there is no need to set the mutiaddress byte and control byte.


Note:It can be executed by write operation of command register.
(4) Master transmit routine

After the communication inhibit state is released, the unit won the arbitration and acts as master. Then master transmit routine is used to transmit data to the slave. This routine is executed inside interrupt routine with ST3-0 bits (upper 2 bits are 00) in status register indicating the status as master transmit has been set.


Note1: The reason for the abnormal termination of transmission can be known by reading the TE, PEF and ACK bits of status register. The remaining data that can't be transmitted will be sent out when GOTM bit in command register CMRH is written ' 1 ' again.
In order to stop the master transmit and clear the WDB, the bit WDBC in CMRL is written ' 1 '.
Note2: Please do not wrtie WDB when WDBF=1
Note3: N is the number of data byte for master transmit
(5) Slave transmit routine

After the slave receives the control bits and is set as slave transmit, this routine is used to transmit data to the master. This routine is executed inside interrupt routine with ST3-0 bits (upper 2 bits are 00) in status register indicating the status as slave transmit has been set.


Note1: The reason for the abnormal termination of transmission can be known by reading the TE, PEF and ACK bits of status register. The remaining data that can't be transmitted will be sent out when GOTS bit in command register CMRH is written ' 1 ' again.
In order clear the WDB, the bit WDBC in CMRL is written ' 1 '.
Note2: Please do not wrtie WDB when WDBF=1
Note3: N is the number of data byte for slave transmit
(6) Master receive routine

After the master transmit the control bits, this routine is used for the master to receive data, slave address or log address from the slave. This routine is consisted of four parts depending on the content of ST3-0.

1. Start of master reception (ST3-0 is 4 H )

When the master receive the telegraph length field from the slave correctly, the status code 4 H is set and the master reception starts. However, interrupt will not occur at that time..


Read out multiaddress, control bits and master receive byte number

Done by hardware

Note1: The status register need not be read because each registers are set. However, it is required to take care the timing of setting the registers. Before updating the register contents, read the registers first.

Note2: N is the number of data byte for master receive.
2. Master received data read request (ST3-0 is 5 H )


Note1: Do not read RDB when RDBE=1.
Note2: N is the number of data byte for master receive.

### 13.5 Operation

3. Master receive ends normally (ST3-0 is 6 H )


Read out multiaddress, control bits and master receive byte number

Done by hardware

Read out master receive data

Done by hardware

Done by hardware

Note1: It is not required to read the status as these data are stored in different registers. As the data will be updated, read the register before the next communication frame.

Note2: Do not read RDB when RDBE $=1$.
4. Master reception ends without all data being received (ST3-0 is 7 H )


Note1: It is not required to read the status as these data are stored in different registers. As the data will be updated, read the register before the next communication frame.

Note2: Do not read RDB when RDBE $=1$.

The routine for slave receive and multiaddress receive is the same as that of master receive but the status code is different. Please refer to section 13.5.2 for the status code of slave receive and multiaddress receive.

### 13.5.4 Timing Diagram of Multiple Frame Transmission

1. When setting ' 1 ' on WDBC (Master side of master transmission)


Figure 13.5.4a When setting ' 1 ' on WDBC (Master side of master transmission)

## 2. When setting ' 0 ' on WDBC (Master side of master transmission)



Figure 13.5.4b When setting ' 0 ' on WDBC (Master side of master transmission)

### 13.5.5 Timing diaram of transmission data when an error is generated

1. The following is an example when the master transmission, an error is generated at the second byte data on the slave side. NAK is received by the master. the following data is transmitted at the second frame.


Figure 13.5.5a Error happened on the Slave side when master transmission
2. The following is an example when the master transmission, an error is generated at the second byte data on the master side. The following data is transmitted at the second frame.


Figure 13.5.5b Error happened on the Master side when master transmission

## Chapter 14: <br> 8/16-Bit PPG

### 14.1 Outline

The 8/16-bit PPG timer is an 8-bit reload timer module, and outputs PPG by control pulse output according to timer operation.
The hardware includes two eight-bit down counters, four eight-bit reload registers, one 16 -bit control register, two external pulse output pins, and two interrupt outputs. The following functions are implemented:

- 8-bit PPG output 2-CH independent operation mode

This is a mode for operating independent 2-CH 8-bit PPG timer, in which PPG0 and PPG1 pins correspond to outputs from PPG0 and PPG1 respectively.

- 16-bit PPG output operation mode In this mode, PPG0 and PPG1 are combined to be operated as a 1 -CH 8/16-bit PPG timer operating as a 16-bit timer. Because PRG0 and PRG1 outputs are reversed by an underflow from PRG1 outputting the same output pulses from PRG0 and PRG1 pins.
- $8+8$ bit PPG output operation mode

In this mode, PPG0 is operated as an 8-bit pre-scaler, in which an underflow output of PPG0 is used as a clock source for PPG1. A toggle output of PPG0 and PPG output of PPG1 are output from PPG0 and PPG1 respectively.

- PPG output operation

The 8/16-bit PPG timer can output pulse waveforms with variable period and duty ratio. Also, it can be used as D/A converter in conjunction with an external circuit.

### 14.2 Block Diagram


(Operation mode control)

Figure 14.2a 8-bit PPG ch0 block diagram


Figure 14.2b 8-bit PPG ch1 block diagram

### 14.3 Registers and Register Details

PPG0 operation mode control register

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\begin{aligned} & \text { Bit No. } \\ & \text { PPGC0 } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: ch0 000044H | PEN0 | - | PE00 | PIE0 | PUF0 | - | - | Reserved |  |
| Read/write $\Rightarrow$ | (R/W) | (-) | (R/W) | (R/W) | (R/W) | $(-)$ | $(-)$ | (-) |  |
| Initial value $\quad \square$ | (0) | (X) | (0) | (0) | (0) | (X) | (X) | (1) |  |

PPG1 operation mode control register

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $\Leftarrow$ Bit No. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: ch0 000045H | PEN1 | - | PE10 | PIE1 | PUF1 | MD1 | MD0 | Reserved | PPGC1 |

Read/write $\quad \Rightarrow$ Initial value $\Rightarrow$
(0) (X)
(0) (0)
(0)
(0)
(-)
(0) (0)
(0) (1)

PPG0,1 output control register


Reload register H


Reload register L


Figure 14.3a Registers of 8/16-bit PPG

### 14.3.1 PPGO operation mode control register (PPGC0)

PPG0 operation mode control register

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\hookleftarrow$ Bit No. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: ch0 000044H | PEN0 | - | PE00 | PIE0 | PUF0 | - | - | Reserved | PPGC0 |
| Read/write $\Rightarrow$ | (R/W) | (-) | (R/W) | (R/W) | (R/W) | (-) | (-) | (-) |  |
| Initial value $\Rightarrow$ | (0) | (X) | (0) | (0) | (0) | (X) | (X) | (1) |  |

PPGC0 is a five-bit control register that selects the operation mode of the block, controls pin outputs, selects count clock, and controls triggers.
[bit 7] PENO (PPG enable): Operation enable bit
This bit selects the PPG operation mode as described below.

| PENO | Operation |  |
| :---: | :--- | :--- |
| 0 | Stop ('L' level output maintained) | [initial value] |
| 1 | PPG operation enabled |  |

Setting this bit to 1 makes the PPG start counting.
This bit is initialized to ' 0 ' upon a reset. This bit is readable and writable.
[bit 5] PE00 (PPG output enable 0): PPG0 pin output enable bit
This bit controls the PPG0 pulse output external pin as described below.

| PE00 | Operation |  |  |
| :---: | :--- | :--- | :---: |
| 0 | General-purpose port pin (pulse output disabled) | [initial value] |  |
| 1 | PPG0 = pulse output pin (pulse output enabled) |  |  |

This bit is initialized to '0' upon a reset. This bit is readable and writable.
[bit 4] PIE0 (PPG interrupt enable): PPG interrupt enable bit
This bit controls PPG interrupt as described below.

| PIE0 | Operation |  |
| :---: | :---: | :---: |
| 0 | Interrupt disabled | [initial value] |
| 1 | Interrupt enabled |  |

While ' 1 ' is written to this bit, an interrupt request is issued as soon as ' 1 ' is written to PUF0. No interrupt request is issued while this bit is set to ' 0 .'

This bit is initialized to '0' upon a reset. This bit is readable and writable.
Note: PIEO is assigned the same interrupt vector number as that of 16-bit reload timer. When using $\mathrm{El}^{2} \mathrm{OS}$ in 16-bit reload timer, write '0' to PIE0.
[bit 3] PUF0 (PPG underflow flag): PPG counter underflow bit

This bit controls the PPG counter underflow as described below.

| PUFO | Operation |  |
| :---: | :--- | :--- |
| 0 | PPG counter underflow is not detected | [initial value] |
| 1 | PPG counter underflow is detected |  |

In 8-bit PPG 2ch mode or 8-bit prescaler + 8-bit PPG mode, '1' is written to this bit when an underflow occurs as a result of the ch0 counter value becoming between 00 H and FFH. In 16-bit PPG 1ch mode, ' 1 ' is written to this bit when an underflow occurs as a result of the ch $1 / \mathrm{ch} 0$ counter value becoming between 0000 H and FFFFH. To set this bit to ' 0 ,' write ' 0 .' Writing ' 1 ' to this bit is invalid. Upon a read operation during a read-modify-write instruction, ' 1 ' is read.

This bit is initialized to ' 0 ' upon a reset. This bit is readable and writable.
[bit 0] This is a reserved bit.
When setting PPGC0, always set this bit to 1 .

### 14.3.2 PPG1 operation mode control register (PPGC1)

PPG1 operation mode control register

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $\stackrel{\text { Bit No. }}{\sim}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: ch0 000045H | PEN1 | - | PE10 | PIE1 | PUF1 | MD1 | MD0 | Reserved |  |
| Read/write $\Rightarrow$ | (R/W) | (-) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (-) |  |
| Initial value $\Rightarrow$ | (0) | (X) | (0) | (0) | (0) | (0) | (0) | (1) |  |

PPGCO is a seven-bit control register that selects the operation mode of the block, controls pin outputs, selects count clock, and controls triggers.
[bit 15] PEN1 (PPG enable): Operation enable bit
This bit selects the PPG operation mode as described below.

| PEN1 | Operation |  |
| :---: | :--- | :--- |
| 0 | Stop ('L' level output maintained) | [initial value] |
| 1 | PPG operation enabled |  |

Setting this bit to 1 makes the PWM start counting.
This bit is initialized to '0' upon a reset. This bit is readable and writable.
[bit 13] PE10 (PPG output enable 1): PPG1 pin output enable bit

| PE10 | Operation |  |  |
| :---: | :--- | :--- | :---: |
| 0 | General-purpose port pin (pulse output disabled) | [initial value] |  |
| 1 | PPG1 = pulse output pin (pulse output enabled) |  |  |

This bit controls the PPG1 pulse output external pin as described below.
This bit is initialized to '0' upon a reset. This bit is readable and writable.
[bit 12] PIE1 (PPG interrupt enable): PPG interrupt enable bit
This bit controls PPG interrupt as described below.

| PIE1 | Operation |  |
| :---: | :---: | :---: |
| 0 | Interrupt disabled |  |
| 1 | Interrupt enabled |  |

While ' 1 ' is set in this bit, an interrupt request is issued as soon as ' 1 ' is written to PUF1. No interrupt request is issued while this bit is set to ' 0 .'

This bit is initialized to '0' upon a reset. This bit is readable and writable.
Note: PIE1 is assigned the same interrupt vector number as that of UART 0 transmission complete. When using $\mathrm{El}^{2} \mathrm{OS}$ in UART 0 transmissioin complete, write ' 0 ' to PIE1.
[bit 11] PUF1 (PPG underflow flag): PPG counter underflow bit
This bit controls the PPG counter underflow as described below.

| PUF1 | Operation |  |
| :---: | :---: | :---: |
| 0 | PPG counter underflow is not detected | [initial value] |
| 1 | PPG counter underflow is detected |  |

In 8-bit PPG 2ch mode or 8 -bit prescaler + 8-bit PPG mode, ' 1 ' is written to this bit when an underflow occurs as a result of the ch1 counter value becoming between 00 H and FFH. In 16-bit PPG 1ch mode, ' 1 ' is written to this bit when an underflow occurs as a result of the ch $1 / \mathrm{ch} 0$ counter value becoming between 0000 H and $\operatorname{FFFFH}$. To set ' 0 ' in this bit, write ' 0 .' Writing ' 1 ' to this bit is invalid. Upon a read operation during a read-modify-write instruction, ' 1 ' is read.

This bit is initialized to '0' upon a reset. This bit is readable and writable.
[bit 10, 9] MD2, 1 (PPG count mode): Operation mode selection bit
This bit selects the PPG timer operation mode as described below.

| MD1 | MD0 | Operation mode |
| :---: | :---: | :--- |
| 0 | 0 | 8-bit PPG 2ch independent mode |
| 0 | 1 | 8-bit prescaler + 8-bit PPG 1ch mode |
| 1 | 0 | Reserved (setting inhibited) |
| 1 | 1 | 16-bit PPG 1ch mode |

This bit is initialized to ' 00 ' upon a reset. This bit is readable and writable.
Note: Do not set '10' in this bit.
Note: To write ' 01 ' to this bit, ensure that ' 01 ' is not written to the PEN0 bit of PPGC0 or PEN1 bit of PPGC1.
Write '11' or '00' in both the PEN0 and PEN1 bits simultaneously.
Note: To write '11' to this bit, update PPGC0 and PPGC1 by word transfer and write '11' or ' 00 ' to both the PEN0 and PEN1 bits simultaneously.
[bit 8] This is a reserved bit.
When setting PPGC0, always write 1 to this bit.

### 14.3.3 PPGO, 1 output pin control register (PPGOE)

## PPG0,1 output control register

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\Leftarrow$ Bit No. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: ch0 10046H | PCS2 | PCS1 | PCSO | PCM2 | PCM1 | PCM0 | Reserved | Reserved | PPGOE |
| Read/write $\Rightarrow$ | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) |  |
| Initial value $\Rightarrow$ | (0) | (0) | (0) | (0) | (0) | (0) | (0) | (0) |  |

This is an 8-bit control register that controls the pin output of this block.
[bits 7 to 5) PCS2 to 0 (PPG count select): Count clock selection bit
These bits select the channel 1 down counter operation clock as described below.

| PCS2 | PCS1 | PCSO | Operation mode |
| :---: | :---: | :---: | :--- |
|  | 0 | 0 | Peripheral clock (62.5-ns machine clock, 16 MHz ) |
|  | Peripheral clock/2 (125-ns machine clock, 16 MHz ) |  |  |
| 0 | 0 | 1 | Peripheral clock/4 (250-ns machine clock, 16 MHz ) |
| 0 | 1 | 0 | Peripheral clock/8 (500-ms machine clock, 16 MHz ) |
| 0 | 1 | 1 |  |
| 1 | 0 | 0 | Peripheral clock/16 (1-ms machine clock, 16 MHz$)$ |
| 1 | 1 | 1 | Clock input from time base counter (128-ms, 4-Mhz source |

This bit is initialized to '000' upon a reset. This bit is readable and writable.
Note: In 8-bit prescaler + 8-bit PPG mode or in 16-bit PPG mode, ch1 PPG operates in response to a counter clock from ch0. Therefore, the PCS1 bit is invalid.
[bits 4 to 2] PCM2 to 0 (PPG count mode): Count clock selection bit
These bits select the channel 0 down counter operation clock as described below.

| PCM2 | PCM1 | PCM0 | Operation mode |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | Peripheral clock (62.5-ns machine clock, 16 MHz ) |
| 0 | 0 | 1 | Peripheral clock/2 (125-ns machine clock, 16 MHz ) |
| 0 | 1 | 0 |  |
| 0 | 1 | 1 | Peripheral clock/4 (250-ns machine clock, 16 MHz ) |
| 1 | 0 | 0 | Peripheral clock/8 (500-ms machine clock, 16 MHz ) |
| 1 | 1 | 1 | Peripheral clock/16 (1-ms machine clock, 16 MHz ) |
|  | Clock input from time base counter (128-ms, 4-Mhz source |  |  |

This bit is initialized to ' 000 ' upon a reset. This bit is readable and writable.

### 14.3.4 Reload register (PRLL/PRLH )



These are 8-bit registers that hold the reload values for the PCNT down counter. Their roles are described below.

| Register name | Function |
| :---: | :---: |
| PRLL | Holds the L side reload value. |
| PRLH | Holds the H side reload value. |

These registers are readable and writable.
Note: In 8-bit prescaler + 8-bit PPG mode, setting different values in PRLL and PRLH of ch1 may cause the PPG waveform of ch1 to vary in each cycle. Write the same value to PRLL and PRLH of ch0.

### 14.4 Operations

This block has two channels of 8-bit PPG units. These two channels can be used in three modes: independent two-channel mode, 8 -bit prescaler + 8-bit PPG mode, and single-channel 16-bit PPG mode.
Each of the 8-bit PPG units has two eight-bit reload registers. One reload register is for the $L$ side (PRLL) and the other is for the H side (PRLH). The values stored in these registers are reloaded into the 8 -bit down counter (PCNT), from the $L$ side and $H$ side in turn. Thus, the values are decremented for each count clock, and the pin output (PPG) value is inverted upon a reload caused by a counter borrow. This operation results in L -wide or H -wide pulse outputs, corresponding to the reload register value.
The operation is started and resumed by writing data in the corresponding register bit.
The table below lists the relationship between the reload operation and pulse outputs.

Table 14.4a Reload operation and pulse output

| Reload operation |  | Pin output change |  |  |
| :--- | :--- | :--- | :--- | :--- |
| PRLH | PCNT | PPG0x/1x $\left[\begin{array}{ll}0 & 1\end{array}\right]$ | Rise |  |
| PRLL | PCNT | PPP0x/1x [1 | 0 |  |$] \quad$ Fall 

When 1 is set in bit 4 (PIE0) of PPGC0 or in bit 12 (PIE1) of PPGC1, an interrupt request is output upon a borrow from 00 to FF (from 0000 to FFFF in 16-bit PPG mode) of each counter.
(1) Operation mode

This block can be used in three modes: independent two-channel mode, 8 -bit prescaler +8 -bit PPG mode, and single-channel 16-bit PPG mode.
In independent two-channel mode, the two channels of 8-bit PPG units operate independently. The PPG0 pin is connected to the ch0 PPG output, while the PPG1 pin is connected to the ch1 PPG output.
In 8-bit prescaler + 8-bit PPG mode, ch0 is used as an 8-bit prescaler while the count in ch1 is based on borrow outputs from ch0. Thus, 8 -bit PPG waveforms can be output at any cycles. The PPG0 is connected to the ch0 prescaler output, while the PPG1 pin is connected to the ch1 PPG output.
In 16-bit PPG 1ch mode, ch0 and ch1 are connected and used as a single 16-bit PPG. The PPG0 and PPG1 pins are connected to the 16 -bit PPG output.

### 14.4 Operations

(2) PPG output operation

In this block, the ch0 PPG is activated to start counting when '1' is written to bit 7 (PEN0) of the PPGC0 (PWM operation mode control) register. Similarly, the ch1 PPG is activated to start counting when ' 1 ' is written to bit 15 (PEN1) of the PPGC1 register. Once the operation has started, counting is terminated by writing '0' to bit 7 (PEN0) of PPGC0 or in bit 15 (PEN1) of PPGC1. Once the counting is terminated, the pulse output is maintained at the L level.
In 8-bit prescaler +8 -bit PPG mode, do not set ch1 to be in operation while ch0 operation is stopped.
In 16-bit PPG mode, ensure that bit 7 (PEN0) of PPGC0 register and bit 15 (PEN1) of PPGC1 register are started or stopped simultaneously. The figure below is a diagram of PPG output operation. During PPG operation, a pulse wave is continuously output at a frequency and duty ratio (the ratio of the H -level period of the pulse wave to the L-level period). PPG continues operation until stop is specified explicitly.


Figure 14.4a PPG output operation, output waveform
(3) Reload value and pulse width

The width of the output pulse is determined by adding 1 to the reload register value and multiplying it by the count clock cycle. Note that when the reload register value is $00_{\mathrm{H}}$ during 8 -bit PPG operation or $0000_{\mathrm{H}}$ during 16-bit PPG operation, the pulse width is equivalent to one count clock cycle. In addition, note that when the reload register value is $\mathrm{FF}_{H}$ during 8-PPG operation, the pulse width is equivalent to 256 count clock cycles. When the reload register value is $\mathrm{FFFF}_{\mathrm{H}}$ during 16-bit PPG operation, the pulse width is equivalent to 65536 count clock cycles. An example of pulse width calculation is given below.

$$
P 1=T X(L+1)
$$

$\mathrm{Ph}=\mathrm{T} X(\mathrm{H}+1)$
$\begin{array}{lll}\mathrm{L} & : & \mathrm{PRLL} \text { value } \\ \mathrm{H} & : & \text { value } \\ \mathrm{T} & \text { : } & \text { Input clock cycle } \\ \mathrm{Ph}: & \text { High pulse width } \\ \mathrm{Pl}: & \text { Low pulse width }\end{array}$
(4) Count clock selection

The count clock used for the operation of this block is supplied from a peripheral clock or time base counter. The count clock can be selected from six types.
Select ch0 clock at bit 4 to 2 (PCM2 to 0 ) of the PPGOE register, and ch1 clock at bit 7 to $S$ (PCS2 to 0 ) of the PPGOE register.
The clock is selected from a peripheral clock $1 / 16$ to 1 times higher than a machine clock or an input clock from a time base counter.

In 8-bit prescaler + 8-bit PPG mode or 16-bit PPG mode, however, the value in bit 14 (PCS1) of the PPGC1 register is invalid. The register is invalid because ch1 PPG receives a count clock from ch0.
When the time base counter input is used, the first count cycle after a trigger or a stop may be shifted. The cycle may also be shifted if the time base counter is cleared during operation of this module.
In 8-bit prescaler +8 -bit PPG mode, if ch1 is activated while ch0 is in operation and ch1 is stopped, the first count cycle may be shifted.
(5) Pulse pin output control

The pulses generated by this module can be output from external pins PPG0 and PPG1.
To output the pulses from an external pin, write ' 1 ' to the bit corresponding to each pin. Use bit 5 (PE0) of the PPGC0 register for the PPG0 pin, bit 13 (PE1) of the PPGC1 register for the PPG1 pin. When ' 0 ' is written to these bits (default), the pulses are not output from the corresponding external pins; the pins work as general-purpose ports.
In 16-bit PPG mode, the same waveform is output from PPG0 and PPG1. Thus, the same output can be obtained by enabling any external pin.
In 8-bit prescaler + 8-bit PPG mode, the 8-bit prescaler toggle output waveform is output from PPG0, while the 8 -bit PPG waveform is output from PPG1. The figure below is a diagram of output waveforms in this mode.


Note : Set the same value in ch0 PRLL and ch0 PRLH.

Figure 14.4b 8+8 PPG output operation waveform
(6) Interrupts

For this module, an interrupt becomes active when the reload value is counted out and a borrow occurs.
In 8-bit PPG 2ch mode or 8-bit prescaler + 8-bit PPG mode, an interrupt is requested by a borrow in each counter. In 16-bit PPG mode, PUG0 and PUF1 are simultaneously set by a borrow in the 16 -bit counter. Therefore, enable only PIE0 or PIE1 to unify the interrupt causes. In addition, simultaneously clear the interrupt causes for PUF0 and PUF1.
(7) Default values of hardware components

The hardware components of this block are initialized to the following values when reset:

| <Registers> | - PPGCO $\Rightarrow 0 X 000001_{\text {B }}$ |
| :---: | :---: |
|  | - PPGC1 $\Rightarrow 00000001 \mathrm{~B}$ |
|  | - PPGOE XXXXXX00B |
| <Pulse outputs> | PPGO $\Rightarrow$ 'L' |
|  | PPG1 $\Rightarrow$ 'L' |
|  | PE0 $\Rightarrow$ PPG0 output disabled |
|  | PE1 $\quad \Rightarrow$ PPG1 output disabled |
| <Interrupt requests> | IRQ0 $\Rightarrow$ ' ${ }^{\prime}$ |
|  | IRQ1 $\Rightarrow$ ' L ' |

Hardware components other than the above are not initialized.
(8) Reload register write timing

In a mode other than 16-bit PPG mode, it is recommended to use a word transfer instruction to write data in reload registers PRLL and PRLH. If two byte transfer instructions are used to write a data item to these registers, a pulse of unexpected width may be output depending on the timing.


Figure 14.4c Write timing chart
Assume that PRLL is updated from A to C before point (1) in the time chart above, and PRLH is updated from B to $D$ after point (1). Since the PRL values at point (1) are PRLL=C and PRLH=B, a pulse of $L$ side count value $C$ and $H$ side count value $B$ is output only once.

Similarly, to write data in PRL of ch0 and ch1 in 16-bit PPG mode, use a long word transfer instruction, or use word transfer instructions in the order of ch0 and then ch1. In this mode, the data is only temporarily written to ch0 PRL. Then, the data is actually written into ch0 PRL when the ch1 PRL is written to.
In a mode other than 16-bit PPG mode, ch0 and ch1 PRL are written independently.


Figure 14.4d PRL write operation block diagram

## Chapter 15: <br> 16-Bit Reload Timer (with Event Count Function)

### 15.1 Outline

The 16-bit reload timer 1 consists of a 16-bit down-counter, a 16-bit reload register, one input pin (TIN) and one output pin (TOUT), and a control register.
It has an internal clock mode for counting down in synchronization to three types of internal clocks and an event count mode for counting down detecting a given edge of the pulse input to the external bus pin, and either of the two functions can be selectively used.
For this timer, an "underflow" is defined as the timing of transition from the counter value of " $0000_{\mathrm{H}}$ " to "FFFF ${ }_{H}$ ". According to this definition, an underflow occurs after [re-load register setting value +1 ] counts.
In operating the counter, the re-load mode for repeating counting operation after re-loading a counter value after an underflow or the one-shot mode for stopping the counting operation after an underflow can be selectively used.
Because the timer can generate an interrupt upon an underflow, the timer conforms to the extended intelligent $1 / O$ service ( $\mathrm{El}^{2} \mathrm{OS}$ ).
The output pin (TOUT) outputs a toggle output waveform in reload mode or a square waveform during counting in one-shot mode. The input pin (TIN) functions as the event input in event count mode, or as the trigger input or gate input in internal clock mode.

### 15.2 Block Diagram



Figure 15.2a Block Diagram of 16-Bit Reload Timer

### 15.3 Registers and Register Details

Timer control status register (upper)


Timer control status register (lower)


16-bit timer register (upper)/
16-bit reload register (upper)


16-bit timer register (lower)/

16-bit reload register (lower) ch1 00004Ен ch2 000052 H | Read/write | $\Rightarrow$ | $(\mathrm{R} / \mathrm{W})$ | $(\mathrm{R} / \mathrm{W})$ | $(\mathrm{R} / \mathrm{W})$ | $(\mathrm{R} / \mathrm{W})$ | $(\mathrm{R} / \mathrm{W})$ | $(\mathrm{R} / \mathrm{W})$ | $(\mathrm{R} / \mathrm{W})$ |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Initial value |  | $(\mathrm{X})$ | $(\mathrm{X})$ | $(\mathrm{X})$ | $(\mathrm{X})$ | $(\mathrm{X})$ | $(\mathrm{X})$ | $(\mathrm{X})$ |

Figure 15.3a Registers of 16-Bit Reload Timer

### 15.3.1 Timer control status register (TMCSR)

Timer control status register (upper)


Timer control status register (lower)


Figure 15.3.1a Timer Control Status Register
Controls the operation mode and interrupts for the 16-bit timer. Only modify bits other than UF, CNTE, and TRG when CNTE = " 0 ".
[Bits 11, 10] CSL1, CSLO (Clock select 1, 0)
The count clock select bits. The following tMable lists the selected clock sources.LL

| CSL1 | CSLO | Clock Source (Machine cycle $\phi=\mathbf{1 6} \mathbf{~ M H z})$ |
| :---: | :---: | :---: |
| 0 | 0 | $\phi / 2^{1}(0.125 \mu \mathrm{~s})$ |
| 0 | 1 | $\phi / 2^{3}(0.5 \mu \mathrm{~s})$ |
| 1 | 0 | $\phi / 2^{5}(2.0 \mu \mathrm{~s})$ |
| 1 | 1 | External event count mode |

[Bits 9, 8, 7] MOD2, MOD1, MODO
These bits set the operation mode and I/O pin functions.
The MOD2 bit selects the I/O functions. When MOD2 = " 0 ", the input pin functions as a trigger input. In this case, the reload register contents is loaded to the counter when an active edge is input to the input pin and count operation proceeds. When MOD2 $=$ " 1 ", the timer operates in gate counter mode and the input pin functions as a gate input. In this mode, the counter only counts while an active level is input to the input pin.
The MOD1 and 0 bits set the pin functions for each mode. The following tables list the MOD2, 1, 0 bit settings

Internal clock mode (CSL0, 1 = "00", "01", or " 10 ")

| MOD2 | MOD1 | MOD0 | Input Pin Function | Active Edge or Level |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | Trigger disabled | - |
| 0 | 0 | 1 | Trigger input | Rising edge |
| 0 | 1 | 0 | $\Uparrow$ | Falling edge |
| 0 | 1 | 1 | $\Uparrow$ | Both edges |
| 1 | $\times$ | 0 | Gate input | "L" level |
| 1 | $\times$ | 1 | $\Uparrow$ | "H" level |

Event counter mode (CSL0,1 = "11")

| MOD2 | MOD1 | MODO | Input Pin Function | Active Edge or Level |
| :---: | :---: | :---: | :---: | :---: |
| $\times$ | 0 | 0 | - | - |
|  | 0 | 1 | Trigger input | Rising edge |
|  | 1 | 0 | $\Uparrow$ | Falling edge |
|  | 1 | 1 | $\Uparrow$ | Both edges |

Note: Bits marked as X in the table can be set to any value.

## [Bit 6] OUTE

Output enable bit. The TOUT pin functions as a general-purpose port when this bit is " 0 " and as the timer output pin when this bit is " 1 ". In reload mode, the output waveform toggles. In one-shot mode, TOUT outputs a square waveform that indicates that counting is in progress.
Note: For reload timer 1 and 2, TOUT is multiplexed with P94/OUT0 and P95/OUT1 respectively. If output capture is enabled, it has higher priority than reload timer output.

## [Bit 5] OUTL

This bit sets the output level for the TOUT pin. When OUTL is " 0 " or " 1 ", the output pin level is opposite

## [Bit 4] RELD (Reload)

This bit enables reload operations. When RELD is " 1 ", the timer operates in reload mode. In this mode, the timer loads the reload register contents into the counter and continues counting whenever an underflow occurs (when the counter value changes from 0000 н to FFFFH). When RELD is " 0 ", the timer operates in one-shot mode. In this mode, the count operation stops when an underflow occurs due to the counter value changing from 0000 н to $\operatorname{FFFF}$ н..

| OUTE | RELD | OUTL | Output Waveform |
| :---: | :---: | :---: | :--- |
| 0 | X | X | General-purpose port |
| 1 | 0 | 0 | Output an " H " level square waveform during counting. |
| 1 | 0 | 1 | Output an "L" level square waveform during counting. |
| 1 | 1 | 0 | Toggle output. "L" level at count start. |
| 1 | 1 | 1 | Toggle output. "H" level at count start. |

[Bit 3] INTE (Interrupt enable)
Timer interrupt request enable bit. When INTE is " 1 ", an interrupt request is generated when the UF bit changes to " 1 ". When INTE is " 0 ", no interrupt request is generated, even when the UF bit changes to "1".

## [Bit 2] UF (Underflow)

Timer interrupt request flag. UF is set to " 1 " when an underflow occurs (when the counter value changes from 0000 н to $\operatorname{FFFF}$ ). Cleared by writing " 0 " or by the intelligent I/O service. Writing " 1 " to this bit has no meaning. Read as " 1 " by read-modify-write instructions.
[Bit 1] CNTE (Count enable)
Timer count enable bit. Writing " 1 " to CNTE sets the timer to wait for a trigger. Writing " 0 " stops count operation.
[Bit 0] TRG (Trigger)
Software trigger bit. Writing " 1 " to TRG applies a software trigger, causing the timer to load the reload register contents to the counter and start counting. Writing " 0 " has no meaning. Reading always returns " 0 ". Applying a trigger using this register is only valid when CNTE $=$ " 1 ". Writing " 1 " has no effect if CNTE $=$ " 0 ".

### 15.3.2 TMR (16-bit timer register)/TMRLR (16-bit reload register)



Figure 15.3.2a 16-Bit Timer Register and 16-Bit Reload Register
■ TMR contents (for reading)
Reading this register reads the count value of the 16 -bit timer. The initial value is undefined. Always read this register using word move instructions.

TMRLR contents (for writing)
The 16 -bit reload register holds the initial count value. The initial value is undefined. Always write to this register using word transfer instructions.

### 15.4 Operation

### 15.4.1 Internal clock operation

The machine clock divided by $2^{1}, 2^{3}$, or $2^{5}$ can be selected as the clock sources for operating the timer from an internal divide clock. The external input pin can be selected as either a trigger input or gate input by a register setting.
Writing " 1 " to both the CNTE and TRG bits in the control register enables and starts counting simultaneously. Using the TRG bit as a trigger input is always available when the timer is enabled (CNTE = " 1 "), regardless of the operation mode.
Figure 15.4.1a shows counter activation and counter operation. A time period T ( T : machine cycle) is required from the counter start trigger being input until the reload register data is loaded into counter.


Figure 15.4.1a Counter Activation and Operation

### 15.4.2 Underflow operation

An underflow is defined for this timer as the time when the counter value changes from 0000 н to FFFFH. Therefore, an underflow occurs after (reload register setting +1) counts.

If the RELD bit in the control register is " 1 " when the underflow occurs, the contents of the reload register is loaded into the counter and counting continues. When RELD is " 0 ", counting stops with the counter at FFFFн.
The UF bit in the control register is set when the underflow occurs. If the INTE bit is " 1 " at this time, an interrupt request is generated.
Figure 15.4.2a shows the operation when an underflow occurs.


Figure 15.4.2a Underflow Operation

### 15.4.3 Input pin functions (for internal clock mode)

The TIN pin can be used as either a trigger input or a gate input when an internal clock is selected as the clock source. When used as a trigger input, input of an active edge causes the timer to load the reload register contents to the counter and then start count operation after clearing the internal prescaler. Input a pulse width of at least 2 T ( T is the machine cycle) to TIN.

Figure 15.4.3a shows the operation of trigger input.


Figure 15.4.3a Trigger Input Operation
When used as a gate input, the counter only counts while the active level specified by the MODO bit of the control register is input to the TIN pin. In this case, the count clock continues to operate unless stopped. The software trigger can be used in gate mode, regardless of the gate level. Input a pulse width of at least 2 T ( T is the machine cycle) to the TIN pin. Figure 15.4.3b shows the operation of gate input.


Figure 15.4.3b Gate Input Operation

### 15.4.4 External event counter

The TIN pin functions as an external event input pin when an external clock is selected. The counter counts on the active edge specified in the register. Input a pulse width of at least 4 T ( T is the machine cycle) to the TIN pin.

### 15.4.5 Output pin functions

In reload mode, the TOUT pin performs toggle output (inverts at each underflow). In one-shot mode, the TOUT pin functions as a pulse output that outputs a particular level while the count is in progress. The OUTL bit of the control register sets the output polarity. When OUTL = " 0 ", the initial value for toggle output is " 0 " and the one-shot pulse output is " 1 " while the count is in progress. The output waveforms are opposite when OUTL = " 1 ".


Figure 15.4.5a Output Pin Functions (1)


Figure 15.4.5b Output Pin Functions (2)

### 15.4.6 Intelligent I/O service ( $I^{2} \mathrm{OS}$ ) function and interrupts

The timer includes a circuit that supports $\mathrm{I}^{2} \mathrm{OS}$. The timer can activate $\mathrm{I}^{2}$ OS when an underflow occurs. $1^{2} O S$ can be used with both timers on this product. However, as both timers (ch0 and ch1) are connected to the same interrupt control register (ICRx) in the interrupt controller, ch0 and ch1 cannot be assigned to different $\mathrm{I}^{2}$ OS services. Also, as the two timers have different interrupt vectors, they can be assigned to two different interrupt services. However, as ch0 and ch1 share an interrupt control register as described above, the same interrupt level applies to both channels.

### 15.4.7 Counter operation state

The counter state is determined by the CNTE bit in the control register and the internal WAIT signal. Available states are: CNTE $=$ " 0 " and WAIT $=" 1 "$ (STOP state), CNTE $=" 1$ " and WAIT $=" 1$ " (WAIT state for trigger), and CNTE $=" 1 "$ and WAIT $=" 0 "$ (RUN state). Figure 15.4.7a shows the transitions between each state.


Figure 15.4.7a Counter State Transitions

## Chapter 16: <br> A/D Converter

### 16.1 Outline

The A/D converter converts analog input voltages into digital values. The A/D converter has the following features:

- Conversion time: $5.2 \mu \mathrm{~s}$ min. per channel (at 16 MHz machine clock)
- RC sequential compare conversion format with sample and hold circuit
- 10-bit resolution
- Analog input selected from eight channels by programming

Single conversion mode: One channel is selected for conversion.
Scan conversion mode: Voltages in multiple consecutive channels are converted. Up to eight channels can be programmed.
Continuous conversion mode: Voltages in the specified channel are converted repeatedly.
Stop conversion mode: Voltages in a single channel are converted, then the system pauses and stands by for the next activation. (The conversion start points can be synchronized.)

- At the end of $A / D$ conversion, a relevant interrupt request can be issued to the CPU. This interrupt can be used to activate I2OS, which transfers A/D conversion result data to memory. This feature is suitable for continuous processing.
- The activation factors can be selected from software, external trigger (falling edge), or timer (rising edge).


### 16.2 Block Diagram



Figure 16.2a Block Diagram of A/D converter

### 16.3 Registers and Register Details

Control Status Registers (Upper Byte)

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | Bit number <br> ADCS2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 000037 ${ }_{\text {H }}$ | BUSY | INT | INTE | PAUS | STS1 | STS0 | STRT | DA |  |
| Read/write $\Rightarrow$ Initial value $\Rightarrow$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | (R/W) (0) | (R/W) (0) | $\begin{gathered} (R / W) \\ (0) \end{gathered}$ | (W) (0) | $\begin{gathered} (R / W) \\ (0) \end{gathered}$ |  |

Control Status Registers (Lower Byte)

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\diamond$ Bit number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 000036 ${ }_{\text {H }}$ | MD1 | MD0 | ANS2 | ANS1 | ANS0 | ANE2 | ANE1 | ANEO | ADCS1 |
| Read/write $\Rightarrow$ ¢ | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) |  |
| Initial value $\Rightarrow>$ | (0) | (0) | (0) | (0) | (0) | (0) | (0) | (0) |  |

Data Registers (Upper Byte)


Data Registers (Lower Byte)

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 乙 Bit number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 000038 ${ }_{\text {H }}$ | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | ADCR1 |


| Read/write $\Rightarrow$ | $(R)$ | $(R)$ | $(R)$ | $(R)$ | $(R)$ | $(R)$ | $(R)$ | $(R)$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Initial value $\Rightarrow$ | $(X)$ | $(X)$ | $(X)$ | $(X)$ | $(X)$ | $(X)$ | $(X)$ | $(X)$ |

Figure 16.3a Registers of A/D Converter

### 16.3.1 Control status registers (ADCS1 and ADCS2)

These registers are used to control the A/D converter and display the status.
Control Status Registers (Upper Byte)

| Address : 000037 ${ }_{\text {H }}$ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $\triangleleft$ Bit number ADCS2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | BUSY | INT | INTE | PAUS | STS1 | STSO | STRT | DA |  |
| Read/write $\Rightarrow$ | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (W) | (R/W) |  |
| Initial value $\Rightarrow$ | (0) | (0) | (0) | (0) | (0) | (0) | (0) | (0) |  |

Control Status Registers (Lower Byte)

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Bit number <br> ADCS1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 000036 ${ }_{\text {H }}$ | MD1 | MD0 | ANS2 | ANS1 | ANS0 | ANE2 | ANE1 | ANE0 |  |
| Read/write Initial value $\Rightarrow$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (R / W) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (R / W) \\ (0) \end{gathered}$ | (R/W) <br> (0) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | $\begin{gathered} (R / W) \\ (0) \end{gathered}$ |  |

Figure 16.3.1a Control Status Registers
Note: Do not update ADCS1 during A/D conversion.
[bit 15] BUSY (busy flag and stop):
Read:This bit indicates the A/D converter operation. This bit is set when the A/D conversion is activated, and cleared when the conversion ends.
Write: Writing ' 0 ' to this bit during A/D conversion forces the conversion to terminate. This features is used for forced stop in continuous or stop mode.
'1' cannot be written to the operation display bit. With a read-modify-write instruction.
' 1 ' is read from this bit. In single mode, this bit is cleared at the end of A/D conversion.
In continuous or stop mode, this bit is not cleared until conversion is stopped by writing ' 0 .'
This bit is initialized to ' 0 ' upon a reset.
Do not perform forced termination and activation by software simultaneously. (BUSY=0, STRT=1)
[bit 14] INT (Interrupt): A data display bit
This bit is set when conversion data is written to ADCR.
An interrupt request is issued if this bit is set while bit 5 (INTE) is '1.' In addition, I2OS is activated if it is enabled. Writing ' 1 ' has no effect.
This bit is cleared by writing ' 0 ' or by an I2OS interrupt clear signal.
Note: To clear this bit by writing ' 0 ,' ensure that A/D conversion is not in progress.
This bit initialized to ' 0 ' upon a reset.
[bit 13] INTE (Interrupt enable): This bit is used to enable or disable interrupts at the end of conversion..

| 0 | Interrupts are disabled. |
| :---: | :--- | [initial value] 9

Set this bit when using I2OS. I2OS is activated when an interrupt request is issued. Upon a reset, this bit is initialized to ' 0 .'
[bit 12] PAUS (A/D conversion pause):
This bit is set when the A/D conversion is paused.
Only one register is available for storing the A/D conversion result. Therefore, unless the conversion results are transferred by I2OS, the result data would be continuously updated and destroyed in continuous conversion.
To prevent the above condition, the system is designed so that a data register value must be transferred by I2OS before the next conversion data is saved. A/D conversion pauses during that period. A/D conversion is resumed at the end of transfer by I2OS.
This register is valid only when I2OS is used.

* For the conversion data protection function, see Section 2.7.4, "Operations."

Upon a reset, this bit is initialized to ' 0 .'
[bits 11 and 10] STS1 and STS0 (Start source select):
Upon a reset, these bits are initialized to '00.'
These bits are used to select the A/D conversion activation factor.

| STS1 | STS0 | Function |
| :---: | :---: | :--- |
| 0 | 0 | Activation by software |
| 0 | 1 | Activation by external pin trigger and software |
| 1 | 0 | Activation by timer and software |
| 1 | 1 | Activation by external pin trigger, timer, and software |

In a mode allowing two or more activation factors, A/D conversion is activated by the factor that is input first.
The activation factor changes as soon as it is updated. Thus, take care when updating it during A/D conversion.

* The external pin trigger is detected by the falling edge. If this bit is updated to external trigger activation while the external trigger input level is 'L,' A/D may be activated at once.
* When timer is selected, PPG1 output is selected.
[bit 9] STRT (Start):
A/D conversion is activated when ' 1 ' is written to this bit.
To reactivate A/D conversion, write ' 1 ' to this bit again.
In stop mode, restart is disabled due to the operation functions.
Upon a reset, this bit is initialized to ' 0 .'
Note: Do not perform forced termination and activation by software simultaneously. ( $B U S Y=0, S T R T=1$ )
[bit 8] DA
This is a test bit. Always write ' 0 ' to this bit.
[bits 7 and 6] MD1 and MD0 (A/D converter mode set):
These bits are used to set the A/D converter operation mode.

| MD1 | MD0 | Operation mode |
| :---: | :---: | :--- |
| 0 | 0 | Single mode. Reactivation during operation is allowed. |
| 0 | 1 | Single mode. Reactivation during operation is not allowed. |
| 1 | 0 | Continuous mode. Reactivation during operation is not <br> allowed. |
| 1 | 1 | Stop mode. Reactivation during operation is not allowed. |

Single mode: A/D conversion is continuously performed from the channel specified with ANS2 to ANS0 to the channel specified with ANE2 to ANEO. The conversion stops once it has been done for all these channels.

Continuous mode: A/D conversion is repeatedly performed from the channel specified with ANS2 to ANS0 to the channel specified with ANE2 to ANEO.
Stop mode: A/D conversion is performed from the channel specified with ANS2 to ANS0 to the channel specified with ANE2 to ANE0, pausing for each channel. The A/D conversion is resumed upon an activation factor.
Upon a reset, these bits are initialized to '00.'
Note: When activated in continuous or stop mode, A/D conversion continues until it is stopped by the BUSY bit.
Note: The conversion is stopped by writing ' 0 ' to the BUSY bit.
Note: In single, continuous, or stop mode, reactivation is disabled regardless of the activation factor (timer, external trigger, or software).
[bits 5, 4, and 3] ANS2, ANS1, and ANS0 (Analog start channel set):
Use these bits to specify the start channel for $A / D$ conversion.
When the $A / D$ converter is activated, $A / D$ conversion starts from the channel selected with these bits.

| ANS2 | ANS1 | ANS0 | Start channel |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | AN0 |
| 0 | 0 | 1 | AN1 |
| 0 | 1 | 0 | AN2 |
| 0 | 1 | 1 | AN3 |
| 1 | 0 | 0 | AN4 |
| 1 | 0 | 1 | AN5 |
| 1 | 1 | 0 | AN6 |
| 1 | 1 | 1 | AN7 |

* Read

During A/D conversion, the current conversion channel is read from these bits. If the system is stopped in stop mode, the previous conversion channel is read.

* Upon a reset, these bits are initialized to '000.'
[bits 2, 1, and 0] ANE2, ANE1, and ANE0 (Analog end channel set):
Use these bits to set the A/D conversion end channel.

| ANE2 | ANE1 | ANE0 | End channel |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | AN0 |
| 0 | 0 | 1 | AN1 |
| 0 | 1 | 0 | AN2 |
| 0 | 1 | 1 | AN3 |
| 1 | 0 | 0 | AN4 |
| 1 | 0 | 1 | AN5 |
| 1 | 1 | 0 | AN6 |
| 1 | 1 | 1 | AN7 |

* When the same channel is written to ANE2 to ANE0 and ANS2 to ANSO, conversion is performed for one channel only (single conversion).
* In continuous or stop mode, operation returns to the start channel specified in ANS2 to ANS0 after the conversion is completed for the channel specified in ANE2 to ANEO.
* If the ANS value is smaller than the ANE value, conversion starts from the ANS channel. Then, once conversion is complete up to channel 7, operation returns to channel 0 and conversion is performed up to the ANE channel.
* Upon a reset, these bits are initialized to '000.'

Example: ANS=6, ANE=3, single mode
Conversion is performed in the following sequence: $\mathrm{CH} 6, \mathrm{CH} 7, \mathrm{CH} 0, \mathrm{CH} 1, \mathrm{CH} 2, \mathrm{CH} 3$

### 16.3.2 ADCR1 and ADCR0 (Data registers)

Data Registers (Upper Byte)

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $\triangleleft$ Bit number <br> ADCR2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 000039 ${ }_{\text {H }}$ | Reserved | ST1 | ST0 | CT1 | CTO | - | D9 | D8 |  |
| Read/write $\Rightarrow$ | (W) | (W) | (W) | (W) | (W) | (-) | (R) | (R) |  |
| Initial value $\quad ¢$ | (0) | (0) | (0) | (0) | (1) | (-) | (X) | (X) |  |

Data Registers (Lower Byte)

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\triangleleft$ Bit number <br> ADCR1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 000038\% | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |  |
| Read/write | (R) | (R) | (R) | (R) | (R) | (R) | (R) | (R) |  |
| Initial value $\quad \rightarrow$ | (X) | (X) | (X) | (X) | (X) | (X) | (X) | (X) |  |

Figure 16.3.2a Data Registers
[bit 15]
This is reserved bit. This bit should be written to ' 1 ' before AD conversion. Never write ' 0 ' to this bit.
Note: Reading this bit always returns " 1 ".
[bit 14, 13] : ST1, ST0 (Sampling Time)
These bits is used for setting the sampling time in terms of machine cycle.

| ST1 | STO | Sampling time machine <br> cycle | Sampling time |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 64 machine cycle | 4ms at 16MHz machine clock |
| 0 | 1 | Reserved |  |
| 1 | 0 | Reserved |  |
| 1 | 1 | 4096 machine cycle | 256 ms at16MHz machine <br> clock |

Note: Reading these bits always return " 1 ".
[bit 12, 11] : CT1, CT0 (Compare Time)
These bits is used for setting the comparsion time in terms of machine cycle.

| CT1 | CT0 | Comparsion time machine cycle | Comparsion time |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 176 machine cycle | 22 ms at 8 MHz machine clock |
| 0 | 1 | 352 machine cycle | 22 ms at 16 MHz machine <br> clock |
| 1 | 0 | Reserved |  |
| 1 | 1 | Reserved |  |

Note1: When the bits is set to ' 00 ', the machine clock should not be higher than 8 MHz .
Note2: Reading these bits always return " 1 ".
[bit 9 to bit 0] : D9 to D0 (ADCR1:1,0 and ADCRO)
ADCR1:1,0 and ADCR0 stores the AD conversion result. These register values are updated each time conversion is completed. Usually, the final conversion value is stored in these bits.
Upon a reset, these registers are undefined.
The conversion data protection function is available. See Section 2.7.4, "Operations."
Note: Ensure that no data is written to these registers during A/D conversion.

### 16.4 Operations

The A/D converter operates in the sequential compare format, and has a 8-bit resolution.
Since the A/D converter has only one register ( 8 bits) for storing the conversion result, the conversion data registers (ADCRO) are updated each time conversion is completed. Thus, the A/D converter must not be used alone for continuous conversion. Use the $\mathrm{F}^{2} \mathrm{MC}-16$ intelligent I/O service function to transfer converted data to memory while conversion is in progress.
The operation modes are explained below.
(1) Single mode

In this mode, the converter sequentially converts the analog inputs specified with the ANS and ANE bits. The converter stops operation after the conversion is completed for the end channel specified with the ANE bits. If the start and end channels are the same (ANS=ANE), conversion is performed only for one channel.
Example:
ANS $=000$, ANE $=011$
Start $\rightarrow$ AN0 $\rightarrow$ AN1 $\rightarrow$ AN2 $\rightarrow$ AN3 $\rightarrow$ End

$$
\text { ANS = } 010, \text { ANE }=010
$$

Start $\rightarrow$ AN2 $\rightarrow$ End

## (2) Continuous mode

In this mode, the converter sequentially converts the analog inputs specified with the ANS and ANE bits. After the conversion is completed for the end channel specified with the ANE bits, conversion is repeated from the analog inputs of the ANS. If the start and end channels are the same (ANS=ANE), conversion for one channel is repeated.
Example:
ANS $=000$, ANE $=011$
Start $\rightarrow$ ANO $\rightarrow$ AN1 $\rightarrow$ AN2 $\rightarrow$ AN3 $\rightarrow$ ANO $\cdots \cdots \cdot \rightarrow$ Repeat

$$
\text { ANS = } 010, \text { ANE }=010
$$

Start $\rightarrow$ AN2 $\rightarrow$ AN2 $\rightarrow$ AN2 $\cdots \cdots \rightarrow$ Repeat

In continuous mode, conversion is repeated until ' 0 ' is written to the BUSY bit. (Writing ' 0 ' to the BUSY bit forces the operation to end.) If the operation is terminated forcibly, conversion stops before conversion is completed. (Upon a forced termination, the conversion register stores the previous data that has been converted completely.)

## (3) Stop mode

In this mode, the converter sequentially converts the analog inputs specified with the ANS and ANE bits, pausing each time conversion for one channel is completed. To release pausing, activate the A/D converter again.
After the conversion is completed for the end channel specified with the ANE bits, conversion is repeated from the analog inputs of the ANS. If the start and end channels are the same (ANS=ANE), conversion is performed only for one channel.
Example:

$$
\begin{aligned}
\text { ANS }= & 000, \text { ANE }=011 \\
\text { Start } & \rightarrow \text { ANO } \rightarrow \text { End } \rightarrow \text { Restart } \rightarrow \text { AN1 } \rightarrow \text { End } \rightarrow \text { Restartë } \rightarrow \text { AN2 } \rightarrow \text { End } \rightarrow \text { Restart } \rightarrow \\
& \rightarrow \text { AN3 } \rightarrow \text { End } \rightarrow \text { Restart } \rightarrow \text { AN0 } \cdots \cdots \cdots \text { Repeat }
\end{aligned}
$$

$$
\begin{aligned}
& \text { ANS }=010 \text {, ANE }=010 \\
& \text { Start } \rightarrow \text { AN2 } \rightarrow \text { End } \rightarrow \text { Restart } \rightarrow \text { AN2 } \rightarrow \text { End } \rightarrow \text { Restartë } \rightarrow \text { AN2 } \cdots \cdots \cdot \rightarrow \text { Repeat }
\end{aligned}
$$

Only the activation factors specifies with STS1 and STS0 are used. In this mode, start of conversion can be synchronized.
(4) Conversion using $\mathrm{I}^{2} \mathrm{OS}$

Sample flow from A/D conversion activation to transfer of converted data (continuous mode)

$\pm$ The portion indicated by the star ( ) is determined according to the $\mathrm{I}^{2} \mathrm{OS}$ settin

Figure 16.4a Flow chart of A/D Conversion
Usage
- Starting $\mathrm{I}^{2} \mathrm{OS}$ in single mode
-To terminate conversion after analog inputs AN1 to AN3 are converted
-To transfer conversion data sequentially to addresses 200 H to 206 H
-To start conversion by software
-To use the highest interrupt level
$I^{2} O S$ setting
MOV ICR3 \#08H ............................................ (1)
MOV BAPL, \#OOH ............................................ (2)
MOV BAPM, \#02H ............................................ (3)
MOV BAPH, \#OOH ............................................ (4)
MOV ISCS, \#18H ............................................ (5)
MOV IOA, \#38H ............................................ (6)
MOV DCT, \#03H ............................................ (7)
A/D converter setting
MOV ADCS1 \#OBH .................................................. (8)
MOV ADCS2 \#A2H ........................................................ (9)
Interrupt sequence
RETI
...................................................... (10)
(1) Specifies the highest interrupt level, I2OS activation upon an interrupt, and the descriptor address. (2)(3) Specifies the transfer destination address of converted data.
(5) Specifies word data transfer. The transfer destination address is incremented after transfer. Data is transferred from I/O to memory. Transfer is terminated in response to a request from a resource.
(7) $\mathrm{I}^{2} \mathrm{OS}$ transfer is performed three times. This count is the same as the conversion count.
(8) Specifies single mode, start channel AN1, and end channel AN3.
(9) Specifies activation by software and start of A/D conversion.
(10) Specifies return from an interrupt.

ICR3 : Interrupt control register
BAPL : Buffer address pointer, low-order
BAPM : Buffer address pointer, medium-order
BAPH : Buffer address pointer, high-order
ISCS : $1^{2} O S$ status register
I/OA : I/O address counter
DCT : Data counter

$$
\begin{aligned}
\text { Activation } & \text { AN1 } \rightarrow \text { Interrupt } \rightarrow I^{2} \text { OS transfer } \\
& \rrbracket \\
& \text { AN2 } \rightarrow \\
& \text { Interrupt } \rightarrow I^{2} \text { OS transfer } \\
& \text { AN3 } \rightarrow \text { Interrupt } \rightarrow I^{2} \text { OS transfer } \\
& \Downarrow \\
& \text { End } \\
& \llcorner\text { Interrupt sequenc } \\
& \llcorner\text { Parallel processing }-
\end{aligned}
$$

Usage

- Starting $\mathrm{I}^{2} \mathrm{OS}$ in continuous mode
-To convert analog inputs AN3 to AN5 and obtain two conversion data items for each channel
-To transfer conversion data sequentially to addresses 600 H to 60 CH
-To start conversion by external edge input - To use the highest interrupt level
$1^{2} O S$ setting

| MOV | ICR3 | \#08H |  |
| :---: | :---: | :---: | :---: |
| MOV | BAPL, | \#00H |  |
| MOV | BAPM, | \#06H |  |
| MOV | BAPH, | \#00H |  |
| MOV | ISCS, | \#08H |  |
| MOV | I/ OA, | \#38H |  |
| MOV | DCT, | \#06H |  |

A/D converter setting
MOV ADCS1 \#9DH ..................................................... 8
MOV ADCS2 \#A4H ................................................. (9)
Interrupt sequence
MOV ADCS2 \#00H ................................................... (10)
RET
(1) Specifies the highest interrupt level, I2OS activation upon an interrupt, and the descriptor address.
(2)(3) Specifies the transfer destination address of converted data.
(5) Specifies word data transfer. The transfer destination address is incremented after transfer. Data is transferred from I/O to memory. Transfer is terminated in response to a request from a resource.
(6) Transfer source address
(7) $\mathrm{I}^{2} \mathrm{OS}$ transfer is performed six times. Data is transferred for three channels $\times 2$.
(8) Specifies continuous mode, start channel AN3, and end channel AN5.
(9) Specifies activation by external edge and start of A/D conversion.
(10) Specifies return from an interrupt.

ICR3 : Interrupt control register
BAPL : Buffer address pointer, low-order
BAPM : Buffer address pointer, medium-order
BAPH : Buffer address pointer, high-order
ISCS : $\mathrm{I}^{2} \mathrm{OS}$ status register
I/OA : I/O address counter
DCT : Data counter


## Usage

- Starting $\mathrm{I}^{2} \mathrm{OS}$ in stop mode
-To convert analog input AN3 12 times at fixed intervals
-To transfer conversion data sequentially to addresses 600 H to 618 H
-To start conversion by external edge input - To use the highest interrupt level
$I^{2} O S$ setting

| MOV | ICR3 | \#08H |  |
| :---: | :---: | :---: | :---: |
| MOV | BAPL, | \#00H |  |
| MOV | BAPM, | \#06H |  |
| MOV | BAPH, | \#00H |  |
| MOV | ISCS, | \#08H |  |
| MOV | I/ OA, | \#38H |  |
| MOV | DCT, | \#0CH |  |

A/D converter setting
MOV ADCS1 \#DBH ....................................................... (8)
MOV ADCS2 \#A4H ................................................. (9)
Interrupt sequence
MOV ADCS2 \#OOH
(10)

RET
(1) Specifies the highest interrupt level, I2OS activation upon an interrupt, and the descriptor address.
(2)(3) Specifies the transfer destination address of converted data.
(5) Specifies word data transfer. The transfer destination address is incremented after transfer. Data is transferred from I/O to memory. Transfer is terminated in response to a request from a resource.
(6) Transfer source address
(7) $\mathrm{I}^{2} \mathrm{OS}$ transfer is performed 12 times.
(8) Specifies continuous mode, start channel AN3, and end channel AN3 (one-channel conversion).
(9) Specifies activation by external edge and start of A/D conversion.
(10) Specifies return from an interrupt.

ICR3 : Interrupt control register
BAPL : Buffer address pointer, low-order
BAPM : Buffer address pointer, medium-order
BAPH : Buffer address pointer, high-order
ISCS : $\mathrm{I}^{2} \mathrm{OS}$ status register
I/OA : I/O address counter
DCT : Data counter


## (5) Conversion data protection

The A/D converter has a conversion data protection function that enables continuous conversion and preservation of multiple data items using $\mathrm{I}^{2} \mathrm{OS}$.
Since there is only one conversion data register, its value is updated each time conversion is completed. Thus, continuous data conversion results in the loss of the previous data due to storage of the new data. To prevent this situation, the $A / D$ converter pauses after conversion if the previous data item has not been transferred to memory by $\mathrm{I}^{2}$ OS. The converted data is not saved until the previous data is transferred to memory.
The pause is released after data is transferred to memory by $\mathrm{I}^{2} \mathrm{OS}$.
If the previous data has been transferred to memory, the $A / D$ converter continues operation without pausing.
Note: * This function is related to the INT and INTE bits of ADCS2.
The data protection function operates only when interrupts are enabled (INTE=1).
If interrupts are disabled (INTE=0), this function is disabled. Continuous A/D conversion results in loss of previous data, since the converted data items are saved to the register one after another.
If $\mathrm{I}^{2} \mathrm{OS}$ is not used while interrupts are enabled (INTE=1), the INT bit is not cleared. Thus, the data protection function works and the A/D converter pauses. In this case, clearing the INT bit in the interrupt sequence releases the pause.
If the $A / D$ converter is pausing during $I^{2} O S$ operation, disabling interrupts may restart the $A / D$ converter. In this case, the value in the conversion data register may be changed without being transferred.
Restarting the A/D converter while it is pausing destroys the standby data.
Flow of data protection function (when $I^{2} O S$ is used)


Figure 16.4b Flow Chart of Data Protection Function

### 16.5 Notes on use

To start the A/D converter upon an external trigger or internal timer, A/D activation factor bits STS1 and STS0 of the ADCS2 register are used. Ensure that the input values of the external trigger or internal timer are inactive. If the values are active, $A / D$ conversion may start immediately.
When setting STS1 and STS0, ensure that '1' (input) is specified for ADTG and '0' (output) is specified for the internal timer (timer 2).

### 16.5.1 Other considerations

Always write '1' to the ADER bit corresponding to a pin used as analog input.

| Analog input enable register |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |
| Address: $00001 \mathrm{C}_{\mathrm{H}}$ | ADE7 | ADE6 | ADE5 | ADE4 | ADE3 | ADE2 | ADE1 | ADE0 | ADER |
| Read/write $\Rightarrow$ Initial value $\Rightarrow>$ | R/W <br> (1) | R/W <br> (1) | R/W <br> (1) | R/W <br> (1) | R/W <br> (1) | R/W <br> (1) | R/W <br> (1) | R/W <br> (1) |  |

Port 5 pins are controlled as described below.
0 : Port input mode
1: Analog input mode
' 1 ' is set upon a reset.

## Chapter 17: <br> D/A Converter

### 17.1 Outline

This is an R-2R format D/A converter, having an eight-bit resolution. The D/A converter has two channels.
Output control can be performed independently for the two channels using the D/A control register.

### 17.2 Block Diagram



Figure 17.2a Block Diagram of D/A Cobverter

### 17.3 Registers and Register Details

D/A converter data register 1


D/A converter data register 0


D/A control register 1

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | ৮ Bit number DACR1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 00003D ${ }_{\text {H }}$ | - | - | - | - | - | - | - | DAE1 |  |
| Read/write $\Rightarrow$ | (-) | (-) | (-) | (-) | (-) | (-) | (-) | (R/W) |  |
| Initial value $\Rightarrow>$ | (-) | (-) | (-) | (-) | (-) | (-) | (-) | (0) |  |

D/A control register 0

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | > Bit number <br> DACRO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 00003C ${ }_{\text {H }}$ | - | - | - | - | - | - | - | DAEO |  |
| Read/write $\Rightarrow$ | (-) | (-) | (-) | (-) | (-) | (-) | (-) | (R/W) |  |
| Initial value $\Rightarrow>$ | (-) | (-) | (-) | (-) | (-) | (-) | (-) | (0) |  |

Figure 17.3a Register of D/A Converter

### 17.3.1 DATO/1 ( D/A data register)

D/A converter data register 1

| Address : 00003B ${ }_{\mathrm{H}}$ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | Bit number DAT1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | DA17 | DA16 | DA15 | DA14 | DA13 | DA12 | DA11 | DA10 |  |
| Read/write $\Rightarrow$ | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) |  |
| Initial value $\Rightarrow$ | (X) | (X) | (X) | (X) | (X) | (X) | (X) | (X) |  |

D/A converter data register 0

| Address : $00003 \mathrm{~A}_{\mathrm{H}}$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\begin{aligned} & \text { Bit number } \\ & \text { DAT0 } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | DA07 | DA06 | DA05 | DA04 | DA03 | DA02 | DA01 | DA00 |  |
| Read/write $\Rightarrow$ | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) | (R/W) |  |
| Initial value $\Rightarrow$ | (X) | (X) | (X) | (X) | (X) | (X) | (X) | (X) |  |

[bits 15 to 8] DA17 to DA10
These bits are used to set the output voltage of D/A converter ch1.
These bits are not initialized upon a reset. These bits are readable and writable.
[bits 7 to 0] DA07 to DA00
These bits are used to set the output voltage of D/A converter ch0.
These bits are not initialized upon a reset. These bits are readable and writable.

### 17.3.2 DACR0/1 (D/A control register)

D/A control register 1


Read/write $\leftrightharpoons$
$(-) \quad(-)$
$(-) \quad(-)$
$(-) \quad(-)$
$(-) \quad(-)$
(-)
(-) (R/W) Initial value $\Rightarrow \quad(-)$
(-)
(-)
(-)
(-)
(-)
(-)
(0)

D/A control register 0

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Bit number |
| ---: | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 00003C $C_{H}$ | - | - | - | - | - | - | - | DAE0 |  |
| DACR0 |  |  |  |  |  |  |  |  |  |
| Read/write $\Rightarrow$ | $(-)$ | $(-)$ | $(-)$ | $(-)$ | $(-)$ | $(-)$ | $(-)$ | (R/W) |  |
| Initial value | $\Rightarrow$ | $(-)$ | $(-)$ | $(-)$ | $(-)$ | $(-)$ | $(-)$ | $(-)$ | $(0)$ |

## [bit 0] DAE1 and DAE0

These bits are used to enable or disable the D/A converter output. DAE1 controls channel 1 output, while DAEO controls channel 0 output.

When ' 1 ' is written to these bits, D/A output is enabled. When ' 0 ' is set, D/A output is disabled.
These bits are initialized to '0' upon a reset. These bits are readable and writable.

### 17.4 Operations

D/A output is started by writing a desired D/A output value to the D/A data register (DADR) and setting ' 1 ' to the enable bit for the corresponding D/A output channel in the D/A control register (DACR).

Disabling D/A output turns off the analog switch that is inserted serially into the output of each D/A converter channel. In addition, the D/A converter is internally cleared to ' 0 ' and the path of the DC current is shut down. This also applies in stop mode.
Table 17.4a shows the theoretical values of D/A converter output voltages
The D/A converter output voltages are between 0 V and $255 / 256 \mathrm{~V} \times$ DVR. The output voltage range is changed by regulating the DVR voltage externally.
The D/A converter output does not have an internal buffer amplifier. Since an analog switch (=100 $\Omega$ ) is serially inserted into the output, allow sufficient settling time when applying an external output load.

Table 17.4a Theoretical values of D/A converter output voltages

| Values written to <br> DA07 to DA00 <br> and <br> DA17 to DA10 | Theoretical values of output voltages |
| :---: | :---: |
| $00_{\mathrm{H}}$ | $0 / 256 \times \mathrm{DVR}(=0 \mathrm{~V})$ |
| $01_{\mathrm{H}}$ | $1 / 256 \times \mathrm{DVR}$ |
| $02_{\mathrm{H}}$ | $2 / 256 \times \mathrm{DVR}$ |
| 1 |  |
| $\mathrm{FD}_{\mathrm{H}}$ | $253 / 256 \times \mathrm{DVR}$ |
| $\mathrm{FE}_{\mathrm{H}}$ | $254 / 256 \times \mathrm{DVR}$ |
| $\mathrm{FF}_{\mathrm{H}}$ | $255 / 256 \times \mathrm{DVR}$ |

## Chapter 18: <br> Pulse Width Counter (PWC) Timer

### 18.1 Outline

This module is a multi-function 16-bit up-counter with a reload function and a function for counting pulse widths on the input signal. The module hardware consists of a 16-bit up-counter, input pulse divider, divide ratio control register, four count input pins, one pulse output pin, and a 16-bit control register. These perform the following functions.

Timer function:

- Interrupt requests can be generated at specified time intervals.
- A pulse signal can be output synchronized with the timer period.
- The counter clock can be selected from three internal clocks.

Pulse width count function:

- Measures the time between events on an external pulse input.
- The counter clock can be selected from three internal clocks.
- Count modes H pulse width ( $\mathbb{\pi}$ to $\Downarrow$ )/L pulse width ( $\downarrow$ to $\Uparrow$ )

Rising edge period ( $\uparrow$ to $\Uparrow$ )/Falling edge period $(\Downarrow$ to $\Downarrow$ )
Inter-edge count ( $\uparrow$ or $\Downarrow$ to $\Downarrow$ or $\Uparrow$ )

- Using the 8 -bit input divider, the module can divide an input pulse signal by $2^{2 n}(n=1,2,3,4)$ and measure the period.
- An interrupt request can be generated on count completion.
- Single-shot or continuous counting can be selected.

The MB90580 series contains one PWC timer channels.

### 18.2 Block Diagram



Figure 18.2a lock Diagram of Pulse Width Counter Timer

### 18.3 Regiaters and Register Details

PWC Control Status Register (Upper Byte)

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | Bit number <br> PWCSR <br> (HIGH) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 000055 ${ }_{\text {H }}$ | STRT | STOP | EDIR | EDIE | OVIR | OVIE | ERR | POUT |  |
| Read/write $\Rightarrow$ | (R/W) | (R/W) | (R) | (R/W) | (R/W) | (R/W) | (R) | (R/W) |  |
| Initial value $\Rightarrow$ | (0) | (0) | (0) | (0) | (0) | (0) | (0) | (0) |  |

PWC Control Status Register (Lower Byte)

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Bit number <br> PWCSR <br> (LOW) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 000054 ${ }_{\text {H }}$ | CSK1 | CSK0 | PIS1 | PIS0 | S/C | MOD2 | MOD1 | MOD0 |  |
| Read/write Initial value $\Rightarrow$ | (R/W) (0) | R/W) <br> (0) | $\begin{gathered} (R / W) \\ (0) \end{gathered}$ | (R/W) (0) | (R/W) (0) | (R/W) <br> (0) | (R/W) (0) | (R/W) (0) |  |

PWC Data Buffer Register (Upper Byte)


PWC Data Buffer Register (Lower Byte)


Divide Ratio Control Register

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Bit number DIVR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 000058\% | - | - | - | - | - | - | DIV1 | DIV0 |  |
| Read/write $\Rightarrow$ | (-) | (-) | (-) | (-) | $(-)$ | (-) | (R/W) | (R/W) |  |
| Initial value $\Rightarrow$ | (-) | (-) | (-) | (-) | (-) | (-) | (0) | (0) |  |

PWC Noise Cancelling register

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | « Bit number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 000086 ${ }_{\text {H }}$ | - | - | - | - | - | SW1 | SW0 | EN | RNCR |
| Read/write $\Rightarrow>$ | (-) | (-) | (-) | (-) | (-) | (R/W) | (R/W) | (R/W) |  |
| Initial value $\Rightarrow$ | $(-)$ | (-) | (-) | (-) | (-) | (0) | (0) | (0) |  |

Figure 18.3a Register of Pulse Width Counter Timer

### 18.3.1 PWC control status register (PWCSR)

PWC Control Status Register (Upper Byte)


PWC Control Status Register (Lower Byte)


The PWCSR is used to control the operation of the PWC timer and to read the PWC timer status.
[bit 15] STRT (Start) \& [bit 14] STOP (Stop)
These bits start, restart, and stop the 16 -bit up-count timer. Reading the bits returns the operating state of the timer. The bit functions are as follows.

Function of STRT and STOP bits when they are written. (Operation control)

| STRT | STOP | Operation Control Function |
| :---: | :---: | :--- |
| 0 | 0 | No function. Has no effect on operation. |
| 0 | 1 | Starts or restarts the timer (count enable). Note: The clear bit instruction can <br> be used. |
| 1 | 0 | Forcibly halts the operation of the timer (count disable). Note: The clear bit <br> instruction can be used. |
| 1 | 1 | No function. Has no effect on operation. |

Meaning of the STRT and STOP bits when they are read. (Operating status indication)

| STRT | STOP | Operating Status Indication |
| :---: | :---: | :--- |
| 0 | 0 | Timer is halted (not started or count ended). (Initial value) |
| 1 | 1 | Timer is counting (count in progress). |

After a reset: Initialized to $00_{B}$.
Readable and writable. Note that the meanings of the bits differ for reading and writing.
Always read as $11_{\mathrm{B}}$ by read-modify-write instructions regardless of the actual values.
Although bit manipulation instructions (such as the bit clear instruction) can be used to write to the STRT and STOP bits to start and stop the timer, bit manipulation instructions cannot be used to read the operating status (as these always indicate that the timer is operating).
[bit 13] EDIR (End interrupt request)
This flag indicates when counting ends in pulse width count mode. A count end interrupt request is generated if the interrupt is enabled (bit 12: EDIE $=$ "1") when this bit is set.

| Set timing | Set when pulse width counting ends (when the count result is placed in PWCR). |
| :---: | :--- |
| Clear timing | Cleared by reading PWCR (the count result). |

Note: This bit has no meaning in timer mode.
After a reset: Initialized to "0".
Read-only. Writing to the bit does not change the value.
[bit 12] EDIE (End interrupt enable)
Controls the count end interrupt request in pulse width count mode as follows.

| 0 | Disable output of count end interrupt requests <br> (do not generate an interrupt when EDIR is set).$\quad$ (Initial value) |
| :---: | :--- |
| 1 | Enable output of count end interrupt requests (generate an interrupt when EDIR is set). |

Note: Always set to " 0 " during timer mode.
After a reset: Initialized to "0".
Readable and writable.

## [bit 11] OVIR (Overflow interrupt request)

This flag indicates when the 16 -bit up-count timer overflows from $\mathrm{FFFF}_{\mathrm{H}}$ to $0000_{\mathrm{H}}$. Operates in all modes. A timer overflow interrupt request is generated if the interrupt is enabled (bit 10: OVIE = "1") when this bit is set.

| Set timing | Set when a timer overflow occurs $\left(\mathrm{FFFF}_{\mathrm{H}}\right.$ to $\left.0000_{\mathrm{H}}\right)$. |
| :--- | :--- |
| Clear timing | Cleared by writing "0" or by the extended intelligent I/O service. |

After a reset: Initialized to "0".
Readable and writable. However, only writing " 0 " is valid. Writing " 1 " does not change the bit value. Read-modify-write instructions always read the bit as "1" regardless of the actual bit value.

## [bit 10] OVIE (Overflow interrupt enable)

Controls the timer overflow interrupt request as follows.

| 0 | Disable output of overflow interrupt requests <br> (do not generate an interrupt when OVIR is set). | (Initial value) |
| :---: | :--- | :--- |
| 1 | Enable output of overflow interrupt requests <br> (generate an interrupt when OVIR is set). |  |

After a reset: Initialized to "0".
Readable and writable.
[bit 9] ERR (Error)
This flag is used when continuous counting is performed in pulse width count mode. The flag indicates that the next count has completed before the previous count result has been read from PWCR. When this occurs, PWCR is overwritten with the new count result and the previous result is lost. Counting continues regardless of the value of this bit.

| Set timing | Set when a count result that has not been read is overwritten by the next result. |
| :--- | :--- |
| Clear timing | Cleared by reading PWCR (the count result). |

After a reset: Initialized to " 0 ".
Read-only. Writing to the bit does not change the value.
[bit 8] POUT (Pulse output)
In timer mode, this bit is inverted each time the 16 -bit up-count timer overflows from FFFF $_{H}$ to $0000_{\mathrm{H}}$.
The bit has no meaning in pulse width count mode.

| Set timing | Set when the timer overflows from $\mathrm{FFFF}_{\mathrm{H}}$ to $0000_{\mathrm{H}}$ when the value of POUT is <br> " 0 ", or by writing "1" when the timer is halted. |
| :--- | :--- |
| Clear timing | Cleared when the timer overflows from $\mathrm{FFFF}_{\mathrm{H}}$ to $0000_{\mathrm{H}}$ when the value of POUT <br> is "1", by writing "0" when the timer is halted, or by a reset. |

After a reset: Initialized to " 0 ".
Readable and writable. However, the bit can only be written to when the timer is halted (when bit 15 and bit 14: STRT and STOP are both " 0 "). The value of the bit does not change if written to during timer operation (when bit 15 and bit 14: STRT and STOP are both "1").
[bits 7, 6] CKS1, CKS0 (Clock select 1, 0)
These bits select the internal count clock as follows.

| CSK1 | CSK0 | Count Clock Selection |
| :---: | :---: | :--- |
| 0 | 0 | Machine cycle divided by 4 (0.25 $\mu$ for a 16MHz machine cycle) |
| (Initial value) |  |  |

After a reset: Initialized to " $00_{\mathrm{B}}$ ".
Readable and writable. However, setting " $11_{\mathrm{B}}$ " is prohibited.
Note: Changing the setting after activating the timer is prohibited. Only write to these bits before starting or after halting the timer.
[bits 5, 4] PIS1, PIS0 (Pulse input select)
These bits select the input pin on which to perform pulse width counting.

| PIS1 | PIS0 | Count Input Pin Selection |  |
| :---: | :---: | :--- | :--- |
| 0 | 0 | Always set this value. | (Initial value) |
| 0 | 1 | Setting unavailable (Do not set any of these values.) |  |
| 1 | 0 |  |  |
| 1 | 1 |  |  |

After a reset: Initialized to " $00_{\mathrm{B}}$ ".
Readable and writable.
Note: Changing the setting after activating the timer is prohibited. Only write to these bits before starting or after halting the timer.
Note: When developing software for the MB90580 series, always set these bits to " $00_{\mathrm{B}}$ ".
[bit 3] S/C (Single/Continuous)
Select the count mode as follows.

| S/C | Count Mode Selection | Timer Mode | Pulse Width Count Mode |
| :---: | :--- | :--- | :--- |
| 0 | Single-shot count mode <br> (Initial value) | No reload (single-shot) | Halt after one count. |
| 1 | Continuous count mode | Perform reload <br> (reload timer) | Continuous counting: <br> Buffer register enabled |

After a reset: Initialized to " 0 ".
Readable and writable.
Note: Changing the setting after activating the timer is prohibited. Only write to these bits before starting or after halting the timer.
[bits 2, 1, 0] MOD2, MOD1, MOD0 (MOD2, 1, 0)
These bits select the operation mode and the pulse edges for width counting.

| MOD2 | MOD1 | MODO | Operation Mode/Count Edge Selection |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | Timer mode, no pulse output (Initial value) |
| 0 | 0 | 1 | Timer mode, pulse output enabled (using the POT pin): Reload mode only |
| 0 | 1 | 0 | Inter-edge pulse width count mode ( $\uparrow$ or $\downarrow$ to $\downarrow$ or $\Uparrow$ ) |
| 0 | 1 | 1 | Divided period count mode (using input divider) |
| 1 | 0 | 0 | Rising-edge to rising-edge count mode ( $\uparrow$ to $\uparrow$ ). |
| 1 | 0 | 1 | "H" pulse width count mode( $\uparrow$ to $\downarrow$ ). |
| 1 | 1 | 0 | "L" pulse width count mode( $\downarrow$ to $\uparrow$ ). |
| 1 | 1 | 1 | Falling-edge to falling-edge count mode ( $\downarrow$ to $\downarrow$ ). |

After a reset: Initialized to " $000_{\mathrm{B}}$ ".
Readable and writable.
Note: Changing the setting after activating the timer is prohibited. Only write to these bits before starting or after halting the timer.
Note: When continuous count mode is set for the settings marked with an asterisk (*), the divider circuit for the internal count clock is not cleared when the count ends so as to accumulate the number of edges. In all other modes, the divider circuit for the internal count clock is cleared when the count ends.

### 18.3.2 PWC data buffer register (PWCR)

PWC Data Buffer Register (Upper Byte)


PWC Data Buffer Register (Lower Byte)

(1) In timer mode

In reload timer operation mode (bit $3 S / C$ of PWCSR $=$ "1"), this register stores the reload value. In this case, the register is readable and writable.

In single-shot timer operation mode (bit $3 \mathrm{~S} / \mathrm{C}$ of PWCSR $=$ " 0 "), accessing this register directly accesses the up-count timer. Although both reading and writing are allowed in this mode, only write to the register when the timer is halted. The register can be read at any time to read the current timer value.
(2) In pulse width count mode $\bullet$ Read-only $\bullet$

In continuous count mode (bit 3 S/C of PWCSR = "1"), this register acts as a buffer register to store the previous count result. In this case, the register is read-only and writing does not change the register value.
In single-shot count mode (bit $3 \mathrm{~S} / \mathrm{C}$ of PWCSR = "0"), accessing this register directly accesses the up-count timer. The register is read-only in this mode also and writing does not change the register value. The register can be read at any time to read the current timer value. After the count ends, the register stores the count result.
Note: Always use word transfer instructions to access this register.
After a reset: Initialized to " $0000_{\mathrm{H}}$ ".

### 18.3.3 Divide Ratio Control Register (DIVR)

Divide Ratio Control Register

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\begin{aligned} & \text { ® Bit number } \\ & \text { DIVR } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 000058\% | - | - | - | - | - | - | DIV1 | DIV0 |  |
| Read/write $\Rightarrow$ | (-) | (-) | (-) | (-) | (-) | (-) | (R/W) | (R/W) |  |
| Initial value $\Rightarrow$ | (-) | (-) | (-) | (-) | (-) | $(-)$ | (0) | (0) |  |

This register is only used in divided period count mode (bits 2, 1, 0 : MOD2, 1,0 of PWCSR = "011").
In divided period count mode, pulses input from the count pin are divided by the divide ratio set in this register and the period of the divided signal is measured. The divide ratio is selected as follows.

| DIV1 | DIVO | Divide Ratio Selection |  |
| :---: | :---: | :--- | :--- |
| 0 | 0 | $2^{2}=$ divide by 4 | (Initial value) |
| 0 | 1 | $2^{4}=$ divide by 16 |  |
| 1 | 0 | $2^{6}=$ divide by 64 |  |
| 1 | 1 | $2^{8}=$ divide by 256 |  |

After a reset: Initialized to " 00 ${ }_{\mathrm{B}}$ ".
Readable and writable.
Note: Changing the setting after activating the timer is prohibited. Only write to these bits before starting or after halting the timer.

### 18.3.4 PWC noise cancelling register (RNCR)

## PWC Noise Cancelling register

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | < Bit number <br> RNCR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : $000086_{\mathrm{H}}$ | - | - | - | - | - | SW1 | SW0 | EN |  |
| Read/write $\Rightarrow$ | (-) | (-) | (-) | (-) | (-) | (R/W) | (R/W) | (R/W) |  |
| Initial value $\Rightarrow>$ | (-) | $(-)$ | (-) | (-) | (-) | (0) | (0) | (0) |  |

The PWC noise removal circuit is used for removing noises form the input signal. H level and L level detection will be applied to the input signal after it was 'cleaned' by the noise filter.
Noise removal circuit is a digital low pass filter, the filter remove the high frequency components of the input signal. The noise-removed signal is called 'RMCSIG'. This signal has the same polarilty with the orginial input signal, but the there may be slight phase difference. The SW bits of the noise cancelling register specifies the noise pulse width which can be removed by the filter circuit.
This noise cancelling register is a 8 -bit register, when reset, all bits will be initialized to 0 .
[bits 2, 1] SW1, SW0
SW1 and SW0 is the clock mode selection bit which specify the noise pulse width to be removed. The timing of the following table assumes the main clock is 16 MHz .

| SW1 | swo | Input Clock | Noise Pulse <br> Width |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0.5 MHz | $2.0 \mu \mathrm{~s}$ |
| 0 | 1 | 31.25 KHz | $32.0 \mu \mathrm{~s}$ |
| 1 | 0 | 15.62 KHz | $64.0 \mu \mathrm{~s}$ |
| 1 | 1 | 7.81 KHz | $128.0 \mu \mathrm{~s}$ |

[bits 0] EN
EN bit is used for enabling this noise cancelling function.

| 0 | Noise cancelling function disabled | (Initial value) |
| :--- | :--- | :--- |
| 1 | Noise canncelling function enabled |  |

### 18.4 Operations

(1) Summary of Operation

This block is a multi-function timer based on a 16-bit up-count timer and incorporating a count input pin and 8 -bit input divider. The block has two main functions: a timer function and a pulse width count function. Two types of count clock can be selected for either function. The following describes the basic functions and operation of each of these functions.
(a) Timer Function

This function is an up-count timer which can be selected to operate in reload or single-shot mode.
Once started, the timer counts on each count clock.
An interrupt request can be generated when an overflow from $\mathrm{FFFF}_{\mathrm{H}}$ to $0000_{\mathrm{H}}$ occurs.
When an overflow occurs:

- Single-shot mode: $\qquad$ The count stops.
- Reload mode:

The timer is reloaded with the contents of the reload register and the count restarts.


Figure 18.4a Timer Operation (Single-Shot Mode)


Figure 18.4b Timer Operation (Reload Mode)

## (2) Pulse Width Count Function

This function counts the time period between specified events on an input pulse.
After the function is activated, the count does not start until the specified count start edge is input. The counter is cleared to $" 0000_{\mathrm{H}}$ " and counting starts when the start edge is detected. The count halts when the end edge is detected. The count value at the end of this period is stored in the register as the pulse width.

An interrupt request can be generated when the count ends or when an overflow occurs. After counting completes:

- Single-shot count mode: ... Operation halts.
- Continuous count mode: ... The timer value is transferred to the buffer register and the count halts until the next start edge is input.


Figure 18.4c Pulse Width Count Operation (Single-Shot Count Mode, "H" Width Count Mode)


Figure 18.4d Pulse Width Count Operation (Continuous Count Mode, "H" Width Count Mode)

### 18.4 Operations

(3) Count Clock Selection

The timer count clock can be selected from three internal clock sources. The available clock sources are listed below.

Table 18.4a Count Clock Selection

| PWCSR/bit7, 6:CKS1, 0 | Selected Internal Count Clock |
| :---: | :--- |
| $00_{\mathrm{B}}$ | Machine cycle divided by 4 <br> $(0.25 \mu$ f for a 16 MHz machine cycle $)$$\quad$ (Initial value) |

The selection is initialized to "machine cycle divided by 4" after a reset.
Note: Always select the count clock before starting the timer.
(4) Operation Mode Selection

The operation mode and count mode are selected by PWCSR settings.

- Operation mode setting PWCSR bits 2, 1, and 0: Bits MOD2, MOD1, and MOD0
(Selects timer or pulse width count mode and specifies which edges control counting.)
- Count mode setting PWCSR bit 3: S/C bit
(Selects single-shot or continuous counting, or reload or single-shot operation.)
The following lists the operation modes selected by the mode setting bits.
Figure 18.4e Operation Mode Selection

| Operation Mode |  |  | S/C | MOD2 | MOD1 | MODO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Timer | Single-shot timer |  | 0 | 0 | 0 | 0 |
|  | Reload timer |  | 1 | 0 | 0 | 0 |
|  | Setting prohibited |  | 1 | 0 | 0 | 1 |
| Pulse width count | $\Uparrow$ or $\downarrow$ to $\Uparrow$ or $\downarrow$ <br> Counts between all edges | Single-shot count: Buffer not used | 0 | 0 | 1 | 0 |
|  |  | Continuous count: Buffer used | 1 | 0 | 1 | 0 |
|  | Divided period count (divide by 1 to 256 ) | Single-shot count: Buffer not used | 0 | 0 | 1 | 1 |
|  |  | Continuous count: Buffer used | 1 | 0 | 1 | 1 |
|  | $\Uparrow$ to $\Uparrow$ <br> Rising-edge to risingedge count | Single-shot count: Buffer not used | 0 | 1 | 0 | 0 |
|  |  | Continuous count: Buffer used | 1 | 1 | 0 | 0 |
|  |  | Single-shot count: Buffer not used | 0 | 1 | 0 | 1 |
|  | "H" pulse width count | Continuous count: Buffer used | 1 | 1 | 0 | 1 |
|  | $\Downarrow$ to $\Uparrow$ | Single-shot count: Buffer not used | 0 | 1 | 1 | 0 |
|  | "L" pulse width count | Continuous count: Buffer used | 1 | 1 | 1 | 0 |
|  |  | Single-shot count: <br> Buffer not used | 0 | 1 | 1 | 1 |
|  | Falling-edge to fallingedge count | Continuous count: Buffer used | 1 | 1 | 1 | 1 |

The initial value after a reset selects single-shot timer mode.
Note: Always select the operation mode before starting the timer.
(5) Starting and Stopping the Timer and Pulse Width Count

Starting, restarting, and forcibly halting each operation is performed using bits 15 and 14 (STRT and STOP) of PWCSR. Writing "0" to the STRT bit starts or restarts operation and writing " 0 " to the STOP bit forcibly halts operation. However, neither bit performs its operation if the values written to the two bits are contradictory. When using instructions other than bit manipulation instructions (byte or larger instructions), only write the following bit combinations.

Table 18.4b Start and Stop Bit Functions

| Function | STRT | STOP |
| :---: | :---: | :---: |
| Start or restart timer or pulse width count. | 0 | 1 |
| Forcibly halt timer or pulse width count. | 1 | 0 |

When using a bit manipulation instruction (clear bit instruction), writing of the above combinations is enforced automatically by hardware so no particular care is required.
(a) Operation After Starting

- Timer mode: The count operation starts immediately.
- Pulse width count mode:... The count does not start until the count start edge is input.

After detecting the count start edge, the 16 -bit up-count timer is cleared to $0000_{\mathrm{H}}$ and counting starts.
(b) Restarting the Timer

Re-applying the start command (writing " 0 " to the STRT bit) while the timer is still operating after starting in timer mode or pulse width count mode is called restarting. The operation performed for a restart depends on the mode, as follows.

- Single-shot timer mode: .... No effect on the operation.
- Reload timer mode $\qquad$ Performs a reload and continues operation. If the restart occurs at the same time as an overflow, the overflow flag (OVIR) is set and the POUT bit inverted.
- Pulse width count mode:... Has no effect on the operation if the timer is waiting for the count start edge.
If applied during a count, the count halts and the timer returns to the "waiting for a count start edge" state. If the restart occurs at the same time as a count end edge is detected, the count end flag (EDIR) is set and, in continuous count mode, the count result is transferred to PWCR.
(c) Stopping the Timer

In single-shot timer mode or single-shot count mode, the count halts automatically when the timer overflows or the count ends and therefore you do not need to explicitly stop the timer. However, you must forcibly stop the timer in other modes or if you wish to stop the timer before it halts automatically.
(d) Checking the Operating State

The STRT and STOP bits described previously function as indicator bits for the operating state of the timer when read. The table below lists the bit meanings.

Table 18.4c Operating State Indicator Bit Functions

| STRT | STOP | Operating State |
| :---: | :---: | :--- |
| 0 | 0 | The timer is stopped (other than when waiting for a count start edge). <br> Indicates that the timer has not been started or that counting has ended. |
| 1 | 1 | The timer is counting or waiting for a count start edge. |

The STRT and STOP bits both have the same value when read. However, as the bits always have the value " $1_{\mathrm{B}}$ " when read by read-modify-write instructions (such as bit manipulation instructions), do not use these instructions to read the bit values.
(6) Clearing the Timer

The 16 -bit up-count timer is cleared to $0000_{H}$ in the following cases.

- A reset
- When counting starts after detection of a count start edge in pulse width count mode(6)
(7) Details of Timer Mode Operation
(a) Single-Shot Operation Mode

When the timer is started in this mode, the timer counts up on each count clock. The timer automatically stops when an overflow from $\mathrm{FFFF}_{\mathrm{H}}$ to $0000_{\mathrm{H}}$ occurs.
If PWCR is set before starting the timer, the count starts from the set value. In this case, the set value is not saved and PWCR contains the current count value.
Bit 8 (POUT) of PWCSR is inverted when an overflow occurs but the value is not output from the pin in this mode, even if pulse output mode is specified.
(b) Reload Operation Mode

When the timer is started in this mode, the reload value in PWCR is set to the timer and the timer counts up on each count clock. When an overflow from $\mathrm{FFFF}_{\mathrm{H}}$ to $0000_{\mathrm{H}}$ occurs, the reload value in PWCR is set again to the timer (reloading), the POUT bit (bit 8) of PWCSR is inverted, and the count operation repeated. The timer does not stop until forcibly halted by writing to the STOP bit of PWCSR or until a reset occurs.
The reload value set to PWCR before starting the timer is stored during counting and is set to the timer when the timer is started or restarted and each time an overflow occurs. If the set value is changed during counting, the new reload value is used when the next overflow or restart occurs.
(c) Timer Value and Reload Value

In single-shot operation mode, accessing PWCR directly accesses the up-count timer. Writing a value to PWCR writes the value directly to the timer and reading PWCR during count operation reads the current timer value. Setting a value to PWCR before starting the timer causes the count to start from the specified value.
In reload operation mode, the up-count timer cannot be accessed and PWCR acts as the reload register (stores the reload value). The value written to PWCR is set to the timer when the timer is started or restarted and each time an overflow occurs. Reading PWCR reads the stored reload value.
The value in PWCR and the timer value are indeterminate if the timer is set to single-shot mode after forcibly halting operation in reload mode. Therefore, always set a value before using the timer.
The value in PWCR is indeterminate if the timer is set to reload mode after forcibly halting operation in single-shot mode. Therefore, always set a value before using the timer.
(d) Generation of Interrupt Requests

Interrupt requests can be generated by overflows when operating in timer mode. When an overflow occurs due to the timer counting up, the overflow flag is set and an interrupt request is generated if the overflow interrupt request is enabled.
(e) Timer Period

If the timer is started in single-shot mode after setting $0000_{\mathrm{H}}$ to PWCR, the timer overflows after 65536 counts and the count stops. The following formula calculates the time from the timer starting to the timer stopping.

$$
T_{1}=\left(65536-n_{1}\right) \times t\left\{\begin{array}{lll}
T_{1} & \ldots & \text { Time from start to stop }(\mu \mathrm{s}) \\
n_{1} & \ldots & \text { Timer value set in PWCR when the timer starts } \\
t & \ldots & \text { Count clock period }(\mu \mathrm{s})
\end{array}\right.
$$

If the timer is started in reload mode after setting $0000_{H}$ to PWCR, the timer overflows after each 65536 counts. The following formulas calculate the reload period and the period of the POT pin output pulse.

$$
\begin{aligned}
& T_{R}=\left(65536-n_{R}\right) \times t \\
& T_{\text {POUT }}=T_{R} \times 2
\end{aligned}\left\{\begin{array}{l}
T_{R} \ldots \\
T_{\text {POUT }} \ldots \text { Reload period (overflow period of the POT pin output pulse }(\mu \mathrm{s}) \\
\mathrm{n}_{R} \ldots \\
\mathrm{t}
\end{array} \quad \ldots\right. \text { Reload value stored in PWCR }
$$

(f) Count Clock and Maximum Period

For timer mode, the maximum period is when $0000_{\mathrm{H}}$ is set to PWCR.
The following table lists the count clock period and maximum timer period for a 16 MHz machine cycle (indicated by $\phi$ below).

Table 18.4d Count Clock and Period

| Count Clock Selection | CKS1, $\mathbf{0}=\mathbf{0 0}(\phi / \mathbf{4})$ | $\mathbf{C K S 1 , 0}=\mathbf{0 1}(\phi / \mathbf{1 6 )}$ | CKS1, $\mathbf{0}=\mathbf{1 0}(\phi / \mathbf{3 2 )}$ |
| :--- | :---: | :---: | :---: |
| Count clock period | $0.25 \mu \mathrm{~s}$ | $1 \mu \mathrm{~s}$ | $2 \mu \mathrm{~s}$ |
| Maximum timer period | 16.38 ms | 65.5 ms | 131.1 ms |

(g) Timer Operation Flowchart


Figure 18.4f Flowchart of Timer Mode Operation
(8) Details of Pulse Width Count Mode Operation
(a) Count Input Pins and Pin Selection

The pins used to input the signal for pulse width counting are fixed as pin PWC0 for ch0, PWC1 for ch1, PWC2 for ch2, and PWC3 for ch3. Always set bits 4 and 5 of PWCSR to "00" on the MB90580.

Table 18.4e Count Input Pin Selection ( $\mathrm{n}=3$ to 0 )

| PIS1 | PIS0 |  |
| :---: | :---: | :--- |
| 0 | 0 | The PWCn pin for the channel (Initial value) |
| 0 | 1 |  |
| 1 | 0 | Setting unavailable |
| 1 | 1 |  |
| 1 |  |  |

Note: Only select or change the count input pin while the timer is halted.
(b) Single-Shot Counting and Continuous Counting

Pulse width count mode has a mode to perform a count once only and a mode to perform pulse width counting continuously. The following lists the differences between the two modes.

- Single-shot count mode: .. When the first count end edge is input, the timer stops counting, the count end flag (EDIR) in PWCSR is set, and no further count is performed.
(However, if a restart is specified at the same time, the timer goes to the "waiting for a count start edge" state.)
- Continuous count mode: ... When a count end edge is input, the timer stops counting, the count end flag (EDIR) in PWCSR is set, and the count remains stopped until the next count start edge is input. When the next count start edge is input, the timer is cleared to $0000_{\mathrm{H}}$ and counting restarts. The count result in the timer is transferred to PWCR when the count ends.
The S/C bit in PWCSR selects the mode (see (3) Operation Mode Selection).
Note: Only select or change the count mode while the timer is halted.
Note: For any of the pulse width count modes used with continuous count mode, the divider circuit for the internal count clock is not cleared when the count ends. Therefore, the result in continuous count modes is the accumulated number of edges.
(c) Count Result Data

The handling of the count result and timer value and the function of PWCR differ for single-shot count mode and continuous count mode. The differences are as follows.

- Single-shot count mode: ... Reading PWCR during timer operation reads the current timer value. Reading PWCR after the count has ended reads the count result.
- Continuous count mode:... The count result in the timer is transferred to PWCR when the count ends.
Reading PWCR reads the result of the previous count. PWCR continues to store the previous count result while counting is in progress. The timer value during counting cannot be read.
In continuous count mode, if the previous count result is not read before the next count completes, the new count result overwrites the old value. If this occurs, the error flag (ERR) in PWCSR is set. The error flag (ERR) is automatically cleared when PWCR is read.


## (d) Count Mode and Count Operation

The count mode can be selected from five different modes. The mode determines which part of the input pulse to measure. To accurately measure the width of high frequency pulses, a mode is available to divide the input pulses by a specified ratio and to measure the resulting period. The following describes each mode.

Table 18.4f Count Modes

| Count Mode | MOD2 | MOD1 | MOD0 | Count Operation <br> (w: Pulse width being measured) |
| :---: | :---: | :---: | :---: | :---: |
| H pulse width count | 1 | 0 | 1 | Measures the width of the " H " period. <br> - Count (meaOPsurement) start: Rising edge detected <br> - Count (measurement) end: Falling edge detected |
| L pulse width count | 1 | 1 | 0 | Measures the width of the "L" period. <br> - Count (measurement) start: Falling edge detected <br> - Count (measurement) end: Rising edge detected |
| Rising edge to rising edge period count | 1 | 0 | 0 | Measures the time between rising edges. <br> - Count (measurement) start: Rising edge detected <br> - Count (measurement) end: Rising edge detected |
| Falling edge to falling edge period count | 1 | 1 | 1 | Measures the time between falling edges <br> - Count (measurement) start: Falling edge detected <br> - Count (measurement) end: Falling edge detected |

Table 18.4f Count Modes (Continued)

| Count Mode | MOD2 | MOD1 | MODO | Count Operation <br> (w: Pulse width being measured) |
| :---: | :---: | :---: | :---: | :---: |
| Inter-edge pulse width count | 0 | 1 | 0 | Measures the width between consecutive input edges. <br> - Count (measurement) start: Edge detected <br> - Count (measurement) end: Edge detected |
| Divided period count | 0 | 1 | 1 | The input pulses are divided by the divide ratio set in the divide ratio register (DIVR) and the resulting period measured. <br> - Count (measurement) start: Falling edge detected after operation started <br> - Count (measurement) end: End of one period of the divided signal |

In all modes, the timer does not count during the time between starting the count and a count start edge being input. After the count start edge is input, the timer is cleared to $0000_{H}$ and the timer counts up on each count clock until a count end edge is input.
The following operations are performed when a count end edge is input.
(1) The count end flag (EDIR) in PWCSR is set.
(2) The timer stops counting (unless the timer is restarted at the same time).
(3) In continuous count mode:The timer value (count result) is transferred to PWCR and the count remains stopped until the next count start edge is input.
(4) In single-shot count mode:The timer stops counting (unless the timer is restarted at the same time).

In continuous count mode, the end edge also acts as the next start edge in some modes, including inter-edge pulse width count mode and period count mode.
(e) Minimum Input Pulse Width

Pulses input to the pulse width count input pins (PWC3 to PWCO) must be longer than the minimum input pulse width shown below.

## Pulse width:....... 2 machine cycles ( $\geq 0.125 \mu \mathrm{~s}$ for a 16 MHz machine clock)

However, input pulses shorter than the above specification may be recognized as valid pulses in some cases.
The PWC inputs do not have a filter function in the MB90580 series. If required, use a filter or similar circuit externally.
(f) Pulse Width/Period Calculation

Calculate the width or period of the measured pulse from the count result read from PWCR after the count ends as follows.

$$
T_{w}=n \times t \div D_{I V}(\mu s)\left\{\begin{array}{lll}
T_{w} & \ldots & \text { Measured pulse width or period ( } \mu \mathrm{s} \text { ) } \\
n & \ldots & \text { Count result stored in PWCR } \\
t & \ldots & \text { Count clock period ( } \mu \mathrm{s}) \\
D_{I V} \ldots & \text { Divide ratio set in the divide ratio register (DIVR) } \\
& & \text { (Use the value } 1 \text { for modes other than divided period count mode.) }
\end{array}\right.
$$

## (g) Pulse Width/Period Count Range

The range of pulse widths/periods that can be measured depends on the count clock and the divide ratio of the input divider.

The table below lists the measurement range for a 16 MHz machine cycle (indicated by $\phi$ below).
Table 18.4g Pulse Width Count Range

| Divide Ratio | DIV1.0 | CKS1, 0 = 00 ( $\phi / 4$ ) | CKS1, 0 = 01 (\$/16) | CKS1, $0=10$ ( $\phi / 32$ ) |
| :---: | :---: | :---: | :---: | :---: |
| No division | - | $\begin{gathered} \hline 0.125 \mu \mathrm{~s} \text { to } 16.38 \mathrm{~ms} \\ {[0.25 \mu \mathrm{~s}]} \end{gathered}$ | $\begin{gathered} 0.125 \mu \mathrm{~s} \text { to } 65.5 \mathrm{~ms} \\ {[1.6 \mu \mathrm{~s}]} \end{gathered}$ | $\begin{gathered} 0.2 \mu \mathrm{~s} \text { to } 131 \mathrm{~ms} \\ {[3.2 \mu \mathrm{~s}]} \end{gathered}$ |
| Divide by 4 | $0^{\text {B }}$ | $\begin{gathered} \hline 0.125 \mu \mathrm{~s} \text { to } 4.10 \mathrm{~ms} \\ {[62.5 \mu \mathrm{~s}]} \end{gathered}$ | $\begin{gathered} \hline 0.125 \mu \mathrm{~s} \text { to } 16.38 \mathrm{~ms} \\ {[0.4 \mu \mathrm{~s}]} \end{gathered}$ | $\begin{gathered} \hline 0.2 \mu \mathrm{~s} \text { to } 32.75 \mathrm{~ms} \\ {[800 \mathrm{~ns}]} \end{gathered}$ |
| Divide by 16 | $01_{B}$ | $\begin{gathered} \hline 0.125 \mu \mathrm{~s} \text { to } 1024 \mu \mathrm{~s} \\ {[15.6 \mathrm{~ns}]} \end{gathered}$ | $\begin{gathered} 0.125 \mu \mathrm{~s} \text { to } 4.10 \mathrm{~ms} \\ {[0.1 \mu \mathrm{~s}]} \end{gathered}$ | $\begin{gathered} \hline 0.2 \mu \mathrm{~s} \text { to } 8.19 \mathrm{~ms} \\ {[200 \mathrm{~ns}]} \end{gathered}$ |
| Divide by 64 | ${ }^{10}{ }_{B}$ | $\begin{gathered} \hline 0.125 \mu \mathrm{~s} \text { to } 256 \mu \mathrm{~s} \\ {[3.91 \mathrm{~ns}]} \end{gathered}$ | $\begin{aligned} & \hline 0.125 \mu \mathrm{~s} \text { to } 1024 \mu \mathrm{~s} \\ & {[25.0 \mathrm{~ns}]} \end{aligned}$ | $0.2 \mu \mathrm{~s}$ to 2.048 ms [50.0ns] |
| Divide by 256 | $11_{\text {B }}$ | $\begin{gathered} \hline 0.125 \mu \mathrm{~s} \text { to } 64 \mu \mathrm{~s} \\ {[0.98 \mathrm{~ns}]} \end{gathered}$ | $\begin{gathered} 0.125 \mu \mathrm{~s} \text { to } 256 \mu \mathrm{~s} \\ {[6.25 \mathrm{~ns}]} \end{gathered}$ | $\begin{gathered} 0.2 \mu \mathrm{~s} \text { to } 512 \mathrm{~ms} \\ {[12.5 \mathrm{~ns}]} \\ \hline \end{gathered}$ |

Note:The figures in [ ] indicate the resolution per bit.
(h) Generation of Interrupt Requests

The following two interrupt requests can be generated in pulse width count mode.
(1) Timer overflow interrupt request

If an overflow occurs during counting, the overflow flag is set and, if the overflow interrupt request is enabled, an interrupt request is generated.
(2) Count end interrupt request

When the count end edge is detected, the count end flag (EDIR) in PWCSR is set and, if the count end interrupt request is enabled, an interrupt request is generated.

The count end flag (EDIR) is automatically cleared by reading PWCR.
(i) Flowchart of the Pulse Width Count Operation


Figure 18.4g Flowchart of Operation in Pulse Width Count Mode
(9) Initial State

- The initial values of each register are:

| PWCSR | $\Rightarrow$ | $(0000000000000000)_{B}$ |
| :--- | :--- | :--- |
| PWCR | $\Rightarrow$ | $(0000000000000000)_{B}$ |
| DIVR | $\Rightarrow(X X X X X X 00)_{B}$ |  |

### 18.5 Precautions

(1) Changing Register Values

Changing the values of the following PWCSR bits when the timer is operating is prohibited. Only change bit values before starting the timer or after operation stops.
[bits 7, 6] CKS1, CKSO: Clock selection bits
[bits 5, 4] PIS1, PIS0: Count input pin selection bits
[bit 3] S/C: Count mode (single-shot or continuous) selection bit
[bits 2, 1, 0] MOD2, MOD1, MOD0: Operating mode and count edge selection bits
Note that the value of the pulse output level indication bit (POUT: bit 8 ) does not change if the bit is written to when the timer is operating.
Changing the DIVR value when the timer is operating is prohibited. Only change the DIVR value before starting the timer or after operation stops.
(2) Count End Flag in Timer Mode

The value of the count end interrupt request flag (EDIR) in PWCSR has no meaning in timer mode. Therefore, always set the enable bit for the count end interrupt request (EDIE) in PWCSR to "0".
(3) STRT and STOP bits in PWCSR

Note that the meaning of these two bits differs depending on whether they are being read or written (see the register description for details).
Also note that read-modify-write instructions always read the bits as " $11_{\mathrm{B}}$ " regardless of the actual values. Therefore, bit manipulation instructions cannot be used to read the operation state (as the result will always indicate "operating").
However, bit manipulation instructions (such as the bit clear instruction) can be used to write to the STRT or STOP bit to start or stop the timer.
(4) Clearing the Timer

In pulse width count mode, the timer is cleared by the count start edge and therefore the previous data in the timer has no meaning.
(5) Clock Selection Bits

Setting " 11 B" to the clock selection bits (CKS1, CKS0: bits 7,6 ) in PWCSR is prohibited.
(6) PWCR and Timer Value When Changing Mode

The value in PWCR and the timer value are indeterminate if the timer is set to single-shot mode after forcibly halting operation in reload mode. Therefore, always set a value before using the timer.
The value in PWCR is indeterminate if the timer is set to reload mode after forcibly halting operation in sin-gle-shot mode. Therefore, always set a value before using the timer.
When changing from pulse width count mode to timer mode, always set a value to PWCR before starting the timer.
(7) Minimum Input Pulse Width

The following restriction applies to pulses input to the pulse width count input pins.

- Minimum input pulse width: Machine cycle divided by $2(\geq 0.125 \mu \mathrm{~s}$ for a 16 MHz machine cycle)
- Maximum input frequency: Machine cycle divided by 4 ( $\geq 4 \mathrm{MHz}$ for a 16 MHz machine cycle)

The operation of the timer if pulses of shorter width or higher frequency are input is not guaranteed. If it is possible that such noise may be present on the input signal, use an external filter or similar circuit to suppress the noise.
(8) Divided Period Count Mode

Note that the input pulses are divided when divided period count mode is used in pulse width count mode and therefore the pulse width calculated from the count result is an average value.
(9) Restarting the Timer During Operation

Depending on the timing, the following may occur when the timer is restarted after starting the count operation.
(a) If the restart occurs at the same time as an overflow in reload timer mode:

The timer restarts but the overflow flag (OVIR) is set and the POUT bit inverted. (That is, the same operations are performed as for a normal overflow.)
(b) If the restart occurs at the same time as the count end edge in single-shot pulse width count mode:

The timer restarts and waits for a count start edge but the count end flag (EDIR) is also set.
(c) If the restart occurs at the same time as the count end edge in continuous pulse width count mode:

The timer restarts and waits for a count start edge but the count end flag (EDIR) is also set and the count result at that time is transferred to PWCR.
When restarting the timer while it is still operating, take note of the operation of the flags as described above and perform interrupt and other control accordingly.
(10) Pulse Width Count Mode Using Continuous Count Mode

Note that, when performing continuous counting in this mode, the divider circuit for the internal count clock is not cleared and therefore the number of edges below the count clock is added to the result.

## Chapter 19: <br> Clock Monitor Function

### 19.1 Outline

Clock Monitor Function is used to output the machine clock to a port pin. This clock output is generated by dividing the machineclock by $2^{1}$ to $2^{8}$.

### 19.2 Block Diagram



Figure 19.2a Block Diagram of Clock Monitor Function

### 19.3 Registers and Register Details

Clock Output Enable Register

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\checkmark$ Bit number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 00003E $\mathrm{E}_{\mathrm{H}}$ | - | - | - | - | CKEN | FRQ2 | FRQ1 | FRQ0 | CLKR |
| Read/write ${ }^{\text {c }}$ | (-) | (-) | (-) | (-) | (R/W) | (R/W) | (R/W) | (R/W) |  |
| Initial value $\leftrightarrows$ | (-) | (-) | (-) | (-) | (0) | (0) | (0) | (0) |  |

Figure 19.3a Registers of Clock Monitor Function

### 19.3.1 Clock output enable register (CLKR)

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\triangleleft$ Bit number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : $00003 \mathrm{E}_{\mathrm{H}}$ | - | - | - | - | CKEN | FRQ2 | FRQ1 | FRQ0 | CLKR |
| Read/write $¢>$ | (-) | (-) | (-) | (-) | (R/W) | (R/W) | (R/W) | (R/W) |  |
| Initial value $¢$ | (-) | (-) | $(-)$ | (-) | (0) | (0) | (0) | (0) |  |

[bit 3] : CKEN
CKOT output enable bit.

| 0 | Ordinary port |
| :---: | :--- |
| 1 | CKOT output |

[bits 2, 1, and 0] FRQ2, FRQ1, and FRQ0
These bits are used to select the clock output frequency.

| FRQ2 | FRQ1 | FRQ0 | Output clock | $\varnothing=16 \mathrm{MHz}$ | $\varnothing=8 \mathrm{MHz}$ | $\varnothing=4 \mathrm{MHz}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | $\varnothing / 2^{1}$ | 125 ns | 250 ns | 500 ns |
| 0 | 0 | 1 | $\varnothing / 2^{2}$ | 250 ns | 500 ns | $1 \mu \mathrm{~s}$ |
| 0 | 1 | 0 | $\varnothing / 2^{3}$ | 500 ns | $1 \mu \mathrm{~s}$ | $2 \mu \mathrm{~s}$ |
| 0 | 1 | 1 | $\varnothing / 2^{4}$ | $1 \mu \mathrm{~s}$ | $2 \mu \mathrm{~s}$ | $4 \mu \mathrm{~s}$ |
| 1 | 0 | 0 | $\varnothing / 2^{5}$ | $2 \mu \mathrm{~s}$ | $4 \mu \mathrm{~s}$ | $8 \mu \mathrm{~s}$ |
| 1 | 0 | 1 | $\varnothing / 2^{6}$ | $4 \mu \mathrm{~s}$ | $8 \mu \mathrm{~s}$ | $16 \mu \mathrm{~s}$ |
| 1 | 1 | 0 | $\varnothing / 2^{7}$ | $8 \mu \mathrm{~s}$ | $16 \mu \mathrm{~s}$ | $32 \mu \mathrm{~s}$ |
| 1 | 1 | 1 | $\varnothing / 2^{8}$ | $16 \mu \mathrm{~s}$ | $32 \mu \mathrm{~s}$ | $64 \mu \mathrm{~s}$ |

## Chapter 20: 16-Bit I/O Timer

### 20.1 Outline

The 16-bit I/O timer consists of a 16-bit free-run timer, two output compare modules, and four input capture modules. The count values of this timer are used as the base timer for output compare and input capture. Using this function, two independent waveforms can be output based on 16 -bit free-run timer to enable measurement of input pulse withs and external clock cycles.

- Four types of counter clock are available.
- An interrupt can be generated upon a counter value overflow.
- The counter value can be initialized upon a match with compare register 0 , depending on the mode.


## - 16-bit free-run timer ( $\times 1$ )

The 16 -bit free-run timer consists of a 16 -bit up counter, control register, and prescaler. The 16 -bit up counter is used to counting up in synchronization to the machine clock, in which an interrupt factor can be selected from the overflow interrupt and four types of timer intermediate bit interrupt to be operated as an interval timer.

- Four types of counter clock are available. Internal clock: $\varnothing / 4, \varnothing / 16, \varnothing / 32, \varnothing / 64$
- An interrupt can be generated upon a counter value overflow or a match with compare register 0 . (Compare match can be used only in an appropriate mode.)
- The counter value can be initialized to ' 0000 H ' upon a reset, software clear, or match with compare register 0 .
The free-run timer can be used to generating reference timing signals for the input capture (ICU) and output compare (OCU).
- Output compare (×2)

The output compare (OCU) consists of two 16-bit compare registers, compare output latch, and control register.
An interrupt request can be generated for each channel upon a match detection by performing time-division comparison between the OCU compare data register setting value and the counter value of the 16 -bit free-run timer.

When the 16 -bit free-run timer value matches the compare register value, the output level is reversed and an interrupt is issued.

- The four compare registers can be used independently. Output pins and interrupt flags corresponding to compare registers
- Output pins can be controlled based on pairs of the four compare registers. Output pins can be reversed by using the four compare registers.
- Initial values for output pins can be set.
- Interrupts can be generated upon a compare match.
- Input capture ( $\times 4$ )

The input capture (ICU) generates an interrupt request to the CPU simultaneously with a storing operation of current counter value of the 16-bit free-run timer to the ICU data register (IPCP) upon an input of a trigger edge to the external pin.
There are four sets (four channels) of the input capture external pins and ICU data registers (ICDR), enabling measurements of maximum of four events.

- The input capture has four sets of external pins (IN0 to IN3) and ICU registers (IPCPO~3), enabling measurements of maximum of four events.
- A trigger edge direction can be selected from rising/falling/both edges.
- The input capture can be set to generate an interrupt request at the storage timing of the counter value of the 16-bit free-run counter to the ICU data register (IPCP).
- The input compare conforms to the extended intelligent I/O service (EI ${ }^{2} \mathrm{OS}$ ).
- The input capture function is suited for measurements of intervals (frequencies) and pulse-widths.

A reset clears the timer counter value for the 16-bit free-run timer to all zeroes.

### 20.2 Block Diagram

### 20.2.1 Overall Block Diagram of 16-bit I/O Timer



Figure 20.2.1a Overall Block diagram of 16-bit I/O Timer

### 20.2.2 Block Diagram of 16-bit free-run timer



Figure 20.2.2a Block diagram of 16-bit free-run timer

### 20.2.3 Block Diagram of Output Comparison



Figure 20.2.3a Block diagram of Output Comparison

### 20.2.4 Block Diagram of Input Capture



Figure 20.2.4a Block diagram of Input Capture

### 20.3 Registers and Register Details

### 20.3.1 16-bit free-run timer

16-bit Timer Data Register (Upper)

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | > | Bit Number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $00006 \mathrm{D}_{\mathrm{H}}$ | T15 | T14 | T13 | T12 | T11 | T10 | T09 | T08 |  | TCDTH |
| Read/write $\Rightarrow$ Initial value $\Rightarrow$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ |  |  |

16-bit Timer Data Register (Lower)

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Bit Number TCDTL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $00006 \mathrm{C}_{\mathrm{H}}$ | T07 | T06 | T05 | T04 | T03 | T02 | T01 | T00 |  |
| Read/write Initial value | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ |  |

16-bit Timer Control Status Register

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | - Bit Number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $00006 \mathrm{E}_{\mathrm{H}}$ | Reserved | IVF | IVFE | STOP | MODE | CLR | CLK1 | CLKO | TCCS |
| Read/write $\Rightarrow$ | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W |  |
| Initial value $\Rightarrow>$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |

Figure 20.3.1a Registers of 16-bit free-run timer

### 20.3.1.1 16-bit free-run timer data register

| 16-bit Timer Data Register (Upper) |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $00006 \mathrm{D}_{\mathrm{H}}$ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $ـ^{\diamond} \text { Bit Number }$ |  |  |
|  | T15 | T14 | T13 | T12 | T11 | T10 | T09 | T08 |  |  |  |
| Read/write $\Rightarrow$ Initial value $\Rightarrow$ |  | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ |  |  |  |
| 16-bit Timer Data Register (Lower) |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\checkmark$ Bit Number |
| Address: $00006 \mathrm{C}_{\mathrm{H}}$ |  |  | T07 | T06 | T05 | T04 | T03 | T02 | T01 | T00 | TCDTL |
| $\begin{array}{cc} \text { Read/write } \Rightarrow & R / W \\ \text { Initial value } \Rightarrow 0 \end{array}$ |  |  |  | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \mathrm{R} / \mathrm{W} \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \mathrm{R} / \mathrm{W} \\ 0 \end{gathered}$ | $\begin{gathered} \mathrm{R} / \mathrm{W} \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ |  |

The data register can read the count value of the 16 -bit free-run timer. The counter value is cleared to ' 0000 ' upon a reset. The timer value can be set by writing a value to this register. However, ensure that the value is written while the operation is stopped (STOP=1). The data register must be accessed in word access mode.
The 16-bit free-run timer is initialized upon the following factors:

- Reset
- Clear bit (CLR) of control status register
- A match between compare register 0 and the timer counter value (This can be performed only in an appropriate mode.)


### 20.3.1.2 16-bit free-run timer control status register

16-bit Timer Control Status Register

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | > Bit Number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $00006 \mathrm{E}_{\mathrm{H}}$ | Reserved | IVF | IVFE | STOP | MODE | CLR | CLK1 | CLK0 | TCCS |
| Read/write Initial value $\Rightarrow$ | $\begin{gathered} \mathrm{R} / \mathrm{W} \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ |  |

[bit 7] Reserved bit
Always write '0' to this bit.
[bit 6] IVF
This bit is an interrupt request flag of the 16 -bit free-run timer.
If the 16 -bit free-run timer overflows, or if the counter is cleared by a match with compare register 0 in a certain mode, ' 1 ' is written to this bit.

An interrupt is issued if the interrupt request enable bit (bit 5 : IVFE) is set.
This bit is cleared by writing ' 0 .' Writing ' 1 ' has no effect.
' 1 ' is always read by a read-modify-write instruction.

| 0 | No interrupt request (default) |
| :--- | :--- |
| 1 | Interrupt request |

[bit 5] IVFE
IVFE is an interrupt enable bit of the 16-bit free-run timer. While '1' is written to this bit, an interrupt is issued if ' 1 ' is written to the interrupt flag (bit 5 : IVF).

| 0 | Interrupt disabled (default) |
| :--- | :--- |
| 1 | Interrupt enabled |

[bit 4] STOP
The STOP bit is used to stop the 16 -bit free-run timer.
Writing ' 1 ' to this bit stops the timer. Writing ' 0 ' starts the timer.

| 0 | Counting enabled (operation) (default) |
| :--- | :--- |
| 1 | Counting disabled (stop) |

* The output compare operation stops when the 16-bit free-run timer stops.


## [bit 3] MODE

The MODE bit is used to set the initialization condition of the 16-bit free-run timer.
When ' 0 ' is set, the counter value can be initialized by a reset or a clear bit (bit 2: CLR).
When ' 1 ' is set, the counter value can be initialized by a match with compare register 0 in addition to a reset and a clear bit (bit 2: CLR).

| 0 | Initialization by reset or clear bit (default) |
| :--- | :--- |
| 1 | Initialization by reset, clear bit, or compare register 0 |

* The counter value is initialized where the count value is changed.
[bit 2] CLR
The CLR bit initializes the operating 16 -bit free-run timer value to ' 0000 .'
When ' 1 ' is set, the counter value is initialized to ' 0000 .' Writing ' 0 ' has no effect. ' 0 ' is always read from this bit. The counter value is initialized where the count value changes.

| 0 | No effect (default) |
| :--- | :--- |
| 1 | The counter value is initialized to '0000. |

* To initialize the counter value while the timer is stopped, write ' 0000 ' to the data register.
[bits 1 and 0] CLK1 and CLK0
CLK1 and CLK0 are used to select the count clock for the 16 -bit free-run timer. The clock is updated immediately after a value is written to these bits. Therefore, ensure that the output compare and input capture operations are stopped before a value is written to these bits.

| CLK1 | CLK0 | Count clock | $\varnothing=16 \mathrm{MHz}$ | $\varnothing=8 \mathrm{MHz}$ | $\varnothing=4 \mathrm{MHz}$ | $\varnothing=1 \mathrm{MHz}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | $\varnothing / 4$ | $0.25 \mu \mathrm{~s}$ | $0.5 \mu \mathrm{~s}$ | $1 \mu \mathrm{~s}$ | $4 \mu \mathrm{~s}$ |
| 0 | 1 | $\varnothing / 16$ | $1 \mu \mathrm{~s}$ | $2 \mu \mathrm{~s}$ | $4 \mu \mathrm{~s}$ | $16 \mu \mathrm{~s}$ |
| 1 | 0 | $\varnothing / 64$ | $4 \mu \mathrm{~s}$ | $8 \mu \mathrm{~s}$ | $16 \mu \mathrm{~s}$ | $64 \mu \mathrm{~s}$ |
| 1 | 1 | $\varnothing / 256$ | $16 \mu \mathrm{~s}$ | $32 \mu \mathrm{~s}$ | $64 \mu \mathrm{~s}$ | $256 \mu \mathrm{~s}$ |

* $\varnothing$ = Machine clock


### 20.3.2 Output comparison

The output compare module consists of 16-bit compare registers, compare output pins, and control register. If the value written to the compare register of this module matches the 16 -bit free-run timer value, the output level of the pin can be reversed and an interrupt can be issued.

- Two compare registers exist that can be used independently. Depending on the setting, the two compare registers can be used to control pin outputs.
- The initial value for the pin output can be specified.
- An interrupt can be issued upon a match as a result of comparison.

Output Compare Register 0, 1

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | Bit Number OCCPO (Upper) OCCP1 (Upper) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $\begin{array}{r}00005 \mathrm{~B}_{\mathrm{H}} \\ 00005 \mathrm{D}_{\mathrm{H}}\end{array}$ | C15 | C14 | C13 | C12 | C11 | C10 | C09 | C08 |  |
| Read/write $\Rightarrow$ Initial value $\Rightarrow>$ | $\begin{gathered} \text { R/W } \\ \text { X } \end{gathered}$ | $\underset{\text { X }}{\text { R/W }}$ | $\begin{gathered} \text { R/W } \\ \text { X } \end{gathered}$ | $\begin{gathered} \text { R/W } \\ \text { X } \end{gathered}$ | $\begin{gathered} \text { R/W } \\ \text { X } \end{gathered}$ | $\mathrm{R} / \mathrm{W}$ | $\begin{gathered} \text { R/W } \\ \text { X } \end{gathered}$ | $\begin{gathered} \text { R/W } \\ \text { X } \end{gathered}$ |  |


|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $00005 \mathrm{~A}_{\mathrm{H}}$ | C07 | C06 | C05 | C04 | C 03 | C02 | C01 | C00 |  |
| Read Initial | R/W | $\begin{gathered} \text { R/W } \\ \text { X } \end{gathered}$ | $\underset{X}{\text { R/W }}$ | $\begin{gathered} \text { R/W } \\ \text { X } \end{gathered}$ | $\begin{gathered} \text { R/W } \\ \text { X } \end{gathered}$ | $\begin{gathered} \text { R/W } \\ \text { X } \end{gathered}$ | $\begin{gathered} \text { R/W } \\ \text { X } \end{gathered}$ | $\begin{gathered} \text { R/W } \\ \text { X } \end{gathered}$ |  |

Output Compare Control Status Register 0, 1


Figure 20.3.2a Registers of output comparsion

### 20.3.2.1 Compare register

Output Compare Register 0, 1

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | Bit Number OCCPO (Upper) OCCP1 (Upper) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $00005 \mathrm{~B}_{\mathrm{H}}$ | C15 | C14 | C13 | C12 | C11 | C10 | C09 | C08 |  |
| Read/write $\Rightarrow$ Initial value $\leftrightarrows$ | $\begin{gathered} \text { R/W } \\ \text { X } \end{gathered}$ | $\begin{gathered} \text { R/W } \\ \text { X } \end{gathered}$ | $\begin{gathered} \text { R/W } \\ \text { X } \end{gathered}$ | $\begin{gathered} \text { R/W } \\ \text { X } \end{gathered}$ | $\begin{gathered} \text { R/W } \\ \text { X } \end{gathered}$ | $\underset{X}{\text { R/W }}$ | $\begin{gathered} \text { R/W } \\ \text { X } \end{gathered}$ | $\underset{X}{\text { R/W }}$ |  |

Address: $00005 \mathrm{~A}_{\mathrm{H}}$ $00005 \mathrm{C}_{\mathrm{H}}$

Read/write $\Rightarrow$ R/W
nitial value $\Rightarrow$ X X X $\quad$ X $\quad$ X $\quad$ X $\quad$ X $\quad$ X $\quad$ X

This 16 -bit compare register is compared with the 16 -bit free-run timer. Since the initial register value is undefined, set a value before enabling the register. This register must be accessed in word mode. When the value of this register matches that of the 16-bit free-run timer, a compare signal is generated and the output compare interrupt flag is set. If output is enabled, the output level corresponding to the compare register is reversed.

### 20.3.2.2 Control status register

Output Compare Control Status Register 0, 1

| Address: $00005 \mathrm{~F}_{\mathrm{H}}$ | 14 | 13 | 12 | 11 | 10 | 9 | 8 | Bit Number OCS1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | - | - | CMOD | OTE1 | OTE0 | OTD1 | OTD0 |  |
| Read/write Initial value | — | - | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{aligned} & \text { R/W } \\ & 0 \end{aligned}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | 0 - Bit Number |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 |  |
| Address: $00005 \mathrm{E}_{\mathrm{H}}$ | ICP1 | ICP0 | ICE1 | ICE0 | - | - | CST1 | CSTO OCSO |
| Read/write $\Rightarrow$ Initial value $\Rightarrow$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | 二 | 二 | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ |

[bits 15, 14, and 13] Unused bits
[bit 12] CMOD
CMOD is used to switch the pin output level reverse mode upon a match while pin output is enabled ( $O T E 1=1$ or $O T E 0=1$ ).

- When CMOD=0 (default), the output level of the pin corresponding to the compare register is reversed.

OUTO: The level is reversed upon a match with compare register 0 .
OUT1: The level is reversed upon a match with compare register 1.

- When $C M O D=1$, the output level is reversed for compare register 0 in the same manner as for CMOD $=0$. The output level of the pin corresponding to compare register 1 (OUT1), however, is reversed upon a match with compare register 0 or 1 . If compare registers 0 and 1 have the same value, the same operation as with a single compare register is performed.

OUT0: The level is reversed upon a match with compare register 0 .
OUT1: The level is reversed upon a match with compare register 0 or 1.
[bits 11 and 10] OTE1 and OTE0
These bits are used to enable output compare pin output. The initial value for these bits is ' 0. '

| 0 | General-purpose port (default) |
| :--- | :--- |
| 1 | Output compare pin output |

* OTE1: Corresponds to output compare 1/3 OTE0: Corresponds to output compare 0/2
* OUT0/1 are multiplexed with P94/TOUT1 and P95/TOUT2 respectively. Whne both output capture and reload timer output are enabled. OUTO/OUT1 get the higher priority.


## [bits 9 and 8] OTD1 and OTD0

These bits are used to change the pin output level when the output compare pin output is enabled. The initial value of the compare pin output is ' 0 .' Ensure that the compare operation is stopped before a value is written. When read, these bits indicate the output compare pin output value.

| 0 | Sets '0' for the compare pin output. (default) |
| :--- | :--- |
| 1 | Sets '1' for the compare pin output. |

[^0][bits 7 and 6] ICP1 and ICP0
These bits are used as output compare interrupt flags. ' 1 ' is written to these bits when the compare register value matches the 16 -bit free-run timer value. While the interrupt request bits (ICE1 and ICEO) are enabled, an output compare interrupt occurs when the ICP1 and ICP0 bits are set. These bits are cleared by writing ' 0 .'

Writing ' 1 ' has no effect. ' 1 ' is always read by a read-modify-write instruction.

| 0 | No compare match (default) |
| :--- | :--- |
| 1 | Compare match |

* ICP1: Corresponds to output compare $1 / 3$ ICP0: Corresponds to output compare 0/2
[bits 5 and 4] ICE1 and ICE0
These bits are used as output compare interrupt enable flags. While the ' 1 ' is written to these bits, an output compare interrupt occurs when an interrupt flag (ICP1 or ICP0) is set.

| 0 | Output compare interrupt disabled <br> (default) |
| :--- | :--- |
| 1 | Output compare interrupt enabled |

* ICE1: Corresponds to output compare $1 / 3$ ICE0: Corresponds to output compare 0/2
[bits 3 and 2] Unused bits
[bits 1 and 0] CST1 and CST0
The*se bits are used to enable the comparison with 16 -bit free-run timer.

| 0 | Compare operation disabled (default) |
| :--- | :--- |
| 1 | Compare operation enabled |

Ensure that a value is written to the compare register before the compare operation is enabled.

* CST1: Corresponds to output compare 1/3 CST0: Corresponds to output compare 0/2

Note: Since output compare is synchronized with the 16 -bit free-run timer clock, stopping the 16 -bit free-run timer stops compare operation.

### 20.3.3 Input capture

This module detects a rising or falling edge or both edges of an externally input signal and stores the 16-bit free-run timer value in a register. In addition, this module can generate an interrupt upon detection of an edge. The input capture module consists of an input capture data register and a control register. Each input capture has a corresponding external input pin.

- The detection edge of an external input can be selected from three types.
- Rising edge, falling edge, or both edges
- An interrupt can be generated upon detection of a valid edge of an external input.

Input Capture Data Register 0, 1, 2, 3

| Address: $\begin{array}{r}000061^{H} \\ 000063^{H}\end{array}$ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | Bit Number IPCPO (Upper) IPCP1 (Upper) IPCP2 (Upper) IPCP3 (Upper) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 000065_{\mathrm{H}} \\ & 00006 \mathrm{H}_{\mathrm{H}} \end{aligned}$ | CP15 | CP14 | CP13 | CP12 | CP12 | CP11 | CP09 | CP08 |  |
| Read/write $\Rightarrow$ | R | R | R | R | R | R | R | R |  |
| Initial value $\Rightarrow$ | X | X | X | X | X | X | X | X |  |


| Address: $\begin{array}{r}000060_{H} \\ 000062_{H} \\ 00006 H^{H}\end{array}$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Bit Number IPCPO (Lower) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 000064 \mathrm{H} \\ & 000066 \mathrm{H} \end{aligned}$ | CP07 | CP06 | CP05 | CP04 | CP03 | CP02 | CP01 | CP00 | IPCPO (Lower) IPCP1 (Lower) |
| Read/write | R | R | R | R | R | R | R | R | IPCP2 (Lower) |
| Initial value | X | X | X | X | X | X | X | X |  |

Input Capture Control Status Register ch0,1 \& Ch2,3

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\begin{aligned} & \text { Bit Number } \\ & \text { ICS01 } \\ & \text { ICS23 } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $000068_{H}$ | ICP1 | ICP0 | ICE1 | ICE0 | EG11 | EG10 | EG01 | EG00 |  |
| Read/write $\Rightarrow$ Initial value $\Rightarrow$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | R/W | R/W 0 | R/W 0 | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ |  |

Figure 20.3.3a Register of input capture

### 20.3.3.1 Input capture data register

Input Capture Data Register 0, 1, 2, 3
Address: 000061 H

| $\begin{aligned} & 000061 \mathrm{H} \\ & 000063_{\mathrm{H}} \end{aligned}$ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | Bit Number IPCP0 (Upper) IPCP1 (Upper) IPCP2 (Upper) IPCP3 (Upper) |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 000065_{\mathrm{H}} \\ & 00006 \mathrm{H}_{\mathrm{H}} \end{aligned}$ | CP15 | CP14 | CP13 | CP12 | CP12 | CP11 | CP09 | CP08 |  |  |
| Read/write $ᄃ$ Initial value ᄃ | $\begin{aligned} & \mathrm{R} \\ & \mathrm{X} \end{aligned}$ | $\begin{aligned} & \mathrm{R} \\ & \mathrm{X} \end{aligned}$ | R | $\begin{aligned} & \mathrm{R} \\ & \mathrm{X} \end{aligned}$ | R | R | R | $\begin{aligned} & R \\ & X \end{aligned}$ |  |  |


| Address: $\begin{array}{r}000060_{\mathrm{H}} \\ 000062_{\mathrm{H}} \\ 0.002\end{array}$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Bit Number IPCPO (Lower) IPCP1 (Lower) IPCP2 (Lower) IPCP3 (Lowerr) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 000064_{\mathrm{H}} \\ & 000066 \mathrm{H} \end{aligned}$ | CP07 | CP06 | CP05 | CP04 | CP03 | CP02 | CP01 | CP00 |  |
| Read/write $\Rightarrow$ | R | R | R | R | R | R | R | R |  |
| Initial value $\Rightarrow$ > | X | X | X | X | X | X | X | X |  |

This register stores the 16-bit timer value when a valid edge of the corresponding external pin input waveform is detected. (This register must be accessed in word mode. No value can be written to this register.)

### 20.3.3.2 Control status register

Input Capture Control Status Register ch0,1 \& Ch2,3

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\begin{aligned} & \text { Bit Number } \\ & \hline \text { ICSO1 } \\ & \text { ICS23 } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $\begin{array}{r}000068_{H} \\ 00006 \mathrm{~A}_{\mathrm{H}}\end{array}$ | ICP1 | ICP0 | ICE1 | ICE0 | EG11 | EG10 | EG01 | EG00 |  |
| Read/write $\Rightarrow$ Initial value $\Rightarrow$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ | $\begin{gathered} \text { R/W } \\ 0 \end{gathered}$ |  |

[bits 7 and 6] ICP1 and ICP0
These bits are used as input capture interrupt flags. ' 1 ' is written to this bit upon detection of a valid edge of an external input pin. While the interrupt enable bits (ICEO and ICE1) are set, an interrupt can be generated upon detection of a valid edge.

These bits are cleared by writing ' 0 .' Writing ' 0 ' has no effect. ' 1 ' is always read by a read-modify-write instruction.

| 0 | No valid edge detection (default) |
| :--- | :--- |
| 1 | Valid edge detection |

* ICP0: Corresponds to input capture 0. ICP1: Corresponds to input capture 1.
[bits 5 and 4] ICE1 and ICE0
These bits are used to enable input capture interrupts. While ' 1 ' is written to these bits, an input capture interrupt is generated when the interrupt flag (ICPO or ICP1) is set.

| 0 | Interrupt disabled (default) |
| :--- | :--- |
| 1 | Interrupt enabled |

* ICE0: Corresponds to input capture 0. ICE1: Corresponds to input capture 1.
[bits 3, 2, 1, and 0] EG11, EG10, EG01, and EG00
These bits are used to specify the valid edge polarity of an external input. These bits are also used to enable input capture operation.

| EG11 <br> EG01 | EG10 <br> EG00 | Edge detection polarity |
| :---: | :---: | :--- |
| 0 | 0 | No edge detection (stop) |
| 0 | 1 | Rising edge detection $\hat{\Uparrow}$ |
| 1 | 0 | Falling edge detection $\forall$ |
| 1 | 1 | Both edge detection $\hat{\Downarrow} \downarrow$ | (default)

*EG01 and EG00: Correspond to input capture 0 . EG11 and EG10: Correspond to input capture 1.

### 20.4 Operations

### 20.4.1 16-bit free-run timer

The 16 -bit free-run timer starts counting from counter value ' 0000 ' after the reset is released. The counter value is used as the reference time for the 16-bit output compare and 16-bit input capture operations.

The counter value is cleared in the following conditions:

- When an overflow occurs.
- When a match with output compare register 0 occurs. (This depends on the mode.)
- When ' 1 ' is written to the CLR bit of the TCCS register during operation.
- When '0000' is written to the TCDC register during stop.
- Reset

An interrupt can be generated when an overflow occurs or when the counter is cleared due to a match with compare register 0. (Compare match interrupts can be used only in an appropriate mode.)

- Clearing the counter by an overflow


Clearing the counter upon a match with output compare register 0


### 20.4.2 16-bit output compare

In 16-bit output compare operation, an interrupt request flag can be set and the output level can be reversed when the specified compare register value matches the 16-bit free-run timer value.

Sample output waveform when compare registers 0 and 1 are used (The initial output value is 0 .)


The output level can be changed using two compare registers (when $C M O D=1$ ).
Sample output waveform with two compare registers (The initial output value is '0.')


### 20.4.3 16-bit input capture

In 16-bit input capture operation, an interrupt can be generated upon detection of a specified valid edge, fetching the 16-bit free-run timer value and writing it to the capture register.

- Sample input capture fetch timing

Capture 0: Rising edge
Capture 1: Falling edge
Capture example: Both edges


### 20.5 Timing

### 20.5.1 16-bit free-run timer count timing

The 16 -bit free-run timer is incremented based on the input clock (internal or external clock). When external clock is selected, the 16 -bit free-run timer is incremented at the rising edge.

Free-run timer count timing


The counter can be cleared upon a reset, software clear, or a match with compare register 0 . By a reset or software clear, the counter is immediately cleared. By a match with compare register 0 , the counter is cleared in synchronization with the count timing.

- Free-run timer clear timing (match with compare register 0)

Compare | Compare match |
| :--- |
| Cogister value |
| Counter value |

### 20.5.2 Output compare timing

In output compare operation, a compare match signal is generated when the free-run timer value matches the specified compare register value. The output value can be reversed and an interrupt can be issued. The output reverse timing upon a compare match is synchronized with the counter count timing.

- Compare operation upon update of compare register

When the compare register is updated, comparison with the counter value is not performed.


Interrupt timing


- Output pin change timing
Compare register
value

| Compare match |
| :---: |
| signal |

Pin output

### 20.5 Timing

### 20.5.3 Input capture input timing

- Capture timing for input signals



## Chapter 21: <br> ROM Correction Module

### 21.1 Outline

When the setting of the address is the same as the ROM Correction Address register, the INT9 instruction will be executed. By processing the INT9 interrupt service routine, the ROM correction function can be achieved.
There are two address registers, in each containing compare enable bit. When the address register and the program counter are in agreement, and when the compare enable bit is at ' 1 ', then the CPU will be forced to execute INT9 instruction.

### 21.2 Block Diagram



Figure 21.2a Block Diagram of ROM Correction Module

### 21.3 Registers and Register Details

| Program Address Detect Register 0/1 |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | byte |  | byte |  | byte | access |  | initial value undefined |
| PADRO 1FF2H/1FF1H/1FFOH |  |  |  |  |  |  | R/W |  |  |
| PADR1 1FF5H/1FF4H/1FF3H |  |  |  |  |  |  | R/W |  | undefined |
| Program Address Detect Control Status Register |  |  |  |  |  |  |  |  |  |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\diamond$ Bit number |
| Address : $009 \mathrm{E}_{\mathrm{H}}$ | - | - | - | - | AD1E | - | ADOE | - | PACSR |
| Read/write $\Rightarrow$ | (-) | $(-)$ | (-) | (-) | (R/W) | (-) | (R/W) | (-) |  |
| Initial value $\Rightarrow>$ | (-) | (-) | (0) | (0) | (0) | (0) | (0) | (0) |  |

Figure 21.3a Registers of ROM Correction Module

### 21.3.1 Program Address Detect Register 0/1 (PADR0/PADR1)

These registers hold the addresses for the comparison with program counter. If there is an agreement and when the corresponding ADCSR interrupt enable bit is at ' 1 ', this module demands the CPU to execute the INT9 instruction.
If the corresponding interrupt enalble bit is ' 0 ', nothing will occur even there is a match.

| Program Address Detect Register 0/1 |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | byte | byte | byte | access | initial value |
| PADR0 1FF2H/1FF1H/1FF0H |  |  |  | R/W | undefined |
| PADR1 1FF5H/1FF4H/1FF3H |  |  |  | R/W | undefined |

The correspondance to the PACSR will be as follows.

ROM correction register
PADR0
PADR1

Compare enable bit
AD0E
AD1E

### 21.3.2 Program Address detect Control Status Register (PACSR)

Program Address Detect Control Status Register

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | < Bit number |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : $009 \mathrm{E}_{\mathrm{H}}$ | - | - | - | - | AD1E | - | ADOE | - |  |
| Read/write $\Rightarrow$ | (-) | (-) | (-) | (-) | (R/W) | (-) | (R/W) | (-) |  |
| Initial value $\Rightarrow>$ | (-) | (-) | (0) | (0) | (0) | (0) | (0) | (0) |  |

This register provides control bits and status bit for the ROM correction function.
[bit 5~4]
These are the reserved bits, be sure to write ' 0 '.
[bit 3]: AD1E (Compare Enable 1)
This is the ADR1 enable bit.
When this bit is at ' 1 ', this module compares the PADR1 register and the program counter. If there is an agreement, the INT9 instruction is sent to the CPU.
[bit 2]:
This is a reserved bit.
[bit 1]: ADOE (Compare Enable 0)
This is the ADR0 enable bit.
When this bit is at ' 1 ', this module compares the PADR0 register and the program counter. If there is an agreement, the INT9 instruction is sent to the CPU.
[bit 0]:
This is a reserved bit.

### 21.4 Operations

When the program counter indicates the same address as the ROM Correction Address register, the INT9 instruction will be executed. By processing the INT9 interrupt service routine, the ROM correction function can be achieved.

There are two address registers, in each containing a compare enable bit. When the address register and the program counter are in agreement, and when the compare enable bit is at ' 1 ', then the CPU will be forced to execute INT9 instructions.
Note: When the address detection register and the program counter are in agreement, the internal data bus content will be forced to be ' 01 H ', so interrupt INT9 will be executed. Before changing the content of the address detect register, make sure the compare enable bit is at ' 0 '. If it is changed while the compare enable bit is at ' 1 ', there will occur an error.

### 21.5 Application Example

(1) System Structure


Figure 21.5a System Structure Example
(2) EPROM memory map
address:content
0000 H :number of bytes of the corrected program No. 0 ( 0 implies no ROM correction)
0001H:bit 7-0 program address No. 0
0002H:bit 15-8 program address No. 0
0003H:bit 24-16 program address No. 0
0004H:number of bytes of the corrected program No. 0 ( 0 implies no ROM correction)
0005H:bit 7-0 program address No. 1
0006H:bit 15-8 program address No. 1
0007H:bit 24-16 program address No. 1
0010H~: corrected program No. 0/1 body
(3) Initial Condition

EPROM all at ' 0 '.
(4) When ROM Correction is Needed

Send the body of the corrected program and the program address to the MCU through the connector (UART). MCU will write that information into the EEPROM.
(5) Reset Sequence

After resetting, the MCU reads the content of the EEPROM. If the byte number of the corrected program is not ' 0 ', the body of the corrected program will be read from the EEPROM and written in the RAM. Then the MCU sets the correction address either on PADR0 or on PADR1 and sets the compare enable bit. First address of the corrected program can be written in the user-defined location of the RAM if a relocatable correction program is desired. In this case INT9 service routine looks for this user-defined location to jump to the corrected program.
(6) INT9 interrupt

In the interrupt routine, the address that produces the interrupt can be known by checking the stack program couter value. The information stacked during interrupt will be discarded.


Figure 21.5b ROM Correction Processing Example


Figure 21.5c ROM Correction Processing Flow Diagram

## Chapter 22: <br> ROM Mirroring Module

### 22.1 Outline

In ROM Mirroring Module the FF bank of the ROM can be seen through the 00 bank when chosen during register setting.

### 22.2 Block Diagram



Figure 22.2a Block Diagram of ROM Mirroring Module

### 22.3 Registers and Register Details

ROM Mirror Function Select Register

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | Bit number <br> ROMM |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 0006F $\mathrm{H}_{\mathrm{H}}$ | - | - | - | - | - | - | - | MI |  |
| Read/write $\Rightarrow$ | (-) | (-) | (-) | (-) | (-) | (-) | (-) | (W) |  |
| Initial value $\Rightarrow$ | (-) | (-) | (-) | (-) | (-) | (-) | (-) | (1) |  |

Figure 22.3a Register of ROM Mirroring Module

### 22.3.1 ROM Mirror Function Select Register

## ROM Mirror Function Select Register

|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | Bit number <br> ROMM |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address : 0006F $\mathrm{H}_{\mathrm{H}}$ | - | - | - | - | - | - | - | MI |  |
| Read/write $\Rightarrow$ ¢ | (-) | (-) | (-) | (-) | (-) | (-) | (-) | (W) |  |
| Initial value $¢$ | (-) | (-) | (-) | (-) | (-) | (-) | (-) | (1) |  |

Note: Do not access this register when the addresses $004000_{\mathrm{H}} \sim 00 F F F F_{\mathrm{H}}$ is being accessed.
[bit 8] : MI
The ROM data in the FF bank can also be found in the 00 bank when ' 1 ' is written to this bit. However, such as memory mapping will not be done when this bit is written to ' 0 '. This bit is write only.
The memory during single chip mode and during internal ROM external bus mode will be as shown below.

Note: Only FF4000~FFFFFF is mirrorred to 004000~00FFFF when ROM mirroring functing is activated. Therefore, addresses FFF000~FF3FFF will not be mirrorred to 00 bank.

|  | MB90583 | MB90F583 | MB90V580 |
| :--- | :---: | :---: | :---: |
| Address 1 | FE0000 $_{\mathrm{H}}$ | FE0000 $_{\mathrm{H}}$ | FE0000 $_{\mathrm{H}}$ |
| Address 2 | $001900_{\mathrm{H}}$ | $001900_{\mathrm{H}}$ | $001900_{\mathrm{H}}$ |

## ADDRESS



Figure 22.3b Memory in Single Chip Mode


Figure 22.3c Memory in Internal ROM External Bus Mode

## Appendix A: I/O Map

## A. 1 I/O Map

Table A.1a lists the addresses assigned to the registers of each microcontroller resource
Table A.1a I/O map

| Address | Register | Abbreviation | Access | Resource | Initial value |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 00 H | Port 0 data register | PDR0 | R/W | Port 0 | XXXXXXXX |
| 01 H | Port 1 data register | PDR1 | R/W | Port 1 | XXXXXXXX |
| 02 н | Port 2 data register | PDR2 | R/W | Port 2 | XXXXXXXX |
| 03 H | Port 3 data register | PDR3 | R/W | Port 3 | XXXXXXXX |
| 04 н | Port 4 data register | PDR4 | R/W | Port 4 | XXXXXXXX |
| 05 H | Port 5 data register | PDR5 | R/W | Port 5 | XXXXXXXX |
| 06 н | Port 6 data register | PDR6 | R/W | Port 6 | --XXXXXX |
| 07 H | Port 7 data register | PDR7 | R/W | Port 7 | ---XXXX- |
| 08 н | Port 8 data register | PDR8 | R/W | Port 8 | XXXXXXXX |
| 09 н | Port 9 data register | PDR9 | R/W | Port 9 | XXXXXXXX |
| 0 A H | Port A data register | PDRA | R/W | Port A | -----XXX |
| OB to $0 \mathrm{~F}_{\mathrm{H}}$ | Reserved area |  |  |  |  |
| 10 н | Port 0 direction register | DDR0 | R/W | Port 0 | 00000000 |
| 11 H | Port 1 direction register | DDR1 | R/W | Port 1 | 00000000 |
| 12 H | Port 2 direction register | DDR2 | R/W | Port 2 | 00000000 |
| 13 н | Port 3 direction register | DDR3 | R/W | Port 3 | 00000000 |
| 14 н | Port 4 direction register | DDR4 | R/W | Port 4 | 00000000 |
| 15 н | Port 5 direction register | DDR5 | R/W | Port 5 | 00000000 |
| 16 н | Port 6 direction register | DDR6 | R/W | Port 6 | --000000 |
| 17 H | Port 7 direction register | DDR7 | R/W | Port 7 | ---0000- |
| 18 н | Port 8 direction register | DDR8 | R/W | Port 8 | 00000000 |
| 19 н | Port 9 direction register | DDR9 | R/W | Port 9 | 00000000 |
| 1 A H | Port A direction register | DDRA | R/W | Port A | -----000 |
| 1 B н | Port 4 pin register | ODR4 | R/W | Port 4 | 00000000 |
| 1 CH | Analog input enable register | ADER | R/W | Port 5, A/D | 1111111 |
| 1D to 1F H | Reserved area |  |  |  |  |
| 20 H | Serial mode register 0 | SMR0 | R/W | UART0 | 00000000 |
| 21 H | Serial control register 0 | SCR0 | R/W |  | 00000100 |
| 22 н | Serial input register/serial output register 0 | $\begin{aligned} & \text { SIDR/ } \\ & \text { SODRRO } \end{aligned}$ | R/W |  | XXXXXXXX |
| 23 н | Serial status register 0 | SSR0 | R/W |  | 00001-00 |
| 24 н | Serial mode register 1 | SMR1 | R/W | UART1 | 00000000 |
| 25 H | Serial control register 1 | SCR1 | R/W |  | 00000100 |
| 26 н | Serial input register/serial output register 1 | $\begin{aligned} & \text { SIDR/ } \\ & \text { SODR1 } \end{aligned}$ | R/W |  | XXXXXXXX |
| 27 н | Serial status register 1 | SSR1 | R/W |  | 00001-00 |
| 28 н | Serial mode register 2 | SMR2 | R/W | UART2 | 00000000 |
| 29 н | Serial control register 2 | SCR2 | R/W |  | 00000100 |
| 2 A H | Serial input register/serial output register 2 | $\begin{aligned} & \text { SIDR// } \\ & \text { SODRR2 } \end{aligned}$ | R/W |  | XXXXXXXX |
| 2 B H | Serial status register 2 | SSR2 | R/W |  | 00001-00 |

Table A.1a I/O map (Continued)

| Address | Register | Abbreviation | Access | Resource | Initial value |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 2 CH | Clock division control register 0 | CDCRO | R/W | Communication prescaler 0 | 0---1111 |
| 2 D H | Reserved area |  |  |  |  |
| 2 EH | Clock division control register 1 | CDCR1 | R/W | Communication prescaler 1 | 0---1111 |
| $2 \mathrm{~F}_{\mathrm{H}}$ | Reserved area |  |  |  |  |
| 30 H | Interrupt /DTP enable register | ENIR | R/W | DTP/external interrupt | 00000000 |
| 31 H | Interrupt/DTP cause register | EIRR | R/W |  | XXXXXXXX |
| 32 н | Request level setting register | ELVR | R/W |  | 00000000 |
| 33 н |  |  |  |  | 00000000 |
| 34 н | Clock division control register 2 | CDCR2 | R/W | Communication prescaler 2 | 0--1111 |
| 35 н | Reserved area |  |  |  |  |
| 36 H | Control status register | ADCS1 | R/W | A/D converter | 00000000 |
| 37 H |  | ADCS2 |  |  | 00000000 |
| 38 н | Data register | ADCR1 | R |  | XXXXXXXX |
| 39 н |  | ADCR2 |  |  | 00001--XX |
| 3 A H | D/A converter data register 0 | DAT0 | R/W | D/A converter | XXXXXXXX |
| 3 B H | D/A converter data register 1 | DAT1 | R/W |  | XXXXXXXX |
| 3 CH | D/A control register 0 | DACR0 | R/W |  | -----0 |
| 3 D н | D/A control register 1 | DACR1 | R/W |  | ------0 |
| 3E H | Clock output enable register | CLKR | R/W | Clock monitor function | -- - 0000 |
| $3 \mathrm{~F}_{\mathrm{H}}$ | Reserved area |  |  |  |  |
| 40 H | Reload register L (ch.0) | PRLLO | R/W | 8-/16-bit PPG | XXXXXXXX |
| 41 H | Reload register H (ch.0) | PRLH0 | R/W |  | XXXXXXXX |
| 42 н | Reload register L (ch.1) | PRLL1 | R/W |  | XXXXXXXX |
| 43 H | Reload register H (ch.1) | PRLH1 | R/W |  | XXXXXXXX |
| 44 H | PPG0 operation mode control register | PPGC0 | R/W |  | 0X000XX1 |
| 45 H | PPG1 operation mode control register | PPGC1 | R/W |  | $0 \times 000001$ |
| 46 H | PPG0 and PPG1 output control register | PPGOE | R/W |  | 00000000 |
| 47 H | Reserved area |  |  |  |  |
| 48 н | Control status register 0 | TMCSR0 | R/W | 16-bit reload timer 0 | 00000000 |
| 49 н |  |  |  |  | ---- 0000 |
| 4 A H | 16-bit timer register 0 16-bt reload register 0 | $\begin{gathered} \hline \text { TMR0 } \\ \text { TMRLRO } \end{gathered}$ | R/W |  | XXXXXXXX |
| 4 B H |  |  |  |  | XXXXXXXX |
| 4 CH | Control status register 1 | TMCSR1 | R/W | 16-bit reload timer 1 | 00000000 |
| 4D H |  |  |  |  | ---- 0000 |
| 4 EH | 16-bit timer register 1 16-bt reload register 1 | $\begin{gathered} \text { TMR1 } \\ \text { TMRLR1 } \end{gathered}$ | R/W |  | XXXXXXXX |
| 4 F H |  |  |  |  | XXXXXXXX |
| 50 н | Control status register 2 | TMCSR2 | R/W | 16-bit reload timer 2 | 00000000 |
| 51 H |  |  |  |  | ---- 0000 |
| 52 н | 16-bit timer register 2 |  | R/W |  | XXXXXXXX |
| 53 H | 16-bt reload register 2 | TMRLR2 | R/W |  | XXXXXXXX |
| 54 н | PWC control status register | PWCSR | R/W | 16-bit PWC timer | 00000000 |
| 55 н |  |  |  |  | 00000000 |
| 56 н | PWC data buffer register | PWCR | R/W |  | XXXXXXXX |
| 57 H |  |  |  |  | XXXXXXXX |
| 58 н | Divide ratio control register | DIVR | R/W |  | ------00 |
| 59 H | Reserved area |  |  |  |  |

## A. 1 I/O Map

Table A.1a I/O map (Continued)

| Address | Register | Abbreviation | Access | Resource | Initial value |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $5 \mathrm{~A}_{\mathrm{H}}$ | Output Compare Register 0 | ОССР0 | R/W | Output Compare (Channel 0 To 1) | XXXXXXXX |
| $5 \mathrm{~B}_{\mathrm{H}}$ |  |  |  |  | XXXXXXXX |
| $5 \mathrm{C}_{\mathrm{H}}$ | Output Compare Register 1 | OCCP1 | R/W |  | XXXXXXXX |
| $5 \mathrm{D}_{\mathrm{H}}$ |  |  |  |  | XXXXXXXX |
| $5 \mathrm{E}_{\mathrm{H}}$ | Output Compare Control Status Register 0 | OCS0 | R/W |  | 0000--00 |
| $5 \mathrm{~F}_{\mathrm{H}}$ | Output Compare Control Status Register 1 | OCS1 | R/W |  | ---00000 |
| 60 H | Input Capture Register 0 | IPCP0 | R | Input Capture (Channel 0 To 3 ) | XXXXXXXX |
| 61 H |  |  | R |  | XXXXXXXX |
| 62 н | Input Capture Register 1 | IPCP1 | R |  | XXXXXXXX |
| 63 H |  |  | R |  | XXXXXXXX |
| 64 H | Input Capture Register 2 | IPCP2 | R |  | XXXXXXXX |
| 65 H |  |  | R |  | XXXXXXXX |
| 66 H | Input Capture Register 3 | IPCP3 | R |  | XXXXXXXX |
| 67 H |  |  | R |  | XXXXXXXX |
| 68 H | Input Capture Control Status Register Ch0, 1 | ICS01 | R/W |  | 00000000 |
| 69 н | Reserved area |  |  |  |  |
| $6 \mathrm{~A}_{\mathrm{H}}$ | Input Capture Control Status Register | ICS23 | R/W |  | 00000000 |
| 6 B H | Reserved area |  |  |  |  |
| $6 \mathrm{C}_{\mathrm{H}}$ | 16-bit Timer Data Register (Low) | TCDTL | R/W | Free Run Timer | 00000000 |
| $6 \mathrm{D}_{\text {H }}$ | 16-bit Timer Data Register (High) | TCDTH | R/W |  | 00000000 |
| $6 \mathrm{E}_{\mathrm{H}}$ | 16-bit Timer Control Status Register | TCCS | R/W |  | 00000000 |
| $6 \mathrm{~F}_{\mathrm{H}}$ | Rom Mirror Function Select Register | ROMM | W | ROM mirroring Module | ---- ---1 |
| 70 H | Unit Address Register (Low) | MAWL | R/W | IEBus Interface | XXXXXXXX |
| 71 H | Unit Address Register (High) | MAWH | R/W |  | XXXXXXXX |
| 72 H | Slave Address Register (Low) | SAWL | R/W |  | XXXXXXXX |
| 73 H | Slave Address Register (High) | SAWH | R/W |  | XXXXXXXX |
| 74 H | Telegraph Length Set Register | DEWR | R/W |  | 00000000 |
| 75 H | Multiaddress, Control Bit Set Register | DCWR | R/W |  | 00000000 |
| 76 H | Command Register (Low) | CMRL | R/W |  | XX00000 |
| 77 н | Command Register (High) | CMRH | R/W |  | 000000XX |
| 78 н | Status Register (Low) | STRL | R |  | 0011XXXX |
| 79 H | Status Register (High) | STRH | R/W |  | 00000000 |
| 7 A H | Lock Read Register (Low) | LRRL | R |  | XXXXXXXX |
| 7 BH | Lock Read Register (High) | LRRH | R |  | XXX0XXXX |
| 7C H | Master Address Read Register (Low) | MARL | R |  | XXXXXXXX |
| 7D н | Master Address Read Register (High) | MARH | R |  | XXXXXXXX |
| 7E H | Telegraph Length Read Register | DERR | R |  | XXXXXXXX |
| $7 \mathrm{~F}_{\mathrm{H}}$ | Multiaddress, Control Bit Read Register | DCRR | R |  | 000XXXXX |
| 80 H | Write Data Buffer | WDB | R/W |  | XXXXXXXX |
| 81 H | Read Data Buffer | RDB | R |  | XXXXXXXX |
| 82 H | Serial mode register 3 | SMR3 | R/W | UART3 | 00000000 |
| 83 H | Serial control register 3 | SCR3 | R/W |  | 00000100 |
| 84 H | Serial input register/serial output register 3 | $\begin{aligned} & \hline \text { SIDR/ } \\ & \text { SODR3 } \end{aligned}$ | R/W |  | XXXXXXXX |
| 85 H | Serial status register 3 | SSR3 | R/W |  | 00001-00 |
| $86{ }_{H}$ | PWC Noise cancelling register | RNCR | R/W | PWC noise filter | ---- -000 |
| $8^{\text {H }}$ | Clock division control register 3 | CDCR3 | R/W | Communication prescaler 3 | 0---1111 |

Table A.1a I/O map (Continued)

| Address | Register | Abbreviation | Access | Resource | Initial value |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $88^{\text {H }}$ | Serial mode register 4 | SMR4 | R/W | UART4 | 00000000 |
| $89_{\mathrm{H}}$ | Serial control register 4 | SCR4 | R/W |  | 00000100 |
| $8 \mathrm{~A}_{\mathrm{H}}$ | Serial input register/serial output register 4 | $\begin{gathered} \text { SIDR// } \\ \text { SODRR } \end{gathered}$ | R/W |  | XXXXXXXX |
| $8 \mathrm{~B}_{\mathrm{H}}$ | Serial status register 4 | SSR4 | R/W |  | 00001-00 |
| $8 \mathrm{C}_{\mathrm{H}}$ | Port 0 resistor register | RDR0 | R/W | Port 0 | 00000000 |
| $8 \mathrm{D}_{\mathrm{H}}$ | Port 1 resistor register | RDR1 | R/W | Port 1 | 00000000 |
| $8 \mathrm{E}_{\mathrm{H}}$ | Port 6 resistor register | RDR6 | R/W | Port 6 | --000000 |
| $8 \mathrm{~F}_{\mathrm{H}}$ | Clock division control register 4 | CDCR4 | R/W | Communication prescaler 4 | 0--1111 |
| $90_{H}$ to $9 \mathrm{D}_{\mathrm{H}}$ | Reserved area |  |  |  |  |
| 9E H | Program address detect control status register | PACSR | R/W | ROM correction module | --000000 |
| 9 F | Delayed interrupt cause occurrence/ release register | DIRR | R/W | Delayed interrupt occurrence module | -- - - - -0 |
| A0 H | Low-power mode register | LPMCR | R/W | Low power | 00011000 |
| A1 H | Clock selection register | CKSCR | R/W |  | 11111100 |
| A2 H | Low noise output select register (Lower) | LNSRL | R/W | I/O port | 00000000 |
| A3 H | Low noise output select register (Upper) | LNSRH | R/W | I/O port | ----0000 |
| A4 H | Reserved area |  |  |  |  |
| A5 H | Automatic read function selection register | ARSR | W | External bus interface | 0011--00 |
| A6 H | External address output control register | HACR | W |  | 0000000 |
| A7 H | Bus control signal selection register | ECSR | W |  | 0000000- |
| A8 H | Watchdog control register | WDTC | R/W | Watchdog timer | XXXXX111 |
| A9 H | Time base timer control register | TBTC | R/W | Time base timer | 1-00100 |
| $\mathrm{AA}_{\mathrm{H}}$ | Watch timer control register | WTC | R/W | Watch Timer | 1X000000 |
| $\begin{gathered} \mathrm{AB}_{\mathrm{H}} \text { to } \\ \mathrm{AD}_{\mathrm{H}} \end{gathered}$ | Reserved area |  |  |  |  |
| $\mathrm{AE}_{\mathrm{H}}$ | Flash control register | FMCS | R/W | Flash interface | 000X0XX0 |
| $\mathrm{AF}_{\mathrm{H}}$ | Reserved area |  |  |  |  |
| B0 H | Interrupt control register 00 | ICR00 | R/W | Interrupt controller | 00000111 |
| B1 H | Interrupt control register 01 | ICR01 | R/W |  | 00000111 |
| B2 H | Interrupt control register 02 | ICR02 | R/W |  | 00000111 |
| B3 H | Interrupt control register 03 | ICR03 | R/W |  | 00000111 |
| B4 H | Interrupt control register 04 | ICR04 | R/W |  | 00000111 |
| B5 H | Interrupt control register 05 | ICR05 | R/W |  | 00000111 |
| B6 H | Interrupt control register 06 | ICR06 | R/W |  | 00000111 |
| B7 H | Interrupt control register 07 | ICR07 | R/W |  | 00000111 |
| B8 н | Interrupt control register 08 | ICR08 | R/W |  | 00000111 |
| B9 н | Interrupt control register 09 | ICR09 | R/W |  | 00000111 |
| $\mathrm{BA}_{\mathrm{H}}$ | Interrupt control register 10 | ICR10 | R/W |  | 00000111 |
| BB H | Interrupt control register 11 | ICR11 | R/W |  | 00000111 |
| BC H | Interrupt control register 12 | ICR12 | R/W |  | 00000111 |
| BD H | Interrupt control register 13 | ICR13 | R/W |  | 00000111 |
| BE H | Interrupt control register 14 | ICR14 | R/W |  | 00000111 |
| BF H | Interrupt control register 15 | ICR15 | R/W |  | 00000111 |
| $\begin{gathered} \mathrm{CO} \text { to } \mathrm{FF} \\ \hline \end{gathered}$ | External area | - | - | - | - |
| $100_{\mathrm{H}}$ to $\#_{\mathrm{H}}$ | RAM area | - | - | - | - |
| $\#_{H}$ to $1 \mathrm{FEFF}_{\mathrm{H}}$ | Reserved area | - | - | - | - |

Table A.1a I/O map (Continued)

| Address | Register | Abbreviation | Access | Resource | Initial value |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1FF0 H | Program address detection register 0 | PADR0 | R/W | Program patch manipulation | XXXXXXXX |
| 1FF1 H | Program address detection register 1 |  | R/W |  | XXXXXXXX |
| 1FF02 H | Program address detection register 2 |  | R/W |  | XXXXXXXX |
| 1FF3 H | Program address detection register 3 | PADR1 | R/W |  | XXXXXXXX |
| 1FF4 H | Program address detection register 4 |  | R/W |  | XXXXXXXX |
| 1FF5 H | Program address detection register 5 |  | R/W |  | XXXXXXXX |
| $\begin{gathered} \text { 1FF6 }_{H} \text { to } \\ \text { 1FFF }_{\mathrm{H}} \end{gathered}$ | Reserved area | - | - | - | - |

## APPENDIX B: <br> Instructions

## B. 1 Addressing

In the $\mathrm{F}^{2} \mathrm{MC}$-16LX, the address format is determined by either the instruction's effective address specification, or by the instruction code itself (implied addressing).

## B.1.1 Effective address field

The address formats specified in the effective address field are shown in Table B.1.1a.
Table B.1.1a Effective Address Field

| Code | Notation |  |  | Address format | Default bank |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 00 | R0 | RW0 : | RLO |  |  |
| 01 | R1 | RW1 | (RLO) |  |  |
| 02 | R2 | RW2 | RL1 |  |  |
| 03 | R3 | RW3 | (RL1) |  |  |
| 04 | R4 | RW4 | RL2 | Starting from the left, "ea" corresponds to the byte, word and long-word types. | None |
| 05 | R5 | RW5 | (RL2) |  |  |
| 06 | R6 | RW6 | RL3 |  |  |
| 07 | R7 | RW7 | (RL3) |  |  |
| 08 |  | @RW0 |  |  | DTB |
| 09 |  | @RW1 |  |  | DTB |
| 0 A |  | @RW2 |  | Register indirect | ADB |
| 0B |  | @RW3 |  |  | SPB |
| OC |  | @RW0+ |  |  | DTB |
| OD |  | @RW1+ |  |  | DTB |
| OE |  | @RW2+ |  | Register indirect with post-incrementing | ADB |
| OF |  | @RW3+ |  |  | SPB |
| 10 |  | @RW0+disp8 |  |  | DTB |
| 11 |  | @RW1+disp8 |  |  | DTB |
| 12 |  | @RW2+disp8 |  | Register indirect with 8-bit displacement | ADB |
| 13 |  | @RW3+disp8 |  |  | SPB |
| 14 |  | @RW4+disp8 |  |  | DTB |
| 15 |  | @RW5+disp8 |  |  | DTB |
| 16 |  | @RW6+disp8 |  | Register indirect with 8-bit displacement | ADB |
| 17 |  | @RW7+disp8 |  |  | SPB |
| 18 |  | @RW0+disp16 |  |  | DTB |
| 19 |  | @RW1+disp16 |  |  | DTB |
| 1 A |  | @RW2+disp16 |  | Register indirect with 16-bit displacement | ADB |
| 1B |  | @RW3+disp16 |  |  | SPB |
| 1 C |  | @RW0+RW7 |  | Register indirect with index | DTB |
| 1 D |  | @RW1+RW7 |  | Register indirect with index | DTB |
| 1E |  | @PC+disp16 |  | PC indirect with 16-bit displacement | PCB |
| 1F |  | addr16 |  | Direct address | DTB |

## B.1.2 Addressing Details

## (1) Immediate value (\#imm)

This format specifies the operand value directly.

- \#imm4
- \#imm8
- \#imm16
- \#imm32


## (2) Compressed direct address (dir)

In this format, the operand specifies the low-order 8 bits of the memory address. Bits 8 to 15 of the address are specified by the DPR. Bits 16 to 23 of the address are indicated by the DTB.
(3) Direct address (addr16)

In this format, the operand specifies the low-order 16 bits of the memory address. Bits 16 to 23 of the address are indicated by the DTB.
(4) Register direct

This format specifies a direct register as the operand.
General-purpose registers
Byte: $\quad$ R0, R1, R2, R3, R4, R5, R6, R7
Word: RW0, RW1, RW2, RW3, RW4, RW5, RW6, RW7
Long word: RLO, RL1, RL2, RL3
Dedicated registers
Accumulator: A, AL
Pointer: SP
Bank: PCB, DTB, USB, SSB, ADB
Page: DPR
Control: PS, CCR, RP, ILM
Note: Regarding the SP, either the USP or the SSP is selected and used, depending on the value of the S bit in the CCR. In addition, in a branching instruction, the PC is implicitly specified, and is not described in the instruction operand.

## (5) Register indirect (@RWj j=0 to 3)

This format accesses the memory address indicated by the contents of the general-purpose register RWj. When RW0/RW1 is used, bits 16 to 23 of the address are indicated by DTB; if RW3 is used, bits 16 to 23 of the address are indicated by SPB, and if RW2 is used, bits 16 to 23 of the address are indicated by ADB.
(6) Register indirect with post-incrementing (@RWj+ $\mathbf{j}=0$ to 3 )

This format accesses the memory address indicated by the contents of the general-purpose register RWj . After the operand operation, RWj is incremented by the data length of the operand (by 1 for a byte, 2 for a word, and 4 for a long-word). When RW0/RW1 is used, bits 16 to 23 of the address are indicated by DTB; if RW3 is used, bits 16 to 23 of the address are indicated by SPB, and if RW2 is used, bits 16 to 23 of the address are indicated by ADB. Note that if the post-incremented result is the address of the register for which the increment specification was made, the value that is referenced subsequently is the incremented value. In addition, in such a case, if the instruction was a write instruction, the data written by the instruction is given priority, so the register that was to have been incremented contains the write data in the end.
(7) Register indirect with displacement (@RWi + disp8 i=0 to 7/@RWj + disp16 j=0 to 3)

This format accesses the memory address indicated by the sum of the contents of the general-purpose register RWj and the displacement value. The displacement value can be one of two types, either a byte or a word, and is added as a signed value. When RW0, RW1, RW4, or RW5 is used, bits 16 to 23 of the address are indicated by DTB; if RW3 or RW7 is used, bits 16 to 23 of the address are indicated by SPB, and if RW2 or RW6 is used, bits 16 to 23 of the address are indicated by ADB.
(8) Register indirect with base index (@RW0 + RW7, @RW1 + RW7)

This format accesses the memory address indicated by the sum of the contents of the general-purpose register and either RW0 or RW1. Bits 16 to 23 of the address are indicated by DTB.

## (9) Program counter indirect with displacement (@PC + disp16)

This format accesses the memory address indicated by the sum of the "instruction address $+4+$ disp16". The displacement value is a word length value. Bits 16 to 23 of the address are indicated by PCB.
The operand address is generally regarded as "the next instruction address + disp16", but note that this does not hold true for the instructions indicated below:

- DBNZ eam, rel
- DWBNZ eam, rel
- MOV eam, \#imm8
- MOVW eam, \#imm16
- CBNE eam, \#imm8, rel
- CWBNE eam, \#imm16, rel


## (10) Accumulator indirect (@A)

This format has two types: one in which the contents of AL specify bits 00 to 15 of the address and DTB indicates bits 16 to 23 ; and one in which the low-order 24 bits of A specify bits 00 to 23 of the address.
(11) I/O direct (io)

In this format, the memory address of the operand is specified directly by the 8 -bit displacement value. Regardless of the value of DTB and DPR, the I/O space from 000000 to to 0000FFh is accessed. The access space specification prefix has no effect on this addressing format.
(12) Long register indirect with displacement (@RLi + disp8 i=0 to 3)

This format accesses the memory address indicated by the low-order 24 bits of the sum of the contents of the general-purpose register RLi plus the displacement value. The displacement value is 8 bits, and is added as a signed numeral.
(13) Compressed direct bit address (dir:bp)

This format specifies the low-order 8 bits of the memory address with the operand. In addition, bits 8 to 15 of the address are indicated by DPR. Finally, bits 16 to 23 of the address are indicated by DTB. The bit position is indicated by ":bp", with larger numbers being closer to the MSB and smaller numbers being closer to the LSB.
(14) I/O direct bit address (io:bp)

This format directly specifies a bit within a physical address from 000000h to 0000FFh. The bit position is indicated by ":bp", with larger numbers being closer to the MSB and smaller numbers being closer to the LSB.

## (15) Direct bit address (addr16:bp)

This format directly specifies any bit within a 64-kilobyte region. Bits 16 to 23 of the address are indicated by DTB. The bit position is indicated by ":bp", with larger numbers being closer to the MSB and smaller numbers being closer to the LSB.
(16) Register list (rlst)

This format specifies the register that is the target of a stack push/pop instruction.
MSB

|  | LSB |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :---: |
| RW7 | RW6 | RW5 | RW4 | RW3 | RW2 | RW1 | RW0 |

A register is selected when the corresponding bit is " 1 ", and is not selected when the corresponding bit is " 0 ".

Fig. B.1.2a Register List Configuration

## (17) Program counter relative branching address (rel)

With this format, the address of the destination of a branching instruction is the sum of the value of the PC and the 8-bit displacement value. If the result exceeds 16 bits, the amount of the overflow is ignored and the bank register is not incremented or decremented; therefore, the address is kept within a 64 -kilobyte bank. This format is used in unconditional and conditional branching instructions. Bits 16 to 23 of the address are indicated by PCB.
(18) Direct branching address (addr16)

With this format, the address of the destination of a branching instruction is specified directly by the displacement value. The displacement value is 16 bits, and indicates the branching destination within a logical memory space. This format is used in unconditional branching instructions and subroutine call instructions. Bits 16 to 23 of the address are indicated by PCB.
(19) Physical direct branching address (addr24)

With this format, the address of the destination of a branching instruction is specified directly by the displacement value. The displacement value is 24 bits, and specifies the physical address of the branching destination. This format is used in unconditional branching instructions, subroutine call instructions, and software interrupt instructions.

## (20) Accumulator indirect branching address (@A)

In this format, the 16 bits of the accumulator AL specify the branching destination address. This address indicates a branching destination within a bank space; in this case, bits 16 to 23 of the address are indicated by the PCB. In the case of JCTX, however, bits 16 to 23 of the address are indicated by DTB. This format is used in unconditional branching instructions.

## (21) Vector address (\#vct)

The contents of the specified vector become the branching destination address. There are two data lengths for vector numbers: 4 bits and 8 bits. This format is used in subroutine call instructions and software interrupt instructions.
(22) Indirect specification branching address (@ear)

The word data in the address indicated by "ear" is the branching destination address.
(23) Indirect specification branching address (@eam)

The word data in the address indicated by "eam" is the branching destination address.

## B. 2 Instruction Set

Table B.2a Explanation of Items in Table of Instructions

| Item | Explanation |
| :---: | :---: |
| Mnemonic | Upper-case letters and symbols: ......... Described as they appear in assembler. Lower-case letters: .......................Replaced when described in assembler. Numbers after lower-case letters: ..... Indicate the bit width within the instruction. |
| \# | Indicates the number of bytes. |
|  | Indicates the number of cycles. <br> See Table 4.2.4 for details about meanings of letters in items. |
| RG | Indicates the register access count during execution of instruction. Used to calculate compensation values for CPU intermittent operation. |
| B | Indicates the compensation value for calculating the number of actual cycles during execution of instruction. <br> The number of actual cycles during execution of instruction is the compensation value summed with the value in the " $\sim$ " column. |
| Operation | Indicates operation of instruction. |
| LH | Indicates special operations involving bits 15 through 08 of the accumulator. <br> Z:....... Transfers " 0 ". <br> X: $\qquad$ Sign-extended transfer through sign extension. <br> -:.........Transfers nothing. |
| AH | Indicates special operations involving the high-order 16 bits in the accumulator. $\qquad$ Transfers from AL to AH. $\qquad$ No transfer. <br> Z:........ Transfers 00 to AH. <br> X:.........Transfers 00 H or FF н to AH using sign extension AL. |
| 1 | Indicates the status of each of the following flags: I (interrupt enable), S (stack), T (sticky bit), N (negative), Z (zero), V (overflow), and C (carry). <br> *:......... Changes due to execution of instruction. <br> -:......... No change. <br> S:........ Set by execution of instruction. <br> R: ....... Reset by execution of instruction. <br> Indicates whether the instruction is a read-modify-write instruction (a single instruction that reads data from memory, etc., processes the data, and then writes the result to memory.). $\qquad$ $\qquad$ Instruction is a read-modify-write instruction. <br> Note: A read-modify-write instruction cannot be used on addresses that have different meanings depending on whether they are read or written. |
| S |  |
| T |  |
| N |  |
| Z |  |
| V |  |
| C |  |
| RMW |  |

- Number of execution cycles

The number of cycles required for the execution of an instruction is obtained by summing the value shown in the table for the "number of cycles" for the instruction in question, the compensation value (which depends on certain conditions), and the "number of cycles" needed for the program fetch.
When fetching a program in memory connected to the 16 -bit bus, such as on-chip ROM, a program fetch is performed for each two-byte (word) boundary crossed by the instruction being executed; therefore, if there is any interference with data access, etc., the number of execution cycles increases.
When fetching a program in memory connected to the 8 -bit external data bus, a program fetch is performed for each byte of the instruction being executed; therefore, if there is any interference with data access, etc., the number of execution cycles increases.
In CPU intermittent operation, each access to general-purpose registers, internal ROM, internal RAM, internal I/O functions or external bus causes the CPU clock to pause for a fixed number of cycles determined by the CG1/CG0 bits in the low power consumption mode control register. For this reason, the number of machine clock cycles required to execute an instruction under CPU intermittent operation is the normal number of cycles plus an offset number of cycles that is derived by multiplying the number of access operations by the length (in cycles) of the fixed pause.

Table B.2b Explanation of Symbols in Table of Instructions

| Symbol | $\quad$ Explanation |
| :--- | :--- |
| A | 32-bit accumulator <br> The bit length varies according to the instruction. <br> Byte:......... Low-order 8 bits of AL <br> Word: ......... 16 bits of AL |
| AH <br> AL | High-order 16 bits of A <br> Low-order 16 bits of A |
| SP | Stack pointer (USP or SSP) |

Table B.2c Effective Address Fields

| Code | Notation |  |  | Address format | Number of bytes in address extension [Note] |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 00 | R0 | RW0 | RLO | Register direct "ea" corresponds to byte, word, and longword types, starting from the left | - |
| 01 | R1 | RW1 | (RLO) |  |  |
| 02 | R2 | RW2 | RL1 |  |  |
| 03 | R3 | RW3 | (RL1) |  |  |
| 04 | R4 | RW4 | RL2 |  |  |
| 05 | R5 | RW5 | (RL2) |  |  |
| 06 | R6 | RW6 | RL3 |  |  |
| 07 | R7 | RW7 | (RL3) |  |  |
| 08 | @RW0 |  |  | Register indirect | 0 |
| 09 | @RW1 @RW2 @RW3 |  |  |  |  |
| 0A |  |  |  |  |  |
| OB |  |  |  |  |  |
| OC | @RW0+ |  |  | Register indirect with post-incrementing | 0 |
| OD | @RW1+@RW2+@RW3+ |  |  |  |  |
| OE |  |  |  |  |  |
|  |  |  |  |  |  |
| 10 | @RW0+disp8 |  |  | Register indirect with 8-bit displacement | 1 |
| 11 | @RW1+disp8 |  |  |  |  |
| 12 | @RW2+disp8 |  |  |  |  |
| 13 | @RW3+disp8 |  |  |  |  |
| 14 | @RW4+disp8 |  |  |  |  |
| 15 | @RW5+disp8 |  |  |  |  |
| 16 | @RW6+disp8 |  |  |  |  |
| 17 | @RW7+disp8 |  |  |  |  |
| 18 | @RW0+disp16 |  |  | Register indirect with 16-bit displacement | 2 |
| 19 | @RW1+disp16 @RW2+disp16 @RW3+disp16 |  |  |  |  |
| 1 A |  |  |  |  |  |
| 1B |  |  |  |  |  |
| 1 C | @RW0+RW7 |  |  | Register indirect with index | 0 |
| 1D | @RW1+RW7 |  |  | Register indirect with index | 0 |
| 1 E | @PC+disp16 |  |  | PC indirect with 16 -bit displacement | 2 |
| 1F | addr16 |  |  | Direct address | 2 |

Note: The number of bytes for address extension is indicated by the " + " symbol in the " $\#$ " (number of bytes) column in the Table of Instructions and by the number of bytes in the detailed instruction rules.

Table B.2d Number of Execution Cycles for Each Form of Addressing
$\begin{array}{|c|c|c|c|}\hline \text { Code } & \text { Operand } & \begin{array}{c}\text { (a) } \\$\cline { 3 - 4 }\end{array} \& $\left.\begin{array}{c}\text { Number of execution } \\ \text { cycles for each form of } \\ \text { addressing }\end{array} \\ \text { Number of accesses for } \\ \text { each form of addressing }\end{array}\right]$

Note: "(a)" is used in the " $\sim$ " (number of cycles) column, column B (compensation value) and in the detailed instruction rules in the Table of Instructions.

Table B.2e Compensation Values for Number of Cycles Used to Calculate Number of Actual Cycles

| Operand | (b) byte |  | (c) word |  | (d) long |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Cycles | Access <br> cycles | Cycles | Access <br> cycles | Cycles | Access <br> cycles |
| Internal register | +0 | 1 | +0 | 1 | +0 | 2 |
| Internal RAM even address | +0 | 1 | +0 | 1 | +0 | 2 |
| Internal RAM odd address | +0 | 1 | +2 | 2 | +4 | 4 |
| Even address on external data bus (16 bits) | +1 | 1 | +1 | 1 | +2 | 2 |
| Odd address on external data bus (16 bits) | +1 | 1 | +4 | 2 | +8 | 4 |
| External data bus (8 bits) | +1 | 1 | +4 | 2 | +8 | 4 |

Note: "(b)", "(c)", and "(d)" are used in the " $\sim$ " (number of cycles) column, column B (compensation value) and in the detailed instruction rules in the Table of Instructions.
When the external data bus is used, it is necessary to add in the number of weighted cycles used for ready input and automatic ready.

## Table B.2f Compensation Values for Number of Cycles Used to Calculate Number of Program Fetch Cycles

| Instruction | Byte boundary | Word boundary |
| :---: | :---: | :---: |
| Internal memory | - | +2 |
| External data bus (16 bits) | - | +3 |
| External data bus ( 8 bits) | +3 | - |

Note: When the external data bus is used, it is necessary to add in the number of weighted cycles used for ready input and automatic ready.
Because instruction execution is not slowed down by all program fetches in actuality, these compensation values should be used for "worst case" calculations.

## B.2.1 F2MC-16LX Instruction Set (351 Instructions)

Table B.2.1a Transfer Instructions (Byte) (41 Instructions)

|  | Mnemonic | \# | $\sim$ | RG | B | Operation | LH | AH | I | S | T | N | Z | V | C | RMW |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MOV | A, dir | 2 | 3 | 0 | (b) | byte $(\mathrm{A}) \leftarrow$ (dir) | Z | * | - | - | - | * | * | - | - | - |
| MOV | A,addr16 | 3 | 4 | 0 | (b) | byte $($ A $) \leftarrow$ (addr16) | Z | * | - | - | - | * | * | - | - | - |
| MOV | A,Ri | 1 | 2 | 1 | 0 | byte $(\mathrm{A}) \leftarrow(\mathrm{Ri})$ | Z | * | - | - | - | * | * | - | - | - |
| MOV | A, ear | 2 | 2 | 1 | 0 | byte $(A) \leftarrow$ (ear) | Z | * | - | - | - | * | * | - | - | - |
| MOV | A, eam | 2+ | $3+(a)$ | 0 | (b) | byte $(A) \leftarrow$ (eam) | Z | * | - | - | - | * | * | - | - | - |
| MOV | A,io | 2 | 3 | 0 | (b) | byte $(A) \leftarrow$ (io) | Z | * | - | - | - | * | * | - | - | - |
| MOV | A,\#imm8 | 2 | 2 | 0 | 0 | byte $(A) \leftarrow($ imm 8$)$ | Z | * | - | - | - | * | * | - | - | - |
| MOV | A,@A | 2 | 3 | 0 | (b) | byte $(A) \leftarrow((A))$ | Z | - | - | - | - | * | * | - | - | - |
| MOV | A,@RLi+disp8 | 3 | 10 | 2 | (b) | byte $(A) \leftarrow(($ RLi $)+$ disp8) | Z | * | - | - | - | * | * | - | - | - |
| MOVN | A,\#imm4 | 1 | 1 | 0 | 0 | byte $(A) \leftarrow$ imm4 | Z | * | - | - | - | R | * | - | - | - |
| MOVX | A, dir | 2 | 3 | 0 | (b) | byte $(\mathrm{A}) \leftarrow$ (dir) | X | * | - | - | - | * | * | - | - | - |
| MOVX | A,addr16 | 3 | 4 | 0 | (b) | byte $($ A $) \leftarrow$ (addr16) | X | * | - | - | - | * | * | - | - | - |
| MOVX | A,Ri | 2 | 2 | 1 | 0 | byte $(\mathrm{A}) \leftarrow(\mathrm{Ri})$ | X | * | - | - | - | * | * | - | - | - |
| MOVX | A, ear | 2 | 2 | 1 | 0 | byte $(A) \leftarrow$ (ear) | X | * | - | - | - | * | * | - | - | - |
| MOVX | A,eam | 2+ | $3+(a)$ | 0 | (b) | byte $(A) \leftarrow($ eam $)$ | X | * | - | - | - | * | * | - | - | - |
| MOVX | A,io | 2 | 3 | 0 | (b) | byte $(A) \leftarrow$ (io) | X | * | - | - | - | * | * | - | - | - |
| MOVX | A,\#imm8 | 2 | 2 | 0 | 0 | byte $(A) \leftarrow($ imm8) | X | * | - | - | - | * | * | - | - | - |
| MOVX | A,@A | 2 | 3 | 0 | (b) | byte $(A) \leftarrow((A))$ | X | - | - | - | - | * | * | - | - | - |
| MOVX | A,@RWi+disp8 | 2 | 5 | 1 | (b) | byte $(A) \leftarrow(($ RWi)+disp8) | X | * | - | - | - | * | * | - | - | - |
| MOVX | A,@RLi+disp8 | 3 | 10 | 2 | (b) | byte $(\mathrm{A}) \leftarrow((\mathrm{RLi})+$ disp8) | X | * | - | - | - | * | * | - | - | - |
| MOV | dir,A | 2 | 3 | 0 | (b) | byte ( dir) $\leftarrow$ (A) | - | - | - | - | - | * | * | - | - | - |
| MOV | addr16, A | 3 | 4 | 0 | (b) | byte (addr16) $\leftarrow($ A $)$ | - | - | - | - | - | * | * | - | - | - |
| MOV | Ri,A | 1 | 2 | 1 | 0 | byte $(\mathrm{Ri}) \leftarrow(\mathrm{A})$ | - | - | - | - | - | * | * | - | - | - |
| MOV | ear,A | 2 | 2 | 1 | 0 | byte (ear) $\leftarrow(A)$ | - | - | - | - | - | * | * | - | - | - |
| MOV | eam,A | 2+ | $3+(a)$ | 0 | (b) | byte (eam) $\leftarrow(A)$ | - | - | - | - | - | * | * | - | - | - |
| MOV | io,A | 2 | 3 | 0 | (b) | byte (io) $\leftarrow$ (A) | - | - | - | - | - | * | * | - | - | - |
| MOV | @RLi+disp8,A | 3 | 10 | 2 | (b) | byte $((\mathrm{RLi})+$ disp8 $) \leftarrow(\mathrm{A})$ | - | - | - | - | - | * | * | - | - | - |
| MOV | Ri,ear | 2 | 3 | 2 | 0 | byte (Ri) $\leftarrow$ (ear) | - | - | - | - | - | * | * | - | - | - |
| MOV | Ri,eam | 2+ | 4+(a) | 1 | (b) | byte $(\mathrm{Ri}) \leftarrow($ eam $)$ | - | - | - | - | - | * | * | - | - | - |
| MOV | ear,Ri | 2 | 4 | 2 | 0 | byte (ear) $\leftarrow$ (Ri) | - | - | - | - | - | * | * | - | - | - |
| MOV | eam,Ri | 2+ | 5+(a) | 1 | (b) | byte (eam) $\leftarrow$ (Ri) | - | - | - | - | - | * | * | - | - | - |
| MOV | Ri,\#mm8 | 2 | 2 | 1 | 0 | byte (Ri) $\leftarrow$ imm8 | - | - | - | - | - | * | * | - | - | - |
| MOV | io,\#imm8 | 3 | 5 | 0 | (b) | byte (io) $\leftarrow$ imm8 | - | - | - | - | - | - | - | - | - | - |
| MOV | dir,\#imm8 | 3 | 5 | 0 | (b) | byte (dir) $\leftarrow$ imm8 | - | - | - | - | - | - | - | - | - | - |
| MOV | ear,\#imm8 | 3 | 2 | 1 | 0 | byte (ear) $\leftarrow$ imm8 | - | - | - | - | - | * | * | - | - | - |
| MOV | eam,\#imm8 | 3+ | 4+(a) | 0 | (b) | byte (eam) $\leftarrow$ imm8 | - | - | - | - | - | - | - | - | - | - |
| MOV | @AL,AH / MOV @A,T | 2 | 3 | 0 | (b) | byte $((\mathrm{A})) \leftarrow(\mathrm{AH})$ | - | - | - | - | - | * | * | - | - | - |
| XCH | A, ear | 2 | 4 | 2 | 0 | byte $(A) \longleftrightarrow \rightarrow$ (ear) | Z | - | - | - | - | - | - | - | - | - |
| XCH | A, eam | 2+ | 5+(a) | 0 | $2 \times$ (b) | byte $(A) \longleftrightarrow$ (eam) | Z | - | - | - | - | - | - | - | - | - |
| XCH | Ri,ear | 2 | 7 | 4 | 0 | byte (Ri) $\longleftrightarrow$ (ear) | - | - | - | - | - | - | - | - | - | - |
| XCH | Ri,eam | 2+ | 9+(a) | 2 | $2 \times(\mathrm{b})$ | byte (Ri) $\longleftrightarrow$ (eam) | - | - | - | - | - | - | - | - | - | - |

Note: For an explanation of "(a)" to "(d)" in the colunm "B", see Table B.2d and Table B.2e.

Table B.2.1b Transfer Instructions (Word/Long-Word) (38 Instructions)

| Mnemonic | \# | $\sim$ | RG | B | Operation | LH | AH | I | S | T | N | Z | V | C | RMW |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MOVW A,dir | 2 | 3 | 0 | (c) | word $(\mathrm{A}) \leftarrow$ (dir) | - | * | - | - | - | * | * | - | - | - |
| MOVW A,addr16 | 3 | 4 | 0 | (c) | word $(A) \leftarrow$ (addr16) | - | * | - | - | - | * | * | - | - | - |
| MOVW A,SP | 1 | 1 | 0 | 0 | word $(A) \leftarrow(S P)$ | - | * | - | - | - | * | * | - | - | - |
| MOVW A,RWi | 1 | 2 | 1 | 0 | word $(\mathrm{A}) \leftarrow(\mathrm{RWi})$ | - | * | - | - | - | * | * | - | - | - |
| MOVW A,ear | 2 | 2 | 1 | 0 | word $(A) \leftarrow$ (ear) | - | * | - | - | - | * | * | - | - | - |
| MOVW A,eam | 2+ | 3+(a) | 0 | (c) | word $(A) \leftarrow($ eam $)$ | - | * | - | - | - | * | * | - | - | - |
| MOVW A,io | 2 | 3 | 0 | (c) | word $(A) \leftarrow$ (io) | - | * | - | - | - | * | * | - | - | - |
| MOVW A,@A | 2 | 3 | 0 | (c) | word $(A) \leftarrow((A))$ | - | - | - | - | - | * | * | - | - | - |
| MOVW A,\#imm16 | 3 | 2 | 0 | 0 | word $(A) \leftarrow$ imm16 | - | * | - | - | - | * | * | - | - | - |
| MOVW A,@RWi+disp8 | 2 | 5 | 1 | (c) | word $(\mathrm{A}) \leftarrow((\mathrm{RWi})+$ disp8) | - | * | - | - | - | * | * | - | - | - |
| MOVW A,@RLi+disp8 | 3 | 10 | 2 | (c) | word $(A) \leftarrow((R L i)+$ disp8) | - | * | - | - | - | * | * | - | - | - |
| MOVW dir,A | 2 | 3 | 0 | (c) | word ( dir) $\leftarrow$ ( A$)$ | - | - | - | - | - | * | * | - | - | - |
| MOVW addr16,A | 3 | 4 | 0 | (c) | word (addr16) $\leftarrow(\mathrm{A})$ | - | - | - | - | - | * | * | - | - | - |
| MOVW SP,A | 1 | 1 | 0 | 0 | word (SP) $\leftarrow(\mathrm{A})$ | - | - | - | - | - | * | * | - | - | - |
| MOVW RWi,A | 1 | 2 | 1 | 0 | word $(\mathrm{RWi}) \leftarrow(\mathrm{A})$ | - | - | - | - | - | * | * | - | - | - |
| MOVW ear,A | 2 | 2 | 1 | 0 | word (ear) $\leftarrow(A)$ | - | - | - | - | - | * | * | - | - | - |
| MOVW eam,A | 2+ | 3+(a) | 0 | (c) | word (eam) $\leftarrow(\mathrm{A})$ | - | - | - | - | - | * | * | - | - | - |
| MOVW io,A | 2 | 3 | 0 | (c) | word (io) $\leftarrow$ (A) | - | - | - | - | - | * | * | - | - | - |
| MOVW @RWi+disp8,A | 2 | 5 | 1 | (c) | word $((\mathrm{RWi})+$ disp8 $) \leftarrow(\mathrm{A})$ | - | - | - | - | - | * | * | - | - | - |
| MOVW @RLi+disp8,A | 3 | 10 | 2 | (c) | word $((R L i)+$ disp8) $\leftarrow(A)$ | - | - | - | - | - | * | * | - | - | - |
| MOVW RWi,ear | 2 | 3 | 2 | 0 | word $(\mathrm{RWi}) \leftarrow(\mathrm{ear})$ | - | - | - | - | - | * | * | - | - | - |
| MOVW RWi,eam | 2+ | 4+(a) | 1 | (c) | word $($ RWi $) \leftarrow($ eam $)$ | - | - | - | - | - | * | * | - | - | - |
| MOVW ear,RWi | 2 | 4 | 2 | 0 | word (ear) $\leftarrow($ RWi) | - | - | - | - | - | * | * | - | - | - |
| MOVW eam,RWi | 2+ | 5+(a) | 1 | (c) | word (eam) $\leftarrow(\mathrm{RWi})$ | - | - | - | - | - | * | * | - | - | - |
| MOVW RWi,\#imm16 | 3 | 2 | 1 | 0 | word $(\mathrm{RWi}) \leftarrow$ imm16 | - | - | - | - | - | * | * | - | - | - |
| MOVW io,\#imm16 | 4 | 5 | 0 | (c) | word (io) $\leftarrow$ imm16 | - | - | - | - | - | - | - | - | - | - |
| MOVW ear,\#imm16 | 4 | 2 | 1 | 0 | word (ear) $\leftarrow$ imm16 | - | - | - | - | - | * | * | - | - | - |
| MOVW eam,\#imm16 | 4+ | 4+(a) | 0 | (c) | word (eam) $\leftarrow$ imm16 | - | - | - | - | - | - | - | - | - | - |
| MOVW @AL,AH / MOVW @A,T | 2 | 3 | 0 | (c) | word $((\mathrm{A})) \leftarrow(\mathrm{AH})$ | - | - | - | - | - | * | * | - | - | - |
| XCHW A,ear | 2 | 4 | 2 | 0 | word (A) $\leftarrow \rightarrow$ (ear) | - | - | - | - | - | - | - | - | - | - |
| XCHW A,eam | 2+ | 5+(a) | 0 | $2 \times$ (c) | word $(A) \longleftrightarrow$ (eam) | - | - | - | - | - | - | - | - | - | - |
| XCHW RWi,ear | 2 | 7 | 4 | 0 | word (RWi) $\longleftrightarrow \rightarrow$ (ear) | - | - | - | - | - | - | - | - | - | - |
| XCHW RWi,eam | 2+ | 9+(a) | 2 | $2 \times(\mathrm{c})$ | word (RWi) $\hookleftarrow \rightarrow$ (eam) | - | - | - | - | - | - | - | - | - | - |
| MOVL A,ear | 2 | 4 | 2 | 0 | long $(A) \leftarrow$ (ear) | - | - | - | - | - | * | * | - | - | - |
| MOVL A,eam | 2+ | 5+(a) | 0 | (d) | long $($ A $) \leftarrow$ (eam) | - | - | - | - | - | * | * | - | - | - |
| MOVL A,\#imm32 | 5 | 3 | 0 | 0 | long $(A) \leftarrow$ imm32 | - | - | - | - | - | * | * | - | - | - |
| MOVL ear,A | 2 | 4 | 2 | 0 | long (ear1) $\leftarrow(A)$ | - | - | - | - | - | * | * | - | - | - |
| MOVL eam,A | 2+ | 5+(a) | 0 | (d) | long (eam1) $\leftarrow(A)$ | - | - | - | - | - | * | * | - | - | - |

Note: For an explanation of "(a)" to "(d)" in the colunm "B", see Table B.2d and Table B.2e.

Table B.2.1c Addition and Subtraction Instructions (Byte/Word/Long-Word) (42 Instructions)

| Mnemonic |  | \# | $\sim$ | RG | B | Operation | LH | AH | I | S | T | N | Z | V | C | RMW |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADD | A,\#imm8 | 2 | 2 | 0 | 0 | byte $(\mathrm{A}) \leftarrow(\mathrm{A})+$ imm8 | Z | - | - | - | - | * | * | * | * | - |
| ADD | A, dir | 2 | 5 | 0 | (b) | byte $(A) \leftarrow(A)+$ (dir $)$ | Z | - | - | - | - | * | * | * | * | - |
| ADD | A,ear | 2 | 3 | 1 | 0 | byte $(A) \leftarrow(A)+$ (ear) | Z | - | - | - | - | * | * | * | * | - |
| ADD | A,eam | 2+ | 4+(a) | 0 | (b) | byte $(A) \leftarrow(A)+($ eam $)$ | Z | - | - | - | - | * | * | * | * | - |
| ADD | ear,A | 2 | 3 | 2 | 0 | byte (ear) $\leftarrow($ ear $)+(\mathrm{A})$ | - | - | - | - | - | * | * | * | * | - |
| ADD | eam,A | 2+ | 5+(a) | 0 | $2 \times(\mathrm{b})$ | byte $($ eam $) \leftarrow($ eam $)+(\mathrm{A})$ | Z | - | - | - | - | * | * | * | * | * |
| ADDC | A | 1 | 2 | 0 | 0 | byte $(A) \leftarrow(A H)+(A L)+(C)$ | Z | - | - | - | - | * | * | * | * | - |
| ADDC | A,ear | 2 | 3 | 1 | 0 | byte $(\mathrm{A}) \leftarrow(\mathrm{A})+($ ear $)+(\mathrm{C})$ | Z | - | - | - | - | * | * | * | * | - |
| ADDC | A, eam | 2+ | 4+(a) | 0 | (b) | byte $(A) \leftarrow(A)+($ eam $)+(C)$ | Z | - | - | - | - | * | * | * | * | - |
| ADDDC | A | 1 | 3 | 0 | 0 | byte $(A) \leftarrow(A H)+(A L)+(C)$ <br> (hexadecimal) | Z | - | - | - | - | * | * | * | * | - |
| SUB | A,\#imm8 | 2 | 2 | 0 | 0 | byte $(A) \leftarrow(A)$ - imm8 | Z | - | - | - | - | * | * | * | * | - |
| SUB | A,dir | 2 | 5 | 0 | (b) | byte $(A) \leftarrow(A)-$ (dir) | Z | - | - | - | - | * | * | * | * | - |
| SUB | A, ear | 2 | 3 | 1 | 0 | byte $(\mathrm{A}) \leftarrow(\mathrm{A})$ - (ear) | Z | - | - | - | - | * | * | * | * | - |
| SUB | A,eam | 2+ | 4+(a) | 0 | (b) | byte $(A) \leftarrow(A)-($ eam $)$ | Z | - | - | - | - | * | * | * | * | - |
| SUB | ear,A | 2 | 3 | 2 | 0 | byte (ear) $\leftarrow$ (ear) - (A) | - | - | - | - | - | * | * | * | * | - |
| SUB | eam,A | 2+ | 5+(a) | 0 | $2 \times(\mathrm{b})$ | byte (eam) $\leftarrow$ (eam) - (A) | - | - | - | - | - | * | * | * | * | * |
| SUBC | A | 1 | 2 | 0 | 0 | byte $(A) \leftarrow(A H)-(A L)-(C)$ | Z | - | - | - | - | * | * | * | * | - |
| SUBC | A, ear | 2 | 3 | 1 | 0 | byte $(A) \leftarrow(A)-($ ear $)-(C)$ | Z | - | - | - | - | * | * | * | * | - |
| SUBC | A, eam | 2+ | 4+(a) | 0 | (b) | byte $(A) \leftarrow(A)-($ eam $)-(C)$ | Z | - | - | - | - | * | * | * | * | - |
| SUBDC | A | 1 | 3 | 0 | 0 | byte $(A) \leftarrow(A H)-(A L)-(C)$ (hexadecimal) | Z | - | - | - | - | * | * | * | * | - |
| ADDW | A | 1 | 2 | 0 | 0 | word $(A) \leftarrow(A H)+(A L)$ | - | - | - | - | - | * | * | * | * | - |
| ADDW | A, ear | 2 | 3 | 1 | 0 | word $(A) \leftarrow(A)+$ (ear) | - | - | - | - | - | * | * | * | * | - |
| ADDW | A, eam | 2+ | 4+(a) | 0 | (c) | word $(A) \leftarrow(A)+$ (eam) | - | - | - | - | - | * | * | * | * | - |
| ADDW | A,\#imm16 | 3 | 2 | 0 | 0 | word $(A) \leftarrow(A)+$ imm16 | - | - | - | - | - | * | * | * | * | - |
| ADDW | ear,A | 2 | 3 | 2 | 0 | word (ear) $\leftarrow$ (ear) + (A) | - | - | - | - | - | * | * | * | * | - |
| ADDW | eam,A | 2+ | 5+(a) | 0 | $2 \times$ (c) | word (eam) $\leftarrow($ eam $)+(\mathrm{A})$ | - | - | - | - | - | * | * | * | * | * |
| ADDCW | A,ear | 2 | 3 | 1 | 0 | word $(A) \leftarrow(A)+($ ear $)+(C)$ | - | - | - | - | - | * | * | * | * | - |
| ADDCW | A, eam | 2+ | 4+(a) | 0 | (c) | word $(A) \leftarrow(A)+($ eam $)+(C)$ | - | - | - | - | - | * | * | * | * | - |
| SUBW | A | 1 | 2 | 0 | 0 | word $(A) \leftarrow(A H)-(A L)$ | - | - | - | - | - | * | * | * | * | - |
| SUBW | A,ear | 2 | 3 | 1 | 0 | word $(A) \leftarrow(A)$ - (ear) | - | - | - | - | - | * | * | * | * | - |
| SUBW | A, eam | 2+ | 4+(a) | 0 | (c) | word $(A) \leftarrow(A)-($ eam $)$ | - | - | - | - | - | * | * | * | * | - |
| SUBW | A,\#imm16 | 3 | 2 | 0 | 0 | word $(A) \leftarrow(A)$ - imm16 | - | - | - | - | - | * | * | * | * | - |
| SUBW | ear,A | 2 | 3 | 2 | 0 | word (ear) $\leftarrow$ (ear) - (A) | - | - | - | - | - | * | * | * | * | - |
| SUBW | eam,A | 2+ | 5+(a) | 0 | $2 \times$ (c) | word (eam) $\leftarrow($ eam) - (A) | - | - | - | - | - | * | * | * | * | * |
| SUBCW | A,ear | 2 | 3 | 1 | 0 | word $(A) \leftarrow(A)-($ ear $)-(C)$ | - | - | - | - | - | * | * | * | * | - |
| SUBCW | A,eam | 2+ | 4+(a) | 0 | (c) | word $(A) \leftarrow(A)-($ eam $)-(C)$ | - | - | - | - | - | * | * | * | * | - |
| ADDL | A, ear | 2 | 6 | 2 | 0 | long $(A) \leftarrow(A)+$ (ear) | - | - | - | - | - | * | * | * | * | - |
| ADDL | A,eam | 2+ | 7+(a) | 0 | (d) | long $(A) \leftarrow(A)+($ eam $)$ | - | - | - | - | - | * | * | * | * | - |
| ADDL | A,\#imm32 | 5 | 4 | 0 | 0 | long $(A) \leftarrow(A)+$ imm32 | - | - | - | - | - | * | * | * | * | - |
| SUBL | A,ear | 2 | 6 | 2 | 0 | long $(A) \leftarrow(A)-$ (ear) | - | - | - | - | - | * | * | * | * | - |
| SUBL | A, eam | 2+ | 7+(a) | 0 | (d) | long $(A) \leftarrow(A)-$ (eam $)$ | - | - | - | - | - | * | * | * | * | - |
| SUBL | A,\#imm32 | 5 | 4 | 0 | 0 | long $(A) \leftarrow(A)$ - imm32 | - | - | - | - | - | * | * | * | * | - |

Note: For an explanation of "(a)" to "(d)" in the colunm "B", see Table B.2d and Table B.2e.

Table B.2.1d Increment and Decrement Instructions (Byte/Word/Long-Word) (12 Instructions)

| Mnemonic |  | \# | $\sim$ | RG | B | Operation | LH | AH | I | S | T | N | Z | V | C | RMW |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INC | ear | 2 | 3 | 2 | 0 | byte (ear) $\leftarrow$ (ear) +1 | - | - | - | - | - | * | * | * | - | - |
| INC | eam | 2+ | 5+(a) | 0 | $2 \times(\mathrm{b})$ | byte $($ eam $) \leftarrow($ eam $)+1$ | - | - | - | - | - | * | * | * | - | * |
| DEC | ear | 2 | 3 | 2 | 0 | byte (ear) $\leftarrow$ (ear) - 1 | - | - | - | - | - | * | * | * | - | - |
| DEC | eam | 2+ | 5+(a) | 0 | $2 \times(\mathrm{b})$ | byte $($ eam $) \leftarrow($ eam $)-1$ | - | - | - | - | - | * | * | * | - | * |
| INCW | ear | 2 | 3 | 2 | 0 | word (ear) $\leftarrow$ (ear) +1 | - | - | - | - | - | * | * | * | - | - |
| INCW | eam | 2+ | 5+(a) | 0 | $2 \times$ (c) | word $($ eam $) \leftarrow($ eam $)+1$ | - | - | - | - | - | * | * | * | - | * |
| DECW | ear | 2 | 3 | 2 | 0 | word (ear) $\leftarrow$ (ear) - 1 | - | - | - | - | - | * | * | * | - | - |
| DECW | eam | 2+ | 5+(a) | 0 | $2 \times$ (c) | word (eam) $\leftarrow$ (eam) - 1 | - | - | - | - | - | * | * | * | - | * |
| INCL | ear | 2 | 7 | 4 | 0 | long (ear) $\leftarrow$ (ear) +1 | - | - | - | - | - | * | * | * | - | - |
| INCL | eam | 2+ | 9+(a) | 0 | $2 \times(\mathrm{d})$ | long (eam) $\leftarrow($ eam $)+1$ | - | - | - | - | - | * | * | * | - | * |
| DECL | ear | 2 | 7 | 4 | 0 | long (ear) $\leftarrow$ (ear) - 1 | - | - | - | - | - | * | * | * | - | - |
| DECL | eam | 2+ | 9+(a) | 0 | $2 \times(\mathrm{d})$ | long (eam) $\leftarrow($ eam ) - 1 | - | - | - | - | - | * | * | * | - | * |

Table B.2.1e Compare Instructions (Byte/Word/Long-Word) (11 Instructions)

| Mnemonic |  | \# | $\sim$ | RG | B | Operation | LH | AH | I | S | T | N | Z | V | C | RMW |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CMP | A | 1 | 1 | 0 | 0 | byte (AH) - (AL) | - | - | - | - | - | * | * | * | * | - |
| CMP | A, ear | 2 | 2 | 1 | 0 | byte (A) - (ear) | - | - | - | - | - | * | * | * | * | - |
| CMP | A, eam | 2+ | $3+(\mathrm{a})$ | 0 | (b) | byte (A) - (eam) | - | - | - | - | - | * | * | * | * | - |
| CMP | A,\#imm8 | 2 | 2 | 0 | 0 | byte (A) - imm8 | - | - | - | - | - | * | * | * | * | - |
| CMPW | A | 1 | 1 | 0 | 0 | word (AH) - (AL) | - | - | - | - | - | * | * | * | * | - |
| CMPW | A, ear | 2 | 2 | 1 | 0 | word (A) - (ear) | - | - | - | - | - | * | * | * | * | - |
| CMPW | A,eam | 2+ | $3+(\mathrm{a})$ | 0 | (c) | word (A) - (eam) | - | - | - | - | - | * | * | * | * | - |
| CMPW | A,\#imm16 | 3 | 2 | 0 | 0 | word (A) - imm16 | - | - | - | - | - | * | * | * | * | - |
| CMPL | A, ear | 2 | 6 | 2 | 0 | long (A) - (ear) | - | - | - | - | - | * | * | * | * | - |
| CMPL | A, eam | 2+ | 7+(a) | 0 | (d) | long (A) - (eam) | - | - | - | - | - | * | * | * | * | - |
| CMPL | A,\#imm32 | 5 | 3 | 0 | 0 | long (A) - imm32 | - | - | - | - | - | * | * | * | * | - |

Note: For an explanation of "(a)" to "(d)" in the colunm "B", see Table B.2d and Table B.2e.

Table B.2.1f Unsigned Multiplication and Division Instructions (Word/Long-Word) (11 Instructions)

| Mnemonic |  | \# | $\sim$ | RG | B | Operation | LH | AH | 1 | S | T | N | Z | V | C | RMW |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DIVU | A | 1 | *1 | 0 | 0 | word (AH) / byte (AL) Quotient $\rightarrow$ byte (AL) | - | - | - | - | - | - | - | * | * |  |
| DIVU | A,ear | 2 | *2 | 1 | 0 | Remainder $\rightarrow$ byte (AH) word (A) / byte (ear) Quotient $\rightarrow$ byte (A) | - | - | - | - | - | - | - | * | * | - |
| DIVU | A,eam | 2+ | *3 | 0 | *6 | Remainder $\rightarrow$ byte (ear) word (A) / byte (eam) Quotient $\rightarrow$ byte (A) Remainder $\rightarrow$ byte (ear) | - | - | - | - | - | - | - | * | * | - |
| DIVUW | A,ear | 2 | *4 | 1 | 0 | long (A) / word (ear) <br> Quotient $\rightarrow$ word (A) <br> Remainder $\rightarrow$ word (ear) | - | - | - | - | - | - | - | * | * | - |
| DIVUW | A,eam | 2+ | *5 | 0 | *7 | long (A) / word (eam) Quotient $\rightarrow$ word (A) Remainder $\rightarrow$ word (eam) | - | - | - | - | - | - | - | * | * | - |
| MULU | A | 1 | *8 | 0 | 0 | byte (AH) * byte (AL) $\rightarrow$ word (A) | - | - | - | - | - | - | - | - | - | - |
| MULU | A,ear | 2 | *9 | 1 | 0 | byte (A) * byte (ear) $\rightarrow$ word (A) | - | - | - | - | - | - | - | - | - | - |
| MULU | A,eam | 2+ | *10 | 0 | (b) | byte (A) * byte (eam) $\rightarrow$ word (A) | - | - | - | - | - | - | - | - | - | - |
| MULUW | A | 1 | *11 | 0 | 0 | word (AH) * word (AL) $\rightarrow$ Long (A) | - | - | - | - | - | - | - | - | - | - |
| MULUW | A,ear | 2 | *12 | 1 | 0 | word (A) * word (ear) $\rightarrow$ Long (A) | - | - | - | - | - | - | - | - | - | - |
| MULUW | A,eam | 2+ | *13 | 0 | (c) | word (A) * word (eam) $\rightarrow$ Long (A) | - | - | - | - | - | - | - | - | - | - |

*1: 3 when dividing into zero, 7 when an overflow occurs, and 15 normally.
*2: 4 when dividing into zero, 8 when an overflow occurs, and 16 normally.
*3: $6+(a)$ when dividing into zero, $9+$ (a) when an overflow occurs, and $19+$ (a) normally.
*4: 4 when dividing into zero, 7 when an overflow occurs, and 22 normally.
*5: $6+(a)$ when dividing into zero, $8+$ (a) when an overflow occurs, and $26+(a)$ normally.
*6: (b) when dividing into zero or when an overflow occurs, and $2 \times$ (b) normally.
*7: (c) when dividing into zero or when an overflow occurs, and $2 \times$ (c) normally.
*8: $\quad 3$ when byte (AH) is zero, and 7 when byte (AH) is not 0 .
*9: $\quad 4$ when byte (ear) is zero, and 8 when byte (ear) is not 0 .
*10: $5+(\mathrm{a})$ when byte (eam) is zero, and $9+(\mathrm{a})$ when byte (eam) is not 0 .
*11: 3 when word ( AH ) is zero, and 11 when word ( AH ) is not 0 .
*12: 4 when word (ear) is zero, and 12 when word (ear) is not 0 .
*13: $5+(\mathrm{a})$ when word (eam) is zero, and $13+$ (a) when word (eam) is not 0 .
Note: For an explanation of "(a)" to "(d)" in the colunm "B", see Table B.2d and Table B.2e.

Table B.2.1g Signed Multiplication and Division Instructions (Word/Long-Word) (11 Instructions)

| Mne | onic | \# | $\sim$ | RG | B | Operation | LH | AH | I | S | T | N | Z | V | C | RMW |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DIV | A | 1 | *1 | 0 | 0 | word (AH) / byte (AL) <br> Quotient $\rightarrow$ byte (AL) <br> Remainder $\rightarrow$ byte (AH) | Z | - | - | - | - | - | - | * | * | - |
| DIV | A, ear | 2 | *2 | 1 | 0 | word (A) / byte (ear) <br> Quotient $\rightarrow$ byte (A) <br> Remainder $\rightarrow$ byte (ear) | Z | - | - | - | - | - | - | * | * | - |
| DIV | A, eam | 2+ | *3 | 0 | *6 | word (A) / byte (eam) <br> Quotient $\rightarrow$ byte (A) <br> Remainder $\rightarrow$ byte (ear) | Z | - | - | - | - | - | - | * | * | - |
| DIVW | A, ear | 2 | *4 | 1 | 0 | long (A) / word (ear) <br> Quotient $\rightarrow$ word (A) <br> Remainder $\rightarrow$ word (ear) | - | - | - | - | - | - | - | * | * | - |
| DIVW | A,eam | 2+ | *5 | 0 | *7 | long (A) / word (eam) <br> Quotient $\rightarrow$ word (A) Remainder $\rightarrow$ word (eam) | - | - | - | - | - | - | - | * | * | - |
| MUL | A | 2 | *8 | 0 | 0 | byte (AH) * byte (AL) $\rightarrow$ word (A) | - | - | - | - | - | - | - | - | - | - |
| MUL | A, ear | 2 | *9 | 1 | 0 | byte (A) * byte (ear) $\rightarrow$ word (A) | - | - | - | - | - | - | - | - | - | - |
| MUL | A, eam | 2+ | *10 | 0 | (b) | byte (A) * byte (eam) $\rightarrow$ word (A) | - | - | - | - | - | - | - | - | - | - |
| MULW | A | 2 | *11 | 0 | 0 | word (AH) * word (AL) $\rightarrow$ Long (A) | - | - | - | - | - | - | - | - | - | - |
| MULW | A, ear | 2 | *12 | 1 | 0 | word (A) * word (ear) $\rightarrow$ Long (A) | - | - | - | - | - | - | - | - | - | - |
| MULW | A, eam | 2+ | *13 | 0 | (c) | word (A) * word (eam) $\rightarrow$ Long (A) | - | - | - | - | - | - | - | - | - | - |

*1: 3 when dividing into zero, 8 or 18 when an overflow occurs, and 18 normally.
*2: 3 when dividing into zero, 10 or 21 when an overflow occurs, and 22 normally.
*3: $\quad 4+(a)$ when dividing into zero, $11+(a)$ or $22+(a)$ when an overflow occurs, and $23+(a)$ normally.
*4: When dividend is positive: 4 when dividing into zero, 10 or 29 when an overflow occurs, and 30 normally.
When dividend is negative: 4 when dividing into zero, 11 or 30 when an overflow occurs, and 31 normally.
*5: When dividend is positive: $4+$ (a) when dividing into zero, $11+$ (a) or $30+(a)$ when an overflow occurs, and 31+ (a) normally.
When dividend is negative: 4+ (a) when dividing into zero, 12+ (a) or 31+ (a) when an overflow occurs, and 32+ (a) normally.
*6: (b) when dividing into zero or when an overflow occurs, and $2 \times$ (b) normally.
*7: (c) when dividing into zero or when an overflow occurs, and $2 \times$ (c) normally.
*8: $\quad 3$ when byte (AH) is zero, 12 when the result is possible, and 13 when the result is negative.
*9: $\quad 3$ when byte (ear) is zero, 12 when the result is possible, and 13 when the result is negative.
*10: $4+(a)$ when byte (eam) is zero, $13+(a)$ when the result is positive, and $14+(a)$ when the result is negative.
*11: 3 when word (AH) is zero, 12 when the result is possible, and 13 when the result is negative.
*12: 3 when word (ear) is zero, 16 when the result is possible, and 19 when the result is negative.
*13: $4+(a)$ when word (eam) is zero, $17+(a)$ when the result is positive, and $20+(a)$ when the result is negative.
Note: Two cycle counts are given for overflows occurring from DIV or DIVW instructions, because the overflow may be detected before or after execution.
The contents of AL are destroyed when an overflow occurs from a DIV or DIVW instruction.
For an explanation of "(a)" to "(d)" in the colunm "B", see Table B.2d and Table B.2e.

Table B.2.1h Logical 1 Instructions (Byte/Word) (39 Instructions)

| Mnemonic |  | \# | $\sim$ | RG | B | Operation | LH | AH | 1 | S | T | N | Z | V | C | RMW |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AND | A,\#imm8 | 2 | 2 | 0 | 0 | byte $(\mathrm{A}) \leftarrow(\mathrm{A})$ and imm8 | - | - | - | - | - | * | * | R | - | - |
| AND | A, ear | 2 | 3 | 1 | 0 | byte $(A) \leftarrow(A)$ and (ear) | - | - | - | - | - | * | * | R | - | - |
| AND | A,eam | 2+ | 4+(a) | 0 | (b) | byte $(A) \leftarrow(A)$ and (eam) | - | - | - | - | - | * | * | R | - | - |
| AND | ear,A | 2 | 3 | 2 | 0 | byte (ear) $\leftarrow$ (ear) and (A) | - | - | - | - | - | * | * | R | - | - |
| AND | eam,A | 2+ | 5+(a) | 0 | $2 \times(\mathrm{b})$ | byte $($ eam $) \leftarrow$ (eam) and $(\mathrm{A})$ | - | - | - | - | - | * | * | R | - | * |
| OR | A,\#imm8 | 2 | 2 | 0 | 0 | byte $(A) \leftarrow(A)$ or imm8 | - | - | - | - | - | * | * | R | - | - |
| OR | A,ear | 2 | 3 | 1 | 0 | byte $(A) \leftarrow(A)$ or (ear) | - | - | - | - | - | * | * | R | - | - |
| OR | A, eam | 2+ | 4+(a) | 0 | (b) | byte $(A) \leftarrow(A)$ or (eam) | - | - | - | - | - | * | * | R | - | - |
| OR | ear,A | 2 | 3 | 2 | 0 | byte (ear) $\leftarrow$ (ear) or (A) | - | - | - | - | - | * | * | R | - | - |
| OR | eam,A | 2+ | 5+(a) | 0 | $2 \times$ (b) | byte $($ eam $) \leftarrow$ (eam) or $($ A | - | - | - | - | - | * | * | R | - | * |
| XOR | A,\#imm8 | 2 | 2 | 0 | 0 | byte $(A) \leftarrow(A)$ xor imm8 | - | - | - | - | - | * | * | R | - | - |
| XOR | A,ear | 2 | 3 | 1 | 0 | byte $(A) \leftarrow(A)$ xor (ear) | - | - | - | - | - | * | * | R | - | - |
| XOR | A,eam | 2+ | 4+(a) | 0 | (b) | byte $(\mathrm{A}) \leftarrow$ (A) xor (eam) | - | - | - | - | - | * | * | R | - | - |
| XOR | ear,A | 2 | 3 | 2 | 0 | byte (ear) $\leftarrow$ (ear) xor (A) | - | - | - | - | - | * | * | R | - | - |
| XOR | eam,A | 2+ | 5+(a) | 0 | $2 \times(\mathrm{b})$ | byte (eam) $\leftarrow$ (eam) xor (A) | - | - | - | - | - | * | * | R | - | * |
| NOT | A | 1 | 2 | 0 | 0 | byte $(\mathrm{A}) \leftarrow \operatorname{not}(\mathrm{A})$ | - | - | - | - | - | * | * | R | - | - |
| NOT | ear | 2 | 3 | 2 | 0 | byte (ear) $\leftarrow$ not (ear) | - | - | - | - | - | * | * | R | - | - |
| NOT | eam | 2+ | 5+(a) | 0 | $2 \times(\mathrm{b})$ | byte (eam) $\leftarrow$ not (eam) | - | - | - | - | - | * | * | R | - | * |
| ANDW | A | 1 | 2 | 0 | 0 | word $(A) \leftarrow(A H)$ and $(A)$ | - | - | - | - | - | * | * | R | - | - |
| ANDW | A,\#imm16 | 3 | 2 | 0 | 0 | word $(A) \leftarrow(A)$ and imm16 | - | - | - | - | - | * | * | R | - | - |
| ANDW | A, ear | 2 | 3 | 1 | 0 | word $(A) \leftarrow(A)$ and (ear) | - | - | - | - | - | * | * | R | - | - |
| ANDW | A,eam | 2+ | 4+(a) | 0 | (c) | word $(A) \leftarrow(A)$ and (eam) | - | - | - | - | - | * | * | R | - | - |
| ANDW | ear,A | 2 | 3 | 2 | 0 | word (ear) $\leftarrow$ (ear) and (A) | - | - | - | - | - | * | * | R | - | - |
| ANDW | eam, A | 2+ | 5+(a) | 0 | $2 \times$ (c) | word $($ eam $) \leftarrow($ eam $)$ and $(A)$ | - | - | - | - | - | * | * | R | - | * |
| ORW | A | 1 | 2 | 0 | 0 | word $(A) \leftarrow(A H)$ or $(A)$ | - | - | - | - | - | * | * | R | - | - |
| ORW | A,\#imm16 | 3 | 2 | 0 | 0 | word $(A) \leftarrow(A)$ or imm16 | - | - | - | - | - | * | * | R | - | - |
| ORW | A, ear | 2 | 3 | 1 | 0 | word $(A) \leftarrow(A)$ or (ear) | - | - | - | - | - | * | * | R | - | - |
| ORW | A,eam | 2+ | 4+(a) | 0 | (c) | word $(A) \leftarrow(A)$ or (eam) | - | - | - | - | - | * | * | R | - | - |
| ORW | ear,A | 2 | 3 | 2 | 0 | word (ear) $\leftarrow$ (ear) or (A) | - | - | - | - | - | * | * | R | - | - |
| ORW | eam,A | 2+ | 5+(a) | 0 | $2 \times$ (c) | word $($ eam $) \leftarrow($ eam $)$ or $(A)$ | - | - | - | - | - | * | * | R | - | * |
| XORW | A | 1 | 2 | 0 | 0 | word $(A) \leftarrow(A H)$ xor $(A)$ | - | - | - | - | - | * | * | R | - | - |
| XORW | A,\#imm16 | 3 | 2 | 0 | 0 | word $(A) \leftarrow(A)$ xor imm16 | - | - | - | - | - | * | * | R | - | - |
| XORW | A, ear | 2 | 3 | 1 | 0 | word $(A) \leftarrow(A)$ xor (ear) | - | - | - | - | - | * | * | R | - | - |
| XORW | A,eam | 2+ | 4+(a) | 0 | (c) | word $(A) \leftarrow(A)$ xor (eam) | - | - | - | - | - | * | * | R | - | - |
| XORW | ear,A | 2 | 3 | 2 | 0 | word (ear) $\leftarrow$ (ear) xor (A) | - | - | - | - | - | * | * | R | - | - |
| XORW | eam,A | 2+ | 5+(a) | 0 | $2 \times$ (c) | word (eam) $\leftarrow$ (eam) xor $(A)$ | - | - | - | - | - | * | * | R | - | * |
| NOTW | A | 1 | 2 | 0 | 0 | word $(\mathrm{A}) \leftarrow \operatorname{not}(\mathrm{A})$ | - | - | - | - | - | * | * | R | - | - |
| NOTW | ear | 2 | 3 | 2 | 0 | word (ear) $\leftarrow$ not (ear) | - | - | - | - | - | * | * | R | - | - |
| NOTW | eam | 2+ | 5+(a) | 0 | $2 \times$ (c) | word $($ eam $) \leftarrow$ not (eam) | - | - | - | - | - | * | * | R | - | * |

Note: For an explanation of "(a)" to "(d)" in the colunm "B", see Table B.2d and Table B.2e.

Table B.2.1i Logical 2 Instructions (Long-Word) (6 Instructions)

| Mnemonic |  | \# | ~ | RG | B | Operation | LH | AH | I | S | T | N | z | V | C | RMW |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ANDL | A,ear | 2 | 6 | 2 | 0 | long $(\mathrm{A}) \leftarrow(\mathrm{A})$ and (ear) | - | - | - | - | - | * | * | R | - | - |
| ANDL | A,eam | $2+$ | 7+(a) | 0 | (d) | long $(A) \leftarrow(A)$ and (eam) | - | - | - | - | - | * | * | R | - | - |
| ORL | A,ear | 2 | 6 | 2 | 0 | long $(A) \leftarrow(A)$ or (ear) | - | - | - | - | - | * | * | R | - | - |
| ORL | A,eam | $2+$ | 7+(a) | 0 | (d) | long $(\mathrm{A}) \leftarrow(\mathrm{A})$ or (eam) | - | - | - | - | - | * | * | R | - | - |
| XORL | A,ear | 2 | 6 | 2 | 0 | long (A) $\leftarrow$ (A) xor (ear) | - | - | - | - | - | * | * | R | - | - |
| XORL | A,eam | $2+$ | 7+(a) | 0 | (d) | long $(A) \leftarrow(A)$ xor (eam) | - | - | - | - | - | * | * | R | - | - |

Table B.2.1j Sign Inversion Instructions (Byte/Word) (6 Instructions)

| Mnemonic |  | \# | $\sim$ | RG | B | Operation | LH | AH | I | S | T | N | Z | V | C | RMW |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| NEG | A | 1 | 2 | 0 | 0 | byte $(\mathrm{A}) \leftarrow 0-(\mathrm{A})$ | X | - | - | - | - | * | * | * | * | - |
| NEG | ear | 2 | 3 | 2 | 0 | byte (ear) $\leftarrow 0-$ (ear) | - | - | - | - | - | * | * | * | * | - |
| NEG | eam | 2+ | 5+(a) | 0 | 2+(b) | byte $($ eam $) \leftarrow 0-($ eam $)$ | - | - | - | - | - | * | * | * | * | * |
| NEGW | A | 1 | 2 | 0 | 0 | word $(\mathrm{A}) \leftarrow 0-(\mathrm{A})$ | - | - | - | - | - | * | * | * | * | - |
| NEGW | ear | 2 | 2 | 2 | 0 | word (ear) $\leftarrow 0-$ (ear) | - | - | - | - | - | * | * | * | * | - |
| NEGW | eam | 2+ | 5+(a) | 0 | 2+(c) | word (eam) $\leftarrow 0-$ (eam) | - | - | - | - | - | * | * | * | * | * |

Table B.2.1k Normalize Instruction (Long-Word) (1 Instruction)

| Mnemonic | $\#$ | $\sim$ | RG | B | Operation | LH | AH | I | S | T | N | Z | V | C | RMW |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| NRML A,R0 | 2 | $* 1$ | 1 | 0 | long (A) $\leftarrow$ Shift to the <br> position where 1 was <br> formerly placed <br> byte (R0) $\leftarrow$ Number of shifts <br> at that time | - | - | - | - | - | - | $*$ | - | - | - |

*1: 4 when the contents of the accumulator are all zeroes, $6+(\mathrm{RO})$ in all other cases.
Note: For an explanation of "(a)" to "(d)" in the colunm "B", see Table B.2d and Table B.2e.

Table B.2.1I Shift Instructions (Byte/Word/Long-Word) (18 Instructions)

| Mnemonic |  | \# | ~ | RG | B | Operation | LH | AH | I | S | T | N | Z | v | C | RMW |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RORC | A | 2 | 2 | 0 | 0 | byte (A) $\leftarrow$ Right rotate with carry | - | - | - | - | - | * | * | - | * | - |
| ROLC | A | 2 | 2 | 0 | 0 | byte (A) $\leftarrow$ Left rotate with carry | - | - | - | - | - | * | * | - | * | - |
| RORC | ear | 2 | 3 | 2 | 0 | byte (ear) $\leftarrow$ Right rotate with carry | - | - | - | - | - | * | * | - | * | - |
| RORC | eam | $2+$ | 5+(a) | 0 | $2 \times$ (b) | byte (eam) $\leftarrow$ Right rotate with carry | - | - | - | - | - | * | * | - | * | * |
| ROLC | ear | 2 | 3 | 2 | 0 | byte (ear) $\leftarrow$ Left rotate with carry | - | - | - | - | - | * | * | - | * | - |
| ROLC | eam | $2+$ | 5+(a) | 0 | $2 \times$ (b) | byte (eam) $\leftarrow$ Left rotate with carry | - | - | - | - | - | * | * | - | * | * |
| ASR | A,RO | 2 | *1 | 1 | 0 | byte $(A) \leftarrow$ Arithmetic right barrel shift (A,R0) | - | - | - | - | * | * | * | - | * | - |
| LSR | A,RO | 2 | ${ }^{*} 1$ | 1 | 0 | byte (A) $\leftarrow$ Logical right barrel shift ( $\mathrm{A}, \mathrm{RO}$ ) | - | - | - | - | * | * | * | - | * | - |
| LSL | A, RO | 2 | *1 | 1 | 0 | byte (A) $\leftarrow$ Logical left barrel shift (A,RO) | - | - | - | - | - | * | * | - | * | - |
| ASRW | A | 1 | 2 | 0 | 0 | word (A) $\leftarrow$ Arithmetic right shift (A,1 bit) | - | - | - | - | * | * | * | - | * | - |
| LSRW | A /SHRW A | 1 | 2 | 0 | 0 | word (A) $\leftarrow$ Logical right shift ( $\mathrm{A}, 1$ bit) | - | - | - | - | * | R | * | - | * | - |
| LSLW | A /SHLW A | 1 | 2 | 0 | 0 | word (A) $\leftarrow$ Logical left shift (A, 1 bit) | - | - | - | - | - | * | * | - | * | - |
| ASRW | A,R0 | 2 | *1 | 1 | 0 | word $(A) \leftarrow$ Arithmetic right barrel shift ( $\mathrm{A}, \mathrm{RO}$ ) | - | - | - | - | * | * | * | - | * | - |
| LSRW | A,R0 | 2 | *1 | 1 | 0 | word (A) $\leftarrow$ Logical right barrel shift ( $\mathrm{A}, \mathrm{RO}$ ) | - | - | - | - | * | * | * | - | * | - |
| LSLW | A, RO | 2 | *1 | 1 | 0 | word (A) $\leftarrow$ Logical left barrel shift ( $\mathrm{A}, \mathrm{RO}$ ) | - | - | - | - | - | * | * | - | * | - |
| ASRL | A,R0 | 2 | *2 | 1 | 0 | long (A) $\leftarrow$ Arithmetic right barrel shift (A,R0) | - | - | - | - | * | * | * | - | * | - |
| LSRL | A,R0 | 2 | *2 | 1 | 0 | long (A) $\leftarrow$ Logical right barrel shift (A,RO) | - | - | - | - | * | * | * | - | * | - |
| LSLL | A,RO | 2 | *2 | 1 | 0 | long $(A) \leftarrow$ Logical left barrel shift ( $A, R 0$ ) | - | - | - | - | - | * | * | - | * | - |

*1: 6 when R0 is $0,5+(R 0)$ in all other cases.
*2: $\quad 6$ when $R 0$ is $0,6+(R 0)$ in all other cases.
Note: For an explanation of "(a)" to "(d)" in the colunm "B", see Table B.2d and Table B.2e.

Table B.2.1m Branch 1 Instructions (31 Instructions)

| Mnem | onic | \# | $\sim$ | RG | B | Operation | LH | AH | I | S | T | N | Z | V | C | RMW |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BZ / BEQ |  | 2 | *1 | 0 | 0 | Branch when $(Z)=1$ | - | - | - | - | - | - | - | - | - | - |
| BNZ / BNE |  | 2 | *1 | 0 | 0 | Branch when $(Z)=0$ | - | - | - | - | - | - | - | - | - | - |
| BC / BLO |  | 2 | *1 | 0 | 0 | Branch when (C) = 1 | - | - | - | - | - | - | - | - | - | - |
| BNC / BHS |  | 2 | *1 | 0 | 0 | Branch when (C) $=0$ | - | - | - | - | - | - | - | - | - | - |
| BN | rel | 2 | *1 | 0 | 0 | Branch when (N) = 1 | - | - | - | - | - | - | - | - | - | - |
| BP | rel | 2 | *1 | 0 | 0 | Branch when (N) = 0 | - | - | - | - | - | - | - | - | - | - |
| BV | rel | 2 | *1 | 0 | 0 | Branch when (V) = 1 | - | - | - | - | - | - | - | - | - | - |
| BNV | rel | 2 | *1 | 0 | 0 | Branch when (V) $=0$ | - | - | - | - | - | - | - | - | - | - |
| BT | rel | 2 | *1 | 0 | 0 | Branch when $(T)=1$ | - | - | - | - | - | - | - | - | - | - |
| BNT | rel | 2 | *1 | 0 | 0 | Branch when ( T ) $=0$ | - | - | - | - | - | - | - | - | - | - |
| BLT | rel | 2 | *1 | 0 | 0 | Branch when (V) xor ( N ) $=1$ | - | - | - | - | - | - | - | - | - | - |
| BGE | rel | 2 | *1 | 0 | 0 | Branch when (V) xor ( N ) $=0$ | - | - | - | - | - | - | - | - | - | - |
| BLE | rel | 2 | *1 | 0 | 0 | Branch when ((V) xor (N)) or (Z) = 1 | - | - | - | - | - | - | - | - | - | - |
| BGT | rel | 2 | *1 | 0 | 0 | Branch when ((V) xor (N)) or $(\mathrm{Z})=0$ | - | - | - | - | - | - | - | - | - | - |
| BLS | rel | 2 | *1 | 0 | 0 | Branch when (C) or $(Z)=1$ | - | - | - | - | - | - | - | - | - | - |
| BHI | rel | 2 | *1 | 0 | 0 | Branch when (C) or (Z) =0 | - | - | - | - | - | - | - | - | - | - |
| BRA | rel | 2 | *1 | 0 | 0 | Unconditional branching | - | - | - | - | - | - | - | - | - | - |
| JMP | @A | 1 | 2 | 0 | 0 | word (PC) $\leftarrow(\mathrm{A})$ | - | - | - | - | - | - | - | - | - | - |
| JMP | addr16 | 3 | 3 | 0 | 0 | word $(\mathrm{PC}) \leftarrow$ addr16 | - | - | - | - | - | - | - | - | - | - |
| JMP | @ear | 2 | 3 | 1 | 0 | word (PC) $\leftarrow$ (ear) | - | - | - | - | - | - | - | - | - | - |
| JMP | @eam | 2+ | 4+(a) | 0 | (c) | word (PC) $\leftarrow$ (eam) | - | - | - | - | - | - | - | - | - | - |
| JMPP | @ear *1 | 2 | 5 | 2 | 0 | word $(\mathrm{PC}) \leftarrow(\mathrm{ear}),(\mathrm{PCB}) \leftarrow(\mathrm{ear}+2)$ | - | - | - | - | - | - | - | - | - | - |
| JMPP | @eam *1 | 2+ | 6+(a) | 0 | (d) | word $(\mathrm{PC}) \leftarrow(\mathrm{eam}),(\mathrm{PCB}) \leftarrow(\mathrm{eam}+2)$ | - | - | - | - | - | - | - | - | - | - |
| JMPP | addr24 | 4 | 4 | 0 | 0 | word $(\mathrm{PC}) \leftarrow \operatorname{ad} 24$ 0-15, (PCB) $\leftarrow$ ad24 16-23 | - | - | - | - | - | - | - | - | - | - |
| CALL | @ear *2 | 2 | 6 | 1 | (c) | word (PC) $\leftarrow$ (ear) | - | - | - | - | - | - | - | - | - | - |
| CALL | @eam *2 | 2+ | $7+(a)$ | 0 | $2 \times$ (c) | word (PC) $\leftarrow$ (eam) | - | - | - | - | - | - | - | - | - | - |
| CALL | addr16 *3 | 3 | 6 | 0 | (c) | word (PC) $\leftarrow$ addr16 | - | - | - | - | - | - | - | - | - | - |
| CALLV | \#vct4 *3 | 1 | 7 | 0 | $2 \times$ (c) | Vector call instruction | - | - | - | - | - | - | - | - | - | - |
| CALLP | @ear *4 | 2 | 10 | 2 | $2 \times$ (c) | word (PC) $\leftarrow$ (ear) 0-15, (PCB) $\leftarrow($ ear $) 16-23$ | - | - | - | - | - | - | - | - | - | - |
| CALLP | @eam *4 | 2+ | 11+(a) | 0 | *2 | $\begin{aligned} & \text { word }(P C) \leftarrow(\text { eam }) 0-15 \text {, } \\ & (P C B) \leftarrow(\text { eam }) 16-23 \end{aligned}$ | - | - | - | - | - | - | - | - | - | - |
| CALLP | addr24 *5 | 4 | 10 | 0 | $2 \times$ (c) | word $(\mathrm{PC}) \leftarrow$ addr0-15, $(\mathrm{PCB}) \leftarrow$ addr16-23 | - | - | - | - | - | - | - | - | - | - |

*1: 4 when branching, 3 when not branching.
*2: $\quad 3 \times(\mathrm{c})+(\mathrm{b})$
Note 1: Read (word) branch address.
Note 2: W: Save (word) into stack; R: read (word) branch address.
Note 3: Save (word) into stack.
Note 4: W: Save (long-word) into W stack; R: read (long-word) R branch address.
Note 5: Save (long-word) into stack.
Note: For an explanation of "(a)" to "(d)" in the colunm "B", see Table B.2d and Table B.2e.

Table B.2.1n Branch 2 Instructions (19 Instructions)

| Mnemonic |  | \# | $\sim$ | RG | B | Operation | LH | AH | I | S | T | N | Z | V | C | RMW |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CBNE | A,\#imm8,rel | 3 | *1 | 0 | 0 | Branch when byte (A) $=$ imm8 | - | - | - | - | - | * | * | * | * | - |
| CWBNE | A,\#imm16,rel | 4 | *1 | 0 | 0 | Branch when word $(A) \neq$ imm16 | - | - | - | - | - | * | * | * | * | - |
| CBNE | ear,\#imm8,rel | 4 | *2 | 1 | 0 | Branch when byte (ear) $=$ imm8 | - | - | - | - | - | * | * | * | * | - |
| CBNE | eam,\#imm8,rel | 4+ | *3 | 0 | (b) | Branch when byte (eam) $=$ imm8 | - | - | - | - | - | * | * | * | * | - |
| CWBNE | ear,\#imm16,rel | 5 | *4 | 1 | 0 | Branch when word (ear) $=$ imm16 | - | - | - | - | - | * | * | * | * | - |
| CWBNE | eam,\#imm16,rel | 5+ | *3 | 0 | (c) | Branch when word (eam) $\neq$ imm16 | - | - | - | - | - | * | * | * | * | - |
| DBNZ | ear,rel | 3 | *5 | 2 | 0 | Branch when byte (ear)=(ear)-1, (ear) $=0$ | - | - | - | - | - | * | * | * | - | - |
| DBNZ | eam,rel | 3+ | * 6 | 2 | $2 \times(\mathrm{b})$ | Branch when byte (eam) $=($ eam $)-1,($ eam $) \neq 0$ | - | - | - | - | - | * | * | * | - | * |
| DWBNZ | ear,rel | 3 | *5 | 2 | 0 | Branch when word (ear) $=($ ear $)-1,($ ear $) \neq 0$ | - | - | - | - | - | * | * | * | - | - |
| DWBNZ | eam,rel | 3+ | *6 | 2 | $2 \times$ (c) | Branch when word (eam) $=($ eam) $-1,($ eam $) \neq 0$ | - | - | - | - | - | * | * | * | - | * |
| INT | \#vct8 | 2 | 20 | 0 | $8 \times$ (c) | Software interrupt | - | - | R | S | - | - | - | - | - | - |
| INT | addr16 | 3 | 16 | 0 | $6 \times(\mathrm{c})$ | Software interrupt | - | - | R | S | - | - | - | - | - | - |
| INTP | addr24 | 4 | 17 | 0 | $6 \times(\mathrm{c})$ | Software interrupt | - | - | R | S | - | - | - | - | - | - |
| INT9 |  | 1 | 20 | 0 | $8 \times(\mathrm{c})$ | Software interrupt | - | - | R | S | - | - | - | - | - | - |
| RETI |  | 1 | 11 | 0 | *7 | Recovery from interrupt | - | - | * | * | * | * | * | * | * | - |
| LINK | \#imm8 | 2 | 6 | 0 | (c) | At the entrance of function, save old frame pointers into a stack, set up new frame pointers, reserve area for local pointers. | - | - | - | - | - | - | - | - | - | - |
| UNLINK |  | 1 | 5 | 0 | (c) | At the exit of function, recover the old frame pointers from the stack. | - | - | - | - | - | - | - | - | - | - |
| RET | *1 | 1 | 4 | 0 | (c) | Recover from the subroutine. | - | - | - | - | - | - | - | - | - | - |
| RETP | *2 | 1 | 6 | 0 | (d) | Recover from the subroutine. | - | - | - | - | - | - | - | - | - | - |

*1: $\quad 5$ when branching, 4 when not branching
*2: 13 when branching, 12 when not branching
*3: $7+$ (a) when branching, $6+$ (a) when not branching
*4: 8 when branching, 7 when not branching
*5: 7 when branching, 6 when not branching
*6: $\quad 8+(a)$ when branching, $7+$ (a) when not branching
*7: $3 \times(\mathrm{b})+2 \times(\mathrm{c})$ when an interrupt request is generated, $6 \times(\mathrm{c})$ at recovery.
Note 1: Return from stack (word)
Note 2: Return from stack (long)
Note 3: RWj+ addressing mode should not be used with the CBNE/CWBNE instructions.
Note: For an explanation of "(a)" to "(d)" in the colunm "B", see Table B.2d and Table B.2e.

Table B.2.10 Other Control Instructions (Byte/Word/Long-Word) (36 Instructions)

| Mnemonic |  | \# | $\sim$ | RG | B | Operation | LH | AH | I | S | T | N | Z | V | C | RMW |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PUSHW | A | 1 | 4 | 0 | (c) | word $(\mathrm{SP}) \leftarrow(\mathrm{SP})-2,((\mathrm{SP})) \leftarrow(\mathrm{A})$ | - | - | - | - | - | - | - | - | - | - |
| PUSHW | AH | 1 | 4 | 0 | (c) | word $(S P) \leftarrow(S P)-2,((S P)) \leftarrow(A H)$ | - | - | - | - | - | - | - | - | - | - |
| PUSHW | PS | 1 | 4 | 0 | (c) | word $(\mathrm{SP}) \leftarrow(\mathrm{SP})-2,((\mathrm{SP})) \leftarrow(\mathrm{PS})$ | - | - | - | - | - | - | - | - | - | - |
| PUSHW | rlst | 2 | *3 | +\& | *4 | $(\mathrm{SP}) \leftarrow(\mathrm{SP})-2 \mathrm{n},((\mathrm{SP})) \leftarrow(\mathrm{rlst})$ | - | - | - | - | - | - | - | - | - | - |
| POPW | A | 1 | 3 | 0 | (c) | word $(\mathrm{A}) \leftarrow((\mathrm{SP}))$, $(\mathrm{SP}) \leftarrow(\mathrm{SP})+2$ | - | * | - | - | - | - | - | - | - | - |
| POPW | AH | 1 | 3 | 0 | (c) | word $(\mathrm{AH}) \leftarrow((\mathrm{SP})$ ), (SP) $\leftarrow(\mathrm{SP})+2$ | - | - | - | - | - | - | - | - | - | - |
| POPW | PS | 1 | 4 | 0 | (c) | word $(\mathrm{PS}) \leftarrow((\mathrm{SP})),(\mathrm{SP}) \leftarrow(\mathrm{SP})+2$ | - | - | * | * | * | * | * | * | * | - |
| POPW | rlst | 2 | *2 | +\& | *4 | $(\mathrm{rlst}) \leftarrow((\mathrm{SP})),(\mathrm{SP}) \leftarrow(\mathrm{SP})$ | - | - | - | - | - | - | - | - | - | - |
| JCTX | @A | 1 | 14 | 0 | $6 \times(\mathrm{c})$ | Context switching instruction | - | - | * | * | * | * | * | * | * | - |
| AND | CCR,\#imm8 | 2 | 3 | 0 | 0 | byte $(\mathrm{CCR}) \leftarrow(\mathrm{CCR})$ and imm8 | - | - | * | * | * | * | * | * | * | - |
| OR | CCR,\#imm8 | 2 | 3 | 0 | 0 | byte $(C C R) \leftarrow(C C R)$ or imm8 | - | - | * | * | * | * | * | * | * | - |
| MOV | RP,\#imm8 | 2 | 2 | 0 | 0 | byte (RP) $\leftarrow$ imm8 | - | - | - | - | - | - | - | - | - | - |
| MOV | ILM, \#imm8 | 2 | 2 | 0 | 0 | byte $($ ILM $) \leftarrow$ imm8 | - | - | - | - | - | - | - | - | - | - |
| MOVEA | RWi,ear | 2 | 3 | 1 | 0 | word $($ RWi) $\leftarrow$ ear | - | - | - | - | - | - | - | - | - | - |
| MOVEA | RWi,eam | 2+ | 2+(a) | 1 | 0 | word $(\mathrm{RWi}) \leftarrow$ eam | - | - | - | - | - | - | - | - | - | - |
| MOVEA | A,ear | 2 | 1 | 0 | 0 | word $(A) \leftarrow$ ear | - | * | - | - | - | - | - | - | - | - |
| MOVEA | A,eam | 2+ | 1+(a) | 0 | 0 | word $(A) \leftarrow$ eam | - | * | - | - | - | - | - | - | - | - |
| ADDSP | \#imm8 | 2 | 3 | 0 | 0 | word $(\mathrm{SP}) \leftarrow \operatorname{ext}(\mathrm{imm} 8)$ | - | - | - | - | - | - | - | - | - | - |
| ADDSP | \#imm16 | 3 | 3 | 0 | 0 | word $(\mathrm{SP}) \leftarrow$ imm16 | - | - | - | - | - | - | - | - | - | - |
| MOV | A,brgl | 2 | *1 | 0 | 0 | byte $($ A $) \leftarrow($ brg 1$)$ | Z | * | - | - | - | * | * | - | - | - |
| MOV | brg2,A | 2 | 1 | 0 | 0 | byte $($ brg2 $) \leftarrow(A)$ | - | - | - | - | - | * | * | - | - | - |
| NOP |  | 1 | 1 | 0 | 0 | No operation | - | - | - | - | - | - | - | - | - | - |
| ADB |  | 1 | 1 | 0 | 0 | Prefix code for AD space access | - | - | - | - | - | - | - | - | - | - |
| DTB |  | 1 | 1 | 0 | 0 | Prefix code for DT space access | - | - | - | - | - | - | - | - | - | - |
| PCB |  | 1 | 1 | 0 | 0 | Prefix code for PC space access | - | - | - | - | - | - | - | - | - | - |
| SPB |  | 1 | 1 | 0 | 0 | Prefix code for SP space access | - | - | - | - | - | - | - | - | - | - |
| NCC |  | 1 | 1 | 0 | 0 | Prefix code for flag unchange setting | - | - | - | - | - | - | - | - | - | - |
| CMR |  | 1 | 1 | 0 | 0 | Prefix for common register banks | - | - | - | - | - | - | - | - | - | - |

*1: PCB, ADB, SSB, USB, and SPB: ... 1 cycle
DTB, DPR: $\qquad$ 2 cycles
*2: $\quad 7+3 \times$ (pop count) $+2 \times$ (last register number to be popped), 7 when RLST $=0$
*3: $29+3 \times$ (pop count) $-3 \times$ (last register number to be popped), 8 when RLST $=0$
*4: Pop count $x$ (c), or push count $x$ (c)
Note: For an explanation of "(a)" to "(d)" in the colunm "B", see Table B.2d and Table B.2e.

Table B.2.1p Bit Manipulation Instructions (22 Instructions)

| Mnemonic |  | \# | $\sim$ | RG | B | Operation | LH | AH | 1 | S | T | N | Z | V | C | RMW |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MOVB | A,dir:bp | 3 | 5 | 0 | (b) | byte $(\mathrm{A}) \leftarrow($ dir:bp $) \mathrm{b}$ | Z | * | - | - | - | * | * | - | - | - |
| MOVB | A,addr16:bp | 4 | 5 | 0 | (b) | byte $(\mathrm{A}) \leftarrow($ addr16:bp $) \mathrm{b}$ | Z | * | - | - | - | * | * | - | - | - |
| MOVB | A,io:bp | 3 | 4 | 0 | (b) | byte $(\mathrm{A}) \leftarrow($ io:bp $) \mathrm{b}$ | Z | * | - | - | - | * | * | - | - | - |
| MOVB | dir:bp,A | 3 | 7 | 0 | $2 \times$ (b) | bit ( dir:bp )b $\leftarrow(A)$ | - | - | - | - | - | * | * | - | - | * |
| MOVB | addr16:bp,A | 4 | 7 | 0 | $2 \times$ (b) | bit ( addr16:bp ) $\mathrm{b} \leftarrow(\mathrm{A})$ | - | - | - | - | - | * | * | - | - | * |
| MOVB | io:bp,A | 3 | 6 | 0 | $2 \times$ (b) | bit ( io:bp )b $\leftarrow$ (A) | - | - | - | - | - | * | * | - | - | * |
| SETB | dir:bp | 3 | 7 | 0 | $2 \times$ (b) | bit ( dir:bp )b $\leftarrow 1$ | - | - | - | - | - | - | - | - | - | * |
| SETB | addr16:bp | 4 | 7 | 0 | $2 \times$ (b) | bit ( addr16:bp )b $\leftarrow 1$ | - | - | - | - | - | - | - | - | - | * |
| SETB | io:bp | 3 | 7 | 0 | $2 \times$ (b) | bit ( io:bp )b $\leftarrow 1$ | - | - | - | - | - | - | - | - | - | * |
| CLRB | dir:bp | 3 | 7 | 0 | $2 \times$ (b) | bit ( dir:bp ) b ¢0 | - | - | - | - | - | - | - | - | - | * |
| CLRB | addr16:bp | 4 | 7 | 0 | $2 \times$ (b) | bit ( addr16:bp )b $\leftarrow 0$ | - | - | - | - | - | - | - | - | - | * |
| CLRB | io:bp | 3 | 7 | 0 | $2 \times$ (b) | bit ( io:bp )b $\leftarrow 0$ | - | - | - | - | - | - | - | - | - | * |
| BBC | dir:bp,rel | 4 | *1 | 0 | (b) | Branch when ( dir:bp )b $=0$ | - | - | - | - | - | - | * | - | - | - |
| BBC | addr16:bp,rel | 5 | *1 | 0 | (b) | Branch when ( addr16:bp )b $=0$ | - | - | - | - | - | - | * | - | - | - |
| BBC | io:bp,rel | 4 | *2 | 0 | (b) | Branch when ( io:bp) $b=0$ | - | - | - | - | - | - | * | - | - | - |
| BBS | dir:bp,rel | 4 | *1 | 0 | (b) | Branch when ( dir:bp )b=1 | - | - | - | - | - | - | * | - | - | - |
| BBS | addr16:bp,rel | 5 | *1 | 0 | (b) | Branch when ( addr16:bp )b $=1$ | - | - | - | - | - | - | * | - | - | - |
| BBS | io:bp,rel | 4 | *2 | 0 | (b) | Branch when ( io:bp) $\mathrm{b}=1$ | - | - | - | - | - | - | * | - | - | - |
| SBBS | addr16:bp,rel | 5 | *3 | 0 | $2 \times(\mathrm{b})$ | Branch when (addr16:bp) $\mathrm{b}=1$, bit $=1$ | - | - | - | - | - | - | * | - | - | * |
| WBTS | io:bp | 3 | *4 | 0 | *5 | Wait until (io:bp) $\mathrm{b}=1$ | - | - | - | - | - | - | - | - | - | - |
| WBTC | io:bp | 3 | *4 | 0 | *5 | Wait until (io:bp) $\mathrm{b}=0$ | - | - | - | - | - | - | - | - | - | - |

*1: 8 when branching, 7 when not branching
*2: 7 when branching, 6 when not branching
*3: $\quad 10$ when condition is satisfied, 9 when not satisfied
*4: Undefined count
*5: Until condition is satisfied
Note: For an explanation of "(a)" to "(d)" in the colunm "B", see Table B.2d and Table B.2e.

Table B.2.1q Accumulator Manipulation Instructions (Byte/Word) (6 Instructions)

| Mnemonic | $\#$ | $\sim$ | RG | B | Operation | LH | AH | I | S | T | N | Z | V | C | RMW |
| :--- | :---: | :---: | :---: | :---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :---: |
| SWAP | 1 | 3 | 0 | 0 | byte $(\mathrm{A}) 0-7 \leftarrow \rightarrow(\mathrm{~A}) 8-15$ | - | - | - | - | - | - | - | - | - | - |
| SWAPW $/$ XCHW A,T | 1 | 2 | 0 | 0 | word $($ AH $) \leftarrow \rightarrow(\mathrm{AL})$ | - | $*$ | - | - | - | - | - | - | - | - |
| EXT | 1 | 1 | 0 | 0 | byte signed extension | X | - | - | - | - | $*$ | $*$ | - | - | - |
| EXTW | 1 | 2 | 0 | 0 | word signed extension | - | X | - | - | - | $*$ | $*$ | - | - | - |
| ZEXT | 1 | 1 | 0 | 0 | byte zero extension | Z | - | - | - | - | R | $*$ | - | - | - |
| ZEXTW | 1 | 1 | 0 | 0 | word zero extension | - | Z | - | - | - | R | $*$ | - | - | - |

Table B.2.1r String Instructions (10 Instructions)

| Mnemonic | \# | $\sim$ | RG | B | Operation | LH | AH | 1 | S | T | N | Z | V | C | RMW |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MOVS / MOVSI | 2 | *2 | +\& | *3 | byte transfer @AH+ ¢@AL+, counter = RW0 | - | - | - | - | - | - | - | - | - | - |
| MOVSD | 2 | *2 | +\& | *3 | byte transfer @AH- ¢ @AL-, counter = RW0 | - | - | - | - | - | - | - | - | - | - |
| SCEQ / SCEQI | 2 | *1 | +\& | *4 | byte search @AH+ | - | - | - | - | - | * | * | * | * | - |
| SCEQD | 2 | *1 | +\& | *4 | byte search @AH- ¢ AL, counter = RW0 | - | - | - | - | - | * | * | * | * | - |
| FILS / FILSI | 2 | $6 m+6$ | +\& | *3 | byte fill @AH+ ¢ AL, counter = RW0 | - | - | - | - | - | * | * | - | - | - |
| MOVSW / MOVSWI | 2 | *2 | +) | *6 | word transfer @AH+ ¢ @AL+, counter = RW0 | - | - | - | - | - | - | - | - | - | - |
| MOVSWD | 2 | *2 | +) | * 6 | word transfer @AH- ¢ @AL-, counter = RW0 | - | - | - | - | - | - | - | - | - | - |
| SCWEQ / SCWEQI | 2 | *1 | +) | *7 | word search @AH+ $\leftarrow A L$, counter $=$ RW0 | - | - | - | - | - | * | * | * | * | - |
| SCWEQD | 2 | *1 | +) | *7 | word search @AH- $\leftarrow$ AL, counter $=$ RW0 | - | - | - | - | - | * | * | * | * | - |
| FILSW / FILSWI | 2 | $6 m+6$ | +) | *6 | word fill @AH+ $\leftarrow$ AL, counter $=$ RW0 | - | - | - | - | - | * | * | - | - | - |

*1: $\quad 5$ when RW0 is $0,4+7 \times($ RW0 $)$ for count out, and $7 \mathrm{n}+5$ when match occurs.
*2: 5 when RW0 is $0,4+8 \times(\mathrm{RWO})$ in any other case.
*3: $\quad(b) \times($ RWO $)+(b) \times($ RWO $)$ : when accessing a source and a destination in different areas, the value of item (b) should be computed separately for each.
*4: (b) $\times n$
*5: $\quad 2 \times($ RW0 $)$
*6: $\quad(\mathrm{c}) \times($ RWO $)+(\mathrm{c}) \times($ RW0 $)$ : when accessing a source and a destination in different areas, the value of item (c) should be computed separately for each.
*7: (c) $\times n$
*8: $2 \times$ (RW0)
m : RW0 value (counter value)
n : Loop count
Note: For an explanation of "(a)" to "(d)" in the colunm "B", see Table B.2d and Table B.2e.

## B. 3 Instruction Map

Because the $\mathrm{F}^{2} \mathrm{MC}-16 \mathrm{LX}$ operation codes each consist of one or two bytes, the instruction map consists of numerous pages. The structure of the instruction map is shown below.


Fig. B.3a Structure of $\mathrm{F}^{2}$ MC-16LX Instruction Map

Instructions that consist of only one byte (such as NOP) are concluded on the basic page. Regarding instructions that require two bytes (such as MOVS), the existence of the map for the second byte is indicated when the first byte is referenced, so it is clear that it is necessary to use the following byte to reference the map for the second byte.

The correspondence between the actual instruction code and the instruction map is shown below.


Fig. B.3b Correspondence between Actual Instructions and the Instruction Maps

## B． 3 Instruction Map

B．3．1 Basic Page Map

| ㅇ |  |  |  |  |  | ¢0 ${ }_{0}^{\square}$ | $\stackrel{\square}{\text { ¢ }}$ | $\underset{\sim}{i}$ | $\stackrel{\bar{\omega}}{\square}$ | ${\underset{\sim}{\text { a }}}^{\text {co }}$ | $\underset{\frac{\square}{\omega}}{\stackrel{\square}{o}}$ |  | $\underset{\sim}{\underset{\omega}{w}}$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| － |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $\bigcirc$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $\bigcirc$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $\bigcirc$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $\bigcirc$ |  | \| |  |  |  |  |  |  |  | 1 |  |  |  |  |  |  |
| क |  | \| |  |  |  |  |  |  |  | 1 |  |  |  |  |  |  |
| － |  | $1$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $\stackrel{\circ}{\wedge}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $\bigcirc$ |  |  |  |  | $\begin{aligned} \\ \hline \end{aligned}$ | 势 | $\left\lvert\, \begin{array}{\|c} \stackrel{n}{\underset{\sim}{u}} \\ \hline \end{array}\right.$ | $\underset{\sim}{\underset{\sim}{x}}$ |  |  |  |  |  |  |  |  |
| is |  |  |  |  |  |  |  |  |  |  |  |  |  | $\begin{array}{\|l\|l\|l\|} \substack{\frac{1}{4} \\ 3 \\ 0 \\ 0 \\ 0 \\ 0} \end{array}$ | $\left[\begin{array}{l} \infty \\ 3 \\ 3 \\ 0 \\ 0 \\ 0 \end{array}\right.$ | $2$ |
| $\stackrel{\circ}{\circ}$ |  |  |  |  |  |  | $\begin{array}{ll}  & 0 \\ 3 & 8 \\ 3 & 4 \\ 0 & \\ \Sigma \end{array}$ | $\begin{array}{cc} 4 \\ 3 & 0 \\ 3 \\ 0 & 0 \\ 2 \end{array}$ | $\begin{array}{ll}  & : 亏 \\ 3 \\ 3 \\ 3 \\ 0 & \\ \Sigma & \end{array}$ | $\left\{\right.$ |  |  | $\left\{\begin{array}{l} 3 \\ \frac{3}{1}< \\ 9 \\ 2 \end{array}\right.$ |  |  |  |
| 앙 |  | $\underset{\sim}{c}$ |  |  |  |  |  |  |  |  |  |  |  |  |  | 3 2 2 |
| $\stackrel{\circ}{\text { ® }}$ |  |  |  | $x<$ |  |  |  | $\left[\begin{array}{l} \Sigma^{4} \\ { }_{2} \\ x^{2} \end{array}\right.$ | $\begin{aligned} & 3^{\varangle} \\ & 3^{4} \\ & \frac{1}{4} \end{aligned}$ | $\mathfrak{r}$ |  | $3_{0}^{3_{0}^{4}}$ | $\underbrace{\ll}_{2}$ | $\underset{\substack{x}}{\substack{3}}$ | $\left.\right\|_{\substack{3 \\ \\ \times \\ \times}} ^{\substack{ \\\hline}}$ | c |
| 안 | $\sum_{0}^{\infty}$ | $\begin{aligned} & 0 \\ & \mathrm{O} \\ & \hline \end{aligned}$ | $\begin{aligned} & 0^{\varangle} \\ & 0 \\ & \omega \\ & \stackrel{\rightharpoonup}{\omega} \\ & \hline \end{aligned}$ |  | 妾 | $\stackrel{\stackrel{-}{x}}{\underset{N}{n}}$ | $\underset{\substack{0 \\ \sum_{n} \\ \hline}}{n}$ |  |  |  |  | $\begin{gathered} \tilde{N} \\ M \\ \sum_{0}^{\#} \\ \sum_{0}^{n} \\ \hline \end{gathered}$ | \|3 | $\underset{\substack{3 \\ \underset{N}{x} \\ \hline}}{ }$ |  |  |
| $\bigcirc$ | $\underline{0}$ | $\stackrel{\otimes}{\underset{z}{2}}$ |  | $\left\lvert\, \begin{gathered} < \\ \underset{\sim}{\sim} \\ \underset{\sim}{\sim} \end{gathered}\right.$ | $0$ | © |  | $\begin{aligned} & \mathrm{m} \\ & \mathrm{o} \end{aligned}$ |  | $\underbrace{\underset{y}{z}}_{\underset{J}{y}}$ |  | $\left\lvert\, \begin{aligned} & z_{0}^{4} \\ & \widetilde{N}_{2} \end{aligned}\right.$ | $\underbrace{\ll}_{3}$ |  |  |  |
|  | $\stackrel{+}{+}$ | ${ }_{+}+$ | $\stackrel{\sim}{+}$ | $\stackrel{+}{+}$ | $\stackrel{+}{+}$ | $\stackrel{\sim}{+}$ | $\stackrel{+}{+}$ | $\stackrel{+}{+}$ | $\stackrel{\infty}{+}$ | $\stackrel{\square}{+}$ | ¢ | $\stackrel{\infty}{+}$ | 0 + + | $\bigcirc$ | $\stackrel{+}{\text { ¢ }}$ | $\stackrel{+}{+}$ |



Table B.3.1c Character String Manipulation Instruction Map (First byte =6EH)

Table B.3.1d Two-byte Instruction Map (First byte = 6FH)

|  | 00 | 10 | 20 | 30 | 40 | 50 | 60 | 70 | 80 | 90 | A 0 | во | co | D 0 | E 0 | Fo |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| +0 | $\begin{aligned} & \text { MOV } \\ & \quad \text { A, DTB } \end{aligned}$ | $\mathrm{MOV}_{\text {DTB, A }}$ | MOVX <br> A, @RL0 +d8 | $\begin{aligned} & \text { MOV } \\ & \text { @RLO+d8, A } \end{aligned}$ | MOV <br> A, @RLO+d8 |  |  |  |  |  |  |  |  |  |  |  |
| +1 | $\begin{aligned} & \mathrm{MOV} \\ & \mathrm{~A}, \mathrm{ADB} \end{aligned}$ | $\mathrm{MOV}_{\mathrm{ADB}, \mathrm{~A}}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| +2 | $\begin{aligned} & \mathrm{MOV} \\ & \quad \mathrm{~A}, \mathrm{SSB} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{MOV} \\ & \mathrm{SSB}, \mathrm{~A} \end{aligned}$ | MŌv̄ <br> A, @RL1+d8 | Mov̄ <br> @RL1+d8, A | $\left\|\begin{array}{l} \overline{M O} \bar{v} \\ A, @ R L 1+d 8 \end{array}\right\|$ |  |  |  |  |  |  |  |  |  |  |  |
| +3 | $\begin{aligned} & \mathrm{MOV} \\ & \mathrm{~A}, \text { USB } \end{aligned}$ | $\begin{gathered} \mathrm{MOV} \\ \quad \text { USB, } \mathrm{A} \end{gathered}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| +4 | MOV A. DPR | $\begin{gathered} \mathrm{MOV} \\ \text { DPR, A } \end{gathered}$ | Mōv̄ <br> A, @RL2+d8 | Mō <br> @RL2+d8, A | MŌ̄ <br> A, @RL2+d8 |  |  |  |  |  |  |  |  |  |  |  |
| +5 | $\begin{aligned} & \text { MOV } \\ & \quad \text { A. @A } \\ & \hline \end{aligned}$ | MOV @AL, AH |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| +6 | $\begin{aligned} & \mathrm{MOV} \\ & \quad \mathrm{~A}, \mathrm{PCB} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \text { MOVX } \\ & \text { A, @A } \\ & \hline \end{aligned}$ | movx <br> A, @RL3+d8 | MOV <br> @RL3+d8, A | MOV <br> A, @RL3+d8 |  |  |  |  |  |  |  |  |  |  |  |
| +7 | $\begin{array}{r} \hline \text { ROLC } \\ \hline \end{array}$ | $\begin{array}{r} \text { RORC } \\ \hline \end{array}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| +8 |  |  |  | MOVW @RL0+d8, A | MOVW <br> A, @RLO+d8 |  |  | MUL |  |  |  |  |  |  |  |  |
| +9 |  |  |  |  |  |  |  | MULW |  |  |  |  |  |  |  |  |
| +A |  |  |  | movw @RL1+d8, A | MOVW A, @RL1+d8 |  |  | DIVU |  |  |  |  |  |  |  |  |
| +B |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| +C | $\begin{aligned} & \text { LSLW } \\ & \quad \text { A, RO } \\ & \hline \end{aligned}$ | $\stackrel{\text { LSLL }}{ }, \mathrm{RO}^{2}$ | $\begin{array}{ll} \hline \text { LSL } & \\ & \text { A, RO } \end{array}$ | MOVW @RL2+d8, A | MOV̄W A, @RL2+d8 |  |  |  |  |  |  |  |  |  |  |  |
| +D | MOVW $\mathrm{A}, @ \mathrm{~A}$ | MOVW @AL, AH | NRML <br> A, RO |  |  |  |  |  |  |  |  |  |  |  |  |  |
| +E | $\begin{aligned} & \hline \text { ASRW } \\ & \text { A, RO } \\ & \hline \end{aligned}$ | $\begin{array}{r} \text { ASRL } \\ \text { A, RO } \\ \hline \end{array}$ | $\begin{aligned} & \text { ASR } \\ & \\ & \hline \end{aligned}$ | MOVW @RL3+d8, A | MŌ̄W <br> A, @RL3+d8 |  |  |  |  |  |  |  |  |  |  |  |
| +F | $\begin{aligned} & \text { LSRW } \\ & \quad \text { A, R0 } \end{aligned}$ | $\begin{array}{r} \hline \text { LSRL } \\ \\ \hline \end{array}$ | $\begin{array}{rr} \hline \text { LSR } & \\ & \\ \hline \end{array}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |

Table B.3.1e "ea" Instructions 1 (First byte $=70 \mathrm{H}$ )

Table B.3.1f "ea" Instructions 22 (First byte $=\mathbf{7 1 H}$ )

|  | 00 | 10 | 20 | 30 | 40 | 50 | 60 | 70 | 80 | 90 | A 0 | во | co | D 0 | E 0 | F0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| +0 | JMPP @RLO | JMPP <br> @@RW0+d8 | CALLP @RLO | $\begin{aligned} & \text { CALLP } \\ & \text { @@RWO+d8 } \end{aligned}$ | $\begin{aligned} & \text { INCL } \\ & R L O \end{aligned}$ | INCL @RW0+d8 | $\begin{gathered} \mathrm{DECLL} \\ \mathrm{RLO} \\ \hline \end{gathered}$ | DECL | $\begin{gathered} \mathrm{MOVL} \\ \mathrm{~A}, \mathrm{RLO} \end{gathered}$ | MOVL A, @RW0+d8 | MOVL RLO, A | MOVL @R W0+d8, A | $\mathrm{MOV}$ | $\begin{aligned} & \text { MOV @R } \\ & \text { WO+d8, \#8 } \end{aligned}$ | MOVEA A, RWO | MOVEA A, @RW0+d8 |
| +1 | JMPP @RLO | iJMPP ' @@RW1+d8 | CALLP @RLO | $\begin{aligned} & \text { CALLP } \\ & \text { @@RW1+d8 } \end{aligned}$ | $\begin{gathered} \text { NOL- } \\ \text { RLO } \end{gathered}$ | INCL @RW1+d8 | ECL | @ECL | $\begin{aligned} & \text { MOL RLO } \end{aligned}$ | MOVL A, @RW1+d8 | MOVL RLO, A | MOVL @R W1+d8, A | MOV | MOV @R | $\begin{gathered} \text { MOEA } \\ \text { A, RW } \end{gathered}$ | MOVEA A, @RW1+d8 |
| +2 | JMPP @RL1 | 'JMPP <br> , @@RW2+d8 | $\begin{gathered} \text { CALLP } \\ \text { @RL1 } \end{gathered}$ | $\begin{aligned} & \text { CALLP } \\ & \text { @@RW2+d8 } \end{aligned}$ | $\begin{array}{ll} C L \\ R L 1 \end{array}$ | INCL @RW2+d8 | $\begin{aligned} & E C L \\ & R L 1 \end{aligned}$ | $\begin{aligned} & \text { DECL } \\ & \text { @RW2 }+d 8 \end{aligned}$ | MOVL A, RL1 | MOVL A, @RW2+d8 | MOVL RL1, A | MOVL @R W2+d8, A | MOV R2, \#8 | $\begin{aligned} & \text { MOV @R } \\ & \text { W2+d8, \#8 } \end{aligned}$ | MOVEA A, RW2 | MOVEA A, @RW2+d8 |
| +3 | JMPP @RL1 | $\begin{aligned} & 1.1 M P P- \\ & 1 @ @ R W 3+d 8 \end{aligned}$ | CALLP @RL1 | $\begin{aligned} & \text { TALLP- } \\ & 1 @ @ R W 3+d 8 \end{aligned}$ | $\mathrm{CiL}_{\mathrm{RL}}^{-1}$ | INCL @RW3+d8 | ${ }_{R L-}^{D E L}$ | DECL @RW3+d8 | MOVL A, RL | MOVL A, @RW3+d8 | MOVL RL1, A | MOVL @R W3+d8, A | MOV R3, \#8 | MOV @R W3+d8, \#8 | MOVEA A, RW3 | MOVEA A, @RW3+d8 |
| +4 | $\begin{array}{\|c} \text { JMPP } \\ \text { @RL2 } \end{array}$ | $\begin{aligned} & \text { JMPP } \\ & \text { @@RW4+d8 } \end{aligned}$ | $\begin{aligned} & \text { CALLP } \\ & \text { @RL2 } \end{aligned}$ | CALLP @@RW4+d8 | $\stackrel{\overline{N N C L}}{\text { RL2 }}$ | INCL @RW4+d | $\begin{gathered} \mathrm{DECL} \\ \mathrm{RLL} \end{gathered}$ | $\begin{aligned} & \text { @RW4-d8 } \end{aligned}$ | $\underset{A, ~ R L 2}{M O V L}$ | MOVL A, @RW4+d8 | MOVL RL2, A | MOVL @R W4+d8, A | $\begin{aligned} & \text { MOV } \\ & \text { R4, \#8 } \end{aligned}$ | MOV @R W4+d8, \#8 | MOVEA A, RW4 | MOVEA A, @RW4+d8 |
| +5 | JMPP @RL2 | 'JMPP <br> , @@RW5+d8 | CALLP @RL2 | CALLP @@RW5+d8 | $\begin{gathered} \mathrm{CL} \\ \mathrm{RL} 2 \end{gathered}$ | NCL @RW5+d8 | $\mathrm{ECL}$ | DECL @RW5+d8 | MOVL A, RL2 | MOVL A @RW5+d8 | MOVL RL2, A | MOVL @R W5+d8, A | MOV R5, \#8 | MOV @R <br> W5+d8, \#8 | MOVEA A, RW5 | MOVEA A, @RW5+d8 |
| +6 | JMPP @RL3 | MPPRW6+d8 | CALLP @RL3 | CALLP @@RW6+d8 | RL3 | NCL @RW6+d8 | CL | DECL @RW6+d8 | MOVL <br> A, RL3 | MOVL A, @RW6+d8 | MOVL RL3, A | MOVL @R W6 $+\mathrm{d} 8, \mathrm{~A}$ | $\begin{aligned} & \mathrm{MOV} \\ & \mathrm{R6}, \# 8 \end{aligned}$ | MOV @R W6+d8, \#8 | MOVEA A, RW6 | MOVEA A @RW6+d8 |
| +7 | $\begin{aligned} & \text { JMPP } \\ & \text { @RL3 } \end{aligned}$ | JMPP @@RW7+d8 | CALLP @RL3 | $\begin{aligned} & \text { CALLP } \\ & \text { @@RW7+d8 } \end{aligned}$ | $\begin{array}{r} \mathrm{INCL} \overline{R L}^{-} \end{array}$ | NCL @RW7+d8 | $\begin{gathered} \mathrm{ECL} \\ \mathrm{RL} 3 \end{gathered}$ | $\begin{aligned} & \text { DECL } \\ & \text { @RW7+d8 } \end{aligned}$ | MÓvL <br> A, RL3 | MOVL A @RW7+d8 | MOVL RL3, A | MOVL @R W7+d8, A | MOV | MOV @R W7+d8, \#8 | MOVEA A, RW7 | MOVEA A, @RW7+d8 |
| +8 | JMPP @@RW0 | JMPP @ @RW0+d16 | @@RW0 | CALLP @ @RW0+d16 | INCL @RW0 | INCL @RWO+d16 | DECL @RW0 | $\begin{aligned} & \text { DECL } \\ & \text { @ROO d } 16 \end{aligned}$ | MOVL <br> A, @RW0 | MOVL A, @RW0+d16 | MOVL @RWO, A | MOVL @R W0+d16, A | MOV @RW0, \#8 | MOV @R W0+d16, \#8 | MOVEA A, @RW0 | MOVEA A, @RW0+d16 |
| +9 | JMPP <br> @@RW1 | JMPP @ @RW1+d16 | CaLlp @@RW1 | CALLP @ @RW1+d16 | INCL @RW1 | INCL @RW1+d16 | DECL @RW1 | $\begin{aligned} & \text { DECL } \\ & \text { @RW1+d16 } \end{aligned}$ | MOVL <br> A, @RW1 | MOVL A @RW1+d16 | MOVL @RW1, A | MOVL @R W1+d16, A | MOV @RW1, \#8 | MOV @R W1+d16, \#8 | MOVEA A, @RW1 | MOVEA A, @RW1+d16 |
| +A | JMPP @@RW2 | JMPP @ @RW2+d16 | CALLP @@RW2 | CALLP @ @RW2+d16 | INCL @RW2 | INCL @RW2+d16 | DECL @RW2 | DECL @RW2+d16 | MOVL <br> A, @RW2 | MOVL A, @RW2+d16 | MOVL @RW2, A | MOVL @R W2+d16, A | MOV @RW2, \#8 | MOV @R W2+d16, \#8 | MOVEA A, @RW2 | MOVEA A, @RW2+d16 |
| +B | JMPP @@RW3 | JMPP @ @RW3+d16 | CALLP @@RW3 | CALLP @ @RW3+d16 | INCL @RW | INCL @RW3+d16 | DECL @RW3 | DECL @RW3+d16 | MOVL <br> A, @ RW3 | MOVL A, @RW3+d16 | MOVL @RW3, A | MOVL @R W3+d16, A | MOV @RW3, \#8 | MOV @R W3+d16, \#8 | MOVEA <br> A, @RW3 | MOVEA A, @RW3+d16 |
| +C | JMPP <br> @@RW0+ | JMPP @ @RW0+RW7 | CALLP @@RW0 | CALLP @ @RWO+RW7 | INCL @RWO+ | INCL @RW0+RW7 | DECL @RW0+ | DECL @RW0+RW7 | MOVL <br> A, @RW0+ | 'MOVL A, @RW0+RW7 | MOVL @RW0+, A | MOVL @R W0+RW7, A | MOV @RW0+, \#8' | MOV @R W0+RW7, \#8 | MOVEA A, @RW0+ | MOVEA A, @RW0+RW7 |
| +D | JMPP @@RW1+ | JMPP @ @RW1+RW7 | CALLP @@RW1 | callp @ @RW1+RW7 | INCL @RW1+ | NCL @RW1+RW7 | DECL @RW1+ | DECL @RW1+RW7 | MOVL <br> A, @RW1+ | MOVL A @RW1+RW7 | MOVL @RW1+, A | MOVL @R W1+RW7, A | MOV @RW1+, \#8 | MOV @R W1+RW7, \#8 | MOVEA A, @RW1 | MOVEA A, @RW1+RW7 |
| +E | JMPP @@RW2+ | @@PC+d16 | CALLP @@RW2+ | CALLP @@PC+d16 | INCL @RW2+ | INCL @PC+d16 | DECL @RW2+ | DECL @PC+d16 | MOVL <br> A, @RW2+ | MOVL A, @PC+d16 | MOVL @RW2+, A | MOVL @P C+d16, A | MOV @RW2+, \#8' | MOV @P C+d16, \#8 | MOVEA A, @RW2+ | MOVEA A, @PC+d16 |
| +F | JMPP @@RW3+ | JMPP <br> ' @addr16 | CALLP @@RW3 | $\begin{aligned} & \text { CALLP } \\ & \text { @addr1 } \end{aligned}$ | INCL @RW3+ | INCL addr16 | DECL @RW3+ | DECL addr16 | MOVL A, @RW3+ | MOVL A, addr16 | MOVL @RW3+, A | MOVL addr16, A | MOV | MOV addr16, \#8 | MOVEA A, @RW3+ | MOVEA A, addr16 |

Table B.3.1g "ea" Instructions 3 (First byte $=\mathbf{7 2 H}$ )

|  | 00 | 10 | 20 | 30 | 40 | 50 | 60 | 70 | 80 | 90 | A 0 | B 0 | Co | D 0 | E 0 | F 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| +0 | $\begin{array}{r} \mathrm{ROLC} \\ \mathrm{RO} \end{array}$ | $\begin{aligned} & \text { ROLC } \\ & \text { @RW0+d8 } \end{aligned}$ | $\begin{array}{r} \hline \text { RORC } \\ \text { R0 } \end{array}$ | $\begin{aligned} & \text { RORC } \\ & \text { @RW0+d8 } \end{aligned}$ | $\begin{aligned} & \mathrm{INC} \\ & \mathrm{RO} \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & @ R W 0+d 8 \end{aligned}$ | $\begin{array}{r} \hline \mathrm{DEC} \\ \mathrm{RO} \end{array}$ | $\begin{aligned} & \text { DEC } \\ & \text { @RW0+d8 } \end{aligned}$ | MOV <br> A, RO | , MOV A, @RW0+d8 | MOV RO, A | $\begin{gathered} \mathrm{MOV} @ \mathrm{R} \\ \mathrm{WO}+\mathrm{d} 8, \mathrm{~A} \end{gathered}$ | MOVX A, R0 | MOVX A, @RW0+d8 | $\begin{array}{r} \mathrm{XCH} \\ \mathrm{~A}, \mathrm{RO} \end{array}$ | XCH A , @RW0+d8 |
| +1 | $\begin{array}{r} \text { ROLC } \\ \text { R1 } \end{array}$ | $\begin{aligned} & \text { ROLC } \\ & \text { @RW1+d8 } \end{aligned}$ | $\begin{array}{r} \text { RORC } \\ \text { R1 } \end{array}$ | $\begin{aligned} & \text { RORC } \\ & \text { @RW1+d8 } \end{aligned}$ | INC R1 | $\begin{aligned} & \text { INC } \\ & \text { @RW1+d8 } \end{aligned}$ | $\begin{gathered} \overline{D E C} \\ \text { R1 } \end{gathered}$ | $\begin{aligned} & \text { DEC - } \\ & 1 \text { @RW1+d8 } \end{aligned}$ | MOV <br> A, R1 | MOV A, @RW1+d8 | MOV R1, A | $\begin{aligned} & \text { MOV @R } \\ & \text { W1+d8, A } \end{aligned}$ | MOVX A, R1 | MOVX A, @RW1+d8 | $\begin{gathered} \mathrm{XCH} \\ \mathrm{~A}, \mathrm{R} 1 \end{gathered}$ | XCH A, @RW1+d8 |
| +2 | $\begin{array}{\|c} \text { ROLC } \\ \text { R2 } \end{array}$ | $\begin{aligned} & \text { ROLC } \\ & 1 \text { @RW2+d8 } \end{aligned}$ | $\begin{array}{r} \text { RORC } \\ \text { R2 } \end{array}$ | RORC @RW2+d8 | $\mathrm{C}_{\mathrm{R} 2}$ | INC @RW2+d8 | $\begin{gathered} \mathrm{DEC} \\ \mathrm{R} 2 \end{gathered}$ | DEC @RW2+d8 | MOV <br> A, R2 | MOV A, @RW2+d8 | MOV R2, A | MOV @R W2+d8, A | MOVX A, R2 | MOVX A, @RW2+d8 | XCH <br> A, R2 | XCH A, @RW2+d8 |
| +3 | $\begin{array}{r} \text { ROLC } \\ \text { R3 } \end{array}$ | $\begin{aligned} & \text { ROLC } \\ & \text { @RW3+d8 } \end{aligned}$ | $\begin{array}{r} \text { RORC } \\ \text { R3 } \end{array}$ | $\begin{aligned} & \text { RORC } \\ & \text { @RW3+d8 } \end{aligned}$ | NC | $\begin{aligned} & \text { INC } \\ & \text { @RW3+d8 } \end{aligned}$ | $\begin{gathered} \text { DEC } \\ \text { R3 } \end{gathered}$ | $\begin{aligned} & \text { DEC } \\ & \text { @RW3+d8 } \end{aligned}$ | MOV <br> A, R3 | MOV A, @RW3+d8 | MOV R3, A | $\begin{aligned} & \text { MOV @R } \\ & \text { W3+d8, A } \end{aligned}$ | MOVX A, R3 | MOVX A, @RW3+d8 | $\begin{array}{r} \mathrm{XCH} \\ \mathrm{~A}, \mathrm{R} 3 \end{array}$ | XCH A , @RW3+d8 |
| +4 | $\begin{array}{r} \mathrm{ROLC} \\ \mathrm{R} 4 \end{array}$ | $\begin{aligned} & \text { ROLC } \\ & \text { QRW4+d8 } \end{aligned}$ | $\begin{array}{r} -\overline{R O R C} \\ R 4 \end{array}$ | $\begin{aligned} & \text { RORC } \\ & \text { @RW4+d8 } \end{aligned}$ | $\mathrm{INC}_{\mathrm{R} 4}^{-}$ | INC @RW4+d8 | $\begin{gathered} \text { DEC } \\ \text { R4 } \end{gathered}$ | $\begin{aligned} & \text { DEC } \\ & \text { @RW4+d8 } \end{aligned}$ | MOV <br> A, R4 | MOV A, @RW4+d8 | MOV R4, A | $\begin{aligned} & \text { MOV @R } \\ & \text { W4+d8, A } \end{aligned}$ | MOVX <br> A, R4 | MOVX A, @RW4+d8 | $\begin{array}{r} \mathrm{XCH} \\ \mathrm{~A}, \mathrm{R} 4 \end{array}$ | XCH A, @RW4+d8 |
| +5 | $\begin{array}{r} \text { ROLC } \\ \text { R5 } \end{array}$ | $\begin{aligned} & \text { ROLC } \\ & \text { @RW5+d8 } \end{aligned}$ | $\begin{array}{r} \mathrm{RORC} \\ \hline \end{array}$ | $\begin{aligned} & \text { RORC } \\ & \text { @RW5+d8 } \end{aligned}$ | $\mathrm{IC}_{\text {R5 }}$ | INC @RW5+d8 | $\begin{aligned} & \text { DEC } \\ & \text { R5 } \end{aligned}$ | DEC @RW5+d8 | $\begin{aligned} & \mathrm{MOV} \\ & \mathrm{~A}, \mathrm{R} 5 \end{aligned}$ | MOV A, @RW5+d8 | MOV <br> R5, A | MOV @R W5+d8, A | $\begin{aligned} & \mathrm{MOVX} \\ & \text { A, R5 } \end{aligned}$ | MOVX A, @RW5+d8 | $\begin{gathered} \mathrm{XCH} \\ \mathrm{~A}, \mathrm{R} 5 \end{gathered}$ | XCH A, @RW5+d8 |
| +6 | $\begin{array}{r} \text { ROLC- } \\ \text { R6 } \end{array}$ | $\begin{aligned} & \text { ROLC } \\ & \text { @RW6+d8 } \end{aligned}$ | $\begin{array}{r} \text { RORC } \\ \text { R6 } \end{array}$ | $\begin{aligned} & \text { RORC } \\ & \text { @RW6+d8 } \end{aligned}$ | $\bar{C}_{\mathrm{R} 6}$ | INC @RW6+d8 | $\begin{array}{r} \text { DEC } \\ \text { R6 } \end{array}$ | $\begin{aligned} & \text { DEC } \\ & \text { @RW6+d8 } \end{aligned}$ | MOV <br> A, R6 | MOV A, @RW6+d8 | MOV R6, A | $\begin{aligned} & \text { MOV @R } \\ & \text { W6+d8, A } \end{aligned}$ | MOVX A, R6 | MOVX A, @RW6+d8 | $\begin{array}{r} \mathrm{XCH} \\ \mathrm{~A}, \mathrm{R} 6 \end{array}$ | XCH A, @RW6+d8 |
| +7 | $\begin{array}{\|r} \text { ROLC } \\ \text { R7 } \end{array}$ | $\begin{aligned} & \text { ROLC } \\ & \text { @RW7+d8 } \end{aligned}$ | $\begin{array}{r} -\overline{R O R C} \\ \text { R7 } \end{array}$ | RORC @RW7+d8 | ${ }^{\mathrm{INC}}{ }_{\mathrm{R} 7}$ | INC @RW7+d8 | $\begin{array}{r} \text { DEC } \\ \text { R7 } \end{array}$ | DEC @RW7+d8 | MOV A, R7 | MOV A, @RW7+d8 | MOV R7, A | $\begin{aligned} & \text { MOV @R } \\ & \text { W7+d8, A } \end{aligned}$ | MOVX <br> A, R7 | MOVX A, @RW7+d8 | $\begin{gathered} \mathrm{XCH} \\ \mathrm{~A}, \mathrm{R} 7 \end{gathered}$ | XCH A, @RW7+d8 |
| +8 | ROLC @RW0 | ROLC @RW0+d16 | RORC @RW0 | RORC @RW0+d16 | INC @RW0 | NC @RW0+d16 | DEC @RW0 | DEC @RW0+d16 | MOV A, @RWO | MOV A, d @RW0+d16 | MOV @RWo, A | MOV @R W0+d16, A | MOVX A, @RW0 | MOVX A, @RW0+d16 | XCH <br> A, @RW0 | XCH A, @RW0+d16 |
| +9 | ROLC @RW1 | ROLC <br> @RW1+d16 | RORC @RW1 | RORC <br> @RW1+d16 | INC @RW1 | INC @RW1+d16 | DEC @RW1 | DEC @RW1+d16 | MOV <br> A, @RW1 | MOV A, @RW1+d16 | MOV @RW1, A | MOV @R W1+d16, A | MOVX A, @RW1 | MOVX A, @RW1+d16 | XCH <br> A, @RW1 | XCH A, @RW1+d16 |
| +A | ROLC @RW2 | 'ROLC @RW2+d16 | RORC @RW2 | RORC @RW2+d16 | INC @RW2 | INC @RW2+d16 | DEC @RW2 | DEC @RW2+d16 | MOV A, @RW2 | MOV A, @RW2+d16 | MOV @RW2, A | MOV @R W2+d16, A | MOVX A, @RW2 | MOVX A, @RW2+d16 | $\begin{aligned} & \text { XCH, @RW2 } \end{aligned}$ | XCH A, @RW2+d16 |
| +B | ROLC @RW3 | 'ROLC @RW3+d16 | RORC @RW3 | RORC @RW3+d16 | INC @RW3 | INC @RW3+d16 | DEC @RW3 | DEC @RW3+d16 | MOV <br> A, @RW3 | MOV A, @RW3+d16 | MOV @RW3, A | MOV @R <br> W3+d16, A | MOVX A, @RW3 | MOVX A, @RW3+d16 | $\mathrm{XCH}$ <br> A, @RW3 | XCH A , @RW3+d16 |
| +C | ROLC @RW0+ | 'ROLC @RW0+RW7 | RORC @RW0+ | RORC @RW0+RW7 | INC @RW0+ | INC @RW0+RW7 | DEC @RW0+ | DEC @RW0+RW7 | MOV A, @RW0 | ' MOV A, <br> + @RW0+RW7 | MOV @RW0+, A | MOV @R W0+RW7, A | MOVX A, @RW0+ | MOVX A, @RW0+RW7 | $\mathrm{XCH}$ <br> A, @RW0+ | XCH A, @RW0+RW7 |
| +D | ROLC @RW1+ | $\begin{aligned} & \text { ROLC } \\ & \text { @RW1+RW7 } \end{aligned}$ | RORC @RW1+ | $\begin{aligned} & \text { RORC } \\ & \text { @RW }+ \text { RW7 } \end{aligned}$ | INC @RW1+ | INC @RW1+RW7 | DEC @RW1+ | DEC <br> '@RW1+RW7 | MOV | MOV A, <br> + @RW1+RW7 | MOV @RW1+, A | MOV @R <br> W1+RW7, A | MOVX A, @RW1+ | MOVX A, @RW1+RW7 | $\mathrm{XCH}$ <br> A, @RW1+ | XCH A, <br> @RW1+RW7 |
| +E | ROLC @RW2+ | ROLC <br> @PC+d16 | RORC @RW2+ | RORC <br> @PC+d16 | INC @RW2+ | $\begin{aligned} & \text { INC } \\ & \text { @PC+d16 } \end{aligned}$ | DEC @RW2+ | $\begin{aligned} & \text { DEC } \\ & \text { @PC+d16 } \end{aligned}$ | MOV <br> A, @RW2 | MOV A, @PC+d16 | MOV @RW2+, A | MOV @P <br> C+d16, A | MOVX A, @RW2+ | MOVX A, @PC+d16 | $\overline{X C H}$ <br> A, @RW2+ | XCH A, @PC+d16 |
| +F | ROLC @RW3+ | ROLC | RORC @RW3+ | $\begin{array}{r} \text { RORC } \\ \quad \text { addr16 } \\ \hline \end{array}$ | INC @RW3+ | $\begin{aligned} & \text { INC } \\ & \text { addr16 } \\ & \hline \end{aligned}$ | DEC @RW3+ | $\begin{aligned} & \text { DEC } \\ & \text { addr16 } \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { A, @RW3+ } \end{aligned}$ | + MOV A, $+\quad$ addr16 | MOV | $\begin{aligned} & \text { MOV } \\ & \text { addr16, A } \\ & \hline \end{aligned}$ | MOVX <br> A, @RW3+ | $\begin{aligned} & \text { MOVX A, } \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, @ \mathrm{RW} 3+! \end{aligned}$ | $\begin{aligned} & \text { XCH A, } \\ & \text { addr16 } \\ & \hline \end{aligned}$ |

Table B.3.1h"ea" Instructions 4 (First byte $=\mathbf{7 3 H}$ )

|  | 0 | 10 | 20 | 30 | 40 | 50 | 60 | 70 | 80 | 90 | A 0 | B 0 | C0 | D 0 | E 0 | F0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| +0 | JMP @RW0 | @@RWO+d8 | $\begin{aligned} & \text { CALL } \\ & \text { @RW0 } \end{aligned}$ | , CALL !@@RW0+d8 | $\begin{gathered} \hline \text { INCW } \\ \text { RWO } \end{gathered}$ | $\begin{aligned} & \text { INCW } \\ & @ R W 0+d 8 \end{aligned}$ | $\begin{aligned} & \text { DECW } \\ & \text { RWO } \end{aligned}$ | $\begin{aligned} & \hline \mathrm{DECW} \\ & \text { @RW0+d8 } \end{aligned}$ | $\begin{aligned} & \text { MOVW } \\ & \text { A, RWO } \end{aligned}$ | MOVW A, @RW0+d8 | MOVW RWO, A | MOVW @R $\mathrm{W} 0+\mathrm{d} 8, \mathrm{~A}$ | $\begin{aligned} & \text { MOVW } \\ & \text { RW0, \#16! } \end{aligned}$ | MOVW @RW 0+d8, \#16 | $\begin{gathered} \text { CHW } \\ \text { A, RWO } \end{gathered}$ |  |
| +1 | M | IJMP <br> @@RW1+d8 | ALL @RW1 | $\begin{aligned} & \text { CALL } \\ & \text { @@RW1+d8 } \end{aligned}$ | $\mathrm{NCW}_{\mathrm{RW}}$ | $\begin{aligned} & \text { INCW } \\ & \text { @RW1+d8 } \end{aligned}$ | $\begin{aligned} & \text { DECW } \\ & \text { RW1 } \end{aligned}$ | $\begin{aligned} & \text { ECW } \\ & \text { @RW1+d8 } \end{aligned}$ | MOVWA, RW1 | MOVW A, @RW1+d8 | MOVW RW1, A | MOVW @R W1+d8, A | MOVW RW1, \#16 | MOVW@RW 1+d8, \#16 | $\begin{aligned} & \text { KCHW } \\ & \text { A, RW1 } \end{aligned}$ | XCHW A, @RW1+d8 |
| +2 | © | $\begin{aligned} & \text { JMP } \\ & \text { @ @RW2+d8 } \end{aligned}$ | ALL | $\begin{aligned} & \text { CALL } \\ & \text { @@RW2+d8 } \end{aligned}$ | $\begin{gathered} \text { ciw } \\ \text { RW2 } \end{gathered}$ | $\begin{gathered} 1 \mathrm{NCW}-- \\ @ R W 2+d 8 \end{gathered}$ | $\begin{gathered} \text { DECW } \\ \text { RW } \end{gathered}$ | @RW2+d8 | $\begin{gathered} \text { MOVW } \\ \hline \end{gathered}$ | MOVW A, @RW2+d8 | MOVW RW2, A | MOVW @R W2+d8, A | movw RW2, \#16 | MOVW@RW 2+d8,\#16 | $\begin{aligned} & \mathrm{XCHW}, \mathrm{RW} 2 \end{aligned}$ | XCHW A, @RW2+d8 |
| +3 |  |  | ALL | $\begin{aligned} & \text { CALL } \\ & \text { @@RW3+d8 } \end{aligned}$ | $\begin{gathered} \text { CCW } \\ \text { RW3 } \end{gathered}$ |  | $\begin{gathered} \text { CCW } \\ \text { RW3 } \end{gathered}$ |  | $\underset{A, R W}{M O}$ | MOVW A, @RW3+d8 | MOVW RW3, A | MOVW @R W3+d8, A | MOVW RW3, \#16 | MOVW @RW 3+d8, \#16 | ${ }_{A, ~ R W W}^{2}$ | CHW A, @RW3+d8 |
| +4 | JMP |  | $\begin{aligned} & \text { CALL } \\ & \text { @RW4 } \end{aligned}$ | $\begin{aligned} & \text { CALL } \\ & \text { @@R4+d8 } \end{aligned}$ | $\underset{\text { RW4 }}{\substack{\text { NNCW }}}$ |  | $\begin{gathered} \text { DECW } \\ \text { RW4 } \end{gathered}$ |  | $\begin{gathered} \mathrm{MOVW}, \mathrm{RW}_{4} \\ \hline \end{gathered}$ | MOVW A, @RW4+d8 | MOVW RW4, A | MOVW @R W4+d8, A | MOVW RW4, \#16 | MOVW @RW $4+d 8, \# 16$ | ${ }_{\text {CHW }}^{\text {R RW }}$ |  |
| +5 | JMP @RW5 |  | $\begin{gathered} \text { CALL } \\ \text { @RW5 } \end{gathered}$ | $\begin{aligned} & \mathrm{CALL} \\ & \text { @ } @+\mathrm{d8} 8 \end{aligned}$ | $\underset{\text { RW5 }}{\substack{\text { INCW }}}$ |  | $\begin{gathered} \text { DECW } \\ \text { RWW5 } \end{gathered}$ |  | $\begin{aligned} & \text { MOVW } \\ & \text { A, RW5 } \end{aligned}$ | MOVW A, @RW5+d8 | MOVW RW5, A | MOVW @R W5+d8, A | MOVW RW5, \#16 | $\begin{aligned} & \text { MOVW@RW } \end{aligned}$ $5+d 8, \# 16$ | $\underset{A, \text { RW5 }}{\text { XCHW }}$ |  |
| +6 | JMP @RW6 | MP @@RW6+d8 | CALL @RW | $\begin{aligned} & \text { CALL } \\ & \text { @@W6+d8 } \end{aligned}$ | $\underset{\text { RW6 }}{\text { INCW }}$ | CW @RW6+d8 | $\begin{gathered} E C W \\ \text { RW6 } \end{gathered}$ |  | כטw $A, R M$ | MOVW A. @RW6+d8 | MOVW RW6, A | MOVW @R W6+d8, A | MOVW RW6, \#16 | iw | $\begin{aligned} & \text { CHW } \\ & \text { A, RW6 } \end{aligned}$ |  |
| +7 | @RW7 | @@RW7+d8 | ALL @RW7 | CALL '@@RW7+d8 | $\begin{gathered} \text { INCW } \\ \text { RW } \end{gathered}$ | NCW @RW7+d8 | $\begin{gathered} \text { DECW } \\ \text { RW7 } \end{gathered}$ | ECW @RW7+ | MOVW A, RW7 | MOVW A. @RW7+d8 | MOVW RW7, A | MOVW @R W7+d8, A | MOVW RW7, \#16 | MOVW @RW <br> 7+d8, \#16 | - HW A, RW7 |  |
| +8 | @@RW | @@RW0+d16 | @@RW0 | $\begin{aligned} & \text { CALL } \\ & @ @ R W 0+d 16 \end{aligned}$ | INCW @R | @RW0+d16 | @RV | $\begin{aligned} & \text { CW } \\ & \text { RWO } \end{aligned}$ | MOVW <br> A, @RW0 | MOVW A @RW0+d16 | MOVW @RW0, A | MOVW @R W0+d16, A | MOVW @RW0, \#16 | MOVW@RW0 <br> +d16, \#16 | XCHW A, @RW0 |  |
| +9 | JMP @@RW | @@RW1+d16 | @@RW1 | ,@@RW1+d16 | INCW | NCW @RW1+d16 | @RW1 | W1+d16 | MOVW <br> A, @RW1 | MOVW A, @RW1+d16 | MOVW @RW1. A | MOVW @R W1+d16, A | MOVW <br> @RW1, \#16 | MOVW@RW1 +d16, \#16 | XCHW <br> A, @RW1 | XCHW A, @RW1+d16 |
| +A | JMP @@RW2 | @@RW2+d16 | CALL @@RW2 | @@RW2+d16 | INCW @RW | INCW @RW2+d16 | @RW2 | RW2+d16 | MOVW <br> A, @RW | MOVW A, @RW2+d16 | MOVW @RW2, | MOVW @R W2+d16, A | MOVW @RW2, \#16 | MOVW@ +d16, \#1 | CHW <br> A, @RW2 | XCHW A, @RW2+d16 |
| B | JMP @@RW3 | 'JMP '@@RW3+d16 | CALL <br> @@RW3 | @@RW3+d16 | INCW @RW3 | INCW @RW3+d16 | DECW @RW3 | DECW @RW3+d16 | MOVW <br> A, @RW3 | MOVW A @RW3+d16 | MOVW @RW3, A | MOVW @R W3+d16, A | MOVW @RW3, \#16' | MOVW @RW3 <br> +d16, \#16 | CHW <br> A, @RW3 | XCHW A @RW3+d16 |
| c | JMP @@RW0 | @RW0+RW7 | CALL @@RW | $\text { CALL } @ \text { QWW }$ | @RW0 | INCW @RW0+RW7 | DECW @RW0+ | DECW @RW0+RW7 | MOVW <br> A, @RW | MOVW A @RW0+RW7 | MOVW @RW0+, A | MOVW @R W0+RW7, A | MOVW @ RW0+, \#16 | MOVW@RWO <br> +RW7, \#16 | XCHW <br> A, @RWO+ | RWO + RW7 |
| D | JMP @@RW | @ ${ }^{\text {RWW1+RW7 }}$ | CALL @@RW |  | @RW | INCW @RW1+RW7 | DECW @RW1+ | $\begin{aligned} & \text { DECW } \\ & \text { @RW1+RW7 } \end{aligned}$ | MOVW <br> A, @RW | MOVW A, @RW1+RW7 | MOVW @RW1+, A | MOVW @R W1+RW7, A | MOVw @ <br> RW1+, \#16 | MOVW @RW1 <br> +RW7, \#16 | XCHW <br> A, @RW1 | RW1+RW7 |
| +E | @@RW | @PC+d16 | CALL @@RW2 | CALL @@PC+d16 | @RW2+ | I INCW @PC+d16 | DECW @RW2+ | $@ \mathrm{CC}+\mathrm{d} 1$ | MOVW A, @RW2 | MOVW A, @PC+d16 | MOVW <br> @RW2+, A | $\begin{aligned} & \text { MOVW @P } \\ & \text { C+d16, A } \end{aligned}$ | MOVW @ <br> RW2+, \#16 | MOVW @PC <br> +d16, \#16 | XCHW <br> A, @RW2 | XCHW A, @PC+d16 |
| +F | @@RW3+ | $\begin{aligned} & \text { MMP - } \\ & 1 \text { @addr16 } \end{aligned}$ | CALL @@RW3+ | $\begin{gathered} \text { CALL } \\ \text { @addr16 } \end{gathered}$ | $\begin{gathered} \text { INCW } \\ \text { @RW3 } \end{gathered}$ | $\begin{gathered} \text { INCW } \\ \text { addr16 } \end{gathered}$ | $\begin{aligned} & \text { DECW } \\ & \text { @RW3+ } \end{aligned}$ | DECW <br> addr16 | MOVW <br> A, @RW3 | ${ }_{+}{ }^{\text {MOVW }}$ addr16 , | MOVW @RW3+, A | MOVW addr16, A | $\begin{gathered} \text { MOVW @ } \\ \text { RW3+, \#16 } \end{gathered}$ | MOVW ad dr16, \#16 | $\begin{gathered} \text { XCHW } \\ \text { A, @RW3+1 } \end{gathered}$ | XCHW A, |

Table B.3.1i"ea" Instructions 5 (First byte = 74H)

|  | 00 | 10 | 2030 | 40 | 50 | 60 | 70 | 80 | 90 | A 0 | во | co | D 0 | E 0 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| +0 | $\begin{gathered} \mathrm{ADD} \\ \mathrm{~A}, \mathrm{RO} \end{gathered}$ | ADD @RWO+d8 | $\begin{array}{c:c} \hline \text { SUB } & \text { SUB } \\ \text { A, R0 } & \text { @RW0+d8 } \end{array}$ | $\begin{aligned} & \hline \text { ADDC } \\ & \text { A, RO } \end{aligned}$ | $\begin{array}{\|c\|} \hline \text { ADDC } \\ \text { ARW0+d8 } \end{array}$ | $\begin{array}{cc} \mathrm{CMP}_{\mathrm{A}, \mathrm{RO}} \end{array}$ | CMP @RWO A, 88 | $\begin{aligned} & \text { AND } \\ & \text { A, RO } \end{aligned}$ | $\begin{array}{cc} \text { AND } & \text { A, } \\ \text { @RWO } \mathrm{d} 8 \end{array}$ | $\mathrm{OR}_{\mathrm{A}, \mathrm{RO}}$ | $\begin{aligned} & \mathrm{CR} \begin{array}{c} \mathrm{A} \\ \text { QRWO+d8 } \end{array} \end{aligned}$ | $\underset{A, R 0}{ }$ | $\begin{aligned} & \mathrm{OR} \quad \begin{array}{c} \mathrm{A}_{1} \\ @ \mathrm{ORWO}+\mathrm{d} \end{array} \end{aligned}$ | Ro, | $\begin{aligned} & \text { BNZ } \\ & \text { RWO }+d 8, r \end{aligned}$ |
| +1 | $\begin{array}{r} \text { ADD } \\ \text { A, } 1 \end{array}$ | $\begin{gathered} \text { ADD }, \\ @ R W 1+d 8 \end{gathered}$ | $\begin{array}{c:c}\text { SUB } & \text { SUB A, } \\ \text { A, R1 } & \text { @RW1+d8 }\end{array}$ | $\begin{gathered} A, R 1 \end{gathered}$ | $\begin{gathered} \text { ADDC A, } \\ \text { @RW1+d8 } \end{gathered}$ | $\text { CMP }{ }_{\text {A, R1 }}$ | $\begin{gathered} \text { CMP A, } \\ @ R W 1+d 8 \end{gathered}$ | AND | $\begin{gathered} \text { AND } \\ @ R W 1+d 8 \end{gathered}$ | OR A, R1 | $\begin{gathered} \mathrm{OR}^{\mathrm{A},} \\ \mathrm{@RW} 1+\mathrm{d} 8 \end{gathered}$ | $\begin{array}{r} \text { XOR } \\ \text { A, R1 } \end{array}$ | $\begin{gathered} \text { XOR } \\ \text { @RW1+d } 8 \end{gathered}$ | $\mathrm{NZ}_{\mathrm{R} 1},$ | $\begin{aligned} & \text { BNZ }{ }^{-} \text {@ } 1+d 8, r \end{aligned}$ |
| +2 | $\mathrm{ADD}_{\mathrm{A}, \mathrm{R} 2}$ | ADD A, @RW2+d8 | $\begin{array}{c:c} \text { SUB } & \text { Si, R2 } \\ \text { @RW2+d8 } \\ \hline \end{array}$ | A-' $\bar{A} \bar{C}$ A, R2 | $\begin{gathered} \text { ADDC } \\ \text { @RW+d8 } \end{gathered}$ | ${ }_{\text {CM, R2 }}$ | CMP A, @RW2+d8 | ${ }_{A, R 2}$ | AND A, @RW2+d8 | $\mathrm{OR}_{\mathrm{A}, \mathrm{R} 2}$ | A, @RW2+d8 | $\underset{A, R 2}{X O R}$ | $\begin{aligned} & \text { XOR } \quad \text { A, } \\ & \text { @RW2+d8 } \end{aligned}$ | DBNZ <br> R2, | $\begin{aligned} & \text { BNZ }{ }^{\text {RN } 2+d 8, r} \end{aligned}$ |
| +3 | $\begin{array}{r} \text { ADD } \\ \text { A, } \end{array}$ | $\begin{gathered} \text { ADD } \\ \text { @RW3 } \mathrm{A} \end{gathered}$ | $\begin{array}{\|c\|c} \hline \text { SUB } & \text { ABB } \\ \hline \end{array}$ | $\begin{gathered} \text { AD, R3 } \end{gathered}$ | $\begin{array}{r} \text { ADDC } \\ \text { @RW3 }+ \text {, } \end{array}$ | $\begin{gathered} \text { CMP } \\ \text { A, R3 } \end{gathered}$ | $\begin{gathered} \text { CMP } \\ @ R W 3+d 8 \end{gathered}$ | AND | $\begin{array}{r} \text { AND } \\ \text { @RW3+d8 } \end{array}$ | OR <br> A, R3 | $\begin{gathered} \text { OR A, } \\ \text { @RW3+d8 } \end{gathered}$ | $\underset{A, R 3}{ }$ | $\begin{aligned} & \text { Xor } \\ & @ R W 3+d 8 \end{aligned}$ | DBNZ <br> R3 | $\begin{aligned} & \mathbf{V N O}^{\circ} \mathrm{CW3+d8,r} \end{aligned}$ |
| +4 | $\begin{array}{r} \text { ADD } \\ \text { A, R4 } \end{array}$ |  | $\begin{array}{c:c} \text { SUB } \\ \text { A, R4 } & \text { SUB } \\ \text { @R4+d8 } \end{array}$ | $\begin{gathered} \overline{\text { ADDC }} \\ \text { A, R4 } \end{gathered}$ | $\begin{gathered} \text { ADDC } \\ \text { @RW+d } \end{gathered}$ | ${ }_{\text {CMP }}^{\text {A, R4 }}$ | $\begin{gathered} \text { CMP A, } \\ @ R W 4+d 8 \end{gathered}$ | $\stackrel{\text { AND }}{\text { A, R4 }}$ | AND A, @RW4 +d 8 | $\begin{array}{ll} \text { OR } 4 \end{array}$ | OR A, @RW4+d8 | $\underset{A, R 4}{X O R}$ | $\begin{gathered} \text { XOR A, } \\ @ R W 4+d 8 \end{gathered}$ | DBNZ | BNZ @ RW4+d8, |
| +5 | $\begin{array}{r} \text { ADD } \\ \text { A, R5 } \end{array}$ | $\begin{aligned} & \text { ADD } \\ & @ R W 5+d B \end{aligned}$ | $\begin{array}{cc} \text { UB } & \text { SUB } \\ \text { A, R5 } & \text {, } \\ \text { @RW5+d8 } \end{array}$ | $\begin{gathered} \text { ADDC } \\ \hline \text { A, } \end{gathered}$ | $\begin{gathered} \text { ADDC A, } \\ \text { @RW5+d8 } \end{gathered}$ | ${ }_{\text {CMP }}^{\text {A, R5 }}$ | $\begin{aligned} & \text { CMP A, } \\ & @ R W 5+d 8 \end{aligned}$ | ${ }_{\text {AND }} \mathrm{RD}^{2}$ | , @ND A, | $\mathrm{OR}_{\mathrm{A}, \mathrm{R5}}$ | $\begin{gathered} \mathrm{OR}^{\mathrm{A},} \\ \mathrm{@RW}+\mathrm{d} 8 \end{gathered}$ | $\underset{A, R 5}{X O R}$ | $\begin{aligned} & \text { xOR } \\ & @ R W 5+d 8 \end{aligned}$ | DBNZ | $\begin{aligned} & \text { OBNZ @ } \\ & \text { RW5+d8,r } \end{aligned}$ |
| +6 | A, R6 | $\begin{gathered} \text { ADD } \\ \text { @RW6+d8 } \end{gathered}$ | $\begin{array}{ccc} \mathrm{UB} & \text { SUB } \\ \text { A, } 6 & \text { A } \\ \hline \end{array}$ | $\begin{gathered} A, R 6 \end{gathered}$ | $\begin{gathered} \text { ADDC A, } \\ @ R W 6+d 8 \end{gathered}$ | ${ }^{\text {CMP }}$ | $\begin{gathered} \text { CMP A, } \\ @ R W 6+d 8 \end{gathered}$ | ${ }_{A, R}$ | $\begin{gathered} \text { AND } \\ @ R W 6+d 8 \end{gathered}$ | A, R6 | $\begin{gathered} \text { OR } \\ @ R W 6+d 8 \end{gathered}$ | $\underset{A, R 6}{X O R}$ | $\begin{gathered} \text { XOR A, } \\ @ R W 6+d 8 \end{gathered}$ | - | $\begin{aligned} & \text { OBNZ @ @ } \\ & \text { RW } 6+d 8, r \end{aligned}$ |
| +7 | $\stackrel{A D D}{A, R 7}$ | $\begin{gathered} \text { ADD A, } \\ @ R W 7+d 8 \end{gathered}$ | $\begin{array}{cc} \text { UB } & \text { SUB } \\ \text { A, R7 } & \text { @RW7, } \\ \cline { 1 - 3 } \end{array}$ |  | $\begin{gathered} \text { ADDC A, } \\ \text { @RW7+d8 } \end{gathered}$ | ${ }_{\text {CMP }}^{\text {A, R7 }}$ | $\begin{gathered} \text { CMP A, } \\ @ R W 7+d 8 \end{gathered}$ | $\stackrel{\text { AND }}{\mathrm{A}, \mathrm{R} 7}$ | $\begin{gathered} \text { AND A, A, } \\ \text { @RW7+d8 } \end{gathered}$ | A, R7 | QRW7+d8 @ | $\begin{array}{r} \mathrm{XOR} \\ \mathrm{~A}, \mathrm{R} 7 \end{array}$ | $\begin{gathered} \text { XOR A, } \\ @ R W 7+d 8 \end{gathered}$ | DBNZ $\mathrm{RT}, \mathrm{r}$ | $\begin{aligned} & \text { VBNZ } \\ & \mathrm{RW7}+\mathrm{dB}, \mathrm{r} \end{aligned}$ |
| +8 | $\begin{array}{r} \text { ADD } \\ \text { A, @RWO } \end{array}$ | ADD | $\begin{array}{cc} \text { SUB } \\ A, @ R W O & \text { SRWO } \\ \hline \end{array}$ | ADDC A, @RW0 | $\begin{gathered} \text { ADDC A, } \\ \text { @RWO+d16 } \end{gathered}$ | CMP <br> A, @RW0 | $\begin{aligned} & \text { CMP }{ }_{\text {A }} \text { @RWO+d } \end{aligned}$ | AND A, @RW0 | $: \begin{gathered} -A N D \\ \hline \text { @RWO+d16 } \end{gathered}$ | A, @RW0 | $\begin{array}{cc}\text { OR } & \text { A, } \\ \text { @RW0+d16 }\end{array}$ | $\begin{aligned} & \text { XOR } @ R W 0 \end{aligned}$ | @ROA Ad | DBNZ @RWo, r | $\begin{aligned} & \text { SBNZ } \\ & \text { RWO+d6, r } \end{aligned}$ |
| +9 | ADD @RW | $\begin{aligned} & \text { ADD } \mathrm{A}, \mathrm{~A}, \\ & \text { @RW1+d16 } \end{aligned}$ | $\begin{array}{c:c} \mathrm{suB}_{\mathrm{A}} \text { @RW1 } & \text { @RW1+d16 } \\ \hline \end{array}$ | ADDC <br> A, @RW1 | $\begin{aligned} & \text { ADD } \\ & \text { ©RW1 } \\ & \text { A } \end{aligned}$ | $\begin{aligned} & \text { CMP } \\ & \text { A, @RW } \end{aligned}$ | $\begin{array}{l:c} 1 \\ \text { CMP } & A, \\ 1 \end{array}$ | AND A, @RW1 | $\begin{aligned} & \text { AND, } \\ & \text { @RW1+d } 16 \end{aligned}$ | $\begin{aligned} & \text { OR, @RW1 } \end{aligned}$ | $\begin{aligned} & \mathrm{OR} \\ & @ R W 1+d 16 \end{aligned}$ | $\begin{aligned} & \text { XOR } \\ & \text { A, @RW1 } \end{aligned}$ | $\begin{aligned} & \text { XOR A, } \\ & @ R W 1+d 16 \end{aligned}$ | DBNZ @RW1, r | DBNZ RW1+d16, $r$ |
| +A | $\begin{gathered} \text { ADD } \\ \text { A, @RW2 } \end{gathered}$ | $\begin{aligned} & \text { ADD A, A, } \\ & \text { @RW2+d16 } \end{aligned}$ | $\begin{array}{c:c} \text { SUB } \\ \text { @RW2 } & \text { @RW2+d16 } \end{array}$ | ADDC A, @RW2 | $\begin{aligned} & \text { ADDC } \\ & \text { @RW2+d16 } \end{aligned}$ | CMP <br> A, @RW2 | $\begin{array}{c:c} 1 \mathrm{AMP} \\ 2 \mathrm{ARW}+\mathrm{d} 16 \end{array}$ | AND A, @RW2 |  | $\begin{aligned} & \text { OR @RW2 } \\ & \text { A, } \end{aligned}$ | OR A, @RW2+d16 | - ${ }^{-1}{ }^{-1}$ <br> A, @RW2 | $\begin{array}{ll} \text { OR } \\ \text { @RW2 }+d_{1} \end{array}$ | DBNZ @RW2, r | DBNZ RW2+d16, $r$ |
| +B | ADD | $\begin{aligned} & \text { ADD } \\ & @ R W 3+d 16 \end{aligned}$ | SUB | ADDC <br> A, @RW3 | $\begin{aligned} & \text { ADDC }-\bar{A}, \\ & @ R W 3+d 16 \end{aligned}$ | $\begin{aligned} & \text { CMP } \\ & \text { A, @RW3 } \end{aligned}$ | $\begin{gathered} 1 \\ M M P \\ @ R W 3+d 16 \end{gathered}$ | AND A, @RW3' | $\begin{aligned} & \text { AND } \\ & \text { @RW3 }+\mathrm{d} 16 \end{aligned}$ | $\begin{gathered} \text { A, @RW3 } \end{gathered}$ | $\begin{gathered} \text { OR } \\ \text { @RW3+d16 } \end{gathered}$ | XOR @RW3 | $\begin{aligned} & \text { xor A, } \\ & \text { @RW3 }{ }^{\prime} \text { +d16 } \end{aligned}$ | DBNZ @RW3, r | DBNZ RW3+d16, r |
| +C | $\begin{aligned} & \text { ADD } \\ & \text { A, @RW0+ } \end{aligned}$ | $\begin{array}{\|c\|} \hline \text { ADD } \\ \text { ARWO+RW7 } \end{array}$ | $\begin{array}{cc} \text { sUB } \\ A, @ R W O+ & \text { SRBO } \\ \hline \text { A } \\ \hline \end{array}$ | ADDC A, @RW0+ | $\begin{aligned} & \text { ADDC A, } \\ & \text { @RW0+RW7 } \end{aligned}$ | $\begin{aligned} & \text { CMP } \\ & \text { A, @RWO+ } \end{aligned}$ | $\begin{aligned} & 1 \text { CMP } \mathrm{A}, \\ & +\quad \text { QRWO+RW7 } \end{aligned}$ | AND <br> A, @RW0+ | $\begin{gathered} \text { AND A, A, } \\ + \text { @RWO }+ \text { RW7 } \end{gathered}$ | A, @RWO+ | $\begin{aligned} & \text { OR } \\ & \text { @RWO+RW7 } \end{aligned}$ | $\begin{aligned} & \text { XOR } \\ & \text { A, @RW0+ } \end{aligned}$ | $\begin{aligned} & \text { XOR A, A } \\ & \text { ARWO+RW } \end{aligned}$ | DBNZ @RWO+, r | DBNZ <br> RW0+RW7 |
| +D | ADD, @RW1+ | $\begin{aligned} & \text { ADD } \\ & @ R W 1+R W \end{aligned}$ | $\begin{array}{r} \text { SUB } \\ \text { A, @RW1+@RW1+RW } \end{array}$ | ADDC <br> A, @RW1+ | $\begin{aligned} & \text { ADDC } \\ & @ R W 1+R W 7 \end{aligned}$ | $\begin{aligned} & \text { CMP } \\ & \text { A, @RW1. } \end{aligned}$ |  | AND, @RW1+ |  | $\begin{aligned} & \text { OR } \\ & \text { A, @RW1+ } \end{aligned}$ | $\begin{gathered} \mathrm{A}, \\ \mathrm{ORW}+\mathrm{RW} 7 \end{gathered}$ | AOR @RW1+ | $\begin{aligned} & \text { XoR } \\ & @ R W 1+R W 7 \end{aligned}$ | DBNZ @RW1+ | DBNZ RW1+RW7, r |
| +E | $\begin{aligned} & \text { ADD } \\ & \text { A, @RW2+ } \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { @PC+d16, } \end{aligned}$ | $\begin{aligned} & \text { SUB }{ }_{A} \text { SRW2+ } @ P C+d 16, ~ \end{aligned}$ | ADDC A, @RW2+ | $\begin{gathered} \text { ADDC A, } \\ @ P C+d 16 \end{gathered}$ | $\begin{aligned} & \text { CMP } \\ & \text { A, @RW2 } \end{aligned}$ | $\begin{aligned} & \text { CMP A, } \\ & +\quad @ P C+d 16 \end{aligned}$ | AND A, @RW2+ | AND A, $+\quad$ @PC $+d 16$ | O' A, @RW2+ | $\begin{aligned} & \text { OR A, A, } \\ & \text { @ PC+d16 } \end{aligned}$ | $\begin{aligned} & \text { XOR } \\ & \text { A, @RW2+ } \end{aligned}$ | $\begin{aligned} & \text { XOR } \\ & \text { @PC+d16, } \end{aligned}$ | DBNZ @RW2+, | DBNZ <br> @ PC+d16, r |
| +F | $\begin{aligned} & \text { ADD } \\ & \text { A, @RW3+ } \end{aligned}$ | ${ }^{\mathrm{ADDD}} \mathrm{addr} 16_{\mathrm{A},}$ |  | ADDC <br> A, @RW3+ | $\begin{gathered} \text { ADDC } \\ \text { addr16 } \\ \hline \end{gathered}$ | $\begin{aligned} & \text { CMP } \\ & \text { A, @RW3 } \end{aligned}$ | $\begin{aligned} & \text { CMP }, \\ & +\quad \text { addr16 } \\ & \hline \end{aligned}$ | AND A, @RW3+ | $\begin{aligned} & \text { ADD }{ }^{\text {addr16 }}, \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { OR } \\ & \text { A, @RW3+ } \end{aligned}$ | $\begin{aligned} & \text { OR }{ }_{\text {addr16 }}, \end{aligned}$ | $\begin{gathered} \text { XOR } \\ \text { A, @RW3+ } \end{gathered}$ | $\begin{aligned} & \text { Xor } \\ & \text { addr16 } \end{aligned}$ | DBNZ @RW3+, r | DBNZ <br> @ addr16, r |

Table B.3.1j "ea" Instructions 6 (First byte $=\mathbf{7 5 H}$ )

|  | 00 | 10 | 20 | 30 | 40 | 50 | 60 | 70 | 80 | 90 | A 0 | в 0 | co | D 0 | E 0 | F 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| +0 | $\mathrm{ADD}_{\mathrm{RO}, \mathrm{~A}}$ | $\mathrm{d} 8, \mathrm{~A}^{@ R}$ | $\begin{aligned} & \mathrm{JB} \\ & \mathrm{RO}, \mathrm{~A} \end{aligned}$ | $\begin{array}{ll} \text { SUB } & \text { @R } \\ \text { W0 }+\mathrm{d} 8, ~ \\ \hline \end{array}$ | $\begin{aligned} & \text { SUBC } \\ & A, R O \end{aligned}$ | $\begin{aligned} & \hline \text { SUBC A, } \\ & \text { @RWO+d8 } \end{aligned}$ | $\begin{aligned} & \mathrm{EGG} \\ & \mathrm{RO} \end{aligned}$ | $\begin{aligned} & \text { NEG } \\ & @ R W 0+d 8 \end{aligned}$ | $\begin{aligned} & \mathrm{AND} \\ & \mathrm{RO}, \mathrm{~A} \end{aligned}$ | $\begin{gathered} \text { AND } \\ \mathrm{W} 0+\mathrm{d} 8, \mathrm{~A} \end{gathered}$ | $\mathrm{OR}_{\mathrm{RO}, \mathrm{~A}}$ | 'OR @RW0+d8, A | $\mathrm{XOR}_{\mathrm{RO}, \mathrm{~A}}$ | $\begin{array}{ll} \hline \text { XOR } & @ R \\ \text { W0 }+\mathrm{d} 8, & A \end{array}$ | $\begin{gathered} \text { NOT } \\ \text { RO } \end{gathered}$ | OT @RW0+d8 |
| +1 | ${ }_{\text {R1, A }}$ | $\begin{aligned} & \text { ADD } \\ & W 1+d 8, ~ A \\ & \hline \end{aligned}$ | ${ }_{\text {R1, }}$ | $\begin{aligned} & \text { SUB } \\ & \text { W1+d8, } \\ & \text { AR } \end{aligned}$ | $\begin{aligned} & \text { SUBC } \\ & A, R 1 \end{aligned}$ | $\begin{array}{cc} \hline \text { SUBC } \\ @ R W 1+d 8 \end{array}$ | $\mathrm{EG}_{\mathrm{R}}$ | NEG @RW1+d8 | ${ }_{\text {AND }} \mathrm{A}_{\mathrm{A}}$ | $\begin{gathered} \text { AND } \\ W 1+d 8, ~ \\ \hline \end{gathered}$ | OR $\mathrm{R} 1, \mathrm{~A}$ | OR @RW1+d8, A | R1, A | $\begin{gathered} \text { XOR @ } \\ \text { W1+d8, } \\ \hline \end{gathered}$ | $\mathrm{ROT}_{\mathrm{R}}$ | NOT @RW1+d8 |
| +2 | $\begin{array}{r} \text { ADD } \\ \text { R2, } \end{array}$ | $\begin{aligned} & A D D \\ & \mathrm{~W} 2+\mathrm{dB}, \mathrm{~A} \end{aligned}$ | R2, A | $\text { W2 } \mathrm{Cd8}, \mathrm{~A}$ | $\mathrm{SUBC}_{\mathrm{A}, \mathrm{R}}$ |  | $\mathrm{EG}_{\mathrm{R}}$ | NEG @RW2+d8 | $\begin{gathered} \mathrm{AND}, \mathrm{~A} \end{gathered}$ | $\text { AND } \begin{gathered} \text { WR }+d 8, ~ A \\ \hline \end{gathered}$ | or <br> R2, A | OR @RW2+d8, A | $\mathrm{XOR}$ |  | $\mathrm{R}_{2}$ | NOT @RW2+d8 |
| +3 | $\begin{array}{r} \text { ADD } \\ \text { R3, } \end{array}$ | $\begin{aligned} & A D D \\ & \mathrm{~W} 3+\mathrm{dB}, \mathrm{~A} \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { SUB } \\ & R 3, A \end{aligned}$ |  | $\begin{aligned} & \text { SUBC } \\ & \text { A, } \end{aligned}$ | SUBC A, @RW3 | $\begin{gathered} \overline{N E G} \\ \hline \end{gathered}$ | NEG @RW3+d8 | $\begin{gathered} \text { AND, } \end{gathered}$ | $\begin{aligned} & \text { AND } \\ & \text { W } \\ & \text { WR } \\ & \hline \end{aligned}$ | or <br> R3, A | OR , @RW3+d8, A | R3, |  | $\begin{array}{r} \text { NO } \end{array}$ | NOT @RW3+d8 |
| +4 | $\begin{array}{r} \text { ADD } \\ \text { R4, A } \end{array}$ | $\begin{aligned} & A D D+d 8, ~ @ R \\ & \hline \end{aligned}$ | SUB |  | $\begin{aligned} & \text { SUBC R4 } \end{aligned}$ | $\begin{gathered} - \text { SUBC }^{-A} \\ \text { @RW4+d8 } \end{gathered}$ | $\begin{gathered} \mathrm{NEG} \\ \mathrm{R} 4 \end{gathered}$ | NEG @RW4+d8 | AND <br> R4, A | $\begin{gathered} \text { AND } \\ \text { W4+d8, } \\ \text { AR } \end{gathered}$ | $\mathrm{OR}_{\mathrm{R}, \mathrm{~A}}$ | OR @RW4+d8, A | R4 | $\begin{gathered} \text { xOR } \\ \mathrm{W} 4+\mathrm{d}, \mathrm{~A}^{\mathrm{R}} \end{gathered}$ | $\begin{gathered} \mathrm{NOT} \\ \hline \end{gathered}$ | NOT @RW4+d8 |
| +5 | $\mathrm{ADD}$ | $\begin{aligned} & A D D+d 8, ~ @ R \\ & \hline \end{aligned}$ | SUB | W5 | $\begin{aligned} & \text { SUB, R5 } \end{aligned}$ | $\begin{gathered} \text { subc } \\ \text { @RW5 } \\ \text { A } 8 \end{gathered}$ | $\begin{aligned} & \mathrm{NE} \\ & \hline \end{aligned}$ | NEG @RW5+d8 | AND | $\text { AND } \mathrm{W}+d 8, \mathrm{~A}$ | ${ }^{\mathrm{OR}} \mathrm{R}, \mathrm{~A}$ | OR <br> @RW5+d8, A | R5, | $\begin{gathered} x_{0} \\ w 5+d 8, A \\ \hline \end{gathered}$ | NOT | NOT @RW5+d8 |
| +6 | $\underset{R 6, A}{A D D_{2}}$ | $\begin{aligned} & \text { ADD } \\ & \text { W6+d8, A } \end{aligned}$ | $\mathrm{UB}_{\mathrm{RG}, \mathrm{~A}}$ | UB | $\underset{\text { A, R6 }}{\text { SUBC }}$ | $\begin{array}{cc} \text { SUBC } & \text { A, } \\ @ R W 6+d 8 \end{array}$ | EG | NEG @RW6+d8 | ${ }_{\text {R6, A }}$ | $: \begin{gathered} \text { AND } \\ \mathrm{Wb}+\mathrm{dB},{ }_{\mathrm{A}}^{@ R} \end{gathered}$ | or <br> R6, A | OR @RW6+d8, A | $\mathrm{R}_{\mathrm{R}} \mathrm{R} \text {, }$ | $\begin{gathered} \text { XOR } \\ \text { W } 6+d 8, ~ A \end{gathered}$ | $\begin{array}{r} \mathrm{NOT} \\ \mathrm{R} \end{array}$ | NOT @RW6+d8 |
| +7 | ${ }^{\text {ADD }}$ |  | SUB | $\begin{array}{ll} \mathrm{UB} \\ \mathrm{~W} 7+\mathrm{d}, & \mathrm{~A} \\ \hline \end{array}$ | $\underset{A, R 7}{S U B C}$ | $\begin{gathered} \text { SUBC } \\ @ R W 7+d 8 \end{gathered}$ |  | $\begin{aligned} & \text { NEG } \\ & \text { @RW7+d8 } \end{aligned}$ | $\stackrel{A N D}{{ }_{R 7, ~}}$ |  | $\mathrm{OR}_{\mathrm{RT}, \mathrm{~A}}$ | OR @RW7+d8, A |  | $\begin{gathered} \text { XOR } \\ \mathrm{W} 7+\mathrm{d}, \mathrm{~A} \\ \hline \end{gathered}$ | $\begin{array}{r} \text { NOT } \\ \hline \end{array}$ | NOT @RW7+d8 |
| +8 | ADD @RW0, A | $\begin{aligned} & \bar{A} A D D^{-} \\ & \text {WO+d16, AR } \end{aligned}$ | SUB @RW0, | UB @R W0+d16, A | SUBC A, @RW0 | $\begin{array}{cc} \text { SUBC }^{-A} \\ @ R W 0+d 16 \end{array}$ | NEG @RW0 | NEG @RW0+d16 | AND @RW0, A | $\begin{aligned} & \text { AND } @ R \\ & \mathrm{~W} 0+\mathrm{d} 16, A \end{aligned}$ | OR @RW0, A | ' @RW0+d16, A | XOR @RW0, A | $\begin{gathered} \text { XOR } \\ \text { W0 }+\mathrm{d} 16, \mathrm{~A} \end{gathered}$ | NOT @RW0 | NOT @RW0+d16 |
| +9 | ADD @RW1, A | $\begin{aligned} & A D D \\ & \mathrm{~W} 1+\mathrm{d} 6, \mathrm{~A} \end{aligned}$ | SUB @RW1, A | $\begin{aligned} & \text { SUB } \\ & \text { W1+d16, AR } \end{aligned}$ | SUBC A, @RW1 | $\begin{array}{ll} \text { SUBC } & \text { A, } \\ @ R W+d 16 \end{array}$ | NEG @RW1 | $\begin{aligned} & \text { NEG } \\ & @ R W 1+d 16 \end{aligned}$ | AND @RW1, A | $\begin{aligned} & \text { AND } \left.\begin{array}{l} @ R \\ W 1+d 16, A \end{array}\right] \end{aligned}$ | OR @RW1, A | $\begin{aligned} & \text { OR } \\ & \hline \text { ORW1+d16, A } \end{aligned}$ | XOR @RW1, A | $\begin{gathered} \text { XoR } \\ \mathrm{W} 1+\mathrm{d} 6, \mathrm{~A} \end{gathered}$ | NOT @RW1 | NOT @RW1+d16 |
| +A | ADD | $\begin{aligned} & \text { ADD } \\ & \text { RW2 }+d 16, A \\ & \hline \end{aligned}$ | SUB @RW2, A | $\begin{aligned} & \text { SUB } @ \mathrm{~B} \\ & \text { W2 } \mathrm{d} 16, \mathrm{~A} \end{aligned}$ | SUBC A, @RW2 | ' SUBC A, | NEG @RW2 | NEG @RW2+d16 | AND @RW2, A | $\begin{aligned} & \text { AND } \\ & \text { W2+d16, } \\ & \text { AR } \end{aligned}$ | or @RW2, A | 'OR @RW2+d16, A | XOR @RW2, A | $\begin{gathered} \text { xOR } \\ \text { W2 }+d 16, A \end{gathered}$ | NOT @RW2 | NOT @RW2+d16 |
| +B | ADD | $\begin{aligned} & : A D D \\ & \text { RW3+d16, } A \end{aligned}$ | @UB | $\begin{aligned} & \text { SUB } @ \mathrm{~B} \\ & \text { W } 3+\mathrm{d} 6, ~ A \end{aligned}$ | $\begin{aligned} & \text { SUBC } \quad \text { QRW3 } \end{aligned}$ | $\begin{aligned} & \text { SUBC A, } \\ & \text { @RW3+d16, } \end{aligned}$ | NEG @RW3 | NEG @RW3+d16 | AND @RW3, A | $\begin{aligned} & \text { AND } \\ & \text { W } 3+d 16, ~ \end{aligned}$ | OR @RW3, A | 'OR @RW3+d16, A | XOR @RW3, A | $\begin{gathered} \text { xOR } \\ \text { W3 }+\mathrm{d} 16, A \end{gathered}$ | NOT @RW3 | NOT @RW3+d16 |
| +C | ADD @RW0+, A | $\begin{gathered} A D D \\ \mathrm{AD} 0+\mathrm{RW}, \mathrm{~A} \\ \hline \end{gathered}$ | SUB @RW0+ |  | SUBC A, @RW0+ | $\begin{aligned} & \text { SUBC } \\ & \hline \end{aligned}$ | NEG @RWO+ | NEG @RW0+RW7 | AND @RW0+, A | $\begin{aligned} & \text { AND @R } \\ & \text { W } 0+R W 7, A \end{aligned}$ | OR @RW0+, A | $\begin{aligned} & \text { OR } \\ & \text { W0+RW7, } \end{aligned}$ | XOR @RW0+, A | $\begin{gathered} \text { XOR } \\ \text { WO } \\ \text { ORW7, A } \end{gathered}$ | NOT @RWO+ | NOT @RW0+RW7 |
| +D | ADD @RW1+, A | $\text { ADD } \mathrm{W}=\mathrm{BW}, \mathrm{~A}$ | $\begin{aligned} & \text { SUB } \\ & \text { @RW1+, A' } \end{aligned}$ | $\begin{aligned} & \text { SUB } @ R \\ & \text { W1+RW7, } \end{aligned}$ | SUBC A, @RW1+ |  | NEG @RW1+ | $\begin{aligned} & \mathrm{NEG} \\ & \text { @RW1+RW7 } \end{aligned}$ | AND <br> @RW1+, A | $\begin{aligned} & \text { AND @R } \\ & \text { W1+RW7, } \mathrm{A} \end{aligned}$ | ${ }^{\text {OR }} \text { @R1+, A }$ | W1+RW7, A | XOR <br> @RW1+, A | $\begin{gathered} \text { xOR } \\ \text { W1+RW7, A } \end{gathered}$ | NOT @RW1 | NOT @RW1+RW |
| +E | ADD @RW2+, A | $\begin{aligned} & \text { ADD } \\ & C+d 16, ~ A \end{aligned}$ | SUB @RW2+ | $\begin{gathered} \text { SUB } \\ C+d 16, ~ A P \\ \hline \end{gathered}$ | SUBC <br> A, @RW | $\begin{aligned} & 1 \text { SUBC } \\ & +\quad \text { @PC+d16 } \end{aligned}$ | NEG @RW2+ | NEG @PC+d16 | AND @RW2+, A | $\mathrm{AND}_{\mathrm{C}+\mathrm{d} 16, \mathrm{~A}}^{\mathrm{A}}$ | or @RW2+, A | 'OR @PC+d16, A | XOR @RW2+, A | $\begin{aligned} & \text { XOR } \\ & \text { C+d16, } \end{aligned}$ | NOT @RW2+ | NOT @PC+d16 |
| +F | $\begin{gathered} \text { ADD } \\ \text { @RW3+, A } \\ \hline \end{gathered}$ | $\begin{array}{r} \text { ADD } \\ 1 \\ \hline \end{array}$ | $\begin{aligned} & \text { SUB } \\ & \text { @RW3+, A' } \end{aligned}$ | $\begin{array}{r} \text { addr16, A } \\ \hline \end{array}$ | SUBC A, @RW3+ | $\begin{array}{r} 1 \\ +\quad \text { addr16 } \\ \hline \end{array}$ | NEG @RW3+ | NEG addr16 | AND @RW3+, A | AND <br> addr16, A | OR @RW3+, A | IOR <br> addr16, A | XOR @RW3+, A | XOR addr16, A | NOT @RW3+ | NOT addr16 |

Table B.3.1k"ea" Instructions 7 (First byte $=\mathbf{7 6 H}$ )

|  | 0 | 10 | 2 | 30 | 40 | 50 | 60 | 70 | 80 | 9 | A 0 | B 0 | co | D 0 | E 0 | F 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| +0 | $\begin{gathered} \text { ADDW } \\ \text { A, RW0 } \end{gathered}$ | $\begin{gathered} \text { ADDW } \begin{array}{c} \text { A, } \\ \text { @RW0+d8 } \end{array} \end{gathered}$ | $\underset{\text { A, RWO }}{\substack{\text { SUBW }}}$ | $\begin{aligned} & \text { SUBW A, } \\ & \text { @RWO+d8 } \end{aligned}$ | $\begin{gathered} \mathrm{ADDCW} \\ \mathrm{~A}, \mathrm{RWO} \end{gathered}$ | $\begin{array}{cc} \hline \text { ADDCW A, } \\ @ R W 0+d 8 \end{array}$ | $\begin{gathered} \text { CMPW } \\ \text { A, RWO } \end{gathered}$ | $\begin{gathered} \hline \text { CMPW } \begin{array}{r} \text { A, } \\ \text { @RWO+d8 } \end{array} \end{gathered}$ | $\begin{gathered} \text { ANDW } \\ \text { A, RW0: } \end{gathered}$ | $\begin{aligned} & \text { NDDW } \\ & \text { ARWO+d8 } \end{aligned}$ | $\begin{array}{\|c} \text { ORW } \\ \text { A, RWO } \end{array}$ | $\begin{gathered} \text { DRW } \\ @ R W O+d 8 \end{gathered}$ | $\underset{A, R W 0}{\text { XORW }}$ | $\begin{array}{cc} \hline \text { XORW } & \text { A, } \\ \text { @RWO+d8 } \end{array}$ | $\begin{gathered} \text { VBNZ } \\ \text { RWO, } \end{gathered}$ | WBNZ @ RW0+d8, r |
| +1 | $\underset{\text { A, RW1 }}{\text { ADDW }}$ | $\begin{gathered} \text { ADDW A, } \\ @ R W 1+d 8, \end{gathered}$ | $\begin{aligned} & \text { SUBW } \\ & \text { A, RW1 } \end{aligned}$ | $\begin{aligned} & \text { SUBW } \\ & @ R W 1+d 8, \end{aligned}$ | $\begin{aligned} & \text { ADDCW } \\ & \text { A, RW1 } \end{aligned}$ | $\begin{aligned} & \text { ADDCW A, } \\ & \text { @RW1+d8, } \end{aligned}$ | $\begin{gathered} \text { MPW } \\ \text { A, RW } \end{gathered}$ | $\begin{aligned} & \text { CMPW A, } \\ & \text { @RW1+d8 } \end{aligned}$ | $\begin{gathered} \text { ANDW } \\ \text { A, RW1 } \end{gathered}$ | $\begin{aligned} & \text { NDW A, } \\ & @ R W 1+\mathrm{di} \end{aligned}$ | $\begin{aligned} & \text { ORW } \\ & \text { A, RW1 } \end{aligned}$ | $\begin{aligned} & \text { AR } \\ & @ R W 1+d 8 \end{aligned}$ | $\begin{gathered} \text { XORW } \\ \hline \end{gathered}$ | $\begin{aligned} & \text { XORW A } \\ & @ R W 1+d 8 \end{aligned}$ | BNZ RW1, | RW1 <br> RW1+d8, |
| +2 | $\underset{\text { A, RW2 }}{\text { ADD }}$ | $\begin{aligned} & \text { ADDW A, } \\ & \text { @RW2+d8 } \end{aligned}$ | $\begin{aligned} & \text { SUBW } \\ & \text { A, RW2 } \end{aligned}$ | $\begin{aligned} & \text { SBW } \\ & @ R W 2+d 8, \end{aligned}$ | $\begin{aligned} & \text { ADDCW } \\ & \text { A, RW2 } \end{aligned}$ | ADDCW A, <br> @RW2+d8 | MPW A, RW2 | $\begin{gathered} C M P W \\ @ R W 2+d 8 \\ @ \end{gathered}$ | ANDW A, RW2 | $\begin{aligned} & \text { ANDW A, } \\ & \text { @RW2+d8 } \end{aligned}$ | ORW A, RW2 | $\begin{gathered} \mathrm{ORW} \\ @ \mathrm{AW} 2+\mathrm{d}, \\ \hline \end{gathered}$ | XORW A, RW2 | $\begin{gathered} \text { XORW A, } \\ \text { @RW2+d8 } \end{gathered}$ | RW2, | WBNZ @ <br> RW2+d8, |
| +3 | $\begin{gathered} \text { ADDW } \\ \text { A, RW3 } \end{gathered}$ | $\begin{aligned} & \text { IADDW }{ }^{\text {I }} \\ & \text { @RW3+d8 } \end{aligned}$ | $\underset{A, R W 3}{ }$ | $\begin{aligned} & \text { SUBW A, } \\ & \text { @RW3+d8 } \end{aligned}$ | $\begin{gathered} \text { ADDCW } \\ \text { A, RW3 } \end{gathered}$ | $\begin{array}{cc} \text { ADDCW A, } \\ @ R W 3+d 8 \end{array}$ | CMPW A, RW3 | $\begin{gathered} \text { CMPW } \\ \text { @RW3+ } \mathrm{AB} \end{gathered}$ | ANDW A, RY | $\begin{gathered} \text { ANDW } \\ \text { @RW3+d8 } \end{gathered}$ | ORW $\mathrm{A}, \mathrm{RY}$ | $\begin{aligned} & \text { ORW } \\ & @ R W 3+d 8 \\ & \hline \end{aligned}$ | XORW <br> A, RW3 | $\begin{array}{cc} \text { XORW A, } \\ \text { @RW3+d8 } \end{array}$ | $\begin{aligned} & 3 N Z \\ & \text { RW3 } \end{aligned}$ | WBNZ @ RW3+d8, r |
| +4 | $\begin{gathered} \text { ADDW } \\ \text { A, RW4 } \end{gathered}$ | $\begin{aligned} & \text { ADD A, } \\ & 1 \text { @RW4+d8 } \end{aligned}$ | $\underset{A, R W 4}{ }$ | $\begin{gathered} \text { SUBW A, } \\ @ R W 4+d 8 \end{gathered}$ | $\begin{gathered} \text { ADDCW } \\ \text { A, RW4 } \end{gathered}$ | $\begin{gathered} \text { ADDCW A, } \\ @ R W 4+d 8 \end{gathered}$ | CMPW A, RW4 | $\begin{aligned} & \text { CMPW A, } \\ & @ R W++d 8 \\ & \hline \end{aligned}$ | ANDW | $\begin{aligned} \text { ANDW } \\ \text { @RW4+d8 } \end{aligned}$ | ORW <br> A, RW4 | $\begin{array}{r} \text { ORW } \\ @ R W 4+\mathrm{d} 8 \end{array}$ | $\underset{A, R W 4}{\text { XORW }}$ | $\begin{gathered} \text { XORW A, } \\ \text { @RW4+d8 } \end{gathered}$ | $\begin{gathered} B N Z \\ R W \end{gathered}$ | $\begin{aligned} & \text { DWBNZ, @ } \\ & \text { RW4+d8, r } \end{aligned}$ |
| +5 | $\begin{array}{\|c}  \\ \text { ADDW } \\ \text { A, RW5 } \end{array}$ | $\begin{aligned} & \text { IADDW A, } \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { AU RW5 } \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { SUBW } \\ & \text { @RW5+d8, } \end{aligned}$ | $\begin{aligned} & \text { ADDCW } \\ & \text { A, RW5 } \end{aligned}$ | $\begin{array}{cc} A D D C W & A, \\ @ R W 5+d 8 \end{array}$ | MPW A, RW5 | $\begin{array}{r} \text { CMPW } \\ \text { @RW5+d8 } \end{array}$ | ANDW A, RW | $\begin{gathered} \text { ANDW A, } \\ \text { @RW5+d8 } \end{gathered}$ | $\begin{gathered} \text { ORW, RW5 } \end{gathered}$ |  | XORW A, RW5 | $\begin{gathered} \text { XORW A } \\ \text { @RW5+d8 } \end{gathered}$ | BNZ | RW5 +d 8 , |
| +6 | $\begin{gathered} \text { ADDW } \\ \text { A, RW6 } \end{gathered}$ | $\begin{aligned} & \text { CADDW A, } \\ & \text { @RW } 6+d 8 \end{aligned}$ | $\begin{gathered} \text { SUBW } \\ \text { A, RW6 } \end{gathered}$ | $\begin{gathered} \text { SUBW } \\ \text { @RW6+d8, } \end{gathered}$ | $\begin{gathered} \text { ADDCW } \\ \text { A, RW6 } \end{gathered}$ | $\begin{gathered} \text { ADDCW } \\ @ R W 6+d 8 \end{gathered}$ | MPW A, RW6 | $\begin{gathered} \text { CMPW A, } \\ @ R W 6+d 8 \end{gathered}$ | $\begin{aligned} & \text { ANDW } \\ & \text { A, RU } \end{aligned}$ |  | ORW <br> A, RW6 | $\begin{gathered} \mathrm{A}^{\mathrm{ORW}} \\ @ \mathrm{QW} 6+\mathrm{d} 8 \end{gathered}$ | XORW <br> A, RW6 | $\begin{gathered} \text { XORW } \\ \text { @RW6+d8 } \end{gathered}$ | BNZ RW6 | WWBNZ @ RW6+d8, |
| +7 | ADDW | $\begin{aligned} & \text { ADDW A, } \\ & \text { @RW7+d8 } \end{aligned}$ | SUBW <br> A, RW7 | $\begin{aligned} & \text { SUBW A, } \\ & \text { @RW7+d8 } \end{aligned}$ | $\begin{aligned} & \text { ADDCW } \\ & \text { A, RW7 } \end{aligned}$ | $\begin{gathered} \text { ADDCW A, } \\ @ R W 7+d 8 \end{gathered}$ | $\begin{aligned} & \text { MPW } \\ & \text { A, RW7 } \end{aligned}$ | $\begin{gathered} \text { CMPW A, A } \\ @ R W 7+d 8 \end{gathered}$ | ANDW | $\begin{gathered} \text { ANDW A, } \\ \text { @RW7+d8 } \end{gathered}$ | ORW A, RW7 | $\left\lvert\, \begin{gathered} \text { ORW } \\ @ R W 7+d 8 \end{gathered}\right.$ | $\begin{gathered} \text { XORW } \\ \text { A, RW7 } \end{gathered}$ | $\begin{array}{cc} \text { XORW A, } \\ @ R W 7+d 8 \end{array}$ | BNZ RW7 | DWBNZ RW7+d8, r |
| +8 | $\begin{aligned} & \text { ADDW } \\ & \text { A, @RWO } \end{aligned}$ | $\begin{aligned} & \text { ADDW } \\ & \text { @RWO } \mathrm{A} 16 \end{aligned}$ | SUBW A, @RW0 | $\begin{aligned} & \overline{\text { SUBW }} \\ & \text { @RWO+d16 } \end{aligned}$ | ADDCW <br> A, @RW | $\begin{gathered} \text { ADDCW A, } \\ @ R W 0+d 16 \end{gathered}$ | CMPW <br> A, @RW0 | $\begin{aligned} & \text { CMPW A, } \\ & \text { @RWO+d16 } \end{aligned}$ | ANDW A, @RW0 | $\begin{aligned} & \text { ANDW A, } \\ & @ R W 0+d 16 \end{aligned}$ | ORW <br> A, @RW0 | $\begin{gathered} \text { ORW } \\ @ R W 0+d 16 \end{gathered}$ | $\begin{gathered} \text { XORW } \\ \text { A, @RW0 } \end{gathered}$ | $\begin{gathered} \text { XORW A, } \\ @ R W 0+d 16 \end{gathered}$ | DWBNZ @RW0, | DWBNZ @R W0+d16, r |
| +9 | $\begin{aligned} & \text { ADDW } \\ & \text { A, @RW1 } \end{aligned}$ | $\begin{aligned} & \text { CADDW A, } \\ & , ~ @ R W 1+d 16 \end{aligned}$ | SUBW A, @RW1 | $\begin{aligned} & \text { SUBW A, } \\ & \text { @RW1+d16 } \\ & 1 \end{aligned}$ | $\begin{gathered} \text { ADDCW } \\ \text { A, @RW } \end{gathered}$ | $: \begin{aligned} & \text { ADDCW A, } \\ & @ R W 1+d 16 \end{aligned}$ | CMPW A, @RW1 |  | ANDW A, @RW1 | $\begin{aligned} & \text { ANDW A, } \\ & \text { @RW1+d16 } \end{aligned}$ | ORW | $\begin{aligned} & \text { ORW A, } \\ & @ R W 1+d 16 \end{aligned}$ | $\begin{gathered} \text { XORW } \\ \text { A, @RW1 } \end{gathered}$ | $\begin{array}{cc} \overline{X O R W} & \text { A, } \\ @ R W 1+d 16 \end{array}$ | DWBNZ @RW1 | DWBNZ @R W1+d16, r |
| +A | $\begin{aligned} & \text { ADDW } \\ & \text { A, @RW2 } \end{aligned}$ | $\begin{aligned} & \text { ADD A, } \\ & \text { @RW2+d16 } \end{aligned}$ | SUBW A, @RW2 | $\begin{aligned} & \text { SUBW } \\ & \text { @RW2+d16 } \end{aligned}$ | $\begin{aligned} & \text { ADDCW } \\ & \text { A, @RW } \end{aligned}$ | $\begin{aligned} & \text { ADDCW A, A, } \\ & \text { @RW2+d16 } \end{aligned}$ | CMPW <br> A, @RW2 | $\begin{aligned} & \text { CMPW } \\ & \text { @RW2+d16 } \end{aligned}$ | ANDW A, @RW2 | $\begin{aligned} & \text { ANDW A, } \\ & @ R W 2+d 16 \end{aligned}$ | ORW A, @RW2 | $\begin{aligned} & \text { OWW A, } \\ & @ \mathrm{~A} W+\mathrm{A} \end{aligned}$ | XORW A, @RW2 | $\begin{aligned} & \text { XORW A } \\ & \text { @RW2 } \mathrm{A} \end{aligned}$ | DWBNZ @RW2, r | DWBNZ @R W2+d16, r |
| +B | $\begin{gathered} \text { ADDW } \\ \text { A, @RW3 } \end{gathered}$ | $\begin{aligned} & \text { ADDW A, } \\ & \text { @RW3+d16 } \end{aligned}$ | SUBW A, @RW3 | $\begin{aligned} & \text { SUBW A, A, } \\ & @ R W 3+\text { d16 } \end{aligned}$ | ADDCW A, @RW3 | $\begin{aligned} & \text { ADDCW A, } \\ & @ R W 3+d 16 \end{aligned}$ | CMPW A, @RW3 | $\begin{gathered} \text { CMPW } \\ \text { @RW }+\mathrm{d} 16 \end{gathered}$ | ANDW A, @RW3 | $\begin{aligned} & \text { ANDW } \\ & @ R W 3+d 16 \end{aligned}$ | $\begin{gathered} \text { ORW } \\ \text { A, @RW3 } \end{gathered}$ | $\begin{aligned} & \text { ORW } \\ & \text { @RW3 }+\mathrm{A} 16 \\ & \hline \end{aligned}$ | XORW A, @RW3 | $\begin{aligned} & \text { XORW A } \\ & \text { @RW3, } \end{aligned}$ | DWBNZ @RW3, r | DWBNZ @R W3+d16, r |
| +C | ADDW A, @RW0+ | $\begin{aligned} & \text { ADDW A, A, } \\ & \text { @RW0+RW7 } \end{aligned}$ | SUBW A, @RW0 | $\begin{aligned} & \text { SUBW } \\ & \text { @RWO A, } \\ & \hline R W 7 \end{aligned}$ | ADDCW <br> A, @RW0+ | $\begin{aligned} & \text { ADDCW } \\ & @ R W 0+R W \end{aligned}$ | CMPW A, @RW0+ | $\begin{aligned} & \text { CMPW A } \\ & \text { @RWO RW } \end{aligned}$ | ANDW <br> A, @RWO+ | $\begin{aligned} & \text { ANDW A, } \\ & \end{aligned}$ | ORW <br> A, @RW0+ | @RWO+RW | XORW A, @RW0 | $\begin{aligned} & \text { xORW } \\ & \text { @RWO }+\mathrm{RW} \end{aligned}$ | DWBNZ @RW0+, | WBNZ @R 0+RW7, r |
| +D | ADDW A, @RW1+ | $\begin{gathered} \text { ADDW } \\ \varrho @ R W 1+R W 7 \end{gathered}$ | SUBW <br> A, @RW1 | $\begin{aligned} & \text { SUBW } \\ & \text { @RW1+RW7 } \end{aligned}$ | ADDCW A, @RW1+ | $\begin{aligned} & A D D C W \\ & @ R W 1+R W, \end{aligned}$ | CMPW A, @RW1+ | $\begin{aligned} & \text { CMPW } \\ & \text { @RW1+RW } \end{aligned}$ | ANDW A, @RW1+ | $\begin{aligned} & \text { ANDW A, } \\ & \text { @RW1+RW' } \end{aligned}$ | ORW <br> A, @RW1+ | $\begin{gathered} \text { ORW } \\ @ R W 1+R W \\ \hline \end{gathered}$ | $\begin{aligned} & \text { XORW } \\ & A, @ R W 1 \end{aligned}$ | $\begin{aligned} & \text { XORW } \\ & \text { @RW1+RW7 } \end{aligned}$ | DWBNZ @RW1+ | WBNZ @R V1+RW7, r |
| +E | ADDW A, @RW2+ | $\begin{gathered} \text { ADDW } \\ \text { @PC }+\mathrm{d} 16 \end{gathered}$ | SUBW A, @RW2+ | @PC+d16, | ADDCW A, @RW2+ | $\begin{gathered} \text { ADDCW A, } \\ @ P C+d 16 \end{gathered}$ | CMPW A, @RW2+ | $\begin{gathered} \text { CMPW } \\ \text { @PC }+\mathrm{A} 16 \end{gathered}$ | ANDW A, @RW2 | $\begin{array}{r} \text { ANDW } \\ \text { @PC } \mathrm{A}, \\ \hline \end{array}$ | ORW <br> A, @RW2+ | $\begin{aligned} & \text { ORC+d16, } \\ & \hline \end{aligned}$ | XORW A, @RW2+ | $\begin{aligned} & \text { XORW } \\ & \text { @PC+d16, } \end{aligned}$ | DWBNZ @RW2+, | DWBNZ @ <br> PC+d16, r |
| +F | $\begin{gathered} \text { ADDW } \\ \text { A, @RW3+ } \end{gathered}$ | $\begin{gathered} \text { 'ADDW } \\ 1 \\ 1 \\ \hline \end{gathered}$ | SUBW <br> A, @RW3+ | $\begin{array}{r} \text { addr } 16 \\ \mathrm{~A}, \\ \end{array}$ | ADDCW A, @RW3+ | $\begin{aligned} & \text { ADDCW } \\ & \text { Addr16 } \\ & \hline \end{aligned}$ | CMPW <br> A, @RW3+ | $\begin{aligned} & \text { CMPW } \\ & \text { addr16 } \\ & \hline \end{aligned}$ | ANDW A, @RW3 | $\begin{array}{r} \text { ANDW }{ }_{\text {addr16 }} \\ \hline \end{array}$ | ORW @RW3+ | $\begin{aligned} & \text { addr16 } \mathrm{A}, \\ & \hline \end{aligned}$ | XORW A, @RW3+ | $\begin{aligned} & \text { XORW } \\ & \text { addr16 } \\ & \hline \end{aligned}$ | DWBNZ @RW3+, r | DWBNZ addr16, r |

Table B.3.1। "ea" Instructions 8 (First byte $=\mathbf{7 7 H}$ )

|  | 00 | 0 | 20 | 30 | 40 | 50 | 60 | 70 | 80 | 90 | A 0 | в 0 | co | D 0 | E 0 | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| +0 | $\underset{\substack{\text { ADDW } \\ \text { RWO, A }}}{ }$ | ADDW @R W0+d8, A | $\begin{aligned} & \hline \text { SUBW } \\ & \text { RW0, A } \end{aligned}$ | $\begin{gathered} \text { SUBW } \\ \text { WO+d8, } \end{gathered}$ | $\begin{gathered} \text { SUBCW } \\ \text { A, RV } \end{gathered}$ | SUBCW A, @RWO+d8 |  | $\begin{aligned} & \hline \text { VEGW } \\ & \text { @RWO+d8 } \end{aligned}$ | ANDW RW0, | $\begin{aligned} & \text { ANDW } @ R \\ & W 0+d 8 . A \end{aligned}$ | $\begin{aligned} & \text { ORW } \\ & \text { RWO, A } \end{aligned}$ | $\begin{array}{r} \mathrm{DRW} \\ \text { W0+dB, } \\ \hline \end{array}$ | $\begin{aligned} & \text { XORW } \\ & \text { RW0, A } \end{aligned}$ | $\begin{gathered} \text { XORW } \\ \text { WO }+\mathrm{d} 8, \mathrm{~A} \end{gathered}$ | RWO | @RW0+d8 |
| +1 | $\begin{aligned} & \text { ADDW } \\ & \text { RW } 1, A \end{aligned}$ | DDW @R W1+d8, A | $\begin{aligned} & \text { SUBW } \\ & \text { RW1, A } \end{aligned}$ | $\begin{gathered} \text { SUBW } \\ \text { W1+d8, A } \end{gathered}$ | $\begin{aligned} & \text { SUBCW } \\ & \text { A, RW1 } \end{aligned}$ | $\begin{aligned} & \text { SUBCW A, A, } \\ & \text { @RW1+d } \end{aligned}$ | $\mathrm{aW}_{\mathrm{RW} 1}$ | $\begin{aligned} & \text { NEGW } \\ & \text { @RW1+d8 } \end{aligned}$ | ANDW RW1, A | ANDW @R $\mathrm{W} 1+\mathrm{d} 8, \mathrm{~A}$ | ORW RW1, A | $\begin{gathered} \mathrm{RW} \\ \mathrm{~W} 1+\mathrm{A} 8, \mathrm{~A} \end{gathered}$ | $\begin{array}{r} \text { XORW } \\ R W 1, A \end{array}$ | XORW @R W1+d8, A | RW1 | NOTW <br> @RW1+d8 |
| +2 | ADDW RW2, A | ADDW @R W2+d8, A | SUBW RW2, A | SUBW @R W2+d8, A | $\begin{aligned} & \text { SUBCW } \\ & \text { A, RW2 } \end{aligned}$ | SUBCW A, @RW2+d8 | RW | EGW | ANDW RW2, | $\begin{gathered} \text { ANDW @R } \\ \text { W2+d8, A } \end{gathered}$ | OWR RW2, A | $\begin{gathered} \mathrm{RW} \\ \mathrm{~W} 2+\mathrm{di}, \mathrm{~A} \\ \hline \end{gathered}$ | XORW RW2, A | XORW @R W2+d8, A | $\mathrm{V}^{-}$ | NOTW <br> @RW2+d8 |
| +3 | $\begin{aligned} & \text { ADD } \\ & \text { RW } 3, ~ A ~ \end{aligned}$ | ADDW @R W3+d8, A | $\begin{aligned} & \text { SUBW } \\ & \text { RW, A } \end{aligned}$ | SUBW @R W3+d8, A | $\begin{gathered} \text { AUBCW } \\ \text { A, RW3 } \end{gathered}$ | SUBCW A, | RW3 | EGW @RW3+d8 | ĀNDW RW3, A | $\begin{aligned} & \text { ANDW ©R } \\ & \text { W } 3+d 8, A \end{aligned}$ | ORW RW3, A | $\begin{gathered} R W \\ \text { W3 }+d 8, A \end{gathered}$ | XORW RW3, A | XORW @R W3+d8, A | RW3 | NOTTW @RW3+d8 |
| +4 | $\begin{gathered} \text { ADDW } \\ \text { RW4, A } \end{gathered}$ | ADDW @R W4+d8, A | $\begin{aligned} & \text { SUBū } \\ & \text { RW4, A } \end{aligned}$ | SUBW @R W4+d8, A | $\begin{aligned} & \text { SUBCW } \\ & \text { A, RW4 } \end{aligned}$ | SUBCW A A, @RW4+d | $\begin{gathered} \overline{N E G W} \\ \text { RW4 } \end{gathered}$ | $\begin{aligned} & \text { NEGW- } \\ & \text { @RW4+d } \end{aligned}$ | ANDW RW4, A | $\begin{aligned} & \text { ANDW } \\ & \text { W } 4+d 8, ~ \\ & \text { AR } \end{aligned}$ | $\begin{aligned} & \text { ORW } \\ & \text { RW4, A } \end{aligned}$ | $\begin{gathered} R W \\ \text { W4+d8, } \end{gathered}$ | $\begin{array}{r} \mathrm{XORW} \\ \mathrm{RW} 4, \mathrm{~A} \end{array}$ | XORW @R W4+d8, A | NOTW ${ }_{\text {RW4 }}$ | $\begin{aligned} & \text { NOTW } \\ & \text { @R4+d8 } \end{aligned}$ |
| +5 | ADDW RW5, A | ADDW @R W5+d8, A | SUBW̄ RW5, A | SUBW @R W5+d8, A | $\begin{aligned} & \text { SUBCW } \\ & \text { A, RW5 } \end{aligned}$ | SUBCW A, @RW5+d8 | ${ }^{G W}{ }_{\text {RW5 }}$ | $\begin{aligned} & \text { NEGW } \\ & @ R W 5+d 8 \end{aligned}$ | ANDW RW5, A | ANDW @R W5+d8, A | ORW <br> RW5, A | $\begin{gathered} \text { RW } \\ \text { W5 }+\mathrm{dB}, \mathrm{~A} \\ \hline \end{gathered}$ | XORW RW5, A | XORW @R W5+d8, A | NOTW RW5 | NOTW @RW5+d8 |
| +6 | ADDW RW6, A | ADDW @R W6+d8, A | $\begin{aligned} & \text { SUBW } \\ & \text { RW, A } \end{aligned}$ | W6+d8, <br> SUBW @R | $\begin{aligned} & \text { SUBCW } \\ & \text { A, RW6 } \end{aligned}$ | SUBCW A, @RW6+d8 | GW RW6 | $\begin{aligned} & \text { NEGW } \\ & \text { @RWE+d } \end{aligned}$ | ANDW RW6, A | $\begin{gathered} \text { ANDW } \\ \text { W6 } 68 \text {, AR } \end{gathered}$ | ORW RW6, A | $\begin{aligned} & \mathrm{RW} \\ & \mathrm{~W} 6+\mathrm{d} 8, \mathrm{~A} \end{aligned}$ | XORW RW6, A | XORW @R W6+d8, A | RW | NOTW @RW6+d8 |
| +7 | $\begin{aligned} & \text { ADDW } \\ & \text { RW7, A } \end{aligned}$ | ADDW @R W7+d8, A | SUBW RW7, A | SUBW @R W7+d8, A | $\begin{gathered} \text { SUBCW } \\ \text { A,RW7 } \end{gathered}$ | SUBCW A, @RW7+d8 | RW7 | $\begin{aligned} & \text { NEGW } \\ & @ R W 7+d 8 \\ & \hline \end{aligned}$ | ANDW RW7, A | ANDW @R $\mathrm{W} 7+\mathrm{d} 8, \mathrm{~A}$ | ORW RW7, A | $\begin{gathered} \text { ORW } @ R \\ \text { W } 7+d 8, A \end{gathered}$ | XORW <br> RW7, A | XORW @R W7+d8, A | $\mathrm{RW}$ | NOTW @RW7+d8 |
| +8 | ADDW @RW0, A | ADDW @R W0+d16, A | SUBW @RW0, A | SUBW @R W0+d16, A | $\begin{aligned} & \text { SUBCW } \\ & \text { A, @RWO } \end{aligned}$ | SUBCW A, @RW0+d16 | $\begin{aligned} & \text { NEGW } \\ & \text { @RWo } \end{aligned}$ | $\begin{aligned} & \text { NEGW } \\ & \text { @RWO+d16 } \end{aligned}$ | ANDW @RW0, A | ANDW @R W0+d16, A | ORW @RW0, A | ORW @R W0+d16, A | XORW @RW0, A | XORW @R W0+d16, A | NOTW @RW0 | NOTW @RW0+d16 |
| +9 | ADDW @RW1, A | ADDW @R W1+d16, A | SUBW <br> @RW1, A | SUBW @R W1+d16, A | SUBCW <br> A, @RW1 | SUBCW A, @RW1+d16 | NEḠW @RW | $\begin{aligned} & \text { NEGW } \\ & \text { @RW1+d16 } \end{aligned}$ | ANDW <br> @RW1, A | ANDW @R $\mathrm{W} 1+\mathrm{d} 16, \mathrm{~A}$ | ORW @RW1, A | ORW @R $\mathrm{W} 1+\mathrm{d} 16, \mathrm{~A}$ | XORW @RW1, A | XORW @R W1+d16, A | O-Tw @RW1 | NOTW @RW1+d16 |
| +A | ADDW @RW2, A | ADDW @R W2+d16, A | SUBW @RW2, A | SUBW @R W2+d16, A | SUBCW <br> A, @RW2 | SUBCW A, @RW2+d16 | NEGW @RW2 | NEGW @RW2+d16 | ANDW @RW2, A | ANDW @R W2+d16, A | ORW @RW2, A | ORW @R W2+d16, A | XORW @RW2, A | xorw @ W2+d16, A | NOTW @RW2 | NOTW @RW2+d16 |
| +B | ADDW @RW3, A | ADDW @R W3+d16, A | SUBW @RW3, A | $\begin{aligned} & \text { SUBW } \mathrm{B} \\ & \mathrm{~W} 3+\mathrm{d} 16, \mathrm{~A} \end{aligned}$ | SUBCW <br> A, @RW3 | $\begin{aligned} & \text { SUCW A, } \\ & @ R W 3+d 16 \end{aligned}$ | NEGW @RW3 | NEGW @RW3+d16 | ANDW @RW3, A | ANDW @R W3+d16, A | ORW @RW3, A | $\begin{gathered} \text { ORW © } \\ \text { W } 3+d 16, A \end{gathered}$ | XORW @RW3, A | XORW @R W3+d16, A | NOTW @RW3 | NOTW @RW3+d16 |
| +C | ADDW @RW0+ | ADDW @R WO+RW7 | SUBW @RW0+, A | $\begin{aligned} & \text { SUBW @R } \\ & \text { W0 }+ \text { RW7, A } \end{aligned}$ | SUBCW <br> A, @RW0 | $\begin{aligned} & \text { SUBCW A, } \\ & @ R W 0+R W 7 \end{aligned}$ | NEGW @RWO+ | NEGW @RW0+RW7 | ANDW @RW0+, | ANDW @R W0+RW7, A | ORW <br> @RW0+, | $\begin{aligned} & \text { ORW } \\ & \text { WORW } \end{aligned}$ | XORW @RW0+, A | XORW @R W0+RW7, A | NOTW @RW0+ | NOTW @RW0+RW7 |
| +D | ADDW <br> @RW1+, A | ADDW @R W1+RW7 | SUBW <br> @RW1+, A | $\begin{aligned} & \text { SUBW } \left.\begin{array}{c} \text { WR } \\ \text { W1+RW7, A } \end{array} \right\rvert\, \end{aligned}$ | SUBCW <br> A, @RW1 | $\begin{aligned} & - \text { SUBCW } \\ & +@ R W 1+R W 7 \\ & \hline \end{aligned}$ | NEGW @RW1+ | ' NEGW @RW1+RW7 | ANDW @RW1+, A | ANDW @R W1+RW7, A | ORW @RW1+, A | $\begin{aligned} & \text { ORW } \\ & W 1+B W 7, A \end{aligned}$ | $\begin{aligned} & \text { XORW } \\ & \text { @RW1+, A } \end{aligned}$ | XORW @R W1+RW7, A | NOTW @RW1+ | NOTW <br> @RW1+RW7 |
| +E | ADDW @RW2+, A | ADDW @P C+d16, A | SUBW @RW2+, A | @PC+d16, A | SUBCW A, @RW2 | SUBCW A, @PC+d16 | NEGW @RW2+ | NEGW @PC+d16 | ANDW @RW2+, A | $\begin{aligned} & \text { ANDW } \mathrm{CP} \\ & \mathrm{C}+\mathrm{d} 16, \mathrm{~A} \end{aligned}$ | ORW @RW2+, A | $\begin{aligned} & \text { ORW @r } \\ & \text { C+d16, A } \end{aligned}$ | XORW @RW2+, A | C+d16, A <br> XORW @P | NOTW @RW2+ | NOTW @PC+d16 |
| +F | $\left\lvert\, \begin{gathered} \text { ADDW } \\ \text { @RW3+, A } \end{gathered}\right.$ | $\begin{gathered} \text { ADDW } \\ \text { addr16, } A \end{gathered}$ | $\begin{aligned} & \text { SUBW } \\ & \text { @RW3+, A } \end{aligned}$ | $\begin{array}{r} 1 \\ \text { addr16, } \end{array}$ | $\begin{aligned} & \text { SUBCW } \\ & \text { ARW3 } \end{aligned}$ | $\begin{aligned} & \text { SUBCW } \\ & \hline \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { NEGW } \\ & \text { @RW3 }+1 \end{aligned}$ | $\begin{aligned} & \text { NEGW } \\ & =\text { addr16 } \end{aligned}$ | ANDW @RW3+, A | $\begin{aligned} \\ \hline A_{1} \\ \\ \text { addr16, } \\ \hline \end{aligned}$ | ORW @RW3+, A | $\begin{aligned} & \text { ORW } \\ & \text { add } 6, ~ A ~ \end{aligned}$ | $\begin{gathered} \text { XORW } \\ \text { @RW }+ \text {, A } \end{gathered}$ | XORW addr16, A | NOTW @RW3+ | $\begin{aligned} & \text { NOTW } 16 \\ & \text { adden } \end{aligned}$ |

Table B．3．1m＂ea＂Instructions 9 （First byte＝78H）

|  | 0 | 10 | 0 | 30 | 40 | 50 | 60 | 70 | 80 | 90 | A 0 | во | co | D 0 | E 0 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ＋0 | $\underset{A, R O}{M U L U}$ | $\begin{gathered} \text { MULU } \\ \text { @RWO }+\mathrm{A}^{2} \end{gathered}$ | MULUW <br> A，RW0 | $\begin{aligned} & \text { MULUW A, } \\ & \text { @RW0+d8 } \end{aligned}$ | MUL A, RO | $\begin{gathered} \text { MUL } \\ \text { @RWO+d8 } \end{gathered}$ | $\text { MULW } \quad \text { RWO }{ }^{1 \prime}$ | MULW A， | $\begin{aligned} & \text { DIVU } \\ & \text { A, RO } \end{aligned}$ | $\begin{array}{r} \text { DIVU } \\ \text { @RWO+d8 } \end{array}$ | $\begin{aligned} & \text { DIVUW } \\ & \text { A, RWO } \end{aligned}$ | DIVUW ＠RWO + d A， | DIV A, RO | $\begin{gathered} \text { DIV } \\ \text { @RWO } \\ \hline \end{gathered}$ | DIVW A, RW | DIVW A， ＠RW0＋d8 |
| ＋1 | $\left.\right\|_{\text {A, R1 }} ^{M U U L U}$ | $\begin{aligned} & 1: M U L U \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { MULUW } \\ & \text { A, RW1 } \end{aligned}$ | $\begin{aligned} & \text { MULUW A, } \\ & \text { @RW1+d8 } \end{aligned}$ | MUL A，R1 | $\begin{gathered} \text { MUL } \\ \hdashline ⿴ 囗 十 \end{gathered}$ | MULW <br> A，RW1 | IMULW A， ＠RW1＋d8 | Divu | $\begin{gathered} \text { DIVU } \\ @ R W 1+d 8 \end{gathered}$ | DIVUW A, RW1 | DIVUW A， | DIV A, R1 |  | DIVW A，RW1 | DIVW A， ＠RW1＋d8 |
| ＋2 | MULU A，R2 | ：MULU A， | $\begin{gathered} \text { MULUW } \\ \text { RW2 } \end{gathered}$ | $\begin{gathered} \text { MULUW A, } \\ \text { @RW2+d8 } \end{gathered}$ | MUL A，R2 | $\begin{gathered} \text { MUL } \\ @ R W 2+d 8 \end{gathered}$ | MULW <br> A，RW2 | MULW A， ＠RW2＋d8 | dive | DIVU <br> ＠RW2＋ A | DIVUW <br> A，RW2 | DIVUW A， ＠RW2＋d8 | DIV A, R2 | $\begin{gathered} \text { DIV } \\ @ R W 2+d 8 \end{gathered}$ | DIVW A, RW2 | DIVW A， ＠RW2＋d8 |
| ＋3 | $\left.\right\|_{\text {A, R3 }} ^{\text {MULU }}$ | ，MULU A， | MULUW <br> A，RW3 | $\begin{aligned} & \text { MULUW } \\ & @ R W 3+d 8, \end{aligned}$ | $\begin{aligned} & \text { AU, R3 } \end{aligned}$ | $\begin{gathered} \text { MUL } A_{8} \\ \text { @RW3+d8 } \end{gathered}$ | MULW RW3 | MULW A ＠RW3＋d8 | $\mathrm{VU}_{\mathrm{A}, \mathrm{R}}$ | ＠RW3＋d8 | DIVUW <br> A，RW3 | DIVUW A， ＠RW3＋d8 | DIV A, R3 | $\begin{array}{ll} \text { DIV } \\ \hline \end{array}$ | DIVW A，RW3 | $\begin{aligned} & \mathrm{A}_{8} \\ & \varrho \mathrm{CWW} \\ & \hline \end{aligned}$ |
| ＋4 | $\left.\right\|_{\text {A, R4 }} ^{\text {MULU }}$ | M MRU4＋d8， | $\begin{gathered} \text { MULUW } \\ \text { A, RW4 } \end{gathered}$ | $\begin{aligned} & \text { MULUW A, } \\ & \text { @RW4+d8 } \end{aligned}$ | MUL A, B4 |  | MUL RW, | MULW A， ＠RW4＋d8 | A, R4 | $\begin{aligned} & \text { A, A, } \\ & \text { @RW4+d8 } \end{aligned}$ | DIVUW <br> A，RW4 | DIVUW A， ＠RW4＋d8 | DIV $\mathrm{A}, \mathrm{R} 4$ | $\begin{array}{ll} \text { DIV } \\ @ R W 4+d 8 \end{array}$ | DIVW <br> A，RW4 | DIVW A， ＠RW4＋d8 |
| ＋5 | $\left.\right\|_{\text {A, R5 }} ^{\text {MULU }}$ | $: \begin{gathered} \text { MULU } \\ \hline \text { ARW }+\mathrm{d} \\ \hline \end{gathered}$ | $\begin{gathered} \text { MULUW } \\ \text { A, RW5 } \end{gathered}$ | MULUW A, | MUL | $\begin{aligned} & \text { MUL } \\ & @ R W 5+d 8 \end{aligned}$ | A, RWS | MULW A， | ${ }_{A, ~ R 5}$ | $\begin{aligned} & \text { A, }, \\ & @ R W 5+d 8 \end{aligned}$ | divuw <br> A，RW5 | DIVUW A， ＠RW5＋d8 | DIV A, R5 |  | DIVW A, RW5 |  |
| ＋6 | $\left\lvert\, \begin{gathered} \text { MULU R6 } \end{gathered}\right.$ | MULU A, | MULUW A，RW6 | $\begin{aligned} & \text { TMULUW A, } \\ & \text { @RW6+d8 } \end{aligned}$ | MUL A, R6 |  | $\text { MULW }{ }_{\text {A, RW, }}$ | MULW A， ＠RW6＋d8 | $\begin{aligned} & \text { ive } \\ & \text { A, } \end{aligned}$ | $\begin{aligned} & \text { DivU A, } \\ & \text { @RW6+d8 } \end{aligned}$ | DIVUW A，RW6 | DIVUW A， ＠RW6＋d8 | DIV A, R6 | DIV A， $@ R W 6+d 8$ | $\begin{aligned} & \text { DIVW } \\ & \text { A, RW6 } \end{aligned}$ | IVW A， ＠RW6＋d8 |
| ＋7 | $\left.\right\|_{\text {A, R7 }} ^{\text {MULU }}$ | ＇MULU A， | $\begin{gathered} \text { MULUW } \\ \text { A, RW7 } \end{gathered}$ | $\begin{aligned} & \text { 'MULUW A, } \\ & \text { @RW7+d8 } \end{aligned}$ | MUL A，R7 |  | MULW | MULW A， ＠RW7＋d8 | $\begin{array}{r} \text { Di, R7 } \end{array}$ | DIVU A， ＠RW7＋d8 | DIVUW <br> A，RW7 | DIVUW A， | DIV A, R7 | $\begin{gathered} \text { DIV } \\ @ R W 7+d 8 \end{gathered}$ | DIVW A, RW7 | DIVW A， ＠RW7＋d8 |
| ＋8 | MULU <br> A，＠RWO | $\begin{gathered} M U L U \\ @ R W O+16 \\ \hline \end{gathered}$ | $\begin{aligned} & \text { MU, @RWO } \end{aligned}$ | $\begin{aligned} & \text { MULUW A, }, \\ & \text { @RW0+d16 } \end{aligned}$ | MUL A，＠RW0 | $\begin{gathered} M U L \\ @ R W O+d 16 \end{gathered}$ | $\begin{aligned} & \text { MULW } \\ & \text { A, @RWO: } \end{aligned}$ | MULW A， ＠RW0＋d16 | divu A，＠RW | $\begin{array}{rr} \text { DIVU } \\ @ R W O+d 16 \end{array}$ | DIVUw <br> A，＠RW0 | DIVUW A， ＠RW0＋d16 | DIV A，＠RW0 |  | DIVW A，＠RW0 | DIVW A， ＠RWO＋d16 |
| ＋9 | MULU A，＠RW1 | $\begin{aligned} & \text { MULUL, } \\ & @ R W 1+d 16 \end{aligned}$ | $\begin{gathered} \text { MULUW } \\ \text { A, @RW1 } \end{gathered}$ | $\begin{aligned} & \text { MULUW A, } \\ & \text { @RW1 }+\mathrm{d} 16 \end{aligned}$ | MUL A，＠RW1 | $\begin{aligned} & \text { A, } \\ & @ ⿴ 囗 十 ⺝ 丶 1+d 16 \end{aligned}$ | $\begin{aligned} & \text { MULW } \\ & \text { A, @RW1 } \end{aligned}$ | MULW A， | DIVU @RW1 | $\begin{aligned} & \text { A, } \\ & @ R W 1+16 \end{aligned}$ | $\begin{aligned} & \text { DIVUW @RW1 } \end{aligned}$ | DIVUW A， ＠RW1 A 16 | DIV A，＠RW1 | $\begin{array}{r} \text { A } \\ @ ⿴ 囗 十 心 1+d 16 \end{array}$ | DIVw A, @RW1 | $\begin{array}{cc} \text { OVW } & A, \\ @ R W 1+d 16 \end{array}$ |
| ＋A | MULU A，＠RW2 | $\left[\begin{array}{c} M U L U \\ @ R W 2+d 16 \end{array}\right.$ | $\begin{aligned} & \text { MULUW } \\ & \text { A, @RW2 } \end{aligned}$ | $\begin{aligned} & \text { MUUW } \\ & \text { @RW2d } \\ & \text { A } \end{aligned}$ | MUL A，＠RW2 | $\begin{gathered} \text { MUL } \\ @ R W 2+d 16 \end{gathered}$ | $\begin{aligned} & \text { MULW } \\ & \text { A, @RW2 } \end{aligned}$ | MULW A， ＠RW2＋d16 | DIVU A，＠RW2 | $\begin{aligned} & \text { DIVU A, } \\ & \text { @RW2+d16 } \end{aligned}$ | DIVUW | DIVUW A， ＠RW2＋d16 | DIV A，＠RW2 | $\begin{aligned} & \text { DIV A, } \\ & \text { @RW2+d } 16 \end{aligned}$ | DIVW <br> A，＠RW2 | $\begin{aligned} & \text { DIVW A, } \\ & \text { @RW2+d16 } \end{aligned}$ |
| ＋B | MULU A，＠RW3 | $\begin{array}{\|c\|} \hline \text { MULU } \\ \text { @RW3 } \mathrm{A} \\ \hline \end{array}$ | $\begin{aligned} & \text { MULUW } \\ & \text { A, @RW3 } \end{aligned}$ | $\begin{aligned} & \text { MULUW A, } \\ & \hdashline \text { RW3+d16 } \end{aligned}$ | MUL A，＠RW3 |  | $\begin{aligned} & \text { MULW } \\ & \text { A, @RW3:' } \end{aligned}$ | $\begin{aligned} & \text { MULW A, } \\ & \text { @RW3 +d16 } \end{aligned}$ | DIVU | $\begin{gathered} \text { DIVU A, A, } \\ \text { @RW3+d16 } \end{gathered}$ | DIVUW | DIVUW A， ＠RW3＋d16 | DIV A，＠RW3 | DIV A， $@ R W 3+d 16$ | DIVW A，＠RW3 | $\begin{array}{lc} \text { IVW } & A, \\ @ R W 3+d 16 \end{array}$ |
| ＋C | MULU <br> A，＠RW0 | ＇MULU A， （ $@ R W 0+R W 7$ | MULUW <br> A，＠RW0＋ | ＇MULUW A， | MUL A，＠RW0＋ | $\begin{gathered} \mathrm{MUL} \\ \mathrm{~A}+\mathrm{RW} \\ \hline \end{gathered}$ | MULW <br> A，＠RW0＋ | MULW A， ＠RW0＋RW7 | DIVU <br> A，＠RWO | $\begin{array}{r} \text { DIVU } \\ +\quad \text { ORWO RW } \\ \hline \end{array}$ | DIVUw <br> A，＠RW0＋ | DIVUW A， | $\begin{aligned} & \text { DIV } \\ & \text { A, @WO } \end{aligned}$ | $\begin{gathered} \text { DIV A, } \\ \text { QRWO }+ \text { RW } \\ \hline \end{gathered}$ | DIVW <br> A，＠RWO－ | $\begin{aligned} & \text { At } \\ & \text { DRWO } \\ & \hline \end{aligned}$ |
| ＋D | MULU A，＠RW1 | $\begin{gathered} M U L U \\ @ R W 1+R W 7 \end{gathered}$ | MULUW A，＠RW1＋ | $\begin{aligned} & \text { MULUW A, A, } \\ & \text { @RW1+RWI } \end{aligned}$ | MUL <br> A，＠RW1 |  | MULW <br> A，＠RW1＋ | MuLw A， ＠RW1＋RW7 | DIVU <br> A，＠RW1 |  | DIVUW <br> A，＠RW1＋ | $\begin{aligned} & \text { DIVUW A, } \\ & @ R W 1+R W 7 \end{aligned}$ | $\begin{aligned} & \text { DIV } \\ & \text { A, @RW } \end{aligned}$ | $\begin{gathered} \text { AI } \\ @ R W 1+R W 7 \end{gathered}$ | DIVW A，＠RW1 | $\begin{aligned} & V W \text { A, } \\ & R W 1+R W W \end{aligned}$ |
| ＋E | MULU A，＠RW2＋ | $\begin{gathered} M U L U L A, \\ @ P C+d 16, \end{gathered}$ | $\begin{aligned} & \text { MULUW } \\ & \text { A, @RW2+ } \end{aligned}$ | MULUW A, | MUL <br> A，＠RW2＋ | $\begin{aligned} & \text { MUL A, } \\ & @ P C+d 16 \end{aligned}$ | MULW A，＠RW2＋ | MULW A， ＠PC＋d16 | DIVU <br> A，＠RW2 | AIVU, | DIVUW A，＠RW2＋ | $\begin{aligned} & \text { DIVUW } \\ & \text { @PC+d16, } \end{aligned}$ | DIV <br> A，＠RW2 | $\begin{aligned} & \text { DIVC A, } \\ & \text { @PC+d } 16 \end{aligned}$ | DIVW A，＠RW2＋ | $\begin{aligned} & \text { DIVW A, } \\ & \text { @PC+d } 6 \end{aligned}$ |
| ＋F | MULU A，＠RW3＋ | $\begin{array}{r} \text { MULU } \\ \\ \hline \end{array}$ | $\begin{gathered} \text { MULUW } \\ \text { A, @RW3+1 } \end{gathered}$ | $\begin{array}{r} \text { MULUW } \\ \text { addr16 } \end{array}$ | MUL A，＠RW3＋ | $\begin{array}{r} \text { MUL } \mathrm{Addr} 16, \\ \hline \end{array}$ | $\begin{aligned} & \text { MULW } \\ & \text { A, @RW3+' } \end{aligned}$ | $\begin{array}{r} \text { MULW } \begin{array}{r} \text { addr1 } \\ \hline \end{array} \\ \hline \end{array}$ | $\begin{aligned} & \text { DIVU } \\ & \text { A, @RW3+ } \end{aligned}$ | $\begin{array}{r} \begin{array}{r} \text { DIVU } \\ +\quad \text { addr16 } \\ \hline \end{array} \\ \hline \end{array}$ | $\begin{aligned} & \text { DIVUW } \\ & \text { A, @RW3+ } \end{aligned}$ | DIVUW | DIV | $\begin{array}{r} \text { DIV } \begin{array}{r} \text { addr16 } \end{array} \\ \hline \end{array}$ | DIVW <br> A，＠RW3＋ | $\begin{aligned} & \text { DIVW } \\ & \text { addr16 } \\ & \hline \end{aligned}$ |

Table B.3.1n MOVEA RWi, ea (First byte $=79 \mathrm{H}$ )

|  | 00 | 10 | 20 | 30 | 40 | 50 | 60 | 70 | 80 | 90 | A 0 | B 0 | C0 | D 0 | E 0 | F0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| +0 | MOVEA RW0, RW0 | MOVEA RWO | MOVEA RW1, RW | MOVEA RW1, | MOVEA RW2, RWO | MOVEARW2, @RW0+d8 | MOVEA RW3, RW0 | MOVEA RW3 @RW0+d8 | MOVEA <br> RW4, RW0 | MOVEA RW4, @RW0+d8 | MOVEA RW5, RW0 | MOVEA RW5, @RW0+d8 | MOVEA RW6, RW0 | MOVEA RW6 ,@RW0+d8 | MOVEA RW7, RW | OVEA RW7, @RW0+d8 |
| +1 | MOVEA RW0, RW1 | MOVEA RWO @RW1+d8 | MOVEA RW1, RW | MOVEA RW1, @RW1+d8 | MOVEA RW2, RW1 | OVEA RW2 @RW1+d8 | MOVEA RW3, RW1 | MOVEA RW3, @RW1+d8 | MOVEA RW4, RW1 | MOVEA RW4 @RW1+d8 | MOVEA RW5, RW1 | MOVEA RW5 <br> @RW1+d8 | MOVEA RW6, RW1 | MOVEA RW6 ,@RW1+d8 | MOVEA RW7, RW | IOVEA RW7 @RW1+d8 |
| +2 | MOVEA RW0, RW2 | TMOVEA RWO @RW2+d8 | MOVEA RW1, RW | MOVEA RW1, @RW2+d8 | MOVEA RW2, RW2 | OVEA RW2 @RW2+d8 | MOVEA RW3, RW2 | MOVEA RW3 @RW2+d8 | MOVEA RW4, RW2 | MOVEA RW4 @RW2+d8 | MOVEA RW5, RW2 | MOVEA RW5 @RW2+d8 | MOVEA RW6, RW2 | MOVEA RW6 ,@RW2+d8 | MOVEA RW7, RW | OVEA RW7 @RW2+d8 |
| +3 | MOVEA RW0, RW | 'TMOVEA RWO @RW3+d8 | MOVEA RW1, | MOVEA RW1, @RW3+d8 | MOVEA RW2, RW3 | OVEA RW2 @RW3+d8 | MOVEA RW3, RW3 | MOVEA RW3, @RW3+d8 | MOVEA RW4, RW3 | MOVEA RW4 @RW3+d8 | MOVEA RW5, R | MOVEA RW5 @RW3+d8 | MOVEA RW6, RW3 | MOVEA RW6 ,@RW3+d8 | MOVEA RW7, R | OVEA RW7, @RW3+d8 |
| +4 | MOVEA RW0, RW4 | MOVEA RWO @RW4+d8 | MOVEA RW1, RW | MOVEA RW1 @RW4+d8 | MOVEA RW2, RW4 | OVEA RW2 @RW4+d8 | MOVEA RW3, RW4 | MOVEA RW3, @RW4+d8 | MOVEA RW4, RW4 | MOVEA RW4 @RW4+d8 | MOVEA RW5, RW4 | MOVEA RW5 @RW4+d8 | MOVEA RW6, RW4 | MOVEARW6 ,@RW4+d8 | MOVEA RW7, RW | OVEA RW7 @RW4+d8 |
| +5 | MOVEA RW0, RW5 | 'MOVEA RWO @RW5+d8 | MOVEA RW1, RW | MOVEA RW1, @RW5+d8 | MOVEA RW2, RW5 | OVEA RW2 @RW5+d8 | MOVEA RW3, RW5 | MOVEA RW3, @RW5+d8 | MOVEA RW4, RW5 | MOVEA RW4 @RW5+d8 | MOVEA RW5, R | MOVEA RW5 @RW5+d8 | MOVEA RW6, RW5 | MOVEA RW6 ,@RW5+d8 | MOVEA RW7, RW | OVEA RW7 @RW5+d8 |
| +6 | MOVEA RW0, RW6 | 'MOVEA RWO @RW6+d8 | MOVEA RW1, RW | MOVEA RW1, @RW6+d8 | MOVEA RW2, RW6 | MOVEA RW2, @RW6+d8 | MOVEA RW3, RW6 | MOVEA RW3 @RW6+d8 | MOVEA RW4, RW6 | MOVEA RW4 @RW6+d8 | MOVEA RW5, RW6 | MOVEA RW5 @RW6+d8 | MOVEA RW6, RW6 | MOVEA RW6 ,@RW6+d8 | MOVEA RW7, RW | MOVEA RW7 @RW6+d8 |
| +7 | MOVEA RW0, RW | MOVEA RWO @RW7+d8 | MOVEA RW1, RW7 | MOVEA RW1, @RW7+d8 | MOVEA RW2, RW7 | MOVEA RW2, @RW7+d8 | MOVEA RW3, RW7 | MOVEA RW3 @RW7+d8 | MOVEA RW4, RW7 | MOVEA RW4 @RW7+d8 | MOVEA RW5, RW7 | MOVEA RW5 @RW7+d8 | MOVEA RW6, RW7 | MOVEA RW6 ,@RW7+d8 | MOVEA RW7, RW | MOVEA RW7, @RW7+d8 |
| +8 | MOVEA RW0, @RWo | 'MOVEA RWO @RW0+d16 | MOVEA <br> RW1, @RW0 | 'MOVEA RW1, @RW0+d16 | MOVEA RW2, @RW0 | MOVEA RW2, @RW0+d16 | MOVEA RW3, @RW0 | MOVEA RW3 @RW0+d16 | MOVEA RW4, @RW0 | MOVEA RW4 @RW0+d16 | MOVEA RW5, @R | MOVEA RW5 @RW0+d16 | MOVEA RW6, @RW0 | ' MOVEA RW6 ,@RW0+d16 | MOVEA RW7, @ | OVEA RW7 @RW0+d16 |
| +9 | MOVEA RW0, @RW | 'MOVEA RWO @RW1+d16 | MOVEA <br> RW1, @RW1 | 'MOVEA RW1, @RW1+d16 | MOVEA RW2, @RW1 | 'MOVEA RW2, @RW1+d16 | MOVEA RW3, @RW1 | MOVEA RW3 @RW1+d16 | MOVEA RW4, @RW1 | MOVEA RW4, @RW1+d16 | MOVEA RW5, @RW1 | MOVEA RW5 @RW1+d16 | MOVEA RW6, @RW1 | ' MOVEA RW6 ,@RW1+d16 | MOVEA RW7, @RW1 | MOVEA RW7, @RW1+d16 |
| +A | MOVEA RW0, @RW | 'MOVEA RWO @RW2+d16 | MOVEA RW1, @RW | 'MOVEA RW1, @RW2+d16 | MOVEA RW2, @RW2 | 'MOVEA RW2, @RW2+d16 | MOVEA RW3, @RW2 | MOVEA RW3, @RW2+d16 | MOVEA RW4, @RW2 | MOVEA RW4, @RW2+d16 | MOVEA RW5, @RW | MOVEA RW5 @RW2+d16 | MOVEA RW6, @RW2' | ' MOVEA RW6 ,@RW2+d16 | MOVEA RW7, @RW | MOVEA RW7 @RW2+d16 |
| +B | MOVEA RW0, @RW3 | MOVEA RWO @RW3+d16 | MOVEA RW1, @RW3 | MOVEA RW1, @RW3+d16 | MOVEA RW2, @RW3 | 'MOVEA RW2, @RW3+d16 | MOVEA RW3, @RW3 | MOVEA RW3 @RW3+d16 | MOVEA RW4, @RW3 | MOVEA RW4 @RW3+d16 | MOVEA RW5, @RW3 | MOVEA RW5 @RW3+d16 | MOVEA RW6, @RW3 | ' MOVEA RW6 ,@RW3+d16 | MOVEA RW7, @RW | OVEA RW7, @RW3+d16 |
| +C | MOVEA W0, @RW | MOVEA RWO @RW0+RW7 | W1,@Rwo. | MOVEA RW1, @RW0+RW7 | MOVEA R W2, @RW0+ | 'MOVEA RW @RW0+R | MOVEA R W3, @RW0 | MOVEA R @RWO+R | MOVEA R W4, @RW0+ | MOVEA R @RW0+ | MOVEA R W5, @RW0 | MOVEA RW5 @RW0+RW7 | MOVEA R W6, @RW0+ | MOVEA RW6 @RW0+RW7 | MOVEA W7, @RW | OVVEA RW7 @RW0+RW7 |
| +D | MOVEA W0, @RW1 | MOVEA RWO @RW1+RW7 | MOVEA W1, @RW1 | ' MOVEA RW1, @RW1+RW7 | MOVEA R W2, @RW1+ | MOVEA R @RW1+ | MOVEA R W3, @RW1 | MOVEA R @RW1+ | MOVEA R W4, @RW1+ | MOVEA R @RW1+R | MOVEA R W5, @RW1 | MOVEA RW5 @RW1+RW7 | MOVEA R W6, @RW1+ | MOVEA RW6 ',@RW1+RW7 | MOVEA W7, @RW1 | MOVEA RW7, @RW1+RW7 |
| +E | MOVEA W0, @RW2 | MOVEA RWO @PC+d16 | MOVEA W1, @RW2 | I MOVEA RW1, @PC+d16 | MOVEA R W2, @RW2+ | MOVEA RW2, @PC+d16 | MOVEA R W3, @RW2+ | MOVEA RW @PC+d16 | MOVEA R W4, @RW2+ | MOVEA RW4 @PC+d16 | MOVEA R W5, @RW2+ | MOVEA RW5 @PC+d16 | MOVEA R W6, @RW2+ | MOVEA RW6 ,@PC+d16 | MOVEA R W7, @RW2 | MOVEA RW7, @PC+d16 |
| +F | $\begin{aligned} & \text { MOEA R } \\ & \text { W0, @RW3+ } \end{aligned}$ | MOVEA RWO | MOVEA R W1, @RW3 | 'MOVEA RW1, addr16 | MOVEA R W2, @RW3+ | MOVEA RW2, | MOVEA R W3, @RW3+ | MOVEA RW3, addr16 | MOVEA R W4, @RW3+ | MOVEA RW4 addr16 | MOVEA R W5, @RW3+ | MOVEA RW5 addr16 | MOVEA W6, @RW3+ | ' MOVEA RW6 ,addr16 | MOVEA R W7, @RW3+ | OVEA RW7, addr16 |

Table B.3.10 MOV Ri, ea (First byte = 7AH)

|  | 00 | 10 | 20 | 30 | 40 | 50 | 60 | 70 | 80 | 90 | A 0 | B 0 | C0 | D 0 | E 0 | F0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| +0 | $\underset{\mathrm{RO}, \mathrm{RO}}{\mathrm{MOV}}$ | MOV $\begin{array}{r}\text { RO, } \\ \text { @RWO+d8 }\end{array}, ~$ | $\begin{aligned} & \mathrm{MOV} \\ & \mathrm{R} 1, \mathrm{RO} \end{aligned}$ | $\begin{aligned} & \text { VV R1, R1, } \\ & \text { QRWO+d } \end{aligned}$ | MOV R2, R0 | MOV 2, $@ R W 0+d 8$ | MOV R3, RO | $\begin{aligned} & \text { OV R3, } \begin{aligned} \text { R3 } \\ \text { @RO } \end{aligned} \end{aligned}$ | MOV R4, R0 | R4, @RWO+d8 | $\begin{aligned} & \text { MOV } \\ & \text { R5, RO } \end{aligned}$ | MOV R5, @RWO +dB | MOV R6, R0 | MOV R6, | $\begin{aligned} & \text { MOV } \\ & \mathrm{RT}, \mathrm{RO} \end{aligned}$ | MOV R7, @RW0+d8 |
| +1 | Movi | $\begin{gathered} 1 \mathrm{MOV} \\ @ R W 1+\mathrm{d} 8 \\ \hline \end{gathered}$ | $\begin{aligned} & \mathrm{MOV} \\ & \mathrm{R} 1, \mathrm{R} 1 \end{aligned}$ | $\begin{gathered} \text { MOV R1, } \\ @ R W 1+d 8 \end{gathered}$ | MOV <br> R2, R1 | I MOV R2, @RW1+d8 | MOV R3, R1 | $\begin{gathered} \mathrm{MOV}^{\mathrm{RB}} \\ \mathrm{@RW} 1+\mathrm{d} 8 \end{gathered}$ | MOV <br> R4, R1 | $\begin{aligned} & \text { MOV R4, } \\ & @ R W 1+d 8 \end{aligned}$ | MOV R1 | MOV R5, @RW1+d8 | MOV <br> R6, R1 | Mov r6, @RW1+d8 | $\mathrm{MOV}_{\mathrm{R}, \mathrm{R} 1}$ | MOV R7, @RW1+d8 |
| +2 | $\begin{gathered} \text { MOV } \\ \text { RO, R2 } \end{gathered}$ | $\begin{gathered} \text { MOV RO, } \\ \text { @RW2+d8 } \\ 1 \end{gathered}$ | MOV R1, R2 |  | MOV R2, R2 | MOV R2, @RW2+d8 | MOV R3, R2 | $\begin{aligned} & \text { MOV R3, } \\ & @ R W 2+d 8 \end{aligned}$ | MOV <br> R4, R2 | MOV R4, @RW2+d8 | MOV R5, R2 | MOV R5, @RW2+d8 | MOV R6, R2 | MOV R6, @RW2+d8 | MOV <br> R7, R2 | MOV R7, @RW2+d8 |
| +3 | $\begin{gathered} \text { MOV } \\ \text { R0, R3 } \end{gathered}$ | $\begin{gathered} \text { MOV RO, } \\ @ R W 3+d 8 \end{gathered}$ | $\mathrm{MOV}_{\text {R1, R3 }}$ | $\begin{gathered} \text { Mov R1, } \\ \text { QRW } \end{gathered}$ | $\underset{\text { R2, R3 }}{\text { MOV }}$ | MOV R2, $@ R W 3+d 8$ | $\begin{aligned} & \text { MOV } \\ & \text { R3, R3 } \end{aligned}$ |  | $\begin{aligned} & \text { MOV } \\ & \text { R4, R3 } \end{aligned}$ | $\begin{aligned} & \text { MOV R4, } \\ & @ R W 3+d 8 \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R5, R3 } \end{aligned}$ | MOV R5, @RW3+d8 | $\begin{aligned} & \text { MOV } \\ & \text { R6, R3 } \end{aligned}$ | IMOV R6, @RW3+d8 | $\underset{\mathrm{RT}, \mathrm{R} 3}{\mathrm{MOV}}$ | MOV R7, @RW3+d8 |
| +4 | MOV <br> R0, R4 | $\begin{gathered} \text { MOV RO, } \\ @ R W 4+d 8 \end{gathered}$ | MOV <br> R1, R4 | $\begin{gathered} \text { TMOV R1, } \\ \text { @RW4+d } \end{gathered}$ | MOV <br> R2, R4 | 'MOV R2, @RW4+d8 | MOV R3, R4 | NOV R3, @RW4+d8 | MOV <br> R4, R4 | MOV R4, @RW4+d8 | $\mathrm{mov}_{\mathrm{RS}, \mathrm{R}}$ | MOV R5, @RW4+d8 | MOV R6, R4 | MOV R6, @RW4+d8 | MOV <br> R7, R4 | MOV R7, @RW4+d8 |
| +5 | $\begin{gathered} \mathrm{MOV} \\ \mathrm{RO}, \mathrm{R} 5 \end{gathered}$ | $\begin{gathered} 1-\mathrm{MOV} \\ \mathrm{@RW5}+\mathrm{d} 8 \end{gathered}$ | MOV R1, R5 | $\begin{gathered} \text { Tover } \\ \text { @RW5 } \end{gathered}$ | MOV R2, R5 | , MOV R2, | MOV R3, R5 | $\begin{gathered} \text { RO, } \\ @ R W 5+d 8 \end{gathered}$ | MOV <br> R4, R5 | OV R4, @RW5+d8 | MOV R5, R5 | MOV R5, @RW5+d8 | MOV R6, R5 | MOV RG, @RW5+d8 | MOV <br> R7, R5 | MOV R7, @RW5+d8 |
| +6 | $\begin{aligned} & \text { MOV } \\ & \text { RO, R6 } \end{aligned}$ | $\begin{gathered} \text { MOV RO, } \\ @ R W 6+d 8 \end{gathered}$ | $\begin{array}{\|c\|} \mathrm{MOV} \\ \mathrm{R1}, \mathrm{R} 6 \end{array}$ | TMOV R1, @RW6+d8 | MOV R2, R6 | MOV R2, @RW6+d8 | MOV | $\begin{gathered} \text { Mov R3, } \\ @ R W 6+d 8 \end{gathered}$ | MOV <br> R4, R6 | $\begin{aligned} & \text { MOV R4, } \\ & @ R W 6+d 8 \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { R5, R6 } \end{aligned}$ | MOV R5, @RW6+d8 | MOV R6, R6 | OV R6, @RW6+d8 | $\text { MOV } \mathrm{RT}, \mathrm{R} 6$ | MOV R7, @RW6+d8 |
| +7 | MOV R0, R7 | RO, @RW7+d8 | $\begin{aligned} & \text { MOV } \\ & \text { R1, R7 } \end{aligned}$ | $\begin{gathered} \text { Mov R1, } \\ \text { @RW7+d8 } \end{gathered}$ | MOV R2, R7 | MOV R2, @RW7+d8 | $\begin{aligned} & \text { MOV } \\ & \text { R3, R7 } \end{aligned}$ | $\begin{gathered} \text { MOV } \\ @ R W 7+d 8 \\ \hline \end{gathered}$ | MOV $\square$ $\mathrm{R} 4, \mathrm{R} 7$ | $\begin{aligned} & \text { MOV R4, } \\ & @ R W 7+d 8 \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \quad \text { R5, R7 } \end{aligned}$ | MOV R5, @RW7+d8 | MOV R6, R7 | Mov R6, @RW7+d8 | $\mathrm{MOV} \quad \mathrm{RT}, \mathrm{R7}$ | MOV R7, @RW7+d8 |
| +8 | $\begin{gathered} \mathrm{MOV} \\ \mathrm{RO}, @ \mathrm{RWO} \end{gathered}$ | $\begin{gathered} \text { MOV } \\ \text { @RWO }+\mathrm{d} 16 \end{gathered}$ | MOV- <br> R1, @RW0 | MOV ${ }^{-1}$ @RW0+d16 | MOV <br> R2, @RW0 | MOV R2, @RW0+d16 | MOV R3, @RW0 | $\begin{gathered} \text { MOV R3, } \\ @ R W 0+d 16 \end{gathered}$ | MOV R4, @RW0 | $\begin{gathered} \text { MOV } \\ @ R W 0+d 16 \end{gathered}$ | MOV | MOV R5, @RW0+d16 | MOV R6, @RW0 | MOV R6, @RW0+d16 | MOV R7, @RW0 | MOV R7, @RW0+d16 |
| +9 | Mō Ro, @RW1 | $\begin{aligned} & 1 \mathrm{MOV} \\ & \text { @RW1+d16 } \end{aligned}$ | MOV R1, @RW | MOV R1, @RW1+d16 | MOV <br> R2, @RW1 | MOV R2, @RW1+d16 | MOV R3, @RW1 | $\begin{aligned} & \text { Mov R3, } \\ & @ R W 1+d 16 \end{aligned}$ | MOV <br> R4, @RW1 | MOV R4, @RW1+d16 | MOV <br> R5, @RW1 | MOV R5, @RW1+d16 | MOV <br> R6, @RW1 | MOV RG, @RW1+d16 | MOV R7, @RW1 | MOV R7, @RW1+d16 |
| +A | MOV R0, @RW2 | MOV RO, @RW2+d16 | MOV R1, @RW2 | $\begin{gathered} \text { MOV R1, R1, } \\ \hdashline \text { RW2+d16 } \end{gathered}$ | MOV R2, @RW2 | MOV R2, @RW2+d16 | MOV R3, @RW2 | 'MOV R3, @RW2+d16 | MOV <br> R4, @RW2 | 'MOV R4, @RW2+d16 | MOV <br> R5, @RW2 | MOV R5, @RW2+d16 | MOV <br> R6, @RW2 | MOV R6, @RW2+d16 | MOV <br> R7, @RW2 | $\begin{aligned} & \text { Mov } \mathrm{RT}, \\ & \mathrm{@RW2}+\mathrm{d} 16 \end{aligned}$ |
| +B | MOV R0, @RW3 | $\begin{gathered} \text { MOV RO, } \\ @ R W 3+d 16 \end{gathered}$ | MOV R1, @RW3 | MOV R1, @RW3+d16 | MOV R2, @RW3 | MOV R2, @RW3+d16 | MOV R3, @RW3 | $\begin{aligned} & \text { MOV R3, } \\ & \text { @RW3+d16 } \end{aligned}$ | MOV <br> R4, @RW3 | MOV R4, @RW3+d16 | $\begin{aligned} & \text { MOV } \\ & \text { R5, @RW3 } \end{aligned}$ | MOV R5, @RW3+d16 | MOV <br> R6, @RW3 | MOV R6, @RW3+d16 | MOV <br> R7, @RW3 | MOV R7, @RW3+d16 |
| +C | MOV <br> RO, @RW0+ | $\begin{array}{r} M O V \text { RO, } \\ \hline @ R W O+R W 7 \end{array}$ | MOV - R1, R1, @RW0+ | $\begin{aligned} & \text { 'MOV R1, R1, } \\ & \therefore \text { @RW }+ \text { RW } \end{aligned}$ | MOV <br> R2, @RWO+ | MOV ${ }^{-\quad \text { R2 }}$ @RW0+RW才 | MOV R3, @RW0+' | $\begin{gathered} \text { Mov R3, } \\ +@ R W+R W 7 \end{gathered}$ | MOV R4, @RW0+ | $\begin{aligned} & \text { 'MOV R4, } \\ & \text { @RW+RW7 } \end{aligned}$ | MOV <br> R5, @RW0 | MOV R5, @RW0+RW7 | MOV R6, @RW0+ | MOV R6, @RW0+RW7 | MOV R7, @RWO | $\begin{aligned} & \text { MOV } \\ & @ R W 0+R W 7 \\ & \hline \end{aligned}$ |
| +D | MOV <br> R0, @RW1+ | $\begin{array}{r} M O V \\ \hline @ R W 1+R W 7 \\ \hline \end{array}$ | MOV R1, R1, @RW1+ | $\begin{aligned} & \text { 'MOV R1, R1 } \\ & : \text { @RW1+RW } \end{aligned}$ | MOV <br> R2, @RW1+ | 'MOV R2, @RW1+RW7 | MOV R3, @RW1+ |  | MOV <br> R4, @RW1+ | MOV R4, @RW1+RW7 | MOV <br> R5, @RW1+ | MOV R5, @RW1+RW7 | MOV R6, @RW1+ | MOV R6, @RW1+RW7 | MOV R7, @RW1+ | $\begin{array}{cc} \text { MOV } & \text { R7, } \\ @ R W 1+R W 7 \end{array}$ |
| +E | MOV | $\begin{array}{r} \text { RO, } \\ \hline \\ \hline \end{array}$ | $\begin{aligned} & \text { MOV R1, } \\ & \text { R1, @RW2+ } \end{aligned}$ | $\begin{aligned} & \text { MOV R1, } \\ & @ P C+d 16 \end{aligned}$ | MOV R2, @RW2+ | $\begin{gathered} \text { MOV R2, } \\ \varrho(1) \end{gathered}$ | MOV R3, @RW2+ | $\begin{gathered} \text { MOV } \\ \text { RPC+d } \\ \hline \end{gathered}$ | MOV <br> R4, @RW2 | $\begin{array}{r} \mathrm{MOV} 4, \\ @ \mathrm{CC}+\mathrm{d} 16 \end{array}$ | $\begin{aligned} & \text { Mov } \\ & \text { R5, @RW2+ } \end{aligned}$ | $\begin{gathered} \text { MOV R5, } \\ @ P C+d 16 \end{gathered}$ | @RW2+ <br> MOV R6, | MOV R6, @PC+d16 | $\begin{aligned} & \text { MOV R7, } \\ & \text { @RW2+ } \end{aligned}$ | $\begin{aligned} & \text { OPC RT, } \\ & \hline \end{aligned}$ |
| +F | MOV R0, @RW3+ | $\begin{array}{r} \text { MOV } \begin{array}{r} \text { RO, } \\ +\quad \text { @addr16 } \end{array} \\ \hline \end{array}$ | MOV ${ }^{-\quad-1}$ R1, @RW3+1 | $\begin{array}{r} \text { MOV } 1, \\ \text { addr1 } 16 \end{array}$ | MOV <br> R2, @RW3+ | MOV R2, | MOV R3, @RW3+ | ${ }^{\text {MOV }}{ }^{\text {Raddr16 }}{ }^{\text {, }}$ | MOV R4, @RW3+ | ${ }^{\prime} \text { MOV }{ }_{\text {addr1 } 6} \text { R4, }$ | MOV <br> R5, @RW3+ | $\begin{gathered} \text { MOV R5, } \\ \text { addr16 } \\ \hline \end{gathered}$ | MOV R6, @RW3+ | MOV R6, addr16 | MOV R7, @RW3+ | $\begin{gathered} \mathrm{n}^{2} \mathrm{R}, \\ \text { addr1 } 16 \end{gathered}$ |

Table B.3.1p MOVW RWi, ea (First byte = 7BH)

|  | 00 | 10 | 20 | 30 | 40 | 50 | 60 | 70 | 80 | 90 | A 0 | в 0 | co | Do | E 0 | Fo |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| +0 | $\begin{aligned} & \text { MOVW } \\ & \text { RWO, RW0 } \end{aligned}$ | OVW RWO, @RW0+d8 | MOVW RW1, RW0 | MOVW RW1, <br> D @RW0+d8 | MOVW RW2, RW0 | MOVW RW2, @RW0+d8 | $\begin{aligned} & \text { MOVW } \\ & \text { RW3, RWO } \end{aligned}$ | MOVW RW3, @RW0+d8 | MOVW RW4, RW0 | MOVW RW4, @RW0+d8 | MOVW RW5, RW0 | MOVW RW5, @RW0+d8 | MOVW RW6, RW0 | OVW RW6, @RW0+d8 | MOVW RW7, RW0 | OVW RW7 @RW0+d8 |
| +1 | $\begin{aligned} & \text { MOVW } \\ & \text { RWO, RW } \end{aligned}$ | Viw Rwo @RW1+d8 | MOVW RW1, RW 1 | OVWW RW1, @RW1+d8 | MOVW RW2, RW1 | MOVW RW2, @RW1+d8 | MOVW RW3, RW1 | MOVW RW3, @RW1+d8 | MOVW RW4, RW | MOVW RW4, @RW1+d8 | MOVW RW5, R | MOVW RW5, @RW1+d8 | MOVW RW6, RW1 | MOVW RW6, @RW1+d8 | MOVW RW7, RW1 | $\begin{aligned} & \text { OVW RW7, } \\ & \text { @RW1+d8 } \end{aligned}$ |
| +2 | $\begin{aligned} & \text { MOVW } \\ & \text { RW0, RW2 } \end{aligned}$ | VW RWO @RW2+d8 | MOVW RW1, RW2 | MOVW RW1, @RW2+d8 | MOVW RW2, RW2 | MOVW RW2, @RW2+d8 | MOVW RW3, RW2 | MOVW RW3, @RW2+d8 | MOVW RW4, RW2 | OVW RW4, @RW2+d8 | MOVW RW5, RW2 | MOVW RW5 @RW2+d8 | MOVW RW6, RW2 | MOVW RW6, @RW2+d8 | MOVW RW7, RW2 | MOVW RW7 @RW2+d8 |
| +3 | MOVW RW0, RW3 | OVW RWO, @RW3+d8 | MOVW RW1, RW3 | MOVW RW1, @RW3+d8 | MOVW RW2, RW3 | MOVW RW2, @RW3+d8 | MOVW RW3, RW3 | MOVW RW3, @RW3+d8 | MOVW RW4, RW3 | MOVW RW4 @RW3+d8 | MOVW RW5, RW3 | MOVW RW5 @RW3+d8 | MOVW RW6, RW3 | MOVW RW6, @RW3+d8 | MOVW RW7, RW3 | MOVW RW7, @RW3+d8 |
| +4 | MOVW RW0, RW4 | MOVW RW0, @RW4+d8 | MOVW RW1, RW4 | MOVW RW1, @RW4+d8 | MOVW RW2, RW4 | MOVW RW2, @RW4+d8 | MOVW RW3, RW4 | MOVW RW3, @RW4+d8 | MOVW RW4, RW4 | MOVW RW4 @RW4+d8 | MOVW RW5, RW4 | MOVW RW5, @RW4+d8 | MOVW RW6, RW4 | MOVW RW6, @RW4+d8 | MOVW RW7, RW4 | MOVW RW7, @RW4+d8 |
| +5 | MOVW RW0, RW5 | MOVW RW0, @RW5+d8 | MOVW RW1, RW5 | MOVW RW1, @RW5+d8 | MOVW RW2, RW5 | MOVW RW2, @RW5+d8 | MOVW RW3, RW5 | MOVW RW3, @RW5+d8 | MOVW RW4, RW5 | MOVW RW4 @RW5+d8 | MOVW RW5, RW5 | MOVW RW5, @RW5+d8 | MOVW RW6, RW5 | MOVW RW6, @RW5+d8 | MOVW RW7, RW5 | MOVW RW7, @RW5+d8 |
| +6 | MOVW RW0, RW6 | MOVW RWO, @RW6+d8 | MOVW RW1, RW6 | MOVW RW1, @RW6+d8 | MOVW RW2, RW6 | MOVW RW2, @RW6+d8 | MOVW RW3, RW6 | MOVW RW3, @RW6+d8 | MOVW RW4, RW6 | MOVW RW4, @RW6+d8 | MOVW RW5, RW6 | MOVW RW5, @RW6+d8 | MOVW RW6, RW6 | 'MOVW RW6, @RW6+d8 | MOVW RW7, RW6 | MOVW RW7, @RW6+d8 |
| +7 | MOVW RW0, RW7 | $\begin{gathered} \text { MOWW } \\ \text { @RW7 } \end{gathered}$ | MOVW RW1, RW7 | MOVWRW1, | MOVW RW2, RW7 | MOVW RW2, @RW7+d8 | $\begin{aligned} & \text { MOVW } \\ & \text { RW3, RW7 } \end{aligned}$ | MOVW RW3, @RW7+d8 | MOVW RW4, RW7 | MOVW RW4, $@ R W 7+d 8$ | MOVW RW5, RW7 | MOVW RW5, @RW7+d8 | MOVW RW6, RW7 | MOVW RW6, $@ R W 7+d 8$ | MOVW RW7, RW7 | MOVW RW7, <br> @RW7+d8 |
| +8 | MOVW RW0, @RW0 | OVW RWO @RWO+d16 | MOVW RW1, @RW0 | 'MOVW RW1, <br> @ ${ }^{1}+0+d 16$ | MOVW <br> RW2, @RW0 | MOVW RW2, @RW0+d16 | MOVW RW3, @RW0 | MOVW RW3 @RW0+d16 | MOVW RW4, @RW0 | MOVW RW4 @RW0+d16 | MOVW RW5, @R | MOVW RW5 @RW0+d16 | MOVW RW6, @RW0 | MOVW RW6, @RW0+d16 | MOVW RW7, @RW0 | MOVW RW7 @RW0+d16 |
| +9 | MOVW RW0, @RW1 | OVW RWO, @RW1+d16 | MOVW RW1, @RW1 | MOVW RW1, <br> @ @RW1+d16 | MOVW RW2, @RW1 | MOVW RW2 @RW1+d16 | MOVW RW3, @RW1 | MOVW RW3, @RW1+d16 | MOVW RW4, @RW1 | MOVW RW4 @RW1+d16 | MOVW RW5, @RW1 | MOVW RW5 @RW1+d16 | MOVW RW6, @RW1 | MOVW RWG, @RW1+d16 | MOVW RW7, @RW1 | MOVW RW7 @RW1+d16 |
| +A | MOVW RW0, @RW2 | 'MOVW RW0, @RW2+d16 | MOVW <br> RW1, @RW2 | MOVW RW1, <br> @RW2+d16 | MOVW RW2, @RW2 | MOVW RW2, @RW2+d16 | MOVW RW3, @RW2 | MOVW RW3, @RW2+d16 | MOVW RW4, @RW2 | MOVW RW4 @RW2+d16 | MOVW RW5, @RW2 | MOVW RW5 @RW2+d16 | MOVW RW6, @RW2 | MOVW RW6, @RW2+d16 | MOVW RW7, @RW2 | MOVW RW7, @RW2+d16 |
| +B | MOVW RW0, @RW3 | 'MOVW RWO, @RW3+d16 | MOVW <br> RW1, @RW3 | 'MOVW RW1, ' @RW3+d16 | MOVW RW2, @RW3 | MOVW RW2, @RW3+d16 | MOVW RW3, @RW3 | MOVW RW3, @RW3+d16 | MOVW RW4, @RW3 | MOVW RW4, @RW3+d16 | MOVW RW5, @RW3 | MOVW RW5, @RW3+d16 | MOVW RW6, @RW3 | MOVW RW6, @RW3+d16 | MOVW RW7, @RW3 | MOVW RW7, @RW3+d16 |
| +C | MOVW R W0, @RWO+ | 'MOVW RWO, ' @RW0+RW7 | MOVW R W1, @RW0+ | MOVW RW1, <br> @RW0+RW7 | MOVW R W2, @RW0+ | MOVW RW2, @RW0+RW7 | MOVW R W3, @RW0 | MOVW RW3, @RW0+RW7 | MOVW R W4, @RW0+ | MOVW RW4 <br> @RW0+RW | $\begin{aligned} & \text { MOVW } \\ & \text { W5, @RWO+ } \end{aligned}$ | MOVW RW5 @RW0+RW7 | MOVW R W6, @RW0+ | MOVW RW6, @RW0+RW7 | MOVW W7, @RW0+ | MOVW RW7, @RW0+RW7 |
| +D | Movw R W0, @RW1+ | 'MOVW RWo, ' @RW1+RW7 | MOVW R W1, @RW1+ | + @RW1+RW | MOVW R W2, @RW1+ | OVW RW2, @RW1+RW7 | MOVW R W3, @RW1 | MOVW RW3, @RW1+RW | MOVW R W4, @RW1+ | MOVW RW4 @RW1+RW | $\begin{aligned} & \text { MOVW } \\ & \text { W5, @RW1+ } \end{aligned}$ | MOVW RW5, @RW1+RW7 | MOVW R W6, @RW1+ | MOVW RW6, @RW1+RW7 | MOVW R W7, @RW1+ | ' MOVW RW7, |
| +E | Movw R W0, @RW2+ | MOVW RWo, @PC+d16 | MOVW <br> W1, @RW2 | MOVW RW1, @PC+d16 | MOVW R W2, @RW2+ | MOVW RW2, @PC+d16 | MOVW R W3, @RW2 | MOVW RW3, @PC+d16 | MOVW W4, @RW2+ | MOVW RW4, @PC+d16 | MOVW R W5, @RW2+ | MOVW RW5, @PC+d16 | MOVW R W6, @RW2 | MOVW RW6, @PC+d16 | MOVW W7, @RW2+ | MOVW RW7, @PC+d16 |
| +F | $\begin{aligned} & \text { MOW R } \\ & \text { W0, @RW3+ } \end{aligned}$ | addr16 | MOVW R W1, @RW3+ | $\begin{gathered} \text { MOVW RW1, } \\ +1 \quad \text { addr16 } \\ \hline \end{gathered}$ | MOVW R W2, @RW3+ | MOVW RW2, | MOVW R W3, @RW3+ | MOVW RW3, addr16 | MOVW R W4, @RW3+ | $\begin{aligned} & \text { MOVW RW4, } \\ & \text { addr16 } \end{aligned}$ | $\begin{aligned} & \text { MOVW } \begin{array}{l} \text { R } \\ \text { 5 }, @ R W 3+1 \end{array} \end{aligned}$ | Movw rw5, addr16 | MOVW R W6, @RW3+ | MOVW RW6, addr16 | MOVW W7, @RW3+ | $\begin{gathered} \text { MOVW RW7, } \\ \hline \end{gathered}$ |

Table B.3.1q MOV ea, Ri (First byte $=7 \mathrm{CH}$ )

|  | 00 | 10 | 20 | 30 | 40 | 50 | 60 | 70 | 80 | 90 | A 0 | в 0 | co | D 0 | E 0 | F 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| +0 | $\begin{aligned} & \mathrm{MOV} \\ & \mathrm{RO}, \mathrm{RO} \end{aligned}$ | $0+d 8$, Ro | $\mathrm{MOV}_{\mathrm{RO}, \mathrm{R} 1}$ |  | $\begin{aligned} & \mathrm{MOV} \\ & \mathrm{RO}, \mathrm{R} 2 \end{aligned}$ | $\begin{aligned} & \text { MOV @R, } \\ & \text { W0 }+d 8 \text {, R2 } \end{aligned}$ | MOV | ${ }_{88, R 3}^{@ R}$ | $\begin{aligned} & \mathrm{MOV} \\ & \mathrm{RO}, \mathrm{R} \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { W0 }+\mathrm{d} 8, \mathrm{R} \end{aligned}$ | MOV |  | $\begin{array}{\|l\|} \hline \mathrm{MOV} \\ \mathrm{RO}, \mathrm{R} 6 \end{array}$ | $\begin{aligned} & \text { nov } \\ & \mathrm{WO}+\mathrm{dB}, \mathrm{R} \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { RO, R7 } \end{aligned}$ | $\mathrm{R} 7$ |
| +1 | $\begin{gathered} \text { MOV } \\ \text { R1, RO } \end{gathered}$ | $\begin{aligned} & \text { NOV } \\ & \text { W1+d8, RO } \end{aligned}$ | $\underset{R 1, R 1}{ }$ | W1+d8, R1 | $\begin{aligned} & \mathrm{MOV} \\ & \mathrm{R1}, \mathrm{R} 2 \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \mathrm{W} 1+d 8 \text { R2 } \end{aligned}$ | $\begin{aligned} & \text { mov } \\ & \mathrm{R} 1, \end{aligned}$ | $\begin{gathered} \text { MOV } \\ \text { W1+d8, R3 } \end{gathered}$ | $\begin{aligned} & \text { MOV } \\ & \text { R1, } \end{aligned}$ | $\begin{gathered} M O V \\ \mathrm{~W} 1+d 8, R 4 \end{gathered}$ | $\begin{aligned} & \text { MOV } \\ & \text { R1, } \end{aligned}$ | $\begin{aligned} & \mathrm{MOV} \text { @R } \\ & \mathrm{WW}+\mathrm{de}, \mathrm{R5} \end{aligned}$ | $\underset{\mathrm{R} 1, \mathrm{R} 6}{-\overline{\mathrm{MO}}}$ | $\begin{aligned} & \mathrm{OV}^{\mathrm{Q}} \mathrm{Q}+\mathrm{Q} \\ & \hline \end{aligned}$ | $\mathrm{MOV}_{\mathrm{R} 1, \mathrm{R7}}$ |  |
| +2 | MOV $\mathrm{R} 2, \mathrm{RC}$ | $\begin{aligned} & \text { Cov @R } \\ & \text { W2+d8, Ro } \end{aligned}$ | MOV R2, R1 | $\begin{aligned} & \text { Mov } \\ & \text { W2+d8, R1 } \end{aligned}$ | MOV R2, R2 | $\begin{aligned} & \text { MOV @R } \\ & \text { W2+d8, R2 } \end{aligned}$ | $\begin{gathered} \mathrm{MOV} \\ \text { R2, R3 } \end{gathered}$ | MOV | MOV R2, R4 | $\begin{aligned} & \mathrm{MOV} \\ & \mathrm{~W} 2+d 8, \mathrm{R4} \end{aligned}$ | MOV | 「MOV @R $\mathrm{W} 2+\mathrm{d} 8 \text {, R5 }$ | $\mathrm{MOV}_{\mathrm{R}, \mathrm{R}}^{-}$ | $\begin{gathered} \text { MOV @R } \\ \text { W2+d8, R6 } \end{gathered}$ | MOV R2, R7 | $\begin{gathered} @ R \\ V 2+d 8, R 7 \end{gathered}$ |
| +3 | MOV R3, R0 | 3+d8, R0 | MOV | $\begin{aligned} & \text { MOV } \\ & \text { W } 3+d 8, R 1 \end{aligned}$ | MOV $\mathrm{R} 3, \mathrm{R}$ | $\begin{aligned} & \text { MOV @R } \\ & \text { W } 3+d 8, R 2 \end{aligned}$ | MOV <br> R3, | $\begin{gathered} \text { MOV @R } \\ \text { W3+d8, R3 } \end{gathered}$ | MOV R3, | MOV @R, <br> W3+d8, R4 | MOV R3, R5 | MOV @R W3+d8, R5 | mov $R 3,$ | $\begin{gathered} 10-\mathrm{R} \\ \mathrm{~W} 3+\mathrm{d} 8, \mathrm{R} 6 \end{gathered}$ | MOV R3, | $\begin{aligned} & \text { OV } \\ & \text { W }+d 8, ~ \\ & \hline \end{aligned}$ |
| +4 | MOV R4, R0 | MOV @R W4+d8, R0 | MOV R4, R | $\begin{aligned} & \text { Mov } \\ & \mathrm{W} 4+\mathrm{di}, \mathrm{R} 1 \end{aligned}$ | $\left[\begin{array}{l} \mathrm{MOV} \\ \mathrm{R4}, \mathrm{R} \end{array}\right.$ | $\begin{aligned} & \text { MOV @R } \\ & \mathrm{W} 4+\mathrm{d} 8, \mathrm{R} 2 \end{aligned}$ | $\begin{gathered} \mathrm{MOV} \\ \mathrm{R4}, \mathrm{~F} \end{gathered}$ | $\begin{gathered} \text { MOV @R } \\ \text { W4+d8, R3 } \end{gathered}$ | $\begin{aligned} & \text { MOV } \\ & \hline 84, \end{aligned}$ | $\begin{gathered} M O V \\ \mathrm{~W} 4+\mathrm{dB}, \mathrm{R4} \end{gathered}$ | MOV R4, R5 | MOV @R W4+d8, R5 | $\begin{aligned} & \text { MOV } \\ & \mathrm{R} 4, \mathrm{R} 6 \end{aligned}$ | $\begin{aligned} & \text { OV } \begin{array}{l} \text { QR } \\ \text { W4+d8, R6 } \end{array} \end{aligned}$ | $\begin{aligned} & \mathrm{MOV} \\ & \mathrm{R} 4 \end{aligned}$ | $\begin{aligned} & \mathrm{OV} \text { WR } \\ & \mathrm{W}+\mathrm{d8}, \mathrm{R} \\ & \hline \end{aligned}$ |
| +5 | MOV R5, RC | MOV @R | MOV R5, R | $\begin{gathered} \mathrm{MOV}_{\mathrm{W}+\mathrm{d}, \mathrm{R} 1}^{\mathrm{R}} \end{gathered}$ | MOV R5, F | $\begin{aligned} & \text { MOV @R } \\ & \text { W } 5+d 8, \mathrm{R} 2 \end{aligned}$ | $\begin{aligned} & \mathrm{MOV} \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { MOV @R } \\ & \text { W } \mathrm{Q}+\mathrm{RB}, \end{aligned}$ | $\begin{gathered} \mathrm{MOV} \\ \mathrm{R5}, \end{gathered}$ | $\begin{aligned} & \text { MOV @R } \\ & \mathrm{W}+\mathrm{Q} 8, \mathrm{R4} \end{aligned}$ | MOV R5, | MOV @R W5+d8, R5 | $\mathrm{MOV}$ | $\begin{aligned} & \mathbf{O V}^{\mathrm{QR}} \\ & \mathrm{~W} 5+\mathrm{d}, \mathrm{R} \end{aligned}$ | mov |  |
| +6 | MOV R6, RO | $\begin{aligned} & \text { MOV @R } \\ & \text { W6+d8, RO } \end{aligned}$ | MOV <br> R6, R1 | $\begin{gathered} \text { MOV } \\ \mathrm{W}+\mathrm{Q} 8, \mathrm{R} 1 \end{gathered}$ | MOV <br> R6, R2 | $\begin{aligned} & \text { MOV @R } \\ & \text { W6+d8, R2 } \end{aligned}$ | MOV R6, | $\begin{gathered} \text { MOV } \\ \text { W } 6+d 8, R 3 \end{gathered}$ | $\begin{array}{\|c} \text { MOV } \\ \text { R6, R4 } \end{array}$ | $: \begin{gathered} \text { MOV } @ \mathrm{~B} \\ \mathrm{~W}+\mathrm{d}, \mathrm{R4} \end{gathered}$ | $\mathrm{MOV}_{\mathrm{RG}, \mathrm{R}}$ | MOV @R W6+d8, R5 | $\begin{gathered} -\mathrm{MOV}_{\mathrm{R}} \mathrm{R} 6 \end{gathered}$ | $\begin{gathered} \text { MOV } \\ \text { W6 }+\mathrm{d} 8, \mathrm{R} \end{gathered}$ | $\begin{aligned} & \text { MOV } \\ & \text { R6, R7 } \end{aligned}$ | $\begin{aligned} & 10 V^{@ R} \\ & W 6+d 8, R 7 \end{aligned}$ |
| +7 | $\begin{aligned} & \text { MOV } \\ & \text { R7, RO } \end{aligned}$ | MOV @R | MOV <br> R7, R1 | $\begin{gathered} \text { MOV @R } \\ \text { W7+d8, R1 } \end{gathered}$ | MOV R7, R2 | $\begin{aligned} & \text { MOV @R } \\ & \mathrm{W} 7+\mathrm{d}, \mathrm{R} 2 \end{aligned}$ | $\begin{gathered} \text { MOV } \\ \text { R7, R3 } \end{gathered}$ | $\begin{gathered} \text { MOV @R } \\ \text { W7+d8, R3 } \end{gathered}$ | $\begin{gathered} \mathrm{MOV} \\ \mathrm{RF}, \end{gathered}$ | $\begin{aligned} & \text { MOV @R } \\ & \mathrm{W} 7+\mathrm{dB}, \mathrm{R4} \end{aligned}$ | MOV R | MOV @R W7+d8, R5 | $\begin{aligned} & \mathrm{MOV}-{ }^{-} \\ & \mathrm{RT} 7, \mathrm{R6} \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { W7 } \\ & \text { @R } \\ & \hline \end{aligned}$ | MOV, R7 | $\begin{aligned} & 10 v \\ & w 7+d 8,{ }_{2} \\ & \hline \end{aligned}$ |
| +8 | MOV @RW0, R0 | 'MOV @RW ,W0+d16, R0 | MOV @RW0, R1 | OV @RW $0+d 16, R$ | MOV @RW0, R2 | MOV @RW , 0+d16, R2 | MOV @RW0, R3 | MOV @RW 0+d16, R3 | MOV @RW0, R4 | MOV @RW $0+\mathrm{d} 16, \mathrm{R} 4$ | MOV @RW0, R5 | $\begin{aligned} & \text { MOV @RW } \\ & 0+d 16, ~ R 5 \end{aligned}$ | MOV <br> @RW0, R6 | MOV @RW 0+d16, R6 | MOV @RW0, R7 | MOV @RW 0+d16, R7 |
| +9 | $\mathrm{MOV}_{@ R W 1, ~ R O}$ | 'MOV @RW W1+d16, R0 | MOV @RW1, R1 | $\begin{gathered} \mathbf{M O V} \text { @RW } \\ 1+\mathrm{d} 16, \mathrm{R1} \end{gathered}$ | MOV @RW1, R2 | 'MOV @RW 1+d16, R2 | $\begin{aligned} & \text { MOV } \\ & \text { @RW1, R3 } \end{aligned}$ | $\begin{aligned} & \text { MOV @RW } \\ & 1+\mathrm{d} 16, \mathrm{R} 3 \end{aligned}$ | MOV @RW1, R4 | $\begin{aligned} & \text { MOV @RW } \\ & 1+d 16, ~ R 4 \end{aligned}$ | MOV <br> @RW1, R5 | MOV @RW 1+d16, R5 | MOV <br> @RW1, R6 | MOV @RW 1+d16, R6 | MOV @RW1, R7 | MOV @RW 1+d16, R7 |
| +A | @RW2, R0 | 'MOV @RW 'W2+d16, R0 | MOV @RW2, R1 | $\begin{gathered} \text { MOV @RW } \\ 2+d 16, R 1 \end{gathered}$ | MOV @RW2, R2 | $\begin{aligned} & 1 \mathrm{MOV} \text { @F } \\ & 2+d 16, \mathrm{R} 2 \end{aligned}$ | MOV @RW2, R3 | MOV @RW 2+d16, R3 | MOV @RW2, R4 | 'MOV @RW <br> 2+d16, R4 | MOV <br> @RW2, R5 | $\begin{aligned} & \text { MOV @RW } \\ & 2+d 16, ~ R 5 \end{aligned}$ | MOV <br> @RW2, R6 | MOV @RW 2+d16, R6 | MOV @RW2, R7 | MOV @RW 2+d16, R7 |
| +B | @RW3, R0 | 'MOV @RW 'W3+d16, R0 | MOV @RW3, R1 | $\begin{gathered} \mathrm{MOV}_{3+\mathrm{d} 16, \mathrm{R} 1} \mathrm{RW} \\ \hline \end{gathered}$ | MOV @RW3, R2 | MOV @RW $\text { ' } 3+d 16, \mathrm{R} 2$ | MOV @RW3, R3 | $\begin{aligned} & \text { MOV @RW } \\ & 3+d 16, \text { R3 } \end{aligned}$ | MOV @RW3, R4 | $\begin{array}{lll} 1 \mathrm{MOV} \text { @RW } \\ 3+\mathrm{d} 6, \mathrm{R} 4 \end{array}$ | MOV <br> @RW3, R5 | MOV @RW 3+d16, R5 | MOV <br> @RW3, R6 | MOV @RW 3+d16, R6 | MOV @RW3, R7 | MOV @RW 3+d16, R7 |
| +C | @RWO+, RO | V 0+RW7, R0 | MOV @RW0+, R1 | OV @ 0+RW7, R1 | MOV @RW0+, R2 | MOV @RW 0+RW7, R2 | MOV | MOV @RW 0+RW7, R3 | MOV @RW0+, R4 | MOV @RW 0+RW7, R4 | MOV @RW0+, R5 | $\begin{aligned} & \text { MOV @RW } \\ & 0+\mathrm{RW} 7, \mathrm{R5} \end{aligned}$ | MOV @RW0+, R6 | MOV @RW 0+RW7, R6 | MOV @RW0+, R7 | MOV @RW 0+RW7, R7 |
| +D | $\begin{aligned} & \text { MOV } \\ & @ R W 1+, ~ R O \end{aligned}$ | 'MOV @RW 'W1+RW7, R0 | MOV <br> @RW1+, R1 | 'MOV @RW 1+RW7, R1 | MOV @RW1+, R2 | 'MOV @RW '1+RW7, R2 | $\begin{aligned} & \text { MOV } \\ & \text { @RW1+, R3 } \end{aligned}$ | $\begin{aligned} & \text { MOV @RW } \\ & 1+R W 7, R 3 \end{aligned}$ | MOV @RW1+, R4 | 'MOV @RW <br> 1+RW7, R4 | MOV @RW1+, R5 | $\begin{aligned} & \text { MOV @RW } \\ & 1+\mathrm{RW} 7, \mathrm{R5} \end{aligned}$ | $\begin{aligned} & \text { MOV } \\ & \text { @RW1+, R6 } \end{aligned}$ | MOV @RW 1+RW7,R6 | MOV @RW1+, R7 | MOV @RW 1+RW7, R7 |
| +E | MOV @RW2+, R0 | 'MOV <br> 'PC+d16, R0 | MOV @RW2+, R1 | MOV <br> 'PC+d16, R1 | MOV @RW2+, R2 | MOV <br> ' PC+d16, R2 | $\begin{aligned} & \text { MOV } \\ & \text { @RW2+, R3 } \end{aligned}$ | MOV <br> PC+d16, R3 | MOV @RW2+, R4 | , MOV <br> ' PC+d16, R4 | MOV @RW2+, R5 | PC+d16, R5 | MOV @RW2+, R6 | MOV <br> PC+d16, R6 | MOV @RW2+, R7 | MOV C+d16, R7 |
| +F | $\begin{aligned} & \text { MOV } \\ & \text { @RW3+, RO } \end{aligned}$ | MOV addr16, Ro | $\begin{aligned} & \text { MOV } \\ & \text { @RW3 }+ \text { R1 } \end{aligned}$ | $\begin{gathered} \text { 'MOV } \\ 1 \\ \text { addr16, R1 } \\ \hline \end{gathered}$ | $\begin{array}{\|l\|} \hline \text { MOV } \\ \text { @RW }+ \text {, R2 } \\ \hline \end{array}$ | addr16, R2 | $\begin{aligned} & \text { MOV } \\ & \text { @RW3+, R3 } \end{aligned}$ | BI addr16, R3 | MOV @RW3+, R4 | $\begin{aligned} & \text { MOV } \\ & \quad \text { addr16, R4 } \end{aligned}$ | $\begin{aligned} & \mathrm{MOV} \\ & @ \mathrm{RW} 3+, \mathrm{R} 5 \\ & \hline \end{aligned}$ | addr16, R5 | @RW3+, R6 | MOV <br> addr16, R6 | $\begin{aligned} & \text { MOV } \\ & \text { @RW3+, R7 } \\ & \hline \end{aligned}$ | MOV |

Table B.3.1r MOVW ea, RWi (First byte = 7DH)

|  | 00 | 10 | 20 | 30 | 40 | 50 | 60 | 70 | 80 | 90 | A 0 | B 0 | c 0 | D 0 | E 0 | F 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| +0 | $\begin{aligned} & \hline \text { MOVW } \\ & \text { RW0, RW0 } \end{aligned}$ | vw @Rw -d8, RWo | MOVW RW0, RW1 | 'MOVW @RW 0+d8, RW1 | $\begin{aligned} & \text { MOVW } \\ & \text { RW0, RW2 } \end{aligned}$ | 'MOVW @RW <br> 0+d8, RW2 | $\begin{aligned} & \text { MOVW } \\ & \text { RWO, RW3 } \end{aligned}$ | MOVW @RW 0+d8, RW3 | MOVW <br> RW0, RW4 | OVW @RW +d8, RW4 |  | MOVW @RW 0+d8, RW5 | RW0, RW6 | MOVW @RW 0+d8, RW6 | MOVW RW0, RW7 | 0+d8, RW7 |
| +1 | MOVW RW1, RW | MOVW @RW 1+d8, RW0 | MOVW <br> RW1, RW1 | MOVW @R | MOVW <br> RW1, RW2 | MOVW @R <br> 1+d8, RW2 | MOVW RW1, RW3 | 'MOVW @RW 1+d8, RW3 | MOVW RW1, RW | 'MOVW @RW <br> 1+d8, RW4 | MOVW <br> RW1, RW5 | 'MOVW @RW 1+d8, RW5 | MOVW RW1, RW6 | 'MOVW @RW 1+d8, RW6 | MOVW RW1, RW7 | MOVw @RW 1+d8, RW7 |
| +2 | MOVW RW2, RW0 | MOVW @RW 2+d8, RW0 | MOVW RW2, RW | 'MOVW @RW ' 2+d8, RW1 | $\begin{aligned} & \text { MOVW } \\ & \text { RW2, RW2 } \end{aligned}$ | $\begin{aligned} & \text { 'MOVW @RW } \\ & \text { 2+d8, RW2 } \end{aligned}$ | MOVW RW2, RW3 | 'MOVW @RW 2+d8, RW3 | MOVW RW2, RW4 | $\begin{aligned} & \text { MOVW @RW } \\ & \text { 2+d8, RW4 } \end{aligned}$ | MOVW RW2, R | 'Movw @RW <br> 2+d8, RW5 | MOVW RW2, RW6 | $\begin{aligned} & \text { MOVW @RW } \\ & \text { 2+d8, RW6 } \end{aligned}$ | MOVW RW2, RW7 | OVW @RW 2+d8, RW7 |
| +3 | MOVW RW3, R | MOVW @Rw 3+d8, RW0 | $\left\lvert\, \begin{aligned} & \mathrm{MOV} \\ & \mathrm{RW} \end{aligned}\right.$ | IMOVW @RW \| 3+d8, RW1 | $\begin{gathered} \text { MOVW } \\ \text { RW3, } \end{gathered}$ | $\begin{aligned} & \text { MOVW @RW } \\ & \text { 3+d8, RW2 } \end{aligned}$ |  | IMOVW @RW <br> 1 3+d8, RW3 | MOWW RW3, | MOVW @RW 3+d8, RW4 | MOVW RW3, RW5 | OVW @RW 3+d8, RW5 | RW3, | MOVW @RW <br> I 3+d8, RW6 | MOVW RW3, RW7 | OVW @RW 3+d8, RW7 |
| +4 | RW4, R | $\begin{aligned} & \text { MOVW @RW } \\ & : 4+d 8 \text { RW0 } \end{aligned}$ |  | IMOVW @ 4+d8, RW1 |  | MOVW @RW $4+\mathrm{d} 8$ RW2 |  | $\begin{aligned} & \text { 'MOVW @RW } \\ & \text { 4+d8, RW3 } \end{aligned}$ |  | MOVW @RW 4+d8, RW4 |  | Vvw @RW +d8, RW5 |  | $\begin{aligned} & \text { IMOVW @RW } \\ & \text { I+d8, RW6 } \end{aligned}$ |  | OVw @RW 4+d8, RW7 |
| +5 | MOVW RW5, RW |  |  |  |  |  | MOVW RW5, RW3 |  |  |  |  |  | Vvw W5, RW6 |  | MOVW RW5, RW7 |  |
| +6 |  |  |  |  | $\begin{aligned} & \text { MOVW, RW2 } \\ & \text { RW6, Ren } \end{aligned}$ | MOVW @RW , 6+d8, RW2 | MOVW RW6, RW3 |  | MOVW RW6, RW4 |  |  |  | w W6, RW6 | TMOVW @RW <br> ; 6+d8, RW6 | MOVW RW6, RW7 |  |
| +7 | MOVW RW7, RW0 | Ovw @RW 7+d8, RW0 | MOVW RW7, RW | $\begin{aligned} & \text { MOVW @ } \\ & \text { T+d8, RW1 } \end{aligned}$ | $\begin{aligned} & \text { MOWW } \\ & \text { RW7, RW2 } \end{aligned}$ | $\begin{aligned} & \text { MOVW @RW } \\ & 1+\mathrm{d} 8, \text { RW2 } \end{aligned}$ | MOVW RW7, RW3 | $\begin{aligned} & 1 / \mathrm{MOVW} \text { @RW } \\ & 1+\mathrm{d} 8, \mathrm{RW} 3 \end{aligned}$ | MOVW RW7, RW4 |  |  |  | MOVW RW7, RW6 | $\begin{aligned} & \text { TMOVW @RW } \\ & 17+d 8, R W 6 \end{aligned}$ | MOVW RW7, RW7 |  |
| +8 | MOVW @RW0, RW0 | $\begin{aligned} & \text { +d16W@RWo } \\ & + \text { +16, RWO } \end{aligned}$ | MOVW @RW0, R | MOVW@RWo +d16, RW1 | MOVW @RW0, RW2 | MOVW@RW0 <br> +d16, RW2 | MOVW @RW0, RW3 | MOVW@RWo +d16, RW3 | MOVW @RW0, RW4 | $\begin{array}{c:c} : M O V W @ R W 0 \\ 4 & \text { +d16, RW4 } \end{array}$ | MOVW @RW0, RW5 | 'Movw@Rwo <br> +d16, RW5 | movw @RW0, RW6 | MOVW@RWO <br> , +d16, RW6 | MOVW @RW0, | MOVW@RW0 +d16, RW7 |
| +9 | MOVW @RW1, RW0 | OVW@RW1 d16, RW0 | MOVW <br> @RW1, RW | MOVW@RW1 <br> , +d16, RW1 | MOVW @RW1, RW2 | MOVW@RW1 <br> +d16, RW2 | MOVW @RW1, RW3 | 'MOVW@RW1 <br> +d16, RW3 | MOVW @RW1, RW4 | MOVW@RW1 +d 16 , RW4 | MOVW @RW1, RW5 | OVW@RW1 d16, RW5 | MOVW @RW1, RW6 | MOVW@RW1 +d16, RW6 | MOVW <br> @RW1, RW7 | OVW@RW1 +d16, RW7 |
| +A | MOVW @RW2, RW0 | MOVW@RW2 +d16, RW0 | MOVW @RW2, RW1 | 'MOVW@RW2 <br> +d16, RW1 | MOVW @RW2, RW2 | MOVW@RW2 +d16, RW2 | MOVW @RW2, RW3 | MOVW@RW2 <br> +d16, RW3 | MOVW @RW2, RW4 | MOVW@RW2 <br> +d16, RW4 | MOVW @RW2, RW5 | MOVW@RW2 +d16, RW5 | MOVW @RW2, RW6 | MOVW@RW2 +d16, RW6 | MOVW @RW2, | MovW@RW2 +d16, RW7 |
| +B | @RW3, RW0 | MOVW@RW3 +d16, RW0 | MOVW @RW3, RW 1 | 'MOVW@RW3 <br> +d16, RW1 | MOVW @RW3, RW2 | 'MOVW@Rw3 +d16, RW2 | MOVW @RW3, RW3 | MOVW@RW3 +d16, RW3 | movw @RW3, RW4 | 'movw@rw3 <br> +d16, RW4 | movw @RW3, RW5 | 'MOVW@RW3 +d16, RW5 | Movw @RW3, RW6 | 'MOVW@RW3 +d16, RW6 | MOVW @RW3, RW | MOVW@RW3 +d16, RW7 |
| + | WO + , RWO | 'MOVW@RW0 +RW7, RW0 | $\begin{aligned} & \text { MOW } \\ & R W O+, R W 1 \end{aligned}$ | MOVW@RWo <br> +RW7, RW1 | $\begin{aligned} & \text { MOVW @ } \\ & \text { RW0+, RW2 } \end{aligned}$ | MOVW@RW0 <br> +RW7, RW2 | MOVW RW0+, RW3 | 'MOVW@RWo <br> + RW7, RW3 | $\begin{aligned} & \text { Movw @ } \\ & \text { RWO+, RW4 } \end{aligned}$ | MOVW@RWo <br> +RW7, RW4 | $\begin{aligned} & \text { Movw } \\ & \text { RW0+, Rw } \end{aligned}$ | 'MOVW@Rwo +RW7, RW5 | MOVW @ RW0+, RW6 | 'MOVW@RW0 + +RW7, RW6 | $\begin{aligned} & \text { MOVW @ } \\ & \text { RWO+, RW } \end{aligned}$ | OVW@RW0 RW7, RW7 |
| +D | @RW1+, RW0 | novw@RW1 +RW7, RW0 | $\begin{aligned} & \text { MOWW } \\ & R W 1+R W 1 \end{aligned}$ | MOVW@RW1 '+RW7, RW1 | $\begin{aligned} & \text { Movw } \\ & \text { RW1+, RW2 } \end{aligned}$ | 'MOVW@RW1 '+RW7, RW2 | MOVW @ | 'MOVW@RW1 +RW7, RW3 | MOWW RW1+ RW4 | 'MOVW@RW1 <br> +RW7, RW4 | $\begin{aligned} & \text { Movw } \\ & \text { RW1+, RW5 } \end{aligned}$ | 'MOVW@RW1 + +RW7, RW5 | MOVW RW1+, RW6 | 'MOVW@RW1 + +RW7, RW6 | $\begin{aligned} & \text { Movw } \\ & \text { QW1+, RW7 } \end{aligned}$ | NOVW@RW1 RW7, RW7 |
| +E | @RW2+, RW0 | $\begin{gathered} \text { MOVW @PC+ } \\ \text { d16, RWO } \end{gathered}$ | $\begin{aligned} & \text { MOVW @ } \\ & \text { RW2+, RW1 } \end{aligned}$ | Ovw @PC+ d16, RW1 | $\begin{aligned} & \text { MOVW @ } \\ & \text { RW2+, RW2 } \end{aligned}$ | ovw @PC+ d16, RW2 | MOVW @ RW2+,RW3 | MOVW @PC+ d16, RW3 | MOVW @ RW2+, RW4 | VW @PC+ d16, RW4 | $\begin{aligned} & \text { MOW } \\ & \text { RW2+, RW5 } \end{aligned}$ | VW @PC+ d16, RW5 | MOVW RW2+, RW6 | OVW @PC+ d16, RW6 | $\begin{aligned} & \text { MOVW @ } \\ & \text { RW2+, RW7 } \end{aligned}$ | Ovw @PC+ d16, RW7 |
| +F | MOVW @RW3+, RW0 | VW addr 16, RWO | $0 \begin{array}{cc} \hline \text { MOVW } \\ \text { RW } 3+\text {, RW1 } \end{array}$ | $\begin{array}{r} M O=W_{1} \text { addr } \\ 16 W_{1} \end{array}$ | $\begin{aligned} & \text { Movw } \\ & \text { RW3 } 3+R W 2 \end{aligned}$ | MOVW addr 16, RW2 | $\begin{aligned} & \text { Mow } \\ & \text { RW } 3+\text {, RW3 } \end{aligned}$ | $\begin{aligned} & \text { ovw addr } \\ & 16, \text { RW3 } \end{aligned}$ | $\begin{aligned} & \text { Movw } \\ & \text { RW3 }+ \text {, Rw } \end{aligned}$ | $\begin{aligned} & \text { WVW adr } \\ & 16, R W 4 \end{aligned}$ | $\begin{aligned} & \text { Movw } \\ & \text { RW3+, RW } \end{aligned}$ | $\begin{gathered} \text { avW adr } \\ 16, \text { RW5 } \end{gathered}$ | $\begin{aligned} & \text { MOW } \\ & \text { RW } 3+\text {, RW6 } \end{aligned}$ | MOVW addr <br> $16, \mathrm{RW} 6$ | $\begin{aligned} & \text { MOW } \\ & \text { RW } 3+\text {, RW7 } \end{aligned}$ | $\begin{aligned} & \mathrm{dr} \\ & \mathrm{z} \mathbf{N}^{2} \end{aligned}$ |

Table B.3.1s CH Ri, ea (First byte = 7EH)

|  | 00 | 10 | 20 | 30 | 40 | 50 | 60 | 70 |  | 80 | 90 | A 0 | во | co | D 0 |  | E 0 | Fo |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| +0 | RO, RO | $\begin{array}{cr} \hline \mathrm{XCH} & \mathrm{RO}, \\ \mathrm{QRWO}+\mathrm{d} 8 \end{array}$ | R1, R0 | $\begin{array}{cr} \mathrm{XCH} & \mathrm{R} 1, \\ \mathrm{CRW} 0+\mathrm{d} \end{array}$ |  | XCH R2, <br> @RWO d | $\mathrm{XCH}_{\mathrm{R} 3, \mathrm{RO}}$ | XCH @RWO |  |  | $\begin{array}{cr} \hline \mathrm{XCH} & \mathrm{R} 4, \\ @ R W 0+\mathrm{d} 8 \end{array}$ |  | $\begin{array}{lr} \hline \mathrm{KCH} & \mathrm{R5}, \\ @ R W 0+\mathrm{d} 8 \end{array}$ |  | CH @RW0 |  |  | $\begin{gathered} \mathrm{CH}, \\ \varrho \mathrm{CHW}, \mathrm{~dB} \end{gathered}$ |
| +1 | $\mathrm{XCH}_{\mathrm{RO}, \mathrm{R} 1}$ | $\begin{aligned} & 1 \times \mathrm{RO}, \\ & \mathrm{@RW1+d8} \\ & 1 \end{aligned}$ | $\mathrm{XCH}_{\mathrm{R} 1, \mathrm{R} 1}$ | XCH ${ }^{-1}$ @RW1+d8 | ХХС |  @RW1+d8 | $\mathrm{XCH} \text { R3, }$ | XCH @RW1 |  |  | $\begin{gathered} \mathrm{XCH} \\ @ \mathrm{RW} 1+\mathrm{d} 8 \end{gathered}$ | R5, | $\begin{aligned} & \text { CCH R5, R } \\ & \text { @RW1+d8 } \end{aligned}$ | R6 | $\mathrm{KCH}$ |  | R7, | $\begin{gathered} \text { NoTw R7, R, } \\ \text { @RW1+dd } \end{gathered}$ |
| +2 |  | R R , |  | XCH R1, | хс́ | XCH R2, @RW2+d8 |  | XCH @RW2 |  | R4 | $\begin{array}{cc} \mathrm{XCH} \\ @ R W 2+\mathrm{A} 8 \end{array}$ | $\overline{\mathrm{X} C \mathrm{C}}$ | $\begin{aligned} & \mathrm{COH} \\ & \mathrm{CRW} 2+\mathrm{d} 5, \end{aligned}$ | R6, | $\overline{\mathrm{x} C \mathrm{C}}$ $@ R 1$ |  | XCH | $\begin{gathered} \mathrm{R} \\ @ \mathrm{RW}, \mathrm{di} \end{gathered}$ |
| +3 |  | RO, @RW3+d8 |  | XCH R1, @RW3+d8 |  | $\overline{\mathrm{XCH}} \mathrm{R} 2$, @RW3+d8 |  | XCH @RW |  |  | $\left.\begin{array}{cc} -\mathrm{CH} 4, \\ @ R W 3+d 8 \end{array}\right]$ |  | $\begin{aligned} & \mathrm{CH}, \\ & \mathrm{QRW}, \\ & \hline 188 \end{aligned}$ | $\mathrm{XCH} \mathrm{R6},$ | XCH @RW |  | $\text { " }{ }^{-1}$ | $\begin{aligned} & 107 W \\ & @ R W 3+d 8 \\ & @ \end{aligned}$ |
| +4 | $\mathrm{xCH} \text { Ro, }$ | RHO, @RW4+d8 |  | XCH R1, @RW4+d8 | ${ }^{-x} \bar{c}$ | XCH R2, @RW4+d8 | $\mathrm{XCH}_{\mathrm{F}}$ | $\begin{gathered} \mathrm{XCH} \\ @ \mathrm{R} \end{gathered}$ |  |  | $\begin{gathered} \mathrm{CH} \\ @ \mathrm{RW} 4+\mathrm{d} 8 \end{gathered}$ | $\mathrm{XCH} \mathrm{R5}, \mathrm{R} 4$ | $\begin{aligned} & \text { CH } \mathrm{RF}, \\ & D R W 4+d 8 \end{aligned}$ | $\mathrm{XCH}_{\mathrm{R} 6},$ | $\mathrm{CH}$ $@ \text { RW }$ |  | ; | OTw R7, @RW4+d8 |
| +5 |  | R RO, @RW5+d8 |  | $\begin{aligned} & \text { XCH } \mathrm{R1}, \\ & @ R W 5+d 8 \end{aligned}$ | $\mathrm{XCH} \text { R2, Rs }$ | XCH R2, @RW5+d8 | $\mathrm{XCH}$ | XCH @RW5 |  |  | $\begin{array}{cc} \mathrm{XCH} & \mathrm{R} 4, \\ @ R W 5+d 8 \end{array}$ | XCH R5, R5: | $\begin{gathered} \mathrm{CH}^{2} 5, \\ D \mathrm{RW}+\mathrm{d} 8 \\ \hline \end{gathered}$ |  | CH @RW |  | + | $\begin{gathered} \mathrm{R}, \\ \varrho \mathrm{BW}, \mathrm{~d} \end{gathered}$ |
| +6 |  | RHO, @RW6+d8 |  | XCH R1, @RW6+d8 |  | XCH R2, @RW6+d8 |  | $\times$ @RW6 |  | $\mathrm{R} 4, \mathrm{R6} \mathbf{I}^{\prime}$ | XCH <br> QRW6 48 | XCH | XCH R 5, @RW6+d8 | H | CH @RW6 |  | XCH R7, R6, | $\begin{array}{cc} \mathrm{CH} & \mathrm{R} 7, \\ @ \mathrm{RW}+\mathrm{d} 8 \end{array}$ |
| +7 |  | RO, @RW7+d8 | $x$ | $\begin{gathered} \mathrm{XCH} \\ @ \mathrm{RW} 7+\mathrm{d} 8 \end{gathered}$ |  | XCH R2, |  | XCH @RW7 |  | $\mathrm{X} 4, \mathrm{R7}$ | $\begin{array}{r} \mathrm{XCH}, \\ @ \mathrm{RW}, \mathrm{~dB} \\ \hdashline- \end{array}$ | $\mathrm{R}, \mathrm{R}$ | $\begin{aligned} & \mathrm{XCH} \quad \mathrm{R5}, \\ & @ \mathrm{RW} 7+\mathrm{d} 8 \end{aligned}$ | R6, | XCH @RW7 |  | XCH R7, R7' | $\begin{gathered} \mathrm{xCH}_{\mathrm{RW}} \mathrm{R7}+\mathrm{d} 8 \end{gathered}$ |
| +8 | $\begin{aligned} & \text { XCH } \\ & \text { R0, @RW0 } \end{aligned}$ |  | XCH | $\begin{gathered} 1 \\ D_{1}^{\prime} \mathrm{RCH}, \\ @ R W 0+d 16 \end{gathered}$ | XCH R2, @RW | $: \begin{gathered} \text { XCH } \\ \text { @RWO } 2, \text { d16 } \end{gathered}$ | XCH | XCH @RWO |  | $\begin{aligned} & \text { XCH, @RW0 } \\ & \text { R4, } \end{aligned}$ | $\begin{array}{r} \text { XCH } \\ @ R W 0+d 16 \end{array}$ | $\begin{aligned} & \text { XCH, @RW0 } \\ & \text { R5, } \end{aligned}$ | $\begin{aligned} & \text { XCH R5, } \\ & \text { @RWO+d16, } \end{aligned}$ | XCH R6, @RW0 | XCH @RW0 |  | XCH | XCH <br> $\mathrm{@RWO}+\mathrm{d} 16$ |
| +9 | $\begin{aligned} & \text { XCH } \\ & \text { R0, @RW1 } \end{aligned}$ | 'xCH RO, @RW1+d16 | $\begin{aligned} & \text { XCH } \\ & \text { R1, @RW1 } \end{aligned}$ | ${ }_{1}^{\mathrm{XCH}} \mathrm{R1}$, | XCH2, @RW1 | $\begin{aligned} & \mathrm{xCH} \mathrm{R2} \\ & @ \mathrm{RW} 1+\mathrm{d} 16 \end{aligned}$ | XCH, @RW1 | XCH @RW1 |  | $\begin{aligned} & \text { XCH, @RW1 } \end{aligned}$ | $\begin{aligned} & \text { XCH } \mathrm{R} 4, \\ & @ \mathrm{RW} 1+\mathrm{d} 16 \end{aligned}$ | XCH, @RW1 |  | XCH R6, @RW1 | XCH @RW1+ |  | XCH | $\begin{aligned} & \text { XCH } \mathrm{R}, \\ & @ R W 1+\mathrm{d} 16 \end{aligned}$ |
| +A | XCH <br> R0, @RW2 | XCH RO, @RW2+d16 | XCH <br> R1, @RW2 |  | XCH R2, @RW2 | $\begin{aligned} & \text { XCH } R 2, \\ & @ R W 2+d 16 \end{aligned}$ | $\begin{aligned} & \text { XCH } \\ & \text { R3, @RW } \end{aligned}$ | ${ }^{1} \mathrm{XCH}$ @RW2 |  | XCH | $: \begin{gathered} \text { XCH } \\ @ R W 2+d 16 \end{gathered}$ | XCH | $\begin{aligned} & \text { XCH R5, } \\ & \text { @RW2+d16, } \end{aligned}$ | XCH <br> R6, @RW2 | XCH @RW2 |  | XCH | $\begin{aligned} & \mathrm{XCH} \\ & \text { @RW2+d16, } \end{aligned}$ |
| +B | $\begin{aligned} & \text { XCH } \\ & \text { R0, @RW3 } \end{aligned}$ | $\begin{aligned} & \text { 'XCH } \mathrm{RO}, \\ & @ R W 3+\mathrm{d} 6 \end{aligned}$ | XCH | $\begin{aligned} & 1 \times \mathrm{xCH} \\ & @ \mathrm{RW}+\mathrm{d} 16 \end{aligned}$ | $\begin{aligned} & \text { XCH, @RW3 } \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & @ R W 3+d 16 \end{aligned}$ | $\begin{aligned} & \text { XCH } \\ & \text { R3, @RW3 } \end{aligned}$ | $\begin{array}{ll} 1 \\ \text { XCH } \\ \hline \end{array}$ |  | $\begin{gathered} \text { XCH } \\ \text { R } \end{gathered}$ | $\begin{array}{rr} \mathrm{XCH} & \mathrm{R} 4, \\ @ R W 3+d 16 \end{array}$ | $\begin{aligned} & \text { XCH } \\ & \text { R5, @RW3 } \end{aligned}$ | $\begin{aligned} & \text { XCH } \mathrm{R} 5, \\ & \text { @RW3 } \mathrm{d} 16 \end{aligned}$ | XCH | XCH @RW3 |  | XCH @Rw3 | XCH R7, @RW3+d16 |
| +C | XCH <br> R0, @RW0+ |  | XCH <br> R1, @RW0+ | $\begin{gathered} \times C H \text { R, } \\ \substack{@ R W O+R W 7 \\ \hline} \end{gathered}$ | XCH R2, @RW0+ | $\begin{aligned} & \mathrm{XCH} \\ & @ \mathrm{RWO}+\mathrm{RW}, \end{aligned}$ | XCH R3, @RW | XCH @RW0+ | $\begin{array}{r} R 3, \\ +R W \\ +\quad 7 \end{array}$ | XCH <br> R4, @RW0+ | $\begin{gathered} X C H \\ @ R W+R W 7 \\ \hline \end{gathered}$ | XCH R5, @RW0+ |  | XCH <br> R6, @RWO | ' XCH @RWO |  | XCH <br> R7, @RW0+ |  |
| +D | XCH <br> R0, @RW1+ | $\begin{aligned} & \text { RCH } \\ & @ R W 1+R W 7 \end{aligned}$ | XCH <br> R1, @RW1+ | XCH R1, | XCH R2, @RW | $\begin{gathered} \mathrm{XCH} \\ \mathrm{QRW},+\mathrm{RW} \\ \hline \mathrm{RW} \end{gathered}$ | XCH R3, @RW | XCH @RW1+ | $\begin{array}{r} R 3, \\ +R W \end{array}$ | XCH <br> R4, @RW1+ | $\begin{array}{r} \mathrm{XCH} \\ @ R W 1+\mathrm{RW} 7 \\ \hline \end{array}$ | $\overline{\mathrm{X} C \mathrm{CH}}$ <br> R5, @RW1 | $\begin{array}{r} \mathrm{XCH} \\ \mathrm{RRW}, \\ \hline \mathrm{RW}, \\ \hline \end{array}$ | $\begin{aligned} & \text { XCH, } \\ & \text { R6WW }+ \end{aligned}$ | XCH @RW1 |  | XCH <br> R7, @RW1+ | $\begin{array}{cc} \mathrm{KCH}^{-} \\ \mathrm{QRW} \\ \hline \end{array}$ |
| +E | XCH <br> R0, @RW2+ | $\begin{array}{r} \text { RO, } \\ @ P C+d 16 \end{array}$ | XCH <br> R1, @RW2+ | $\begin{aligned} & \text { XCH R1, } \\ & \text { @PC }+116 \end{aligned}$ | XCH R2, @RW2 | XCH @PC+d16 | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{R} 3, ~ @ R W 2+ \end{aligned}$ | XCH @PC+ |  | XCH <br> R4, @RW2+ | $\begin{gathered} \mathrm{xCH} \\ @ P C+d 16 \\ \hline \end{gathered}$ | $\begin{gathered} \text { XCH } \\ \text { R5, } @ R W 2+1 \end{gathered}$ | $\begin{aligned} & \mathrm{XCH} \mathrm{R}, \\ & @ \mathrm{PC}+\mathrm{d} 16 \end{aligned}$ | XCH <br> R6, @RW2+ | XCH @PC |  | XCH <br> R7, @RW2+ |  |
| +F | XCH <br> R0, @RW3+ | $\begin{gathered} \text { Ro, } \\ \text { addr } 16 \end{gathered}$ | $\begin{aligned} & \text { XCH } \\ & \text { R1, @RW3+ } \end{aligned}$ | $\begin{array}{r} \mathrm{RCH}, \\ \mathrm{~A}^{2} \mathrm{Rdr} 16 \\ \hline \end{array}$ | XCH <br> R2, @RW3 | $\mathrm{XCH}_{\text {addr16 }}$ | XCH, @RW3+ | $\begin{aligned} & \\ &+\quad \text { addr } 16 \\ & \hline \end{aligned}$ | R3, | XCH <br> R4, @RW3+ | ${ }_{1}^{x_{\text {addr16 }} \mathrm{R4},}$ | $\begin{gathered} \text { XCH } \\ \text { R5, @RW3 } \end{gathered}$ | $\begin{aligned} & \text { XCH } \\ & + \text { addr16 } \end{aligned}$ | XCH | $\begin{aligned} & \text { XCH } \\ & + \text { addr16 } \end{aligned}$ | R6, | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{RT}, @ \mathrm{RW} 3+1 \end{aligned}$ | $\begin{array}{cc} \mathrm{XCH} \\ \text { addr16 } \end{array}$ |

Table B.3.1t XCHW RWi, ea (First byte = 7FH)

|  | $00 \quad 10$ | 20 | $40 \quad 50$ | 60 | 70 | 80 | 90 | A 0 | B0 | C0 | D0 | E 0 | F0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| +0 | $\begin{array}{\|c:c} \hline \text { XCHW } & \text { XCHW RWO, } \\ \text { RWO, RW0 } & @ R W 0+d 8 \\ \hline \end{array}$ | $\left[\begin{array}{ccc} \mathrm{XCHW} & \mathrm{XCHW} \\ \mathrm{RWW}, \\ \mathrm{RWW}, & @ R W 0+\mathrm{dB} \end{array}\right]$ | $\begin{array}{c:c}\text { XCHW } \\ \text { RW2, RW0 } & \text { XCHW RW2, } \\ \text { @RW0+d8 }\end{array}$ | XCHW <br> RW3, RW0 | XCHW RW3. @RW0+d8 | xCHW RW4, RWO | CHW RW4 @RW0+d8 | $\begin{aligned} & \text { XCHW } \\ & \text { RW5, RWO } \end{aligned}$ | CHW RW5, RW0+d8 | $\begin{array}{\|l\|} \text { XCHW } \\ \text { RW6, RWO } \end{array}$ | CHW RW6, @RW0+d8 | $\begin{aligned} & \text { 'CHW } \\ & \text { RW7, RWo } \end{aligned}$ | CHW RW7 @RW0+d8 |
| +1 | $\left\|\begin{array}{ccc} \text { XCHW } & \text { XCHW } \\ \text { RWO, RW1 } \\ @ R 1+d 8 \end{array}\right\|$ | $\left[\begin{array}{cc:c} \text { XCHW } & \text { XCHW RW } \\ \text { RW1, RW1 } & @ R W 1+d 8 \end{array}\right]$ | $\begin{array}{\|c:c}  & \begin{array}{ccc}  & \text { XCHW } \\ \text { RW2, RW1 } & @ R W 1+d 8 \end{array} \end{array}$ | XCHW <br> RW3, RW1 | XCHW RW3, @RW1+d8 | $\begin{aligned} & \text { XCHW } \\ & \text { RW4, RW } \end{aligned}$ | XCHW RW4, @RW1+d8 | $\begin{aligned} & \text { XCHW } \\ & \text { RW5, RW1 } \end{aligned}$ | XCHW RW5, @RW1+d8 | XCHW RW6, RW1 | XCHW RW6, | $\begin{aligned} & \text { XCHW } \\ & \text { RW7, RW1 } \end{aligned}$ | XCHW RW7 @RW1+d8 |
| +2 | $\begin{array}{c:c}\text { XCHW } & \text { XCHW RWO, } \\ \text { RW0, RW2 } & @ R W 2+d 8\end{array}$ | $\left\lvert\, \begin{array}{\|c:c} \hline \text { XCHW } & \text { XCHW RW1, } \\ \text { RW1, RW2, } & \text { @RW2+d8 } \end{array}\right.$ | $\begin{array}{cc} \text { XCHW } & \text { XCHW } \\ \text { RW2, } & \text { RW2 } \\ & @ R 2+d 8 \end{array}$ | XCHW RW3, RW2 | XCHW RW3 @RW2+d8 | XCHW RW4, RW2 | XCHW RW4 @RW2+d8 | $\begin{aligned} & \text { XCHW } \\ & \text { RW5, RW2 } \end{aligned}$ | XCHW RW5, @RW2+d8 | XCHW <br> RW6, RW2 | XCHW RW6, @RW2+d8 | XCHW <br> RW7, RW2 | XCHW RW7 @RW2+d8 |
| +3 | $\left\|\begin{array}{c:c}  \\ \text { XWO, } & \text { RW3 } \\ \text { RWW } 3+d 8 \end{array}\right\|$ | $\left[\begin{array}{cc:c} \text { XCHW } & \text { XCHW RW } \\ \text { RW1, } & \text { RW3 } & @ R W 3+d 8 \end{array}\right]$ | $\begin{array}{cc} \text { XCHW } & \text { XCHW } \\ \text { RW2, } & @ R W 3, d 8 \end{array}$ | XCHW RW3, RW3 | XCHW RW3 @RW3+d8 | XCHW RW4, RW3 | XCHW RW4. @RW3+d8 | $\begin{aligned} & \text { XCHW } \\ & \text { RW5, RW3 } \end{aligned}$ | XCHW RW5, @RW3+d8 | $\begin{aligned} & \text { XCHW } \\ & \text { RWW3 } \end{aligned}$ | XCHW RW6, @RW3+d8 | XCHW RW7, RW3 | XCHW RW7 @RW3+d8 |
| +4 |  | $\left[\begin{array}{ccc} \text { XCHW } & \text { XCHW RW1, } \\ \text { RW1, RW4 } & @ R W 4+\mathrm{d} 8 \end{array}\right]$ | $\begin{array}{c:cc}  & \text { XCHW } & \text { XCHW RW2, } \\ \text { RW2, RW4 } & @ R W 4+d 8 \end{array}$ | XCHW <br> RW3, RW4 | XCHW RW3 @RW4+d8 | XCHW RW4, RW4 | XCHW RW4. @RW4+d8 | $\begin{aligned} & \text { XCHW } \\ & \text { RW5 } \end{aligned}$ | XCHW RW5, @RW4+d8 | XCHW RW6, RW4 | XCHW RW6, @RW4+d8 | XCHW | XCHW RW7 @RW4+d8 |
| +5 |  |  |  | XCHW RW3, RW5 | XCHW RW3 @RW5+d8 | XCHW RW4, RW5 | XCHW RW4 @RW5+d8 | $\begin{aligned} & \text { XCHW } \\ & \text { RW5, RW5 } \end{aligned}$ | XCHW RW5, @RW5+d8 | XCHW RW6, RW5 | XCHW RW6, $@ R W 5+d 8$ | XCHW <br> RW7, RW5 | XCHW RW7 @RW5+d8 |
| +6 | $\begin{array}{\|c:c}  \\ \text { XCHW } & \text { XCHW RWO, RW6 } \\ \text { RWW6+d8 } \end{array}$ | $\left\lvert\, \begin{array}{cc} \text { XCHW } & \text { RCHW RW1, } \\ \text { RW1, RW6: } & \text { @RW6+d8 } \end{array}\right.$ |  | XCHW RW3, RW6 | XCHW RW3 @RW6+d8 | $\begin{aligned} & \text { XCHW } \\ & \text { RW4, RW6 } \end{aligned}$ | XCHW RW4. @RW6+d8 | $\begin{aligned} & \text { XCHW } \\ & \text { RW5, RW6 } \end{aligned}$ | XCHW RW5, @RW6+d8 | $\begin{aligned} & \text { XCHW } \\ & \text { RW6, RW6 } \end{aligned}$ | XCHW RW6, @RW6+d8 | $\times \overline{\mathrm{CHW}}$ <br> RW7, RW6 | xCHW RW7 $@ R W 6+d 8$ |
| +7 | $\begin{array}{\|c\|c\|} \hline \text { XCHW } & \text { RCHW } \\ \text { RWO, } & \text { RW7 } \\ \hline \end{array}$ | $\left[\begin{array}{c:c} \text { XCHW } & \text { XCHW RW1, } \\ \text { RW1, RW7 } & @ R W 7+d 8 \end{array}\right]$ | $\begin{array}{cc} \text { XCHW } & \text { XCHW } \\ \text { RW2, } & \text { RWW } \\ \hline \end{array}$ | XCHW <br> RW3, RW7 | XCHW RW3 @RW7+d8 | $\begin{aligned} & \text { XCHW } \\ & \text { RW4, RW7 } \end{aligned}$ | XCHW RW4 @RW7+d8 | $\begin{aligned} & \text { XCHW } \\ & \text { RW5, RW7 } \end{aligned}$ | XCHW RW5, @RW7+d8 | $\begin{aligned} & \text { XC̄HW } \\ & \text { RW6, RW7 } \end{aligned}$ | XCHW RW6, | XCHW RW7, RW7 | XCHW RW7 $@ R W 7+d 8$ |
| +8 | $\left\lvert\, \begin{array}{l:l} \text { xCHW } \\ \text { RWO, @RW0 } & \text { @RWO } \\ \text { @RO, } \end{array}\right.$ | $\left[\begin{array}{ll:l} \text { XCHW } \\ \text { RW1, @RW0, } & \text { @RW0+d16 } \end{array}\right.$ | $\begin{array}{l:l} \text { XCHW } \\ R W 2, ~ @ R W 0, ~ & \text { @RW0+d16 } \end{array}$ | XCHW RW3, @R | CHW RW3 @RW0+d16 | $\begin{aligned} & \text { XCHW } \\ & \text { RW4, @R } \end{aligned}$ | XCHW RW4. @RW0+d16 | XCHW RW5, @RW0, | XCHW RW5, @RW0+d16 | XCHW RW6, @RW0 | (xCHW RW6, | XCHW RW7, @RW0 | $\begin{array}{\|l\|l\|} \hline \text { XCHW RW7 } \\ \hdashline \text { RWO }+ \text { d16 } \end{array}$ |
| +9 | $\left\|\begin{array}{ll} \text { XCHW } \\ R W 0, ~ @ R W 1, ~ & \text { XCHW } R W 0, \\ \text { RWW } \end{array}\right\|$ | $\left[\left.\begin{array}{lll} \text { XCHW } \\ \text { RW1, @RW1, @RW1+d16, } \end{array} \right\rvert\,\right.$ | $\begin{array}{l:l} \text { XCHW } \\ R W 2, ~ @ R W 1: ~ @ R W 1+d 16 ~ \end{array}$ | XCHW RW3, @RW | XCHW RW3 @RW1+d16 | $\begin{aligned} & \text { XCHW } \\ & \text { RW4, @RW1 } \end{aligned}$ | XCHW RW4 @RW1+d16 | XCHW RW5, @RW | XCHW RW5, @RW1+d16 | XCHW RW6, @RW1 | XCHW RW6, @RW1+d16 | XCHW RW7, @RW1 | $\begin{aligned} & \text { XCHW RW7 } \\ & @ R W 1+d 16 \end{aligned}$ |
| +A | $\begin{aligned} & \text { XCHW } \\ & \text { RW0, @RW2 } \mathrm{XCHW} \text { RWO, } \end{aligned}$ | $\left[\begin{array}{lll} \text { XCHW } \\ \text { RW1, @RW2, } @ R W 2+d 16, ~ \end{array}\right]$ | XCHW, @RW2, @RW2+d16, | XCHW RW3, @RW | XCHW RW3 @RW2+d16 | XCHW RW4, @RW2 | XCHW RW4 @RW2+d16 | XCHW RW5, @RW2 | XCHW RW5 @RW2+d16 | XCHW RW6, @RW2 | XCHW RW6, @RW2+d16 | XCHW RW7, @RW2 | XCHW RW7 @RW2+d16 |
| +B | $\begin{aligned} & \text { XCHW } \\ & \text { RWO, @RW3 } \mathrm{XCHW} \text { RWO, } \end{aligned}$ | $\left[\begin{array}{ll} \text { XCHW } \\ \text { RW1, @RW3 } & \text { XRW } \\ \text { RW } \end{array}\right.$ | XCHW ' XCHW RW2, RW2, @RW3' @RW3+d16 | XCHW RW3, @RW3 | XCHW RW3. @RW3+d16 | $\begin{aligned} & \text { XCHW } \\ & \text { RW4, @RW3 } \end{aligned}$ | XCHW RW4. @RW3+d16 | $\begin{aligned} & \text { XCHW } \\ & \text { RW5, @RW } \end{aligned}$ | XCHW RW5, @RW3+d16 | XCHW RW6, @RW3 | XCHW RW6, @RW3+d16 | XCHW RW7, @RW3 | XCHW RW7 @RW3+d16 |
| +C | $\begin{aligned} & \text { XCHW RXCHW RWO, } \\ & W 0, @ R W 0+\text { '@RWO+RW7 } \end{aligned}$ | XCHW R'XCHW RW1, <br> W1, @RW0+' @RW0+RW7 | $\begin{aligned} & \text { XCHW } \\ & \text { W2, } @ R W 0+1 \\ & \text { ORWO } \end{aligned}$ | xCHW W3, @RW0 | xCHW RW3 @RW0+RW才 | $\begin{aligned} & 3 \times \mathbf{B C O}_{1}^{\prime} \\ & 7 \mathrm{~W} 4, @ R W 0 \end{aligned}$ | XCHW RW4 @RW0+RW7 | $\begin{aligned} & \text { xCHW } \\ & \text { W5, @RWO } \end{aligned}$ | xCHW RW5 @RW0+RW7 | $\begin{aligned} & \text { XCHW } \\ & \text { W6, @RW0 } \end{aligned}$ | XCHW RW6, @RW0+RW7 | $\begin{aligned} & \text { XCHW } \\ & \text { W7, @RWO } \end{aligned}$ | XCHW RW7 @RW0+RW7 |
| +D | W0, @RW1+' @RW1+RW7 <br> XCHW R'XCHW RWO, W0 @RW1+' @RW1+RW7 | XCHW R1 XCHW RW1, W1, @RW1+' @RW1+RW7 | $\begin{aligned} & \text { XCHW } \\ & \text { R2, XRW1+1 @RW1+RW7 } \end{aligned}$ | xCHW W3, @RW1 | XCHW RW3. @RW1+RW7 | $\begin{aligned} & \text { XCHW } \\ & \text { W4, @RW1 } \end{aligned}$ | XCHW RW4 @RW1+RW7 | $\begin{aligned} & \text { XCHW } \\ & \text { W5, @RW1+ } \end{aligned}$ | XCHW RW5, @RW1+RW7 | $\begin{aligned} & \text { CHW } \\ & \text { W6, @RW1 } \end{aligned}$ | XCHW RW6, @RW1+RW7 | $\begin{aligned} & \text { XCHW } \\ & \text { W7, @RW1+ } \end{aligned}$ | XCHW RW7 @RW1+RW7 |
| +E |  | XCHW R XCHW RW1, <br> W1, @RW2+' @PC+d16 | XCHW R1 XCHW RW2, W2, @RW2+ @PC+d16 | XCHW W3, @RW2 | $\begin{aligned} & \text { XCHW RW3 } \\ & \text { @PC+d16 } \end{aligned}$ | $\begin{aligned} & x C H W \\ & \text { W4, @RW2+ } \end{aligned}$ | XCHW RW4, @PC+d16 | $\begin{aligned} & \text { xCHW } \\ & \text { W5, @RW2+ } \end{aligned}$ | XCHW RW5, @PC+d16 | $\begin{aligned} & \text { CHW } \\ & \text { W6, @RW2 } \end{aligned}$ | XCHW RW6, @PC+d16 | $\begin{aligned} & \text { XCHW } \\ & \text { W7, @RW2+ } \end{aligned}$ | XCHW RW7 @PC+d16 |
| +F | XCHW R1XCHW RWO, W0, @RW3+1 addr16 | XCHW RIXCHW RW1, | XCHW W 2 $\mathrm{R} \times \mathrm{XCHW}$ addr1 RW 2, | XCHW W3, @RW3+ | $\begin{gathered} \text { RCHW } \\ \text { addr16 } \end{gathered}$ | XCHW R W4, @RW3 | $\begin{gathered} \text { XCHW RW4. } \\ \text { addr16 } \end{gathered}$ | $\begin{aligned} & \text { XCHW R } \\ & \text { W5, @RW } \end{aligned}$ | XCHW RW5, | $\begin{aligned} & \text { CHW } \\ & \text { W6, @RW3+1 } \end{aligned}$ | $\begin{gathered} \text { RXCHW RW6, } \\ +1 \quad \text { addr16 } \\ \hline \end{gathered}$ | $\begin{aligned} & \text { XCHW } \\ & \text { W7, @RW }+1 \end{aligned}$ | $\underset{\text { addr16 }}{ }$ |

## Appendix C: <br> The Flash Memory in the MB90F583

## C. 1 Outline

There is a 1 M -bit Flash memory ( 128 K word $\mathrm{x} 8 / 64 \mathrm{~K}$ word x 16 ) located at the FE~FF bank of the CPU memory map in MB90F583. With the flash memory interface circuit, it is possible for read access from and program access to the CPU. Programming or erasing the flash memory are done by the CPU operation instruction through the flash memory interface circuit. Therefore, with proper CPU control software, it is possible re-programming the flash memory of on-board MB90F583. That means changing of the data in the flash memory of on-board MB90F583 can be done.

## - Features

128 K word $\mathrm{x} 8 / 64 \mathrm{~K}$ word x 16 bit ( $16 \mathrm{~K}+8 \mathrm{~K}+8 \mathrm{~K}+32 \mathrm{~K}+64 \mathrm{~K}$ sector architecture)
Compatible with JEDEC standard command
Automatic Algorithm (Embedded ${ }^{\text {TM }}$ Algorithm: same as MBM29F400TA)

- Automatic Program Algorithm
- Automatic Erase Algorithm

Sector Erase Suspend/Sector Erase Resume function available
Program/Erase cycle completion can be detected by data polling, toggle bit and CPU interrupt
Sector erase function (any combination of sector)
Number of programming/erasing: 10,000 times (minimum)
Note: Embedded ${ }^{\top \mathrm{TM}}$ Algorithm is trademarks of Advanced Mirco device, Inc.

## - Program/Erase operation

The flash memory of MB90F583 cannot be programmed and read in the same time. When programming or erasing the flash memory, the programming data will be copied to the RAM first; and then executing programming or erasing the flash memory in the RAM. This keeps programming and erasing the flash memory as simple as a writing operation.

## - Register

| Flash Control Register (FMCS) |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address: $0000 \mathrm{AE}_{\mathrm{H}}$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $<$ Bit Number |
|  | INTE | RDYINT | WE | RDY | Reserved | LPM1 | Reserved | LPM0 | FMCS |
| Read/write $\Rightarrow(R / W)$ <br> Initial value $\Longleftrightarrow(0)$ |  | (R/W) | $\begin{gathered} \text { (R/W) } \\ (0) \end{gathered}$ | $\begin{aligned} & (\mathrm{W}) \\ & (X) \end{aligned}$ | $\begin{aligned} & (W) \\ & (0) \end{aligned}$ | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ | (W)(0) | $\begin{gathered} (\mathrm{R} / \mathrm{W}) \\ (0) \end{gathered}$ |  |
|  |  | (0) |  |  |  |  |  |  |  |

## C. 2 Sector Structure of 1M Bit Flash Memory

Sector structure of 1M bit flash memory in MB90F583 is shown in Figure C.2a. The address in the Figure C.2a shows upper and lower address of each sector. When accessing from CPU, SA0 is set in the FE bank register and SA1~4 are set in the FF Bank register.


Figure C.2a Sector structure of 1M bit flash memory

## C. 3 Flash Control Register (FMCS)

Flash control register (FMCS) is a register which is used during programming or erasing the flash memory.

| Flash Control Register (FMCS) |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\Longleftrightarrow$ Bit Number |
| Address: $0000 \mathrm{AE}_{\mathrm{H}}$ | INTE | RDYINT | WE | RDY | Reserved | LPM1 | Reserved | LPM0 | FMCS |
| Read/write Initial value | $(\mathrm{R} / \mathrm{W})$ (0) | (R/W) $(0)$ | (R/W) $(0)$ | $(\mathrm{W})$ | (W) (0) | (R/W) $(0)$ | (W) <br> (0) | (R/W) <br> (0) |  |

## [bit 7] INTE (INTerrupt Enable)

This bit is used to enable an interrupt to the CPU when the operation of programming/erasing the flash memory is completed. An interrupt to the CPU will be generated when the INTE bit is " 1 " and the RDYINT bit is a " 1 ". When the INTE bit is " 0 ", an interrupt will not be generated.

| INTE | Interrupt Enable |
| :---: | :--- |
| $\mathbf{0}$ | Interrupt enable when program/erase cycle is completed |
| $\mathbf{1}$ | Interrupt disable when program/erase cycle is completed |

## [bit 6] RDYINT (ReaDY INTerrupt)

This bit is used to show the programming/erasing operation status of the flash memory. This bit will be set to " 1 " when the flash memory program/erase cycle is completed. After flash memory program/erase cycle is completed and the bit is still " 0 ", programing/erasing the flash memory is not allowed. Only when this bit is changed to " 1 ", programming/erasing the flash memory is allowed. Writing " 0 " will clear this bit to " 0 " and writing " 1 " to this bit will be ignored. When Automatic Algorithm (refer to Section C.4, Automatic Algorithm Initiation Method) is completed, this bit will be set to " 1 ". " 1 " is always read when read modify write (RWM) is operated.

| RDYINT | Ready interrupt |
| :---: | :--- |
| $\mathbf{0}$ | Programming/Erasing operation is on-going |
| $\mathbf{1}$ | Programming/Erasing operation is completed (interrupt request generated) |

## [bit 5] WE (Write Enable)

This bit is "write enable" for the flash memory. When this bit is set to " 1 ", the flash memory can be programed/erased right after the command sequence to FE~FF bank is issued. Furthermore, this bit is used to start the command for programming/erasing the flash memory. It is recommended to always keep this bit set to " 0 ", so that the flash memory will not be programmed or erased accidentally.

| WE |  |
| :---: | :--- |
| $\mathbf{0}$ | Disable programming/erasing flash memory |
| $\mathbf{1}$ | Enable programming/erasing flash memory |

[bit 4] RDY (ReaDY)
This bit is used to indicate whether the flash memory is ready for programming/erasing. When this bit is set to " 0 ", programming or erasing the flash memory is not allowed. However, it is possible to issue read/reset command and sector erase suspend command when this bit is " 0 ".

| RDY | Ready |
| :---: | :--- |
| $\mathbf{0}$ | Programming/erasing is operating |
| $\mathbf{1}$ | Programming/erasing is completed (next data programming/erasing is enabled. |

[bit 3] Reserved bit
This bit is reserved. It is recommended to always set this bit to "0" during normal operation.
[bit 0] Reserved bit
This bit is reserved. It is recommended to always set this bit to "0" during normal operation.
[bit 2, 0] LPM1, LPM0 (Low Power Mode)
When accessing flash memory, these two bits are used to control the power consumption of the flash memory. This bit cannot be set to " 00 ". After reset, these bit must be set to " 01 ", " 10 " or " 11 ". Since the flash memory access time by the CPU will be changed according to the frequency of the operating clock, it is recommended to set these bit according to the operating clock frequency of the CPU.

| LMP0 | LMP1 | Low Power Mode |
| :---: | :---: | :--- |
| $\mathbf{0}$ | $\mathbf{0}$ | Initial value (Access prohibited) |
| $\mathbf{0}$ | $\mathbf{1}$ | Low power mode (Internal operation frequency $<4 \mathrm{MHz}$ ) |
| $\mathbf{1}$ | $\mathbf{0}$ | Low power mode (Internal operation frequency $<8 \mathrm{MHz}$ ) |
| $\mathbf{1}$ | $\mathbf{1}$ | Low power mode (Internal operation frequency $<16 \mathrm{MHz}$ ) |

Note: RDYINT bit and RDY bit cannot be changed in the same time. Either one of these two bits should be changed when writing the control software.


Figure C.3a Timing of RDYINT and RDY

## C. 4 Automatic Algorithm Initiation Method

To start the Automatic Algorithm in the flash memory, there are five types of commands, 2 types of read/reset, programming, chip erase and sector erase. For sector erase, there are the sector erase suspend and the sector erase resume command.
Table C.4a shows the commands used during programming/erasing the flash memory. Although the data shown in the command are all in byte, it is necessary to use word access to write the data. At this time, the upper byte of the data will be ignored.

Table C.4a Command Sequence Definitions

| Command Sequence | Bus Write Cycle Req'd | 1st Bus Write Cycle |  | 2nd Bus Write Cycle |  | 3rd Bus Write Cycle |  | 4th Bus Write Cycle |  | 5th Bus Write Cycle |  | 6th Bus Write Cycle |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Addr | Data | Addr | Data | Addr | Data | Addr | Data | Addr | Data | Addr | Data |
| Read/Reset* | 1 | FxXXXX | XXFO | - | - | - | - | - | - | - | - | - | - |
| Read/Reset* | 3 | FxAAAA | XXAA | Fx5554 | XX55 | FxAAAA | XXFO | RA | RD | - | - | - | - |
| Programming | 4 | FxAAAA | XXAA | Fx5554 | XX55 | FxAAAA | XXAO | $\begin{gathered} \text { PA } \\ \text { (even) } \end{gathered}$ | $\underset{\text { (word) }}{\stackrel{P D}{2}}$ | - | - | - | - |
| Chip Erase | 6 | FxAAAA | XXAA | Fx5554 | XX55 | FXAAAA | XX80 | FXAAAA | XXAA | Fx5554 | XX55 | FXAAAA | XX10 |
| Sector Erase | 6 | FxAAAA | XXAA | Fx5554 | XX55 | FxAAAA | XX80 | FxAAAA | XXAA | Fx5554 | XX55 | SA (even) | XX30 |
| Sector Erase Suspend |  | Sector erase is suspend by inputting the address "FxXXXX", data "xxB0 ${ }^{\text {H }}$ " |  |  |  |  |  |  |  |  |  |  |  |
| Sector Erase Resume |  | Sector erase is resumed by inputting the address "FxXXXX", data "xx30 ${ }^{\text {H }}$ " |  |  |  |  |  |  |  |  |  |  |  |

Note: The address Fx in Table C.4a is either FE or FF for MB90F583. When using above commands, the accessible bank value for the device must be used to replaced Fx
The address found in the Table C.4a is corresponding to the CPU memory address. All address and data written in hexadecimal and " $X$ " is arbitrary value.

RA: Read address
PA: Program address, only even number address can be selected
SA: Sector address, refer to Section C.2, Sector Structure of 1M Bit Flash Memory.
RD: Read data
PD: program data, only word data can be selected
*: The 2 types of read/reset command can be reset the flash memory to read mode.

## C. 5 Execution Status of Automatic Algorithm

In the flash memory, the programming or erasing can be done by Automatic Algorithm, so that there is a Hardware Sequence Flag in the flash memory, which indicates the operation status and the operation completion. In the Automatic Algorithm, internal flash memory operation status can be checked by the hardware sequence flag which will be discussed in this section.

## - Hardware Sequence Flag

Hardware Sequence Flag consists of 4 flags, DQ7 (Data polling flag), DQ6 (Toggle bit flag), DQ5 (Exceeded timing limits flag) and DQ3 (Sector erase timer flag). These flag are used to check whether the programming or erasing the flash memory is completed and whether erase code are valid.
Hardware sequence flag is a checking point when performing read access to the address of the sector in the flash memory and after issuing the command sequence (see Table C.4a). Table C.5a shows the bit assignment of the hardware sequence flag.

Table C.5a Hardware sequence flag's bit assignment

| Bit number | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Hardware sequence Flag | DQ7 | DQ6 | DQ5 | - | DQ3 | - | - | - |

To check whether the Automatic Program/Erase Algorithm is under processing, it can be determined by either checking the hardware sequence flag or RDY bit of the flash control register (FMCS). After programming/erasing operation is completed, the flash memory will return to read/reset status. When making a control software, it is necessary to check the Automatic Program/Erase Algorithm completion by either the hardware sequence flag or RDY bit of the flash control register (FMCS) before going to other process such as reading data. It is also possible to check the next and the following sector erase code issued is valid by the hardware sequence flag. Table C.5b shows the function of each hardware sequence flag.

Table C.5b Hardware Sequence Flag

| Status |  | DQ7 | DQ6 | DQ5 | DQ3 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Status Change in normal operation | Programming $\rightarrow$ <br> Programming complete <br> (When program address is indicated) | $\begin{aligned} & \overline{\text { DQ7 }} \boldsymbol{\rightarrow} \\ & \text { DATA:7 } \end{aligned}$ | Toggle $\rightarrow$ DATA:6 | $0 \rightarrow \text { DATA:5 }$ | $0 \rightarrow \underset{\text { DATA:3 }}{ }$ |
|  | Chip/Sector erase $\rightarrow$ Erase is completed | $0 \rightarrow 1$ | Toggle $\rightarrow$ Stop | $0 \rightarrow 1$ | 1 |
|  | Sector erase wait $\rightarrow$ Erase start | 0 | Toggle | $0 \rightarrow 1$ | 1 |
|  | Sector erase $\rightarrow$ <br> Sector erase suspend (Sector being erased) | $0 \rightarrow 1$ | Toggle $\rightarrow 1$ | 0 | $1 \rightarrow 0$ |
|  | Sector erase suspend $\rightarrow$ Sector erase resume (Sector being erased) | $1 \rightarrow 0$ | $1 \rightarrow$ Toggle | 0 | $0 \rightarrow 1$ |
|  | Sector erase suspend is in progress (Sector not being erased) | DATA:7 | DATA:6 | DATA:5 | DATA:3 |
| Abnormal Operation | Programming operation | DQ7 | Toggle | 1 | 0 |
|  | Chip/Sector erase | 0 | Toggle | 1 | 1 |

## C.5.1 Data polling flag (DQ7)

Data polling flag is used to indicate whether the Automatic Algorithm is executing or completed by using data polling function. Table C.5.1a shows the status change of the data polling flag.

- Programming

During Automatic Program Algorithm is executing, an attempt to read the flash memory will output the complement of the last written data to DQ7, rather than the value at the address specified by the current address signal.

- Chip/Sector Erase

During chip erase/sector erase operation is in progress, an attempt to read the flash memory will output " 0 " to DQ7. Upon completion of chip erase/sector erase, an attempt to read the flash memory will output "1" to DQ7.

- Sector Erase Suspend

During sector erase suspend is in progress, an attempt to read the flash memory will output "1" to DQ7, if the address is within the sector which is being erased. If the address is not within the sector being erased, the flash memory will output bit 7 (DATA:7) of the read value of the address which is pointed. By looking at the toggle bit flag (DQ6) together, it is possible to know whether the present sector is in sector erase suspend mode, or to know which sector is being erased.

Note: An attempt to read access to the address where Automatic Algorithm is starting will be ignored. After receiving the completion status of data polling flag (DQ7), an attempt to read access will be allowed. Hence, a read access from Automatic Algorithm completion should be done after the read access of the data polling completion.

Table C.5.1a Status Change of data polling flag (DQ7)

- Status Change in normal operation

| Operation <br> status | Programming <br> $\rightarrow$ complete | Chip/sector erase <br> $\rightarrow$ complete | Sector erase wait <br> $\rightarrow$ start | Sector erase <br> (Sector being <br> erased) | Sector erase suspend <br> (Sector being erased) | Sector erase <br> being suspended <br> (Sector not being <br> erased) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DQ7 | DQ7 $\rightarrow$ DATA: 7 | $0 \rightarrow 1$ | 0 | $0 \rightarrow 1$ | $1 \rightarrow 0$ | DATA: 7 |

- Status Change in abnormal operation

| Operation <br> Status | Programming <br> Operation | Chip/sector <br> erase operation |
| :---: | :---: | :---: |
| DQ7 | DQ7 | 0 |

## C.5.2 Toggle bit flag (DQ6)

Toggle bit flag is used to indicate whether the Automatic Algorithm is in progress or is completed by using toggle bit function. Table C.5.2a shows status change of the toggle bit flag.

- Programming, Chip and Sector Erase

During Automatic Program or Erase Algorithm, successive attempts to read access to the flash memory will result in toggling DQ6 between " 1 " and " 0 ". When Automatic Program Algorithm and Automatic Chip/Sector Erase Algorithm is completed and continuous read access is attempted, the flash memory will stop the DQ6 toggling and output the value of bit 6 of the address specified by the current address signals.

## - Sector Erase Suspend

When an attempt to read access in sector erase suspend mode, read value will be " 1 " if the address is specified within the sector being sector erased. If the specified address is not within to the sector being sector erased, the flash memory will output the value of bit 6 of the address specified by the current address signals.

Note: In programming operation, if the sector to be programmed is write-protected, the DQ6 will be toggled for about $2 \mu \mathrm{~S}$ and then stop toggling without having the data change. In erasing operation, if all sectors are write-protected, the DQ6 will be toggled for about $100 \mu$ S and then go back into read/reset mode without having the data change.

Table C.5.2a Status Change of toggle bit flag (DQ6)

- Status Change in normal operation

| Operation <br> status | Programming <br> $\rightarrow$ complete | Chip/sector erase <br> $\rightarrow$ complete | Sector erase wait <br> $\rightarrow$ start | Sector erase <br> (Sector suspend <br> erased) | Sector erase suspend <br> (Sector being erased) | Sector erase <br> being suspended <br> (Sector not being <br> erased) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DQ6 | Toggle $\rightarrow$ DATA:6 | Toggle $\rightarrow$ Stop | Toggle | Toggle $\rightarrow 1$ | $1 \rightarrow$ Toggle | DATA:6 |

- Status Change in abnormal operation

| Operation <br> Status | Programming <br> Operation | Chip/sector <br> erase operation |
| :---: | :---: | :---: |
| DQ6 | Toggle | Toggle |

## C.5.3 Exceeded timing limits flag (DQ5)

Exceeded timing limits flag is used to indicate whether Automatic Algorithm has executed beyond the time (internal pulse count) specified in the flash memory. Table C.5.3a shows status change of the exceeded timing limits flag.

## - Programming, Chip and Sector Erase

An attempt to read access after programming or chip/sector erase operation will output "0" to DQ5 if Automatic Algorithm has executed within the time (internal pulse count) specified in the flash memory. If it is beyond the limit, "1" will be output to DQ5. With irrespective of he Automatic Algorithm operation status, It is used to determine whether the program/erase operation has suceeded. Thus, when " 1 " is read, it shows that programming or erasing operation is failed if Automatic Algorithm is regarded as still being executed by data polling function or toggle bit function.
For an example, If the user tries to write " 1 " to the flash memory address where " 0 " is written, a failure will occur. In this case, flash memory will be locked and Automatic Algorithm will not be completed. Consequently, valid data will not be outputted from the data polling flag (DQ7). In the case of toggle bit flag (DQ6), the toggle operation on bit 6 will not stopped and bit 5 output "1" to the exceeded timing limits flag (DQ5). It means that the flash memory is not defective and it has been used incorrectly. The operation will return to normal after executing a reset command.

Table C.5.3a Status Change of exceeded timing limits flag (DQ5)

## - Status Change in normal operation

| Operation <br> status | Programming <br> $\rightarrow$ complete | Chip/sector erase <br> $\rightarrow$ complete | Sector erase wait <br> $\rightarrow$ start | Sector erase <br> (Sector being <br> erased) | Sector erase suspend <br> (Sector being erased) | Sector erase <br> being suspended <br> (Sector not being <br> erased) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DQ5 | $0 \rightarrow$ DATA5 | $0 \rightarrow 1$ | 0 | 0 | 0 | DATA:5 |

- Status Change in abnormal operation

| Operation <br> Status | Programming <br> Operation | Chip/sector <br> erase operation |
| :---: | :---: | :---: |
| DQ5 | 1 | 1 |

## C.5.4 Sector erase timer flag (DQ3)

Sector erase timer flag is used to indicate whether the Automatic Algorithm is executed beyond the sector erase wait time after the sector erase command is issued. Table C.5.4a shows status change of the sector erase timer flag.

- During sector erase operation

An attempt to read access after sector erase command is issued will output "0" to DQ3 if Automatic Algorithm is executed within the sector erase wait time. " 1 " will be output to DQ3 if the Automatic Algorithm is executed beyond the sector erase wait time. If the data polling flag or toggle bit flag indicates that the Automatic Erase Algorithm is operating and DQ3 is " 1 ", internally controlled erasing is started. Attempts to issue erase code and command other than sector erase suspend to the sector will be ignored until the erasing is completed. When DQ3 is " 0 ", issuing the additional sector erase code will be accepted. To ensure the command has been accepted, the control software should check the status of DQ3 prior to each subsequent sector erase command. If DQ3 was "1" on the status checking, the command may not be accepted.

- During sector erase suspend

When read accessing during sector erase suspend, "1" will be output to DQ3 if the specified address is within the sector which is being erased. If it does not within the sector being erased, the flash memory will output the value of bit 3 (DATA:3) at the address specified by the current address signals.

Table C.5.4a Status Change of sector erase timer flag (DQ3)

- Status Change in normal operation

| Operation <br> status | Programming <br> $\rightarrow$ complete | Chip/sector erase <br> $\rightarrow$ complete | Sector erase wait <br> $\rightarrow$ start | Sector erase <br> (Sector being <br> erased) | Sector erase suspend <br> (Sector being erased) | Sector erase <br> being suspended <br> (Sector not being <br> erased) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DQ3 | $0 \rightarrow$ DATA:3 | 1 | $0 \rightarrow 1$ | $1 \rightarrow 0$ | $0 \rightarrow 1$ | DATA:3 |

- Status Change in abnormal operation

| Operation <br> Status | Programming <br> Operation | Chip/sector <br> erase operation |
| :---: | :---: | :---: |
| DQ3 | 0 | 1 |

## C. 6 Details of Flash Memory Programming/Erasing

This section describes the following: command generated for initiating Automatic Algorithm, read/reset of flash memory, programming, chip erase, sector erase suspend and sector erase resume.

Flash memory can execute Automatic Algorithm when repeating the bus write cycle in read/reset, programming, chip erase, sector erase, sector erase suspend and sector erase resume command sequence. The bus write cycle must be sent continuously. Completion of the Automatic Algorithm can be determined by checking the hardware sequence flag such as data polling function. If it is completed correctly, the flash memory will return to read/reset status.

## C.6.1 Read/reset status

This section describes how to isssue read/reset command to make flash memory returning to read/reset status.

To make the flash memory returning to read/reset status, the command sequence of the read/reset command found in command sequence table (refer to Section C.4, Automatic Algorithm Initiation Method, Table C.4a) can be used and it needs to be continuously sent to the target sector in the flash memory.
There are two kinds of bus write cycles in read/reset command, 1 and 3 bus write cycles, but there are no significant difference between them.

Since read/reset is the initial state, the flash memory will always go to this state when power-on and any command is correctly implemented. Read/reset status is a waiting state for other command. Normal read access can be done in the read/reset status.
Programming access is possible from the CPU. This command is not necessary for reading data in normal read access. This command is used when the operation is not completed correctly for some reasons, or when automatic algorithm needs to be reseted.

## C.6.2 Data Programming

This section will describe how to issue the programming command to program the flash memory.
To initiate Automatic Program Algorithm in the flash memory, the programming command found in command sequence table (refer to Section C.4, Automatic Algorithm Initiation Method, Table C.4a) can be used and it needs to be sent continuously to the target sector in the flash memory. Automatic Algorithm will be initiated and automatic programming will start when data programming to the target address is completed at the 4th cycle.

## - Specifying Address

Specified programming address must be even number. It is not possible to program correctly on odd numbered addresses, so that it is necessary to program by word data unit with the even numbered address. Programming can be done in any address and can go over sector boundary. However, only one word can be programmed with a single programming command.

## - Precautions on Data Programming

It is impossible to program data from "1" to " 0 ". When programming data from "1" to " 0 ", data polling function (DQ7) and toggle bit function (DQ6) will not be completed. In this case, either the flash memory is considered to have error and programming timing limit will exceed making the exceeded timing limits flag (DQ5) to output an error, or "1" will be assumed to have been programmed. When reading data in the read/reset status, the data remains " 0 ". Only erase operation can change data from "0" to "1".

While automatic programming the flash memory is under processing, all other command will be ignored. If hardware reset is initiated during programming, take a good care on it. It is because the data being programmed to the address will not be guaranteed.

## - Data Programming Procedure

Figure C.6.2a shows the example procedure of programming the flash memory. By checking the hardware sequence flag (refer to Section C.5, Execution Status of Automatic Algorithm), the status of Automatic Algorithm in flash Memory can be determined. Data polling flag (DQ7) is used to check whether programming is completed. The data read from DQ7 is the data found in the next programming address. It is necessary to re-check the data polling flag bit (DQ7) even if the exceeded timing limits flag (DQ5) is " 1 ". It is because data polling flag (DQ7) and the exceed time limit flag (DQ5) will change in the same time. Furthermore, it is not need to re-check the toggle bit flag(DQ6) since it will stop at the same time when exceeded timing limits flag (DQ5) changes to "1".


Figure C.6.2a Example procedure of programming the flash memory

## C.6.3 Chip Erase

This section will describe how to issue the chip erase command to erase the whole chip.
To erase all data from the flash memory, the chip erase command found in command sequence table (refer to Section C.4, Automatic Algorithm Initiation Method, Table C.4a) can be used and needs to be send continuously to the target address in the flash memory.
Chip erase command is executed by six bus write cycles. Chip erase operation will start after 6th bus write cycle is finished. It is no necessary for the user to program the flash memory before erasing the chip. During Automatic Erase Algorithm execution, flash Memory will automatically write " 0 " to all bits before chip erase is operated.

## C.6.4 Sector Erase

This section will describe how to issue the sector erase command to erase any sector in the flash memory.
Single sector or multiple sector can be erased in the same time.
To erase a sector in the flash Memory, the sector erase command found in command sequence table (refer to Section C.4, Automatic Algorithm Initiation Method, Table C.4a) can be used and needs to be sent continuously to the target sector in the flash memory.

## - Specifying sector

Sector erase command is executed by six bus write cycles. $50 \mu \mathrm{~S}$ of sector erase wait time will be started after issuing sector erase code $(30 \mathrm{H})$ to the accessible even numbered address of the sector in the 6th bus write cycle. When erasing several sectors in the same time, the erase code $(30 \mathrm{H})$ to the address of sectors to be erased needs to be issued.

## - Precautions on Specifying Multiple Sectors

Sector erase operation will be started when the $50 \mu \mathrm{~S}$ of sector erase wait time is completed after the last sector erase code is issued. When erasing several sectors, it is necessary to input the address and the erase code of the following sector to erase in the $50 \mu \mathrm{~S}$ of sector erase wait time. However, the sector erase operation may not be accepted even after this wait time. It is necessary to check the sector erase timer flag (DQ3) to ensure whether the sector erase code issued was valid. At this time, the address to read the sector erase timer flag (DQ3) should be specified to the sector to be erased.

## - Sector Erase Procedure

By checking hardware sequence flag, the status of Automatic Algorithm in flash memory can be determined (refer to 1.5 Automatic algorithm execution status). Figure C.6.4a shows the example procedure of sector erase in the Flash Memory. In this example procedure, the toggle bit flag (DQ6) is used to check erase completion Take note that the data read for DQ6 is the data in the sector that will be erased. It is not necessary to check the data polling flag (DQ7) even if the exceeded timing limits flag (DQ5) is "1". It is because data polling flag (DQ7) will change at the same time the exceed timing limits flag (DQ5) is changed. Furthermore, it is necessary to re-check the toggle bit flag (DQ6) since it will stop at the same time exceeded timing limits flag (DQ5) changes to "1".


Figure C.6.4a Example flowchart of erasing flash memory

## C.6.5 Suspend Sector Erase

This section will describe how to issue the sector erase suspend command to suspend sector erase operation in the flash memory. During sector erase, it is possible to read data from the sector which is not being erased.

To suspend sector erase in flash memory, the sector erase suspend command found in command sequence table (refer to Section C.4, Automatic Algorithm Initiation Method, Table C.4a) can be used and needs to be sent continuously to the target sector in the flash memory.
During sector erase suspend command is executing, it is possible to read data from the sector that is not being erased. This enables only reading from the sector but it is not possible to programming the sector. This command is valid only during sector erasing time including the erase wait time, However, this command will be ignored when chip erase is operating or programming is operated.
It will be implemented by issuing erase suspend code $(\mathrm{BOH})$ to the flash memory. The address will be specified to any address within the Flash Memory.
Sector erase suspend command will be ignored during another erase suspend command. If the sector erase suspend command is issued during sector erase wait, sector erase wait will be ended suddenly and sector erase will be suspended. If sector erase suspend command is issued when sector erase is operating after sector erase wait, it will go to sector erase suspend status after maximum of $15 \mu \mathrm{~S}$.

## C.6.6 Resume Sector Erase

This section will describe how to issue the sector erase resume command to restart the suspended sector erase in the flash memory.
To restart the suspended sector erase, the sector erase resume command found in command sequence table (refer to Section C.4, Automatic Algorithm Initiation Method, Table C.4a) can be used and needs to be sent continuously to the target sector in the flash memory.
Sector erase resume command is used to restart the sector erase operation form sector erase suspend status. It will be implemented by issuing the sector erase resume code $(30 \mathrm{H})$ to the flash memory. The address can be specified to any address within the flash memory. Sector erase resume command will be ignored during sector erase is operating.

## FUJITSU LIMITED

For further information please contact:
Japan
FUJITSU LIMITED
Corporate Global Business Support Division Electronic Devices
KAWASAKI PLANT, 4-1-1, Kamikodanaka
Nakahara-ku, Kawasaki-shi
Kanagawa 211-8588, Japan
Tel: (044) 754-3763
Fax: (044) 754-3329
http://www.fujitsu.co.jp/

## North and South America

FUJITSU MICROELECTRONICS, INC.
Semiconductor Division
3545 North First Street
San Jose, CA 95134-1804, USA
Tel: (408) 922-9000
Fax: (408) 922-9179
Customer Response Center
Mon. - Fri.: 7 am-5 pm (PST)
Tel: (800) 866-8608
Fax: (408) 922-9179
http://www.fujitsumicro.com/

## Europe

FUJITSU MIKROELEKTRONIK GmbH
Am Siebenstein 6-10
D-63303 Dreieich-Buchschlag
Germany
Tel: (06103) 690-0
Fax: (06103) 690-122
http://www.fujitsu-ede.com/

## Asia Pacific

FUJITSU MICROELECTRONICS ASIA PTE LTD \#05-08, 151 Lorong Chuan
New Tech Park
Singapore 556741
Tel: (65) 281-0770
Fax: (65) 281-0220
http://www.fmap.com.sg/

## F9806

© FUJITSU LIMITED Printed in Japan

Known bugs in HM MB90580

1. Chapter 20.4.5 Output Compare Unit

The documentation refers to outputs OUT0/1 and OUT2/3.
There does not exist OUT2 and OUT3 (see pinning).
So compare register 0 corresponds to OUT0 only and compare register 1 to OUT1.
last updated : 05-03-98
TKa


[^0]:    * OTD1: Corresponds to output compare 1/3 OTD0: Corresponds to output compare 0/2

