ABOV SEMICONDUCTOR 8-BIT SINGLE-CHIP MICROCONTROLLERS

# MC80F1504/1604

User's Manual (Ver. 1.33)



Version 1.33 Published by FAE Team ©2007 ABOV Semiconductor Co., Ltd. All right reserved.

Additional information of this manual may be served by ABOV semiconductor offices in Korea or Distributors and Representatives.

ABOV semiconductor reserves the right to make changes to any information here in at any time without notice.

The information, diagrams and other data in this manual are correct and reliable; however, ABOV semiconductor is in no way responsible for any violations of patents or other rights of the third party generated by the use of this manual.



# **REVISION HISTORY**

#### VERSION 1.32 (March 8, 2012) This book

16 SOP(300mil) PKG is added The company logo and MDS pictures are updated.

VERSION 1.32 (MAR,4 2009) Remove RC external oscilation options at Device Configuration Area. VERSION 1.31 (JAN,5 2009) Correct 'Figure 19-1 Simple External Reset Circuit'. Add clock source information at 'Figure 11-1 Block Diagram of Basic Interval Timer'. VERSION 1.3 (DEC, 26 2008) Correct the port structure of reest and Xin/Xout pin. Add R33 and R34 informaiton. Correct VPP and Reset circuit. Correct the ISP connector drawings. VERSION 1.23 (NOV,27 2008) 20 TSSOP package is added. Change the pacakge name from '16 SOP( 153 mil )' to '16 SOP( 150 mil )'. VERSION 1.22 (NOV, 26 2008) 16 QFN package is added. VERSION 1.21 (June, 3 2008) Internal OSC specification is changed. VERSION 1.20 (April, 4 2008) The format of Instruction Set and Revision History was renewed. Fixed some errata. **VERSION 1.1 (MAR.2008)** Added POP characteristic on chapter "7. ELECTRICAL CHARACTERISTICS" on page 18. **VERSION 1.0 (MAR.2008)** Added more SIO information on descriptions of port and interrupt. **VERSION 0.6 (FEB.2008)** Repalce 'TBD' with real data in "7. ELECTRICAL CHARACTERISTICS" on page 18. Amended the contents of "21. DEVICE CONFIGURATION AREA" on page 96. **VERSION 0.5 (FEB.2008)** Amend the contents of "21. DEVICE CONFIGURATION AREA" on page 96. **VERSION 0.4 (NOV.2007)** Fixed 16 SOP(153 mil) package infomation. **VERSION 0.3 (OCT.2007)** Added SIO infomation on Feature, Block Diagram, Pin Assignment

#### MC80F1504/1604



VERSION 0.2 (SEP.2007) Added chapater 15 Serial Input/Output (SIO) Added chapter 23 IN-System Programming (ISP) VERSION 0.1 (JUL.2007) The First Edition.





# **Table of Contents**

| 1. | OVERVIEW                         |    |
|----|----------------------------------|----|
|    | Description                      |    |
|    | Features                         |    |
|    | Development Tools                |    |
|    | Ordering Information             |    |
| 2. | LOCK DIAGRAM                     | 4  |
| 3. | PIN ASSIGNMENT                   | 5  |
| 4. | PACKAGE DRAWING                  | 7  |
| 5. | PIN FUNCTION                     | 12 |
| 6. | PORT STRUCTURES                  | 14 |
| 7. | ELECTRICAL CHARACTERISTICS       | 18 |
|    | Absolute Maximum Ratings         | 18 |
|    | Recommended Operating Conditions | 18 |
|    | A/D Converter Characteristics    | 18 |
|    | DC Electrical Characteristics    |    |
|    | AC Characteristics               |    |
|    | Typical Characteristics          | 21 |
| 8. | MEMORY ORGANIZATION              | 25 |
|    | Registers                        | 25 |
|    | Program Memory                   | 27 |
|    | Data Memory                      | 30 |
|    | Addressing Mode                  | 35 |
| 9. | I/O PORTS                        | 39 |
|    | R0 and R0IO register             | 39 |
|    | R1 and R1IO register             | 40 |
|    | R3 and R3IO register             | 41 |
| 10 | CLOCK GENERATOR                  | 43 |
|    | Oscillation Circuit              | 43 |
| 11 | BASIC INTERVAL TIMER             | 45 |
| 12 | WATCHDOG TIMER                   | 47 |
| 13 | .TIMER/EVENT COUNTER             | 50 |
|    | 8-bit Timer / Counter Mode       | 53 |
|    | 16-bit Timer / Counter Mode      | 57 |
|    | 8-bit (16-bit) Compare Output    | 58 |
|    | 8-bit Capture Mode               | 59 |
|    |                                  |    |

| 16-bit Capture Mode                   | 63       |
|---------------------------------------|----------|
| PWM Mode                              |          |
| 14.ANALOG TO DIGITAL CONVERTER        | 67       |
| 15.SERIAL INPUT/OUTPUT (SIO)          | 70       |
| Transmission/Receiving Timing         |          |
| The usage of Serial I/O               |          |
| 16.BUZZER FUNCTION                    | 74       |
| 17.INTERRUPTS                         |          |
| Interrupt Sequence                    |          |
| BRK Interrupt                         | 80       |
| Shared Interrupt Vector               | 80       |
| BRK Interrupt                         |          |
| Multi Interrupt                       |          |
| External Interrupt                    | 82       |
| 18. POWER SAVING OPERATION            | 84       |
| Sleep Mode                            | 84       |
| Stop Mode                             |          |
| Stop Mode at Internal RC-Oscillated V | •        |
| Timer Mode                            |          |
| Minimizing Current Consumption        |          |
| 19.RESET                              | 92       |
| 20.POWER FAIL PROCESSOR               |          |
| 21. DEVICE CONFIGURATION AREA         |          |
| 22.EMULATOR EVA. BOARD SETTING        |          |
| DIP Switch and VR Setting             |          |
| 23.IN-SYSTEM PROGRAMMING (ISP) .      | 100      |
| Getting Started / ISP Installation    |          |
| Basic ISP S/W Information             | 101      |
| Hardware Conditions to Enter the ISP  | Mode 101 |
| Sequence to enter ISP mode/user mo    | de 103   |
| USB-SIO-ISP Board                     |          |
| A. INSTRUCTION                        |          |
| Terminology List<br>Instruction Map   |          |
| Instruction Map                       |          |
|                                       |          |





# MC80F1504/1604

# CMOS SINGLE-CHIP 8-BIT MICROCONTROLLER WITH 10-BIT A/D CONVERTER

#### **1.OVERVIEW**

#### **1.1 Description**

The MC80F1504/1604 is advanced CMOS 8-bit microcontroller with 4K bytes of FLASH. This is a powerful microcontroller which provides a highly flexible and cost effective solution to many embedded control applications. This provides the following features : 4K bytes of FLASH, In System Programming, 256 bytes of RAM, 8/16-bit timer/counter, watchdog timer, on-chip POR, 10-bit A/D converter, buzzer driving port, 10-bit PWM output and on-chip oscillator and clock circuitry. It also has Noise Canceller and Power Faild Detector for Noise Immunity. In addition, the MC80F1504/1604 supports power saving modes to reduce power consumption.

This document explains the base MC80F1604, the other's eliminated functions are same as below table.

| Device Name | FLASH (ROM)<br>Size | RAM  | ADC        | I/O PORT | Package                                        |
|-------------|---------------------|------|------------|----------|------------------------------------------------|
| MC80F1604   |                     | 256B | 10 channel | 16 port  | 20 PDIP, 20 SOP, 20 TSSOP                      |
| MC80F1504   | 4KB                 |      | 8 channel  | 12 port  | 16 PDIP, 16 SOP(150 mil)<br>, 16 TSSOP, 16 QFN |

Note : The DAA, DAS decimal adjust instructions are not provided in these devices.

#### 1.2 Features

- 4K Bytes On-chip FLASH
  - Endurance : 100 times
  - Retention time : 10 years
- In System Programming Support
- 256 Bytes On-chip Data RAM (A stack memory is included)
- Minimum Instruction Execution Time: - 1us at 4MHz (2 cycle NOP instruction)
- Programmable I/O pins (LED direct driving can be a source and sink)
  MC80F1604 : 18(17 + 1 input only)
  MC80F1504 : 14(13 + 1 input only)
- One 8-bit SIO Communication Interface
- One 8-bit Basic Interval Timer
- Timer / Counter / Capture - 8 bit \* 3ch.( 16-bit \* 1ch)
- One Watchdog timer
- One 10-bit High Speed PWM Outputs

- One Buzzer Driving port - 488Hz ~ 250kHz@4MHz
- 10-bit A/D converter
  - MC80F1604 : 10 channels
  - MC80F1504 : 8 channels
  - (Total Accuracy : ±3 LSB)
- 10 Interrupt sources
  - External input : 4
  - Timer / Counter : 3
  - Functional : 3 ( ADC, WDT, BIT )
- Built in Noise Immunity Circuit
   Noise Canceller
  - PFD (Power fail detector)
- Operating Voltage & Frequency
   4.5V ~ 5.5V (at 1 ~ 12 MHz)
- 2.2V ~ 5.5V (at 1 ~ 4.2 MHz)
- Operating Temperature : -40°C ~ 85°C
- On-chip POR (Power on Reset)
- Power Saving Modes



- STOP mode
- SLEEP mode
- RC-WDT mode
- Oscillator Type
  - Crystal
  - Ceramic resonator

#### **1.3 Development Tools**

The MC80F1504/1604 is supported by a full-featured macro assembler, an in-circuit emulator CHOICE-Dr.<sup>TM</sup> and FLASH programmers. There are two different type of programmers such as single type and gang type. For mode detail, Macro assembler operates under the MS-Windows 95 and upversioned Windows OS. Please contact sales part of abov semiconductor.

| Software               | - MS-Windows based assembler<br>- MS-Windows based Debugger<br>- HMS800 C compiler                                                                                                   |
|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Hardware<br>(Emulator) | - CHOICE-Dr.<br>- CHOICE-Dr. EVA80C0x B/D                                                                                                                                            |
| Pod Name               | - CHPOD80C01D-16PD<br>- CHPOD80C02D-20PD                                                                                                                                             |
| FLASH Writer           | <ul> <li>CHOICE - SIGMA I/II (Single writer)</li> <li>PGM plus USB (Single writer)</li> <li>Stand Alone PGM_Plus (Single writer)</li> <li>Stand Alone GANG8 (Gang writer)</li> </ul> |

- Package
  - 16 PDIP/SOP(150/300 mil)/TSSOP/QFN
  - 20 PDIP/SOP/TSSOP
  - Available Pb free package



PGM plus USB (Single Writer)



Choice-Dr. (Emulator)



Stand Alone PGM Plus (Single Writer)





Stand Alone Gang8 (Gang Writer)

# 1.4 Ordering Information

| Device name                                                                  | ROM Size       | RAM size  | Package                                                            |
|------------------------------------------------------------------------------|----------------|-----------|--------------------------------------------------------------------|
| MC80F1504B P<br>MC80F1504M P<br>MC80F1504D P<br>MC80F1504R P<br>MC80F1504U P | 4K bytes FLASH | 256 bytes | 16PDIP<br>16SOP( 150 mil )<br>16SOP( 300 mil )<br>16TSSOP<br>16QFN |
| MC80F1604B P<br>MC80F1604D P<br>MC80F1604R P                                 | 4K bytes FLASH | 256 bytes | 20PDIP<br>20SOP<br>20TSSOP                                         |

Pb free package :

The "P" suffix will be added at the original part number. For example; MC80F1604B (Normal package), MC80F1604B P (Pb free package)



### 2.LOCK DIAGRAM





#### **3.PIN ASSIGNMENT**

#### MC80F1604B/1604D/1604R

#### 20 PDIP 20 SOP 20 TSSOP



#### MC80F1504B/1504M/1504D/1504R







MC80F1504U





# 4.PACKAGE DRAWING



















# **5.PIN FUNCTION**

VDD: Supply voltage.

 $V_{SS}$ : Circuit ground.

**RESET**: Reset the MCU.

 $X_{IN}$ : Input to the inverting oscillator amplifier and input to the internal main clock operating circuit.

**XOUT**: Output from the inverting oscillator amplifier.

**R00~R07**: R0 is an 8-bit, CMOS, bidirectional I/O port. R0 pins can be used as outputs or inputs according to "1" or "0" written the their Port Direction Register(R0IO).

| Port pin | Alternate function                 |
|----------|------------------------------------|
| R00      | INT3 (External Interrupt 3)        |
|          | SCK ( SIO CLK )                    |
| R01      | AN1 (Analog Input Port 1)          |
|          | SIN (SIO Data Input)               |
| R02      | AN2 (Analog Input Port 2)          |
|          | SOUT( SIO Data output )            |
| R03      | AN3 (Analog Input Port 3)          |
|          | INT2 (External Interrupt 2)        |
| R04      | AN4 (Analog Input Port 4)          |
|          | EC0 (Event Counter Input Source 0) |
| R05      | AN5 (Analog Input Port 5)          |
|          | T0O (Timer0 Clock Output )         |
| R06      | AN6 (Analog Input Port 6)          |
|          | T2O (Timer2 Clock Output)          |
| R07      | AN7 (Analog Input Port 7)          |
|          | EC1 (Event Counter Input Source 1) |

Table 5-1 R0 Port

In addition, R0 serves the functions of the various special features in Table 5-1 .

**R10~R14**: R1 is a 5-bit, CMOS, bidirectional I/O port. R1 pins can be used as outputs or inputs according to "1" or "0" written the their Port Direction Register (R1IO).

R1 serves the functions of the various following special features in Table 5-2

| Port pin   | Alternate function                                                                                                    |
|------------|-----------------------------------------------------------------------------------------------------------------------|
| R10        | AN0 ( Analog Input Port 0 )<br>AVref ( External Analog Reference Pin )<br>PWM10 ( PWM1 Output )                       |
| R11<br>R12 | INT0 (External Interrupt Input Port 0)<br>INT1 (External Interrupt Input Port 1)<br>BUZO (Buzzer Driving Output Port) |
| R13<br>R14 |                                                                                                                       |

#### Table 5-2 R1 Port

**R31,R32 and R35**: R3 is an 3-bit, CMOS, bidirectional I/ O port. R3 pins can be used as outputs or inputs according to "1" or "0" written the their Port Direction Register (R3IO). But, R35 pin can be used as input port only.

R3 serves the functions of the following special features in Table 5-3 .

| Port pin | Alternate function         |
|----------|----------------------------|
| R31      | AN14(Analog Input Port 14) |
| R32      | AN15(Analog Input Port 15) |
| R35      | RESET(Reset input port)    |

Table 5-3 R3 Port



| PIN NAME                                 | Pin No.<br>(20PDIP) | In/Out                   | Function           |                                                          |  |  |
|------------------------------------------|---------------------|--------------------------|--------------------|----------------------------------------------------------|--|--|
| V <sub>DD</sub>                          | 5                   | -                        | Supply voltage     | Supply voltage                                           |  |  |
| V <sub>SS</sub>                          | 16                  | -                        | Circuit ground     |                                                          |  |  |
| RESET (R35)                              | 15                  | I ( Input )              | Reset signal input | Input only port                                          |  |  |
| X <sub>IN</sub>                          | 13                  | -                        | Oscillation Input  | -                                                        |  |  |
| X <sub>OUT</sub>                         | 14                  | -                        | Oscillation Output | -                                                        |  |  |
| R00 (INT3 / SCK)                         | 17                  | I/O (Input)              |                    | External Interrupt Input 3 / SIO Clock                   |  |  |
| R01 (AN1 / SI)                           | 18                  | I/O (Input)              |                    | Analog Input Port 1 / SIO Data Input                     |  |  |
| R02 (AN2 / SOUT)                         | 19                  | I/O (Input)              |                    | Analog Input Port 2 / SIO Data Output                    |  |  |
| R03 (AN3 / INT2)                         | 20                  | I/O (Input/Input)        |                    | Analog Input Port 3 / External Interrupt Input 2         |  |  |
| R04 (AN4 / EC0)                          | 1                   | I/O (Input/Input/Input)  |                    | Analog Input Port 4 / Event Counter Input 0              |  |  |
| R05 (AN5 / T0O)                          | 2                   | I/O (Input/Output)       |                    | Analog Input Port 5 / Timer0 Output                      |  |  |
| R06 (AN6 / T2O)                          | 3                   | I/O (Input/Output)       |                    | Analog Input Port 6 / Timer2 Output                      |  |  |
| R07 (AN7 / EC1)                          | 4                   | I/O (Input/Input)        | Normal I/O Ports   | Analog Input Port 7 / Event Counter Input 1              |  |  |
| R10 (AN0 / AV <sub>REF</sub> /<br>PWM1O) | 6                   | I/O (Input/Input/Output) |                    | Analog Input Port 0 / Analog Reference / PWM 1<br>output |  |  |
| R11 (INT0)                               | 7                   | I/O (Input)              |                    | External Interrupt Input 0                               |  |  |
| R12 (INT1 / BUZO)                        | 8                   | I/O (Input/Output)       |                    | External Interrupt Input 1 / Buzzer Driving Output       |  |  |
| R13                                      | 9                   | -                        |                    | -                                                        |  |  |
| R14                                      | 10                  | -                        |                    | -                                                        |  |  |
| R31 (AN14)                               | 11                  | I/O (Input)              |                    | Analog Input Port 14                                     |  |  |
| R32 (AN15)                               | 12                  | I/O (Input)              |                    | Analog Input Port 15                                     |  |  |

Table 5-4 Pin Description



### **6.PORT STRUCTURES**





#### R00 (INT3 / SCK)





#### R02 (AN2 / SOUT)





#### R03 (AN3 / INT2 ),

#### R04 (AN4 / EC0), R07 (AN7 / EC1)



#### $V_{DD}$ Pull-up Pull-up Tr. Reg. Open Drair Reg. VDD VDD ¥ Data Reg. MUX PWM10 Pin PWM10E(PSR0.6) √ vss Direction Reg. Data Bus MUX RD AN[0] -ADEN & AD<u>S[3:0]</u> (ADCM) ADC Reference $V_{\text{DD}}$ Voltage Input MUX AVREFS(PSR1.3)

R10 (AN0 / AV<sub>REF</sub> / PWM1O)





\* RD : Read Signal ( Active High )

#### R05 (AN5 / T0O), R06 (AN6 / T2O)





#### R12 (INT1 / BUZO)



RESET(R35)



\* RD : Read Signal ( Active High )

#### R31 (AN14), R32 (AN15)





#### XIN, XOUT (Crystal or Ceramic Resonator)



XIN, XOUT (External RC or R oscillation)





#### R33 (X<sub>IN</sub>), R34 (X<sub>OUT</sub>)



# **7.ELECTRICAL CHARACTERISTICS**

#### 7.1 Absolute Maximum Ratings

| Supply voltage0.3 to +6.5 V                                                                  |
|----------------------------------------------------------------------------------------------|
| Storage Temperature65 to +150 °C                                                             |
| Voltage on any pin with respect to Ground (V <sub>SS</sub> )<br>0.3 to V <sub>DD</sub> +0.3V |
| Maximum current out of V <sub>SS</sub> pin                                                   |
| Maximum current into V <sub>DD</sub> pin100 mA                                               |
| Maximum current sunk by (I <sub>OL</sub> per I/O Pin)20 mA                                   |
| Maximum output current sourced by (I <sub>OH</sub> per I/O Pin)                              |

#### 7.2 Recommended Operating Conditions

|                                     | 10 mA  |
|-------------------------------------|--------|
| Maximum current ( $\Sigma I_{OL}$ ) | 160 mA |
| Maximum current ( $\Sigma I_{OH}$ ) | 80 mA  |

**Note:** Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

| Parameter             | Symbol           | Condition                                                                           | Min.              | Max.              | Unit |
|-----------------------|------------------|-------------------------------------------------------------------------------------|-------------------|-------------------|------|
| Supply Voltage        | V <sub>DD</sub>  | f <sub>XIN</sub> =1~12MHz<br>f <sub>XIN</sub> =1~8MHz<br>f <sub>XIN</sub> =1~4MHz   | 4.5<br>2.7<br>2.2 | 5.5<br>5.5<br>5.5 | V    |
| Operating Frequency   | f <sub>XIN</sub> | V <sub>DD</sub> =4.5~5.5V<br>V <sub>DD</sub> =2.7~5.5V<br>V <sub>DD</sub> =2.2~5.5V | 1<br>1<br>1       | 12<br>8<br>4      | MHz  |
| Operating Temperature | T <sub>OPR</sub> | V <sub>DD</sub> =2.2~5.5V                                                           | -40               | 85                | °C   |

#### 7.3 A/D Converter Characteristics

(T<sub>a</sub>=-40~85°C, V<sub>SS</sub>=0V, V<sub>DD</sub>=2.7~5.5V @f<sub>XIN</sub>=8MHz)

| Parameter                        | Symbol            | Conditions                                                                           | nditions Min. Typ. |          | Max.                                 | Unit |
|----------------------------------|-------------------|--------------------------------------------------------------------------------------|--------------------|----------|--------------------------------------|------|
| Resolution                       |                   | -                                                                                    | -                  | 10       | -                                    | BIT  |
| Overall Accuracy                 | CAIN              | -                                                                                    | -                  | -        | ±3                                   | LSB  |
| Non Linearity Error              | NLE               |                                                                                      | -                  | -        | ±3                                   | LSB  |
| Differential Non Linearity Error | DLE               | $V_{DD} = AV_{REF} = 5V$                                                             | -                  | -        | ±3                                   | LSB  |
| Zero Offset Error                | NZOE              | CPU Clock = 4MHz<br>V <sub>SS</sub> = 0V                                             | -                  | ±1       | ±3                                   | LSB  |
| Full Scale Error                 | NFSE              |                                                                                      | -                  | ±0.5     | ±3                                   | LSB  |
| Conversion Time                  | T <sub>CONV</sub> | -                                                                                    | 13                 | -        | -                                    | μS   |
| Analog Input Voltage Range       | V <sub>AN</sub>   | -                                                                                    | V <sub>SS</sub>    | -        | V <sub>DD</sub> (AV <sub>REF</sub> ) | V    |
| Analog Reference Voltage         | AV <sub>REF</sub> | -                                                                                    | 2.7                | -        | V <sub>DD</sub>                      | V    |
| Analog Input Impedance           | RAIN              | $V_{DD}$ = AV <sub>REF</sub> = 5V                                                    | 5                  | 100      | -                                    | MΩ   |
| Analog Block Current             | I <sub>AVDD</sub> | V <sub>DD</sub> = AV <sub>REF</sub> = 5V<br>V <sub>DD</sub> = AV <sub>REF</sub> = 3V | -                  | 1<br>0.5 | 3<br>1.5                             | mA   |
| Analog Block Current             |                   | $V_{DD} = AV_{REF} = 5V$<br>power down mode                                          | -                  | 100      | 500                                  | nA   |



# 7.4 DC Electrical Characteristics

(T<sub>A</sub>=-40~85°C, V<sub>DD</sub>=5.0V, V<sub>SS</sub>=0V),

| Demonstern                               | Oh. a l             | <b>D</b> .                                  | 0                                              | Sp                  |      |                     |      |  |
|------------------------------------------|---------------------|---------------------------------------------|------------------------------------------------|---------------------|------|---------------------|------|--|
| Parameter                                | Symbol              | Pin                                         | Condition                                      | Min.                | Тур. | Max.                | Unit |  |
|                                          | V <sub>IH1</sub>    | X <sub>IN</sub> , RESET                     |                                                | 0.8 V <sub>DD</sub> | -    | V <sub>DD</sub>     |      |  |
| Input High Voltage                       | V <sub>IH2</sub>    | Hysteresis Input <sup>1</sup>               |                                                | 0.8 V <sub>DD</sub> | -    | V <sub>DD</sub>     | V    |  |
| V <sub>IH3</sub>                         |                     | Normal Input                                |                                                | 0.7 V <sub>DD</sub> | -    | V <sub>DD</sub>     |      |  |
|                                          | V <sub>IL1</sub>    | X <sub>IN</sub> , RESET                     |                                                | 0                   | -    | 0.2 V <sub>DD</sub> |      |  |
| Input Low Voltage                        | V <sub>IL2</sub>    | Hysteresis Input <sup>1</sup>               |                                                | 0                   | -    | 0.2 V <sub>DD</sub> | V    |  |
|                                          | V <sub>IL3</sub>    | Normal Input                                |                                                | 0                   | -    | 0.3 V <sub>DD</sub> |      |  |
| Output High Voltage                      | V <sub>OH</sub>     | All Output Port                             | V <sub>DD</sub> =5V, I <sub>OH</sub> =-5mA     | V <sub>DD</sub> -1  | -    | -                   | V    |  |
| Output Low Voltage                       | V <sub>OL</sub>     | All Output Port                             | V <sub>DD</sub> =5V, I <sub>OL</sub> =10mA     | -                   | -    | 1                   | V    |  |
| Input Pull-up Current                    | IР                  | Normal Input                                | V <sub>DD</sub> =5V                            | -60                 | -    | -150                | μA   |  |
| Input High                               |                     | All Pins (except X <sub>IN</sub> )          | V <sub>DD</sub> =5V                            | -                   | -    | 5                   | μA   |  |
| Leakage Current                          | I <sub>IH2</sub>    | X <sub>IN</sub>                             | V <sub>DD</sub> =5V                            | -                   | 12   | 20                  | μA   |  |
| Input Low                                | l <sub>IL1</sub>    | All Pins (except X <sub>IN</sub> )          | V <sub>DD</sub> =5V                            | -5                  | -    | -                   | μA   |  |
| Leakage Current                          | I <sub>IL2</sub>    | X <sub>IN</sub>                             | V <sub>DD</sub> =5V                            | -20                 | -12  | -                   | μA   |  |
| Hysteresis                               | V <sub>T</sub>      | Hysteresis Input <sup>1</sup>               | V <sub>DD</sub> =5V                            | 0.5                 | -    | -                   | V    |  |
| PFD Voltage                              | VPFD                | V <sub>DD</sub>                             |                                                | 2.0                 | -    | 3.0                 | V    |  |
| POR Voltage                              | V <sub>POR</sub>    | V <sub>DD</sub>                             |                                                | 2.0                 | 2.4  | 2.8                 | V    |  |
| POR Start Voltage <sup>2</sup>           | V <sub>START</sub>  | V <sub>DD</sub>                             |                                                | 0                   |      | 1.9                 | V    |  |
| POR Rising Time <sup>2</sup>             | T <sub>POR</sub>    | V <sub>DD</sub>                             |                                                |                     |      | 40                  | ms/V |  |
| V <sub>DD</sub> Rising Time <sup>2</sup> | T <sub>VDD</sub>    | V <sub>DD</sub>                             |                                                | -                   | -    | 40                  | ms/V |  |
| Internal RC WDT<br>Period                | T <sub>RCWDT</sub>  | X <sub>OUT</sub>                            | V <sub>DD</sub> =5.5V                          | 36                  | -    | 90                  | μS   |  |
| Operating Current                        | I <sub>DD</sub>     | V <sub>DD</sub>                             | V <sub>DD</sub> =5.5V, f <sub>XIN</sub> =12MHz | -                   | 7    | 15                  | mA   |  |
| Sleep Mode Current                       | I <sub>SLEEP</sub>  | V <sub>DD</sub>                             | V <sub>DD</sub> =5.5V, f <sub>XIN</sub> =12MHz | -                   | 2    | 4.5                 | mA   |  |
| RCWDT Mode Cur-<br>rent at STOP Mode     | I <sub>RCWDT</sub>  | V <sub>DD</sub>                             | V <sub>DD</sub> =5.5V, f <sub>XIN</sub> =12MHz | -                   | 20   | 55                  | μA   |  |
| Stop Mode Current                        | I <sub>STOP</sub>   | V <sub>DD</sub>                             | V <sub>DD</sub> =5.5V, f <sub>XIN</sub> =12MHz | -                   | 1    | 5                   | μA   |  |
| Internal Oscillation<br>Frequency        | fin_clk             | X <sub>OUT</sub>                            | V <sub>DD</sub> =5V, 25°C                      | 3.5                 | 4    | 4.5                 | MHz  |  |
| RESET Input Noise<br>Cancel Time         | T <sub>RST_NC</sub> | RESET                                       | V <sub>DD</sub> =5V                            | 1.5                 |      | 1.8                 | μS   |  |
| External RC                              | f <sub>RC-OSC</sub> | f <sub>XOUT</sub> = f <sub>RC-OSC</sub> ÷ 4 | V <sub>DD</sub> =5.5V<br>R=30kΩ, C=10pF        | 0.5                 | 1.5  | 2.5                 | MHz  |  |
| Oscillator Frequency                     | f <sub>R-OSC</sub>  | $f_{XOUT} = f_{R-OSC} \div 4$               | V <sub>DD</sub> =5.5V, R=30kΩ                  | 1                   | 2    | 3                   | MHz  |  |

Hysteresis Input: INT0(R11),INT1(R12), EC0(R04)
 These parameters are presented for design guidance only and not tested or guaranteed.



#### 7.5 AC Characteristics

 $(T_A = -40 \sim 85^{\circ}C, V_{DD} = 5V \pm 10\%, V_{SS} = 0V)$ 

| Parameter                              | Symbol                             | Dine                               | :    | 11   |      |                  |
|----------------------------------------|------------------------------------|------------------------------------|------|------|------|------------------|
|                                        |                                    | Pins                               | Min. | Тур. | Max. | Unit             |
| Operating Frequency                    | f <sub>XIN</sub>                   | X <sub>IN</sub>                    | 1    | -    | 12   | MHz              |
| System Clock Cycle<br>Time             | tsys                               | -                                  | 166  | -    | 5000 | nS               |
| Oscillation Stabilizing<br>Time (4MHz) | t <sub>ST</sub>                    | X <sub>IN</sub> , X <sub>OUT</sub> | -    | -    | 20   | mS               |
| External Clock Pulse<br>Width          | t <sub>CPW</sub>                   | X <sub>IN</sub>                    | 35   | -    | -    | nS               |
| External Clock Transi-<br>tion Time    | t <sub>RCP</sub> ,t <sub>FCP</sub> | X <sub>IN</sub>                    | -    | -    | 20   | nS               |
| Interrupt Pulse Width                  | t <sub>IW</sub>                    | INTO, INT1                         | 2    | -    | -    | t <sub>SYS</sub> |
| RESET Input Width                      | t <sub>RST</sub>                   | RESET                              | 8    | -    | -    | t <sub>SYS</sub> |
| Event Counter Input<br>Pulse Width     | t <sub>ECW</sub>                   | EC0                                | 2    | -    | -    | tsys             |
| Event Counter Transi-<br>tion Time     | t <sub>REC</sub> ,t <sub>FEC</sub> | EC0                                | -    | -    | 20   | nS               |



Figure 7-1 Timing Chart

**\BO** 

#### 7.6 Typical Characteristics

These graphs and tables provided in this section are for design guidance only and are not tested or guaranteed.

In some graphs or tables the data presented are outside specified operating range (e.g. outside specified  $V_{DD}$  range). This is for information only and devices are guaranteed to operate properly only within the specified range.



The data presented in this section is a statistical summary of data collected on units from different lots over a period of time. "Typical" represents the mean of the distribution while "max" or "min" represents (mean +  $3\sigma$ ) and (mean -  $3\sigma$ ) respectively where  $\sigma$  is standard deviation

























**Note:** The external RC oscillation frequencies shown in above are provided for design guidance only and not tested or guaranteed. The user needs to take into account that the external RC oscillation frequencies generated by the same circuit design may be not the same. Because there are variations in the resistance and capacitance due to the tolerance of external R and C components. The parasitic capacitance difference due to the different wiring length and layout may change the external RC oscillation frequencies.



**Note:** There may be the difference between package types(PDIP, SOP, TSSOP). The user should modify the value of R and C components to get the proper frequency in exchanging MC80F0104/0204 to MC80F0504/0604 or one package type to another package type.





**Note:** The internal 4MHz oscillation frequencies shown in above are provided for design guidance only and not tested or guaranteed. The user needs to take into account that the internal oscillation of the MC80F0504 or MC80F0604 may show different frequency with sample by sample, voltage and temperature. The internal oscillation can be used only in timing insensitive application.



#### **8.MEMORY ORGANIZATION**

The MC80F1504/1604 has separate address spaces for Program memory and Data Memory. 4K bytes program memory can only be read, not written to.

#### 8.1 Registers

This device has six registers that are the Program Counter (PC), a Accumulator (A), two index registers (X, Y), the Stack Pointer (SP), and the Program Status Word (PSW). The Program Counter consists of 16-bit register.



**Figure 8-1 Configuration of Registers** 

Accumulator: The Accumulator is the 8-bit general purpose register, used for data operation such as transfer, temporary saving, and conditional judgement, etc.

The Accumulator can be used as a 16-bit register with Y Register as shown below.



#### Figure 8-2 Configuration of YA 16-bit Register

**X, Y Registers**: In the addressing mode which uses these index registers, the register contents are added to the specified address, which becomes the actual address. These modes are extremely effective for referencing subroutine tables and memory tables. The index registers also have increment, decrement, comparison and data transfer functions, and they can be used as simple accumulators.

**Stack Pointer**: The Stack Pointer is an 8-bit register used for occurrence interrupts and calling out subroutines. Stack Pointer identifies the location in the stack to be accessed (save or restore).

Generally, SP is automatically updated when a subroutine

Data memory can be read and written to up to 256 bytes including the stack area.

call is executed or an interrupt is accepted. However, if it is used in excess of the stack area permitted by the data memory allocating configuration, the user-processed data may be lost.

The stack can be located at any position within  $1C0_H$  to  $1FF_H$  of the internal data memory. The SP is not initialized by hardware, requiring to write the initial value (the location with which the use of the stack starts) by using the initialization routine. Normally, the initial value of "FF<sub>H</sub>" is used.



**Note:** The Stack Pointer must be initialized by software because its value is undefined after Reset.

Example: To initialize the SP LDX #0FFH TXSP ; SP ← FFH

**Program Counter**: The Program Counter is a 16-bit wide which consists of two 8-bit registers, PCH and PCL. This counter indicates the address of the next instruction to be executed. In reset state, the program counter has reset routine address ( $PC_H:OFF_H$ ,  $PC_L:OFE_H$ ).

**Program Status Word**: The Program Status Word (PSW) contains several bits that reflect the current state of the CPU. The PSW is described in Figure 8-3. It contains the Negative flag, the Overflow flag, the Break flag the Half Carry (for BCD operation), the Interrupt enable flag, the Zero flag, and the Carry flag.

[Carry flag C]

This flag stores any carry or borrow from the ALU of CPU after an arithmetic operation and is also changed by the Shift Instruction or Rotate Instruction.

#### [Zero flag Z]

This flag is set when the result of an arithmetic operation or data transfer is "0" and is cleared by any other result.



Figure 8-3 PSW (Program Status Word) Register

[Interrupt disable flag I]

This flag enables/disables all interrupts except interrupt caused by Reset or software BRK instruction. All interrupts are disabled when cleared to "0". This flag immediately becomes "0" when an interrupt is served. It is set by the EI instruction and cleared by the DI instruction.

#### [Half carry flag H]

After operation, this is set when there is a carry from bit 3 of ALU or there is no borrow from bit 4 of ALU. This bit can not be set or cleared except CLRV instruction with Overflow flag (V).

#### [Break flag B]

This flag is set by software BRK instruction to distinguish BRK from TCALL instruction with the same vector address.

[Direct page flag G]

This flag assigns RAM page for direct addressing mode. In the direct addressing mode, addressing area is from zero page  $00_H$  to  $0FF_H$  when this flag is "0". If it is set to "1", addressing area is assigned  $100_H$  to  $1FF_H$ . It is set by SETG instruction and cleared by CLRG.

#### [Overflow flag V]

This flag is set to "1" when an overflow occurs as the result of an arithmetic operation involving signs. An overflow occurs when the result of an addition or subtraction exceeds  $+127(7F_H)$  or  $-128(80_H)$ . The CLRV instruction clears the overflow flag. There is no set instruction. When the BIT instruction is executed, bit 6 of memory is copied to this flag.

#### [Negative flag N]

This flag is set to match the sign bit (bit 7) status of the result of a data or arithmetic operation. When the BIT instruction is executed, bit 7 of memory is copied to this flag.





Figure 8-4 Stack Operation

#### 8.2 Program Memory

A 16-bit program counter is capable of addressing up to 64K bytes, but this device has 4K bytes program memory space only physically implemented. Accessing a location above  $FFFF_H$  will cause a wrap-around to  $0000_H$ .

Figure 8-5, shows a map of Program Memory. After reset, the CPU begins execution from reset vector which is stored in address  $FFFE_H$  and  $FFFF_H$  as shown in Figure 8-6.

As shown in Figure 8-5, each area is assigned a fixed location in Program Memory. Program Memory area contains the user program



Figure 8-5 Program Memory Map



Page Call (PCALL) area contains subroutine program to reduce program byte length by using 2 bytes PCALL instead of 3 bytes CALL instruction. If it is frequently called, it is more useful to save program byte length.

Table Call (TCALL) causes the CPU to jump to each TCALL address, where it commences the execution of the service routine. The Table Call service area spaces 2-byte for every TCALL:  $0FFC0_H$  for TCALL15,  $0FFC2_H$  for TCALL14, etc., as shown in Figure 8-7.

Example: Usage of TCALL



The interrupt causes the CPU to jump to specific location, where it commences the execution of the service routine. The External interrupt 0, for example, is assigned to location  $0FFFC_H$ . The interrupt service locations spaces 2-byte interval:  $0FFFA_H$  and  $0FFFB_H$  for External Interrupt 1,  $0FFFC_H$  and  $0FFFD_H$  for External Interrupt 0, etc.

Any area from  $0FF00_H$  to  $0FFFF_H$ , if it is not going to be used, its service location is available as general purpose Program Memory.



Figure 8-6 Interrupt Vector Area





#### Figure 8-7 PCALL and TCALL Memory Area

#### $\textbf{PCALL} \rightarrow \textbf{rel}$

4F35 PCALL 35H



#### $\textbf{TCALL} \rightarrow \textbf{n}$

4A TCALL 4





| -                                                                                                   | •                                                                                                                                                                                    | -                                                                                                                                                                                                                             |                                              |
|-----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|
| ; Interrupt Ve<br>ORG<br>DW<br>DW<br>DW<br>DW<br>DW<br>DW<br>DW<br>DW<br>DW<br>DW<br>DW<br>DW<br>DW | OFFEOH<br>BIT_TIMER<br>WDT<br>ADC<br>Noticed<br>Noticed<br>TIMER2<br>TIMER1<br>TIMER0<br>Noticed<br>Noticed<br>Noticed<br>Noticed<br>INT3<br>INT2<br>INT1<br>INT0<br>RESET<br>OF000H | <pre>; BIT<br/>; WDT<br/>; AD Converter<br/>;<br/>; Timer-2<br/>; Timer-1<br/>; Timer-0<br/>;<br/>;<br/>; Ext. Int.3<br/>; Ext. Int.3<br/>; Ext. Int.2<br/>; Ext. Int.1<br/>; Ext. Int.0<br/>; Reset<br/>; 4K bytes ROM</pre> | 1 Start address                              |
| ;*********                                                                                          | ********                                                                                                                                                                             | ****                                                                                                                                                                                                                          |                                              |
|                                                                                                     |                                                                                                                                                                                      | GRAM                                                                                                                                                                                                                          | *                                            |
| ;*********                                                                                          | *******                                                                                                                                                                              | ****                                                                                                                                                                                                                          | * * * *                                      |
| RESET:                                                                                              | DI                                                                                                                                                                                   | ;Disable All I                                                                                                                                                                                                                | interrupt                                    |
| ;RAM Clear Ro                                                                                       | utine                                                                                                                                                                                |                                                                                                                                                                                                                               |                                              |
|                                                                                                     | LDX                                                                                                                                                                                  | # O                                                                                                                                                                                                                           |                                              |
| RAM Clear0:                                                                                         |                                                                                                                                                                                      |                                                                                                                                                                                                                               |                                              |
| -                                                                                                   | LDA                                                                                                                                                                                  | # O                                                                                                                                                                                                                           | ;Page0 RAM Clear(0000h ~ 00BFh)              |
|                                                                                                     | STA                                                                                                                                                                                  | { X } +                                                                                                                                                                                                                       |                                              |
|                                                                                                     | CMPX                                                                                                                                                                                 | #0C0h                                                                                                                                                                                                                         |                                              |
|                                                                                                     | BNE                                                                                                                                                                                  |                                                                                                                                                                                                                               | RAM Clear0                                   |
|                                                                                                     |                                                                                                                                                                                      |                                                                                                                                                                                                                               | _                                            |
|                                                                                                     | LDM                                                                                                                                                                                  | RPR,#1                                                                                                                                                                                                                        | ;Page Select                                 |
|                                                                                                     | SETG                                                                                                                                                                                 |                                                                                                                                                                                                                               |                                              |
|                                                                                                     |                                                                                                                                                                                      |                                                                                                                                                                                                                               |                                              |
|                                                                                                     | LDX                                                                                                                                                                                  | #0C0h                                                                                                                                                                                                                         |                                              |
| RAM_Clear1:                                                                                         |                                                                                                                                                                                      |                                                                                                                                                                                                                               |                                              |
| _                                                                                                   | LDA                                                                                                                                                                                  | # O                                                                                                                                                                                                                           |                                              |
|                                                                                                     | STA                                                                                                                                                                                  | { X } +                                                                                                                                                                                                                       |                                              |
|                                                                                                     | CMPX                                                                                                                                                                                 | #00h                                                                                                                                                                                                                          |                                              |
|                                                                                                     | BNE                                                                                                                                                                                  | RAM_Clear1                                                                                                                                                                                                                    |                                              |
|                                                                                                     |                                                                                                                                                                                      |                                                                                                                                                                                                                               |                                              |
| RAM_Clear_Fin                                                                                       |                                                                                                                                                                                      |                                                                                                                                                                                                                               |                                              |
|                                                                                                     | CLRG                                                                                                                                                                                 | ;Page0 Select                                                                                                                                                                                                                 |                                              |
|                                                                                                     | LDX                                                                                                                                                                                  | #OFFh ;In                                                                                                                                                                                                                     | itial Stack Pointer                          |
|                                                                                                     | TXSP                                                                                                                                                                                 |                                                                                                                                                                                                                               |                                              |
|                                                                                                     | :                                                                                                                                                                                    |                                                                                                                                                                                                                               |                                              |
|                                                                                                     | -                                                                                                                                                                                    |                                                                                                                                                                                                                               |                                              |
| ;Initialize I                                                                                       | :                                                                                                                                                                                    |                                                                                                                                                                                                                               |                                              |
|                                                                                                     |                                                                                                                                                                                      |                                                                                                                                                                                                                               |                                              |
|                                                                                                     | O<br>LDM                                                                                                                                                                             | R0, #0                                                                                                                                                                                                                        | ;Normal Port R0                              |
|                                                                                                     | O<br>LDM<br>LDM                                                                                                                                                                      | RO, #0<br>ROIO,#0FFH                                                                                                                                                                                                          | ;Normal Port R0<br>;Normal Port R0 Direction |
|                                                                                                     | O<br>LDM                                                                                                                                                                             |                                                                                                                                                                                                                               |                                              |
|                                                                                                     | O<br>LDM<br>LDM                                                                                                                                                                      |                                                                                                                                                                                                                               |                                              |

for MC80F1604.

Example: The usage software example of Vector address

### 8.3 Data Memory

Figure 8-8 shows the internal Data Memory space availa-

ble. Data Memory is divided into three groups, a user





#### RAM, control registers, and Stack memory.

Figure 8-8 Data Memory Map

#### **User Memory**

The MC80F1504/1604 has  $256 \times 8$  bits user memory (RAM). RAM pages are selected by RPR (See Figure 8-9).

**Note:** After setting RPR(RAM Page Select Register), be sure to execute SETG instruction. Whenever CLRG instruction is excuted, PAGE0 is selected regardless of RPR.

#### **Control Registers**

The control registers are used by the CPU and Peripheral function blocks for controlling the desired operation of the device. Therefore these registers contain control and status bits for the interrupt system, the timer/ counters, analog to digital converters and I/O ports. The control registers are in address range of  $0C0_H$  to  $0FF_H$ .

Note that unoccupied addresses may not be implemented on the chip. Read accesses to these addresses will in general return random data, and write accesses will have an indeterminate effect.

More detailed informations of each registers are explained in each peripheral section.

**Note:** Write only registers can not be accessed by bit manipulation instruction. Do not use read-modify-write instruction. Use byte manipulation instruction, for example "LDM".

Example; To write at CKCTLR

LDM CKCTLR, #0AH ; Divide ratio(÷32)

#### Stack Area

The stack provides the area where the return address is saved before a jump is performed during the processing routine at the execution of a subroutine call instruction or the acceptance of an interrupt.

When returning from the processing routine, executing the subroutine return instruction [RET] restores the contents of the program counter from the stack; executing the interrupt return instruction [RETI] restores the contents of the program counter and flags.

The save/restore locations in the stack are determined by the stack pointed (SP). The SP is automatically decreased after the saving, and increased before the restoring. This means the value of the SP indicates the stack location number for the next save. Refer to Figure 8-4.



Figure 8-9 RPR(RAM Page Select Register)

# MC80F1504/1604



| Address         Register Name         Symbol         RVM         7         6         5         4         3         2         1         0         Mode           00C0         R0 port data register         R0         R/W         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |         | <b>-</b>                             |        |     |   |           | Init | ial | Va | lue       | ) |               | Addressing             |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--------------------------------------|--------|-----|---|-----------|------|-----|----|-----------|---|---------------|------------------------|--|--|
| OOC1         R0 port I/O direction register         R0IO         W         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Address | Register Name                        | Symbol | R/W | 7 | 6         | 5    | 4   | 3  | 2         | 1 | 0             |                        |  |  |
| OOC2       R1 port data register       R1       R/W       -       -       0       0       0       0       byte, bit         OOC3       R1 port I/O direction register       R110       W       -       -       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 00C0    | R0 port data register                | R0     | R/W | 0 | 0         | 0    | 0   | 0  | 0         | 0 | 0             | byte, bit <sup>1</sup> |  |  |
| 00C3       R1 port I/O direction register       R110       W       -       -       0       0       0       0       byte         00C6       R3 port data register       R3       R/W       -       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 00C1    | R0 port I/O direction register       | R0IO   | W   | 0 | 0         | 0    | 0   | 0  | 0         | 0 | 0             | byte <sup>2</sup>      |  |  |
| OOC6       R3 port data register       R3       RW       -       -       0       0       -       byte, bit         OOC7       R3 port I/O direction register       R3IO       W       -       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 00C2    | R1 port data register                | R1     | R/W | - | -         | -    | 0   | 0  | 0         | 0 | 0             | byte, bit              |  |  |
| OOC7         R3 port I/O direction register         R30         W         -         -         0         -         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 00C3    | R1 port I/O direction register       | R1IO   | W   | - | -         | -    | 0   | 0  | 0         | 0 | 0             | byte                   |  |  |
| 00C8         Port 0 Open Drain Selection Register         ROOD         W         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 00C6    | R3 port data register                | R3     | R/W | - | -         | 0    | -   | -  | 0         | 0 | -             | byte, bit              |  |  |
| 00C9         Port 1 Open Drain Selection Register         R10D         W         -         -         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 00C7    | R3 port I/O direction register       | R3IO   | W   | - | -         | 0    | -   | -  | 0         | 0 | -             | byte                   |  |  |
| OOCB         Port 3 Open Drain Selection Register         R3OD         W         -         -         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 00C8    | Port 0 Open Drain Selection Register | R0OD   | W   | 0 | 0         | 0    | 0   | 0  | 0         | 0 | 0             | byte                   |  |  |
| 00D0         Timer 0 mode control register         TM0         R/W         -         -         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 00C9    | Port 1 Open Drain Selection Register | R10D   | W   | - | -         | -    | 0   | 0  | 0         | 0 | 0             | byte                   |  |  |
| Timer 0 register       T0       R       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 00CB    | Port 3 Open Drain Selection Register | R3OD   | W   | - | -         | -    | -   | -  | 0         | 0 | -             | byte                   |  |  |
| OOD1         Timer O data register         TDR0         W         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 00D0    | Timer 0 mode control register        | TM0    | R/W | - | -         | 0    | 0   | 0  | 0         | 0 | 0             | byte, bit              |  |  |
| Timer 0 capture data register         CDR0         R         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |         | Timer 0 register                     | Т0     | R   | 0 | 0         | 0    | 0   | 0  | 0         | 0 | 0             |                        |  |  |
| 00D2         Time 1 mode control register         TM1         R/W         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 00D1    | Timer 0 data register                | TDR0   | W   | 1 | 1         | 1    | 1   | 1  | 1         | 1 | 1             | byte                   |  |  |
| Timer 1 data register         TDR1         W         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1 <th1< th="">         1         1         1</th1<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         | Timer 0 capture data register        | CDR0   | R   | 0 | 0         | 0    | 0   | 0  | 0         | 0 | 0             |                        |  |  |
| 00D3         Timer 1 PWM period register         T1 PPR         W         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1 <th1< th=""> <th1< th=""> <th1< th="">         &lt;</th1<></th1<></th1<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 00D2    | Timer 1 mode control register        | TM1    | R/W | 0 | 0         | 0    | 0   | 0  | 0         | 0 | 0             | byte, bit              |  |  |
| Timer 1 PWM period register         T1 PPR         W         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0000    | Timer 1 data register                | TDR1   | W   | 1 | 1         | 1    | 1   | 1  | 1         | 1 | 1 byte        |                        |  |  |
| 00D4         Timer 1 capture data register         CDR1         R         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 00D3    | Timer 1 PWM period register          | T1PPR  | W   | 1 | 1         | 1    | 1   | 1  | 1         | 1 | 1             | byte                   |  |  |
| 00D4         Timer 1 capture data register         CDR1         R         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |         | Timer 1 register                     | T1     | R   | 0 | 0         | 0    | 0   | 0  | 0         | 0 | 0             |                        |  |  |
| 00D5         Timer 1 PWM high register         T1PWHR         W         -         -         -         0         0         0         0         byte           00D6         Timer 1 PWM high register         TM2         R/W         -         -         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 00D4    | Timer 1 capture data register        | CDR1   | R   | 0 | 0         | 0    | 0   | 0  | 0         | 0 | 0             | byte                   |  |  |
| OOD6         Timer 2 mode control register         TM2         R/W         -         -         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         | Timer 1 PWM duty register            | T1PDR  | R/W | 0 | 0         | 0    | 0   | 0  | 0         | 0 | 0             | byte                   |  |  |
| Timer 2 register         T2         R         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 00D5    | Timer 1 PWM high register            | T1PWHR | W   | - | -         | -    | -   | 0  | 0         | 0 | 0             | byte                   |  |  |
| 00D7       Timer 2 data register       TDR2       W       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1 <th1< td=""><td>00D6</td><td>Timer 2 mode control register</td><td>TM2</td><td>R/W</td><td>-</td><td>-</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>byte, bit</td></th1<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 00D6    | Timer 2 mode control register        | TM2    | R/W | - | -         | 0    | 0   | 0  | 0         | 0 | 0             | byte, bit              |  |  |
| Timer 2 capture data registerCDR2R00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 <th< td=""><td></td><td>Timer 2 register</td><td>T2</td><td>R</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td></td></th<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         | Timer 2 register                     | T2     | R   | 0 | 0         | 0    | 0   | 0  | 0         | 0 | 0             |                        |  |  |
| ODEOBuzzer driver registerBUZRW11111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111 </td <td>00D7</td> <td>Timer 2 data register</td> <td>TDR2</td> <td>W</td> <td>1</td> <td>1</td> <td>1</td> <td>1</td> <td>1</td> <td>1</td> <td>1</td> <td>1</td> <td>byte</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 00D7    | Timer 2 data register                | TDR2   | W   | 1 | 1         | 1    | 1   | 1  | 1         | 1 | 1             | byte                   |  |  |
| O0E1RAM page selection registerRPRR/W0000byte, bit00E2SIO mode control registerSIOMR/W000000000001byte, bit00E3SIO data shift registerSIORR/WR/W0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 <td< td=""><td></td><td>Timer 2 capture data register</td><td>CDR2</td><td>R</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td></td></td<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |         | Timer 2 capture data register        | CDR2   | R   | 0 | 0         | 0    | 0   | 0  | 0         | 0 | 0             |                        |  |  |
| O0E2SIO mode control registerSIOMR/W00000001byte, bit00E3SIO data shift registerSIORR/WVUNUETINUEbyte, bitbyte, bit00EAInterrupt enable register highIENHR/W00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 00E0    | Buzzer driver register               | BUZR   | W   | 1 | 1         | 1    | 1   | 1  | 1         | 1 | 1             | byte                   |  |  |
| O0E3SIO data shift registerSIORR/WUnderstandDote to the total stress of total | 00E1    | RAM page selection register          | RPR    | R/W | - | -         | -    | -   | -  | 0         | 0 | 0             | byte, bit              |  |  |
| O0EAInterrupt enable register highIENHR/W00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 <th0< th="">0<td>00E2</td><td>SIO mode control register</td><td>SIOM</td><td>R/W</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>1</td><td colspan="3">1 byte, bit</td></th0<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 00E2    | SIO mode control register            | SIOM   | R/W | 0 | 0         | 0    | 0   | 0  | 0         | 0 | 1             | 1 byte, bit            |  |  |
| OOEBInterrupt enable register lowIENLR/W0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 <td>00E3</td> <td>SIO data shift register</td> <td>SIOR</td> <td>R/W</td> <td></td> <td colspan="4">Undefined</td> <td>byte, bit</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 00E3    | SIO data shift register              | SIOR   | R/W |   | Undefined |      |     |    | byte, bit |   |               |                        |  |  |
| OOECInterrupt request register highIRQHR/W00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 <th0< th="">0<!--</td--><td>00EA</td><td>Interrupt enable register high</td><td>IENH</td><td>R/W</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td>0</td><td colspan="3">0 0 byte, bit</td></th0<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 00EA    | Interrupt enable register high       | IENH   | R/W | 0 | 0         | 0    | 0   | 0  | 0         | 0 | 0 0 byte, bit |                        |  |  |
| OOEDInterrupt request register lowIRQLR/W0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 </td <td>00EB</td> <td>Interrupt enable register low</td> <td>IENL</td> <td>R/W</td> <td>0</td> <td>0</td> <td>0</td> <td>0</td> <td>0</td> <td>0</td> <td>0</td> <td>0</td> <td colspan="3">byte, bit</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 00EB    | Interrupt enable register low        | IENL   | R/W | 0 | 0         | 0    | 0   | 0  | 0         | 0 | 0             | byte, bit              |  |  |
| 00EE       Interrupt edge selection register       IEDS       R/W       0       0       0       0       0       0       0       0       byte, bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 00EC    | Interrupt request register high      | IRQH   | R/W | 0 | 0         | 0    | 0   | 0  | 0         | 0 | 0             | byte, bit              |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 00ED    | Interrupt request register low       | IRQL   | R/W | 0 | 0         | 0    | 0   | 0  | 0         | 0 | 0             | byte, bit              |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 00EE    | Interrupt edge selection register    | IEDS   | R/W | 0 | 0         | 0    | 0   | 0  | 0         | 0 | 0             | 0 byte, bit            |  |  |
| 00EF         A/D converter mode control register         ADCM         R/W         0         0         0         0         0         1         byte, bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 00EF    | A/D converter mode control register  | ADCM   | R/W | 0 | 0         | 0    | 0   | 0  | 0         | 0 | 0 1 byte, bit |                        |  |  |



| Address | Pogister Name                      | Symbol                                     | R/W                      | Initial Value         |      |   |      |      |      |                 | Addressing |           |
|---------|------------------------------------|--------------------------------------------|--------------------------|-----------------------|------|---|------|------|------|-----------------|------------|-----------|
| Audress | Register Name                      | Symbol                                     | N/ ¥¥                    | 7                     | 6    | 5 | 4    | 3    | 2    | 1               | 0          | Mode      |
| 00F0    | A/D converter result high register | ADCRH                                      | R(W)                     | 0                     | 1    | 0 | I    | Jno  | lefi | nec             | k          | byte      |
| 00F1    | A/D converter result low register  | ADCRL                                      | R                        |                       |      | U | nde  | fine | əd   |                 |            | byte      |
| 00F2    | Basic interval timer register      | BITR                                       | R                        |                       |      | U | nde  | fine | əd   |                 |            | byte      |
| 0012    | Clock control register             | CKCTLR                                     | W                        | 0                     | -    | 0 | 1    | 0    | 1    | 1               | 1          | byte      |
| 00F4    | Watch dog timer register           | WDTR                                       | W                        | 0                     | 1    | 1 | 1    | 1    | 1    | 1               | 1          | byte      |
| 0014    | Watch dog timer data register      | WDTDR                                      | R                        | Undefined             |      |   |      |      | 5,10 |                 |            |           |
| 00F5    | Stop & sleep mode control register | SSCR                                       | W                        | 0 0 0 0 0 0 0 0 0 byt |      |   | byte |      |      |                 |            |           |
| 00F7    | PFD control register               | PFDR                                       | R/W                      | -                     | -    | - | -    | -    | 0    | 0 0 0 byte, bit |            | byte, bit |
| 00F8    | Port selection register 0          | PSR0                                       | W - 0 0 0 0 0 0 0 0 byte |                       | byte |   |      |      |      |                 |            |           |
| 00F9    | Port selection register 1          | PSR1                                       | W                        | -                     | -    | - | -    | 0    | 0    | 0               | 0          | byte      |
| 00FC    | Pull-up selection register 0       | PU0                                        | W                        | 0                     | 0    | 0 | 0    | 0    | 0    | 0               | 0          | byte      |
| 00FD    | Pull-up selection register 1       | II-up selection register 1 PU1 W 0 0 0 0 0 |                          | byte                  |      |   |      |      |      |                 |            |           |
| 00FF    | Pull-up selection register 3       | PU3                                        | W                        | -                     | -    | 0 | -    | -    | 0    | 0               | -          | byte      |

1. The 'byte, bit' means registers are controlled by both bit and byte manipulation instruction. Caution) The R/W register except T1PDR can be byte and bit manipulated.

2. The 'byte' means registers are controlled by only byte manipulation instruction. Do not use bit manipulation instruction such as SET1, CLR1 etc. If bit manipulation instruction is used on these registers, content of other seven bits are may varied to unwanted value.

\*The mark of '-' means this bit location is reserved.

# MC80F1504/1604



| Address | Name                | Bit 7        | Bit 6                                                                    | Bit 5        | Bit 4          | Bit 3        | Bit 2      | Bit 1        | Bit 0 |  |  |
|---------|---------------------|--------------|--------------------------------------------------------------------------|--------------|----------------|--------------|------------|--------------|-------|--|--|
| 0C0H    | R0                  | R0 Port Da   | R0 Port Data Register                                                    |              |                |              |            |              |       |  |  |
| 0C1H    | R0IO                |              | R0 Port Direction Register                                               |              |                |              |            |              |       |  |  |
| 0C2H    | R1                  | R1 Port Da   | ta Register                                                              |              |                |              |            |              |       |  |  |
| 0C3H    | R1IO                | R1 Port Dir  | ection Regist                                                            | ter          |                |              |            |              |       |  |  |
| 0C6H    | R3                  | R3 Port Da   | ta Register                                                              |              |                |              |            |              |       |  |  |
| 0C7H    | R3IO                | R3 Port Dir  | ection Regist                                                            | ter          |                |              |            |              |       |  |  |
| 0C8H    | R0OD                | R0 Open D    | rain Selectio                                                            | n Register   |                |              |            |              |       |  |  |
| 0C9H    | R10D                | R1 Open D    | rain Selectio                                                            | n Register   |                |              |            |              |       |  |  |
| 0CBH    | R3OD                | R3 Open D    | rain Selectio                                                            | n Register   |                |              |            |              |       |  |  |
| 0D0H    | TM0                 | -            | -                                                                        | CAP0         | T0CK2          | T0CK1        | T0CK0      | TOCN         | TOST  |  |  |
| 0D1H    | T0/TDR0/<br>CDR0    | Timer0 Reg   | jister / Timer                                                           | 0 Data Regis | ster / Timer0  | Capture Data | a Register |              |       |  |  |
| 0D2H    | TM1                 | POL          | 16BIT                                                                    | PWM1E        | CAP1           | T1CK1        | T1CK0      | T1CN         | T1ST  |  |  |
| 0D3H    | TDR1/<br>T1PPR      | Timer1 Dat   | a Register / T                                                           | Fimer1 PWM   | Period Regi    | ster         |            |              |       |  |  |
| 0D4H    | T1/CDR1/<br>T1PDR   | Timer1 Reg   | Timer1 Register / Timer1 Capture Data Register /Timer1 PWM Duty Register |              |                |              |            |              |       |  |  |
| 0D5H    | PWM1HR              | -            | -                                                                        | -            | -              | Т            | imer1 PWM  | High Registe | er    |  |  |
| 0D6H    | TM2                 | -            | -                                                                        | CAP2         | T2CK2          | T2CK1        | T2CK0      | T2CN         | T2ST  |  |  |
| 0D7H    | T2/TDR2/<br>CDR2    | Timer2 Reg   | jister / Timer                                                           | 2 Data Regis | ster / Timer2  | Capture Data | a Register |              |       |  |  |
| 0E0H    | BUZR                | BUCK1        | BUCK0                                                                    | BUR5         | BUR4           | BUR3         | BUR2       | BUR1         | BUR0  |  |  |
| 0E1H    | RPR                 | -            | -                                                                        | -            | -              | -            | RPR2       | RPR1         | RPR0  |  |  |
| 0E2H    | SIOM                | POL          | IOSW                                                                     | SM1          | SM0            | SCK1         | SCK0       | SIOST        | SIOSF |  |  |
| 0E3H    | SIOR                | SIO Data S   | hift Register                                                            |              |                |              |            |              |       |  |  |
| 0EAH    | IENH                | INT0E        | INT1E                                                                    | INT2E        | INT3E          | -            | -          | SIOE         | T0E   |  |  |
| 0EBH    | IENL                | T1E          | T2E                                                                      | -            | -              | ADCE         | WDTE       | -            | BITE  |  |  |
| 0ECH    | IRQH                | INT0IF       | INT1IF                                                                   | INT2IF       | INT3IF         | -            | -          | SIOIF        | T0IF  |  |  |
| 0EDH    | IRQL                | T1IF         | T2IF                                                                     | -            | -              | ADCIF        | WDTIF      | -            | BITIF |  |  |
| 0EEH    | IEDS                | IED3H        | IED3L                                                                    | IED2H        | IED2L          | IED1H        | IED1L      | IED0H        | IED0L |  |  |
| 0EFH    | ADCM                | ADEN         | ADCK                                                                     | ADS3         | ADS2           | ADS1         | ADS0       | ADST         | ADSF  |  |  |
| 0F0H    | ADCRH               | PSSEL1       | PSSEL1 PSSEL0 ADC8 ADC Result Reg. High                                  |              |                |              |            |              |       |  |  |
| 0F1H    | ADCRL               | ADC Resul    | ADC Result Register Low                                                  |              |                |              |            |              |       |  |  |
| 05011   | BITR <sup>1</sup>   | Basic Interv | al Timer Dat                                                             | a Register   |                |              |            |              |       |  |  |
| 0F2H    | CKCTLR <sup>1</sup> | ADRST        | ADRST - RCWDT WDTON BTCL BTS2 BTS1 BTS0                                  |              |                |              |            |              |       |  |  |
| 05411   | WDTR                | WDTCL        | 7-bit Watch                                                              | dog Timer R  | egister        |              |            |              |       |  |  |
| 0F4H    | WDTDR               | Watchdog -   | Fimer Data R                                                             | egister (Cou | inter Register | r)           |            |              |       |  |  |

**Table 8-1 Control Register Function Description** 



| Address | Name | Bit 7       | Bit 6                              | Bit 5 | Bit 4 | Bit 3  | Bit 2 | Bit 1 | Bit 0 |  |  |
|---------|------|-------------|------------------------------------|-------|-------|--------|-------|-------|-------|--|--|
| 0F5H    | SSCR | Stop & Slee | Stop & Sleep Mode Control Register |       |       |        |       |       |       |  |  |
| 0F7H    | PFDR | -           | -                                  | -     | -     | -      | PFDEN | PFDM  | PFDS  |  |  |
| 0F8H    | PSR0 | -           | PWM10E                             | EC1E  | EC0E  | INT3E  | INT2E | INT1E | INT0E |  |  |
| 0F9H    | PSR1 | -           | -                                  | -     | -     | AVREFS | BUZO  | T2O   | T0O   |  |  |
| 0FCH    | PU0  | R0 Pull-up  | R0 Pull-up Selection Register      |       |       |        |       |       |       |  |  |
| 0FDH    | PU1  | R1 Pull-up  | R1 Pull-up Selection Register      |       |       |        |       |       |       |  |  |
| 0FFH    | PU3  | R3 Pull-up  | R3 Pull-up Selection Register      |       |       |        |       |       |       |  |  |

#### **Table 8-1 Control Register Function Description**

1. The register BITR and CKCTLR are located at same address. Address ECH is read as BITR, written to CKCTLR.

Caution) The registers of dark-shaded area can not be accessed by bit manipulation instruction such as "SET1, CLR1", but should be accessed by register operation instruction such as "LDM dp,#imm".

## 8.4 Addressing Mode

The MC80 series MCU uses six addressing modes;

- Register addressing
- Immediate addressing
- Direct page addressing
- Absolute addressing
- Indexed addressing
- · Register-indirect addressing

#### 8.4.1 Register Addressing

Register addressing accesses the A, X, Y, C and PSW.

#### 8.4.2 Immediate Addressing $\rightarrow$ #imm

In this mode, second byte (operand) is accessed as a data immediately.

## Example:

0435 ADC #35H



When G-flag is 1, then RAM address is defined by 16-bit address which is composed of 8-bit RAM paging register (RPR) and 8-bit immediate data.

- Example: G=1
- E45535 LDM 35H,#55H



# 8.4.3 Direct Page Addressing $\rightarrow$ dp

In this mode, a address is specified within direct page. Example; G=0



C535 LDA 35H

;A ←RAM[35H]

```
;A ←ROM[135H]
```



# 8.4.4 Absolute Addressing $\rightarrow$ !abs

Absolute addressing sets corresponding memory data to Data, i.e. second byte (Operand I) of command becomes lower level address and third byte (Operand II) becomes upper level address.

With 3 bytes command, it is possible to access to whole memory area.

ADC, AND, CMP, CMPX, CMPY, EOR, LDA, LDX, LDY, OR, SBC, STA, STX, STY

#### Example;



The operation within data memory (RAM) ASL, BIT, DEC, INC, LSR, ROL, ROR

Example; Addressing accesses the address  $0135_{\rm H}$  regardless of G-flag.



!0135H

#### 8.4.5 Indexed Addressing

## X indexed direct page (no offset) $\rightarrow$ {X}

In this mode, a address is specified by the X register. ADC, AND, CMP, EOR, LDA, OR, SBC, STA, XMA

Example; X=15<sub>H</sub>, G=1

D4

; ACC  $\leftarrow$  RAM[X].



{X}

#### X indexed direct page, auto increment $\rightarrow$ {X}+

In this mode, a address is specified within direct page by the X register and the content of X is increased by 1.

LDA, STA

Example; G=0, X=35<sub>H</sub> DB LDA  $\{X\}+$ 





## X indexed direct page (8 bit offset) $\rightarrow$ dp+X

This address value is the second byte (Operand) of command plus the data of X-register. And it assigns the memory in Direct page.

ADC, AND, CMP, EOR, LDA, LDY, OR, SBC, STA STY, XMA, ASL, DEC, INC, LSR, ROL, ROR

Example; G=0, X=0F5<sub>H</sub>

C645 LDA 45H+X



#### Y indexed direct page (8 bit offset) $\rightarrow$ dp+Y

This address value is the second byte (Operand) of command plus the data of Y-register, which assigns Memory in Direct page.

This is same with above (2). Use Y register instead of X.

## Y indexed absolute $\rightarrow$ !abs+Y

Sets the value of 16-bit absolute address plus Y-register data as Memory. This addressing mode can specify memory in whole area.

Example; Y=55<sub>H</sub> D500FA LDA !OFA00H+Y 0F100H D5 0F101H 00 0F102H FA 0FA00H+55H=0FA55H 2 0FA55H data data  $\rightarrow$  A 3

#### 8.4.6 Indirect Addressing

# Direct page indirect $\rightarrow$ [dp]

Assigns data address to use for accomplishing command which sets memory data (or pair memory) by Operand. Also index can be used with Index register X,Y.

#### JMP, CALL

Example; G=0

3F35 JMP [35H]



#### X indexed indirect $\rightarrow$ [dp+X]

Processes memory data as Data, assigned by 16-bit pair memory which is determined by pair data [dp+X+1][dp+X] Operand plus X-register data in Direct page.

ADC, AND, CMP, EOR, LDA, OR, SBC, STA

Example; G=0, X=10<sub>H</sub>



1625 ADC [25H+X]



# Y indexed indirect $\rightarrow$ [dp]+Y

Processes memory data as Data, assigned by the data [dp+1][dp] of 16-bit pair memory paired by Operand in Direct page plus Y-register data.

ADC, AND, CMP, EOR, LDA, OR, SBC, STA

Example; G=0, Y=10<sub>H</sub>

1725 ADC [25H]+Y



# Absolute indirect $\rightarrow$ [!abs]

The program jumps to address specified by 16-bit absolute address.

JMP

Example; G=0

1F25E0 JMP [!0C025H]





# 9.I/O PORTS

The MC80F1504/1604 has three ports (R0, R1 and R3). These ports pins may be multiplexed with an alternate function for the peripheral features on the device. All port can drive maximum 20mA of high current in output low state, so it can directly drive LED device.

All pins have data direction registers which can define these ports as output or input. A "1" in the port direction register configure the corresponding port pin as output. Conversely, write "0" to the corresponding bit to specify it as input pin. For example, to use the even numbered bit of R0 as output ports and the odd numbered bits as input ports, write "55<sub>H</sub>" to address  $0C1_H$  (R0 port direction register) during initial setting as shown in Figure 9-1.

All the port direction registers in the MC80F1504/1604 have 0 written to them by reset function. On the other hand,

# 9.1 R0 and R0IO register

R0 is an 8-bit CMOS bidirectional I/O port (address  $0C0_H$ ). Each I/O pin can independently used as an input or an output through the R0IO register (address  $0C1_H$ ). When R00 through R07 pins are used as input ports, an on-chip pull-up resistor can be connected to them in 1-bit units



Figure 9-1 Example of port I/O assignment

with a pull-up selection register 0 (PU0). Each I/O pin of R0 port can be used to open drain output port by setting the corresponding bit of the open drain selection register 0 (R0OD).



its initial status is input.



## Figure 9-1 R0 Port Register

In addition, Port R0 is multiplexed with various alternate functions. The port selection register PSR0 (address  $0F8_H$ ) and PSR1 (address  $0F9_H$ ) control the selection of alternate functions such as event counter input 0 (EC0) and timer 0 output (T0O). When the alternate function is selected by writing "1" in the corresponding bit of PSR0 or PSR1, port pin can be used as a corresponding alternate features regardless of the direction register R0IO.

The ADC input channel  $1\sim7$  (AN1 $\sim$ AN7) can be selected by setting ADCM(00EF<sub>H</sub>) register to enable the corresponding peripheral operation and select operation mode.

| Port pin | Alternate function                                              |
|----------|-----------------------------------------------------------------|
| R00      | INT3 (External Interrupt 3)                                     |
| R01      | SCK ( SIO CLK )<br>AN1 ( Analog Input Port 1 )                  |
|          | SI ( SIO Data Input )                                           |
| R02      | AN2 ( Analog Input Port 2 )<br>SOUT ( SIO Data Output )         |
| R03      | AN3 (Analog Input Port 3)                                       |
| 564      | INT2 (External Interrupt 2)                                     |
| R04      | AN4 (Analog Input Port 4)<br>EC0 (Event Counter Input Source 0) |
| R05      | AN5 (Analog Input Port 5)                                       |
| 500      | T0O (Timer0 Clock Output )                                      |
| R06      | AN6 ( Analog Input Port 6 )<br>T2O ( Timer2 Clock Output )      |
| R07      | AN7 (Analog Input Port 7)                                       |
|          | EC1 (Event Counter Input Source 1)                              |

# 9.2 R1 and R1IO register

R1 is a 5-bit CMOS bidirectional I/O port (address  $0C2_H$ ). Each I/O pin can independently used as an input or an output through the R1IO register (address  $0C3_H$ ). When R10 through R14 pins are used as input ports, an on-chip pull-up resistor can be connected to them in 1-bit units with a pull-up selection register 1 (PU1). Each I/O pin of R0 port can be used to open drain output port by setting the corresponding bit of the open drain selection register 1 (R1OD).

In addition, Port R1 is multiplexed with various alternate functions. The port selection register PSR0 (address  $0F8_H$ ) and PSR1 (address  $0F9_H$ ) control the selection of alternate functions such as Analog reference voltage input (AV<sub>REF</sub>), external interrupt 0 (INT0), external interrupt 1 (INT1), PWM 1 output (PWM1O) and buzzer output (BUZO). When the alternate function is selected by writing "1" in the corresponding bit of PSR0 or PSR1, port pin can be used as a corresponding alternate features regardless of the direction register R1IO.

The ADC input channel 0 (AN0) can be selected by setting ADCM(00EF\_H) register to enable ADC and select channel 0 .

| Port pin | Alternate function                     |
|----------|----------------------------------------|
| R10      | AN0 ( Analog Input Port 0 )            |
|          | AVref (External Analog Reference Pin)  |
|          | PWM1O (PWM1 Output)                    |
| R11      | INT0 (External Interrupt Input Port 0) |
| R12      | INT1 (External Interrupt Input Port 1) |
|          | BUZO (Buzzer Driving Output Port)      |
| R13      | -                                      |
| R14      | -                                      |





Figure 9-1 1 Port Register

# 9.3 R3 and R3IO register

R3 is a 3-bit CMOS bidirectional I/O port (address  $0C6_{\rm H}$ ). Each I/O pin (except R35) can independently used as an input or an output through the R3IO register (address  $0C7_{\rm H}$ ). R35 is an input only port. When R31,R32 and R35 pins are used as input ports, an on-chip pull-up resistor can be connected to them in 1-bit units with a pull-up selection register 3 (PU3). R31 and R32 pins can be used to open drain output port by setting the corresponding bit of the open drain selection register 3 (R3OD).

In addition, Port R3 is multiplexed with alternate functions. R31 and R32 can be used as ADC input channel 14 and 15 by setting ADCM to enable ADC and select channel 14 and 15.

| Port Pin | Alternate Function          |
|----------|-----------------------------|
| R31      | AN14 (ADC input channel 14) |
| R32      | AN15 (ADC input channel 15) |

R33, R34 and R35 is multiplexed with  $X_{IN}$ ,  $X_{OUT}$ , and RESET pin. These pins can be used as general I/O pins by setting writing option described in "21. DEVICE CONFIGURATION AREA".

# MC80F1504/1604







# **10.CLOCK GENERATOR**

As shown in Figure 10-1, the clock generator produces the basic clock pulses which provide the system clock to be supplied to the CPU and the peripheral hardware. It contains main-frequency clock oscillator. The system clock operation can be easily obtained by attaching a crystal or a ceramic resonator between the  $X_{IN}$  and  $X_{OUT}$  pin, respectively. The system clock can also be obtained from the external oscillator. In this case, it is necessary to input a external clock signal to the  $X_{IN}$  pin and open the  $X_{OUT}$  pin. There are no requirements on the duty cycle of the external clock signal, since the input to the internal clocking circuit-

ry is through a divide-by-two flip-flop, but minimum and maximum high and low times specified on the data sheet must be observed.

To the peripheral block, the clock among the not-divided original clock, clocks divided by 1, 2, 4,..., up to 4096 can be provided. Peripheral clock is enabled or disabled by STOP instruction. The peripheral clock is controlled by clock control register (CKCTLR). See "11. BASIC IN-TERVAL TIMER" on page 45 for details.



Figure 10-1 Block Diagram of Clock Generator

# **10.1 Oscillation Circuit**

 $X_{IN}$  and  $X_{OUT}$  are the input and output, respectively, a inverting amplifier which can be set for use as an on-chip oscillator, as shown in Figure 10-1.



**Figure 10-1 Oscillator Connections** 

**Note:** When using a system clock oscillator, carry out wiring in the broken line area in Figure 10-1 to prevent any effects from wiring capacities.

- Minimize the wiring length.
- Do not allow wiring to intersect with other signal conductors.
- Do not allow wiring to come near changing high current.

- Set the potential of the grounding position of the oscillator capacitor to that of Vss. Do not ground to any ground pattern where high current is present.

- Do not fetch signals from the oscillator.





Figure 10-2 Layout of Oscillator PCB circuit

To drive the device from an external clock source, Xout should be left unconnected while Xin is driven as shown in Figure 10-3. There are no requirements on the duty cycle of the external clock signal, since the input to the internal

clocking circuitry is through a divide-by-two flip-flop, but minimum and maximum high and low times specified on the data sheet must be observed.

Oscillation circuit is designed to be used either with a ceramic resonator or crystal oscillator. Since each crystal and ceramic resonator have their own characteristics, the user should consult the crystal manufacturer for appropriate values of external components.



Figure 10-3 External Clock Connections

# **11.BASIC INTERVAL TIMER**

The MC80F1504/1604 has one 8-bit Basic Interval Timer that is free-run and can not stop. Block diagram is shown in Figure 11-1 . In addition, the Basic Interval Timer generates the time base for watchdog timer counting. It also provides a Basic interval timer interrupt (BITIF).

The 8-bit Basic interval timer register (BITR) is increased every internal count pulse which is divided by prescaler. Since prescaler has divided ratio by 8 to 1024, the count rate is 1/8 to 1/1024 of the oscillator frequency. As the count overflow from FFH to 00H, this overflow causes the interrupt to be generated.

The Basic Interval Timer is controlled by the clock control register (CKCTLR) shown in Figure 11-2. If the RCWDT bit is set to "1", the clock source of the BITR is changed to the internal RC oscillation.

When write "1" to bit BTCL of CKCTLR, BITR register is cleared to "0" and restart to count-up. The bit BTCL becomes "0" after one machine cycle by hardware.

If the STOP instruction executed after writing "1" to bit RCWDT of CKCTLR, it goes into the internal RC oscillated watchdog timer mode. In this mode, all of the block is halted except the internal RC oscillator, Basic Interval Timer and Watchdog Timer. More detail informations are explained in Power Saving Function. The bit WDTON decides Watchdog Timer or the normal 7-bit timer.

Source clock can be selected by lower 3 bits of CKCTLR.

BITR and CKCTLR are located at same address, and address  $0F2_{\rm H}$  is read as a BITR, and written to CKCTLR.

**Note:** All control bits of Basic interval timer are in CKCTLR register which is located at same address of BITR (address  $EC_H$ ). Address  $EC_H$  is read as BITR, written to CKCTLR. Therefore, the CKCTLR can not be accessed by bit manipulation instruction.



Figure 11-1 Block Diagram of Basic Interval Timer



| CKCTLR<br>[2:0] | Source clock                                   | Interrupt (overflow) Period (ms)<br>@ f <sub>XIN</sub> = 8MHz |
|-----------------|------------------------------------------------|---------------------------------------------------------------|
| 000             | f <sub>XIN</sub> ÷8<br>f <sub>XIN</sub> ÷16    | 0.256<br>0.512                                                |
| 010             | f <sub>XIN</sub> ÷32                           | 1.024                                                         |
| 011<br>100      | f <sub>XIN</sub> ÷64<br>f <sub>XIN</sub> ÷128  | 2.048<br>4.096                                                |
| 101<br>110      | f <sub>XIN</sub> ÷256<br>f <sub>XIN</sub> ÷512 | 8.192<br>16.384                                               |
| 111             | f <sub>XIN</sub> ÷1024                         | 32.768                                                        |





## Figure 11-2 BITR: Basic Interval Timer Mode Register

#### Example 1:

#### Example 2:

Interrupt request flag is generated every 8.192ms at 4MHz.

: LDM CKCTLR,#1BH SET1 BITE EI : Interrupt request flag is generated every 8.192ms at 8MHz.

LDM CKCTLR,#1CH SET1 BITE EI :



# **12.WATCHDOG TIMER**

The watchdog timer rapidly detects the CPU malfunction such as endless looping caused by noise or the like, and resumes the CPU to the normal state. The watchdog timer signal for detecting malfunction can be selected either a reset CPU or a interrupt request.

When the watchdog timer is not being used for malfunction detection, it can be used as a timer to generate an interrupt at fixed intervals.

The watchdog timer has two types of clock source. The first type is an on-chip RC oscillator which does not require any external components. This RC oscillator is separate from the external oscillator of the  $X_{IN}$  pin. It means that the watchdog timer will run, even if the clock on the  $X_{IN}$  pin of the device has been stopped, for example, by entering the STOP mode. The other type is a prescaled system clock.

The watchdog timer consists of 7-bit binary counter and the watchdog timer data register. When the value of 7-bit binary counter is equal to the lower 7 bits of WDTR, the interrupt request flag is generated. This can be used as Watchdog timer interrupt or reset the CPU in accordance with the bit WDTON.

**Note:** Because the watchdog timer counter is enabled after clearing Basic Interval Timer, after the bit WDTON set to "1", maximum error of timer is depend on prescaler ratio of Basic Interval Timer. The 7-bit binary counter is cleared by setting WDTCL(bit7 of WDTR) and the WDTCL is cleared automatically after 1 machine cycle. The RC oscillated watchdog timer is activated by setting the bit RCWDT as shown below.

```
LDM CKCTLR,#3FH; enable the RC-OSC WDT
LDM WDTR,#0FFH ; set the WDT period
LDM SSCR, #5AH ;ready for STOP mode
STOP ; enter the STOP mode
NOP
NOP ; RC-OSC WDT running
:
```

The RC-WDT oscillation period is vary with temperature,  $V_{DD}$  and process variations from part to part (approximately, 33~100uS). The following equation shows the RCWDT oscillated watchdog timer time-out.

$$T_{RCWDT} = CLK_{RCWDT} \times 2^{8} \times WDTR + (CLK_{RCWDT} \times 2^{8})/2$$
  
where,  $CLK_{RCWDT} = 33 \sim 100 uS$ 

In addition, this watchdog timer can be used as a simple 7bit timer by interrupt WDTIF. The interval of watchdog timer interrupt is decided by Basic Interval Timer. Interval equation is as below.

 $T_{WDT} = (WDTR+1) \times Interval of BIT$ 



Figure 12-1 Block Diagram of Watchdog Timer



#### Watchdog Timer Control

Figure 12-2 shows the watchdog timer control register. The watchdog timer is automatically disabled after reset.

The CPU malfunction is detected during setting of the detection time, selecting of output, and clearing of the binary counter. Clearing the binary counter is repeated within the detection time.

If the malfunction occurs for any cause, the watchdog tim-

er output will become active at the rising overflow from the binary counters unless the binary counter is cleared. At this time, when WDTON=1, a reset is generated, which drives the RESET pin to low to reset the internal hardware. When WDTON=0, a watchdog timer interrupt (WDTIF) is generated. The WDTON bit is in register CLKCTLR.

The watchdog timer temporarily stops counting in the STOP mode, and when the STOP mode is released, it automatically restarts (continues counting).





Example: Sets the watchdog timer detection time to 1 sec. at 4.194304MHz



#### **Enable and Disable Watchdog**

Watchdog timer is enabled by setting WDTON (bit 4 in CKCTLR) to "1". WDTON is initialized to "0" during reset and it should be set to "1" to operate after reset is released.

Example: Enables watchdog timer for Reset

The watchdog timer is disabled by clearing bit 4 (WD-TON) of CKCTLR. The watchdog timer is halted in STOP mode and restarts automatically after STOP mode is released.

#### Watchdog Timer Interrupt

The watchdog timer can be also used as a simple 7-bit timer by clearing bit4 of CKCTLR to "0". The interval of watchdog timer interrupt is decided by Basic Interval Timer. Interval equation is shown as below.

$$T_{WDT} = (WDTR+1) \times Interval \ of \ BIT$$

The stack pointer (SP) should be initialized before using the watchdog timer output as an interrupt source.

Example: 7-bit timer interrupt set up.

LDM CKCTLR, #xxx0\_xxxxB;WDTON ←0 LDM WDTR, #8FH ;WDTCL ←1







If the watchdog timer output becomes active, a reset is generated, which drives the  $\overline{\text{RESET}}$  pin low to reset the internal hardware.

The main clock oscillator also turns on when a watchdog timer reset is generated in sub clock mode.



# **13.TIMER/EVENT COUNTER**

TheMC80F1504/1604 has Three Timer/Counter registers. Each module can generate an interrupt to indicate that an event has occurred (i.e. timer match).

Timer 0 and Timer 1 can be used either two 8-bit Timer/ Counter or one 16-bit Timer/Counter with combine them. Timer 2 can be used only 8-bit Timer/Counter alon.

In the "timer" function, the register is increased every internal clock input. Thus, one can think of it as counting internal clock input. Since a least clock consists of 2 and most clock consists of 2048 oscillator periods, the count rate is 1/2 to 1/2048 of the oscillator frequency.

In the "counter" function, the register is increased in response to a 0-to-1 (rising edge) transition at its corresponding external input pin, EC0 or EC1.

In addition the "capture" function, the register is increased

in response external or internal clock sources same with timer or counter function. When external clock edge input, the count register is captured into Timer data register correspondingly. When external clock edge input, the count register is captured into capture data register CDRx.

Timer 0 and Timer 1 is shared with "PWM" function and "Compare output" function. It has six operating modes: "8bit timer/counter", "16-bit timer/counter", "8-bit capture", "16-bit capture", "8-bit compare output", and "10-bit PWM" which are selected by bit in Timer mode register TM0 and TM1 as shown in Table 13-1, Figure 13-1.

Timer 2 has three operating modes: "8-bit timer/counter", "16-bit timer/counter" and "8-bit capture", "8-bit compare output" which are selected by bit in Timer mode register TM2 as shown in Table 13-2, Figure 13-2.

| 16BIT | CAP0 | CAP1 | PWM1E | T0CK<br>[2:0] | Т1СК<br>[1:0] | PWM10 | TIMER 0                         | TIMER 1              |
|-------|------|------|-------|---------------|---------------|-------|---------------------------------|----------------------|
| 0     | 0    | 0    | 0     | XXX           | XX            | 0     | 8-bit Timer                     | 8-bit Timer          |
| 0     | 0    | 1    | 0     | 111           | XX            | 0     | 8-bit Event counter             | 8-bit Capture        |
| 0     | 1    | 0    | 0     | XXX           | XX            | 1     | 8-bit Capture (internal clock)  | 8-bit Compare Output |
| 0     | Х    | 0    | 1     | XXX           | XX            | 1     | 8-bit Timer/Counter             | 10-bit PWM           |
| 1     | 0    | 0    | 0     | XXX           | 11            | 0     | 16-bit Timer                    |                      |
| 1     | 0    | 0    | 0     | 111           | 11            | 0     | 16-bit Event counter            |                      |
| 1     | 1    | 1    | 0     | XXX           | 11            | 0     | 16-bit Capture (internal clock) |                      |

#### Table 13-1 Operation Modes of Timer 0, 1

1. X means the value of "0" or "1" corresponds to user operation.

| CAP2 | T2CK<br>[2:0] | TIMER 2                        |
|------|---------------|--------------------------------|
| 0    | XXX           | 8-bit Timer                    |
| 0    | 111           | 8-bit Event counter            |
| 1    | XXX           | 8-bit Capture (internal clock) |
| х    | XXX           | 8-bit Timer/Counter            |

Table 13-2 Operating Modes of Timer 2





Figure 13-1 TM0, TM1 Registers

# MC80F1504/1604





Figure 13-2 TM2, TM3 Registers

**\BOV** 

# 13.1 8-bit Timer / Counter Mode

The MC80F1504/1604 has three 8-bit Timer/Counters, Timer 0, Timer 1, Timer 2. The Timer 0, Timer 1 are shown in Figure 13-3 and Timer 2 is shown in Figure 13-4.

The "timer" or "counter" function is selected by control registers TM0, TM1, TM2 as shown in Figure 13-1. To use as an 8-bit timer/counter mode, bit CAP0, CAP1 or CAP2 of TMx should be cleared to "0" and 16BIT and

PWM1E of TM1 should be cleared to "0" (Figure 13-3). These timers have each 8-bit count register and data register. The count register is increased by every internal or external clock input. The internal clock has a prescaler divide ratio option of 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048 or external clock (selected by control bits TxCK0, TxCK1, TxCK2 of register TMx).



Figure 13-3 8-bit Timer/Counter 0, 1

# MC80F1504/1604





Figure 13-4 8-bit Timer/Counter 2



## Example 1:

Timer0 = 2ms 8-bit timer mode at 4MHz Timer 1 = 0.5 ms 8-bit timer mode at 4MHz Timer2 = 1ms 8-bit timer mode at 4MHz

| LDM                        | TDR0,#249         |
|----------------------------|-------------------|
| LDM                        | TDR1,#249         |
| LDM                        | TDR2,#249         |
| LDM                        | TM0,#0000_1111B   |
| LDM                        | TM1,#0000_1011B   |
| LDM                        | TM2,#0000_1111B   |
| SET1<br>SET1<br>SET1<br>EI | T0E<br>T1E<br>T2E |

## **Example 2:**

Timer0 = 8-bit event counter mode Timer 1 = 0.5ms 8-bit timer mode at 4MHz Timer2 = 8-bit event counter mode

| LDM  | TDR0,#249       |
|------|-----------------|
| LDM  | TDR1,#249       |
| LDM  | TDR2,#249       |
| LDM  | TM0,#0001_1111B |
| LDM  | TM1,#0000_1011B |
| LDM  | TM2,#0001_1111B |
| SET1 | T0E             |
| SET1 | T1E             |
| SET1 | T2E             |

ΕI

These timers have each 8-bit count register and data regis-

ter. The count register is increased by every internal or external clock input. The internal clock has a prescaler divide ratio option of 2, 4, 8, 32, 128, 512, 2048 selected by control bits T0CK[2:0] of register TM0 or 1, 2, 8 selected by control bits T1CK[1:0] of register TM1, or 2, 4, 8, 16, 64, 256, 1024 selected by control bits T2CK[2:0] of register TM2. In the Timer 0, timer register T0 increases from  $00_{\rm H}$ until it matches TDR0 and then reset to 00<sub>H</sub>. The match output of Timer 0 generates Timer 0 interrupt (latched in TOIF bit).

In counter function, the counter is increased every 0-to-1 (rising edge) transition of EC0 pin. In order to use counter function, the bit EC0 of the Port Selection Register (PSR0.4) is set to "1". The Timer 0 can be used as a counter by pin EC0 input, but Timer 1 can not. Likewise, In order to use Timer2 as counter function, the bit EC1 of the Port Selection Register (PSR0.5) is set to "1". The Timer 2 can be used as a counter by pin EC1 input.

#### 13.1.1 8-bit Timer Mode

In the timer mode, the internal clock is used for counting up. Thus, you can think of it as counting internal clock input. The contents of TDR*n* are compared with the contents of up-counter, Tn. If match is found, a timer n interrupt (TnIF) is generated and the up-counter is cleared to 0. Counting up is resumed after the up-counter is cleared.

As the value of TDR*n* is changeable by software, time interval is set as you want.



Figure 13-5 Timer Mode Timing Chart



Figure 13-6 Timer Count Example

# 13.1.2 8-bit Event Counter Mode

In this mode, counting up is started by an external trigger. This trigger means rising edge of the EC0 or EC1 pin input. Source clock is used as an internal clock selected with timer mode register TM0 or TM2. The contents of timer data register TDR*n* (n = 0, 2) are compared with the contents of the up-counter T*n*. If a match is found, an timer interrupt request flag T*n*IF is generated, and the counter is cleared to "0". The counter is restart and count up continuously by every rising edge of the EC0 or EC1 pin input. The maximum frequency applied to the EC0 or EC1 pin is  $f_{XIN}/2$  [Hz].

In order to use event counter function, the bit 4, 5 of the Port Selection Register  $PSR0(address 0F8_H)$  is required to be set to "1".

After reset, the value of timer data register TDRn is initialized to "0", The interval period of Timer is calculated as below equation.

Period (sec) = 
$$\frac{1}{f_{XIN}} \times 2 \times \text{Divide Ratio } \times (\text{TDRn+1})$$



Figure 13-7 Event Counter Mode Timing Chart





Figure 13-8 Count Operation of Timer / Event counter

# 13.2 16-bit Timer / Counter Mode

The Timer register is being run with all 16 bits. A 16-bit timer/counter register T0, T1 are incremented from  $0000_H$  until it matches TDR0, TDR1 and then resets to  $0000_H$ . The match output generates Timer 0 interrupt.

The clock source of the Timer 0 is selected either internal or external clock by bit T0CK[2:0]. In 16-bit mode, the bits T1CK[1:0] and 16BIT of TM1 should be set to "1" respectively as shown in Figure 13-9.





Figure 13-9 16-bit Timer/Counter for Timer 0, 1

# 13.3 8-bit (16-bit) Compare Output

TheMC80F1504/1604 has Timer Compare Output function. To pulse out, the timer match can goes to port pin( T0O or T2O) as shown in Figure 13-4 or Figure 13-4. Thus, pulse out is generated by the timer match. These operation is implemented to pin, R05/AN5//T0O/TXD or R06/AN6/T2O/ACK.

In this mode, the bit TOOE or T2OE bit of Port Selection

register1 (PSR1.0 or PSR1.1) should be set to "1". This pin output the signal having a 50 : 50 duty square wave, and output frequency is same as below equation.

$$f_{COMP} = \frac{\text{Oscillation Frequency}}{2 \times \text{Prescaler Value} \times (TDR+1)}$$



# 13.4 8-bit Capture Mode

The Timer 0 capture mode is set by bit CAP0 of timer mode register TM0 (bit CAP1 of timer mode register TM1 for Timer 1) as shown in Figure 13-11. Likewise, the Timer 2 capture mode is set by bit CAP2 of timer mode register TM2 (bit CAP3 of timer mode register TM3 for Timer 3) as shown in Figure 13-12.

The Timer/Counter register is increased in response internal or external input. This counting function is same with normal timer mode, and Timer interrupt is generated when timer register T0 (T1, T2) increases and matches TDR0 (TDR1, TDR2).

This timer interrupt in capture mode is very useful when the pulse width of captured signal is more wider than the maximum period of Timer.

For example, in Figure 13-14, the pulse width of captured signal is wider than the timer data value  $(FF_H)$  over 2 times. When external interrupt is occurred, the captured

value  $(13_{\rm H})$  is more little than wanted value. It can be obtained correct value by counting the number of timer overflow occurrence.

Timer/Counter still does the above, but with the added feature that a edge transition at external input INTx pin causes the current value in the Timer x register (T0,T1,T2), to be captured into registers CDRx (CDR0, CDR1, CDR2), respectively. After captured, Timer x register is cleared and restarts by hardware. It has three transition modes: "falling edge", "rising edge", "both edge" which are selected by interrupt edge selection register IEDS. Refer to "17.6 External Interrupt" on page 82. In addition, the transition at INT*n* pin generate an interrupt.

**Note:** The CDRn and TDRn are in same address. In the capture mode, reading operation is read the CDRn, not TDRn because path is opened to the CDRn.





Figure 13-10 8-bit Capture Mode for Timer 0, 1





Figure 13-11 8-bit Capture Mode for Timer 2





Figure 13-12 Input Capture Operation of Timer 0 Capture mode



Figure 13-13 Excess Timer Overflow in Capture Mode



# 13.5 16-bit Capture Mode

16-bit capture mode is the same as 8-bit capture, except that the Timer register is being run will 16 bits. The clock source of the Timer 0 is selected either internal or external

clock by bit T0CK[2:0]. In 16-bit mode, the bits T1CK1, T1CK0, CAP1 and 16BIT of TM1 should be set to "1" respectively as shown in Figure 13-15.



Figure 13-14 16-bit Capture Mode of Timer 0, 1

# **Example 1:**

Timer0 = 16-bit timer mode, 0.5s at 4MHz

| LDM<br>LDM<br>LDM<br>LDM<br>SET1<br>EI | TM0,#0000_1111B;8uS<br>TM1,#0100_1100B;16bit Mode<br>TDR0,#<62499 ;8uS X 62500<br>TDR1,#>62499 ;=0.5s<br>TOE |
|----------------------------------------|--------------------------------------------------------------------------------------------------------------|
| :                                      |                                                                                                              |

#### **Example 2:**

Timer0 = 16-bit event counter mode

| LDM | PSR0,#0001 | 0000B;EC0   | Set    |
|-----|------------|-------------|--------|
| LDM | TM0,#0001  | 1111B;Count | erMode |
| LDM | TM1,#0100_ | 1100B;16bit | Mode   |

#### LDM TDR0,#<0FFH ; LDM TDR1, #>0FFH ; SET1 TOE ΕI

#### Example 3:

Timer0 = 16-bit capture mode

:

:

```
PSR0,#0000_0001B;INT0 set
LDM
        TMO,#0010 1111B;CaptureMode
TM1,#0100_1100B;16bit Mode
TDR0,#<0FFH ;</pre>
LDM
LDM
LDM
LDM
         TDR1, #>0FFH
         IEDS, #01H; Falling Edge
LDM
SET1
         TOE
ΕI
```

# 13.6 PWM Mode

TheMC80F1504/1604 has high speed PWM (Pulse Width Modulation) functions which shared with Timer1.

In PWM mode, R10 / PWM1O pin output up to a 10-bit resolution PWM output. The pin should be configured as a PWM output by setting "1" bit PWM1OE in PSR0 register.

The period of the PWM1 output is determined by the T1PPR (T1 PWM Period Register) and T1PWHR[3:2] (bit3,2 of T1 PWM High Register) and the duty of the PWM output is determined by the T1PDR (T1 PWM Duty Register) and T1PWHR[1:0] (bit1,0 of T1 PWM High Register).

The user writes the lower 8-bit period value to the T1PPR and the higher 2-bit period value to the T1PWHR[3:2]. And writes duty value to the T1PDR and the T1PWHR[1:0] same way.

The T1PDR is configured as a double buffering for glitchless PWM output. In Figure 13-8, the duty data is transferred from the master to the slave when the period data matched to the counted value. (i.e. at the beginning of next duty cycle)

# PWM1 Period = [PWM1HR[3:2]T1PPR + 1] X Source Clock

# PWM1 Duty = [PWM1HR[1:0]T1PDR + 1] X Source Clock

The relation of frequency and resolution is in inverse proportion. Table 13-3 shows the relation of PWM frequency vs. resolution.

If it needed more higher frequency of PWM, it should be reduced resolution.

|            | Frequency                |                          |                        |
|------------|--------------------------|--------------------------|------------------------|
| Resolution | T1CK[1:0]<br>= 00(250nS) | T1CK[1:0]<br>= 01(500nS) | T1CK[1:0]<br>= 10(2uS) |
| 10-bit     | 3.9kHz                   | 0.98kHz                  | 0.49kHz                |
| 9-bit      | 7.8kHz                   | 1.95kHz                  | 0.97kHz                |
| 8-bit      | 15.6kHz                  | 3.90kHz                  | 1.95kHz                |
| 7-bit      | 31.2kHz                  | 7.81kHz                  | 3.90kHz                |

#### Table 13-3 PWM Frequency vs. Resolution at 4MHz

The bit POL of TM1 decides the polarity of duty cycle.

If the duty value is set same to the period value, the PWM output is determined by the bit POL (1: High, 0: Low). And if the duty value is set to " $00_{\rm H}$ ", the PWM output is determined by the bit POL (1: Low, 0: High).

It can be changed duty value when the PWM output. However the changed duty value is output after the current period is over. And it can be maintained the duty value at present output when changed only period value shown as Figure 13-15. As it were, the absolute duty time is not changed in varying frequency. But the changed period value must greater than the duty value.

**Note:** If changing the Timer1 to PWM function, it should be stop the timer clock firstly, and then set period and duty register value. If user writes register values while timer is in operation, these register could be set with certain values.

Ex) Sample Program @4MHz 2uS

| LDM | TM1,#1010_1000b | ; Set Clock & PWM1E         |
|-----|-----------------|-----------------------------|
| LDM | T1PPR,#199      | ; Period :400uS=2uSX(199+1) |
| LDM | T1PDR,#99       | ; Duty:200uS=2uSX(99+1)     |
| LDM | PWM1HR,00H      |                             |
| LDM | TM1,#1010_1011b | ; Start timer1              |







Figure 13-15 PWM1 Mode

# MC80F1504/1604



Figure 13-16 Example of PWM1 at 4MHz



Figure 13-17 Example of Changing the PWM1 Period in Absolute Duty Cycle (@4MHz)

R



# **14.ANALOG TO DIGITAL CONVERTER**

The analog-to-digital converter (A/D) allows conversion of an analog input signal to a corresponding 10-bit digital value. The A/D module has ten (eight for MC80F1504) analog inputs, which are multiplexed into one sample and hold. The output of the sample and hold is the input into the converter, which generates the result via successive approximation.

The analog reference voltage is selected to  $V_{DD}$  or AVref by setting of the bit AVREFS in PSR1 register. If external analog reference AVref is selected, the analog input channel 0 (AN0) should not be selected to use. Because this pin is used to an analog reference of A/D converter.

The A/D module has three registers which are the control register ADCM and A/D result register ADCRH and AD-CRL. The ADCRH[7:6] is used as ADC clock source selection bits too. The register ADCM, shown in Figure 14-4, controls the operation of the A/D converter module. The port pins can be configured as analog inputs or digital I/O.

It is selected for the corresponding channel to be converted by setting ADS[3:0]. The A/D port is set to analog input port by ADEN and ADS[3:0] regardless of port I/O direction register. The port unselected by ADS[3:0] operates as normal port.



Figure 14-1 A/D Converter Operation Flow

#### How to Use A/D Converter

The processing of conversion is start when the start bit ADST is set to "1". After one cycle, it is cleared by hardware. The register ADCRH and ADCRL contains the results of the A/D conversion. When the conversion is completed, the result is loaded into the ADCRH and AD-CRL, the A/D conversion status bit ADSF is set to "1", and the A/D interrupt flag ADCIF is set. See Figure 14-1 for operation flow.

The block diagram of the A/D module is shown in Figure 14-3 . The A/D status bit ADSF is set automatically when A/D conversion is completed, cleared when A/D conversion is in process. The conversion time takes 13 times of conversion source clock. The conversion source clock should selected for the conversion time being more than  $25\mu s$ .

#### **A/D Converter Cautions**

#### (1) Input range of AN0 ~ AN7, AN14 and AN15

The input voltage of A/D input pins should be within the specification range. In particular, if a voltage above  $V_{DD}$  (or AVref) or below  $V_{SS}$  is input (even if within the absolute maximum rating range), the conversion value for that channel can not be determinate. The conversion values of the other channels may also be affected.

#### (2) Noise countermeasures

In order to maintain 10-bit resolution, attention must be paid to noise on pins  $V_{DD}$  (or AVref) and analog input pins (AN0 ~ AN7, AN14, AN15). Since the effect increases in proportion to the output impedance of the analog input source, it is recommended in some cases that a capacitor be connected externally as shown in Figure 14-2 in order to reduce noise. The capacitance is user-selectable and appropriately determined according to the target system.



Figure 14-2 Analog Input Pin Connecting Capacitor



### (3) I/O operation

The analog input pins AN0  $\sim$  AN7,AN14 and AN15 also have function as input/output port pins. When A/D conversion is performed with any pin, be sure not to execute a PORT input instruction with the selected pin while conversion is in progress, as this may reduce the conversion resolution.

Also, if digital pulses are applied to a pin adjacent to the pin in the process of A/D conversion, the expected A/D conversion value may not be obtainable due to coupling noise. Therefore, avoid applying pulses to pins adjacent to the pin undergoing A/D conversion.

(4) AV<sub>DD</sub> pin input impedance

A series resistor string of approximately  $5K\Omega$  is connected between the  $AV_{REF}$  pin and the  $V_{SS}$  pin. Therefore, if the output impedance of the analog power source is high, this will result in parallel connection to the series resistor string between the  $AV_{REF}$  pin and the  $V_{SS}$  pin, and there will be a large analog supply voltage error







Figure 14-4 A/D Converter Control & Result Register



# **15.SERIAL INPUT/OUTPUT (SIO)**

The serial Input/Output is used to transmit/receive 8-bit data serially. The Serial Input/Output (SIO) module is a serial interface useful for communicating with other peripheral of microcontroller devices. These peripheral devices may be serial EEPROMs, shift registers, display drivers, A/D converters, etc. This SIO is 8-bit clock synchronous type and consists of serial I/O data register, serial I/O mode register, clock selection circuit, octal counter and control circuit as illustrated in Figure 15-1. The SO pin is designed to input and output. So the Serial I/O(SIO) can be operated with minimum two pin. Pin R00/SCK, R01/SI, and R02/ SO pins are controlled by the Serial Mode Register. The contents of the Serial I/O data register can be written into or read out by software. The data in the Serial Data Register can be shifted synchronously with the transfer clock signal.



Figure 15-1 SIO Block Diagram



Serial I/O Mode Register (SIOM) controls serial I/O function. According to SCK1 and SCK0, the internal clock or external clock can be selected. Serial I/O Data Register (SIOR) is an 8-bit shift register. First LSB is send or is received first.



Figure 15-2 SIO Control Register

## 15.1 Transmission/Receiving Timing

The serial transmission is started by setting SIOST(bit1 of SIOM) to "1". After one cycle of SCK, SIOST and SIOSF (bit 0 of SIOM) is cleared automatically to "0". At the default state of POL bit clear, the serial output data from 8-bit shift register is output at falling edge of SCLK, and in-

put data is latched at rising edge of SCLK pin (Refer to Figure 15-3). When transmission clock is counted 8 times, serial I/O counter is cleared as '0". Transmission clock is halted in "H" state and serial I/O interrupt (SIOIF) occurred. SIOSF is set to "1" automatically.





Figure 15-3 Serial I/O Timing Diagram at POL=0



Figure 15-4 Serial I/O Timing Diagram at POL=1

# 15.2 The usage of Serial I/O

1. Select transmission/receiving mode.

2. In case of sending mode, write data to be send to SIOR.



- 3. Set SIOST to "1" to start serial transmission.
- 4. The SIO interrupt is generated at the completion of SIO and SIOIF is set to "1".
- 5. In case of receiving mode, the received data is acquired by reading the SIOR.
- 6. When using polling method, the completion of 1 byte serial communication can be checked by reading SIOST and SIOSF. As shown in example code, wait until SIOST is changed to "0" and then wait the SIOSF is changed to "1" for completion check.

| LDM     | SIOR,#OAAh ;set tx data         |
|---------|---------------------------------|
| LDM     | SIOM,#0011 1100b;set SIO mode   |
| NOP     | —                               |
| LDM     | SIOM,#0011 1110b;SIO Start      |
| NOP     | _                               |
| SIO WAI | Τ:                              |
| NOP     |                                 |
| BBS     | SIOST,SIO_WAIT ;wait first edge |
| BBC     | SIOSF,SIO_WAIT ;wait complete   |
|         |                                 |

**Note:** When external clock is used, the frequency should be less than 1MHz and recommended duty is 50%. If both transmission mode is selected and transmission is performed simultaneously, error may be occur.



# **16.BUZZER FUNCTION**

The buzzer driver block consists of 6-bit binary counter, buzzer register BUZR, and clock source selector. It generates square-wave which has very wide range frequency (488Hz ~ 250kHz at f<sub>XIN</sub>= 4MHz) by user software.

A 50% duty pulse can be output to R12 / BUZO pin to use for piezo-electric buzzer drive. Pin R12 is assigned for output port of Buzzer driver by setting the bit 2 of PSR1(address  $0F9_H$ ) to "1". For PSR1 register, refer to Figure 16-2

Example: 5kHz output at 4MHz.

| LDM | BUZR, | #0011 | 0001B |
|-----|-------|-------|-------|
| LDM | PSR1, | #XXXX | X1XXB |

X means don't care

The bit 0 to 5 of BUZR determines output frequency for buzzer driving.

Equation of frequency calculation is shown below.

$$f_{BUZ} = \frac{f_{XIN}}{2 \times DivideRatio \times (BUR+1)}$$

 $\label{eq:started} \begin{array}{l} f_{BUZ} : \mbox{Buzzer frequency} \\ f_{XIN} : \mbox{Oscillator frequency} \\ \mbox{Divide Ratio: Prescaler divide ratio by BUCK[1:0]} \\ \mbox{BUR: Lower 6-bit value of BUZR. Buzzer period value.} \end{array}$ 

The frequency of output signal is controlled by the buzzer control register BUZR. The bit 0 to bit 5 of BUZR determine output frequency for buzzer driving.



Figure 16-1 Block Diagram of Buzzer Driver









The 6-bit counter is cleared and starts the counting by writing signal at BUZR register. It is incremental from  $00_H$  until it matches 6-bit BUR value.

When main-frequency is 4MHz, buzzer frequency is shown as below Table 16-1.

| BUR   | BUR[7:6] |         |        |        | BUR   |       | BUR[  | 7:6]  |       |
|-------|----------|---------|--------|--------|-------|-------|-------|-------|-------|
| [5:0] | 00       | 01      | 10     | 11     | [5:0] | 00    | 01    | 10    | 11    |
| 00    | 250.000  | 125.000 | 62.500 | 31.250 | 20    | 7.576 | 3.788 | 1.894 | 0.947 |
| 01    | 125.000  | 62.500  | 31.250 | 15.625 | 21    | 7.353 | 3.676 | 1.838 | 0.919 |
| 02    | 83.333   | 41.667  | 20.833 | 10.417 | 22    | 7.143 | 3.571 | 1.786 | 0.893 |
| 03    | 62.500   | 31.250  | 15.625 | 7.813  | 23    | 6.944 | 3.472 | 1.736 | 0.868 |
| 04    | 50.000   | 25.000  | 12.500 | 6.250  | 24    | 6.757 | 3.378 | 1.689 | 0.845 |
| 05    | 41.667   | 20.833  | 10.417 | 5.208  | 25    | 6.579 | 3.289 | 1.645 | 0.822 |
| 06    | 35.714   | 17.857  | 8.929  | 4.464  | 26    | 6.410 | 3.205 | 1.603 | 0.801 |
| 07    | 31.250   | 15.625  | 7.813  | 3.906  | 27    | 6.250 | 3.125 | 1.563 | 0.781 |
| 08    | 27.778   | 13.889  | 6.944  | 3.472  | 28    | 6.098 | 3.049 | 1.524 | 0.762 |
| 09    | 25.000   | 12.500  | 6.250  | 3.125  | 29    | 5.952 | 2.976 | 1.488 | 0.744 |
| 0A    | 22.727   | 11.364  | 5.682  | 2.841  | 2A    | 5.814 | 2.907 | 1.453 | 0.727 |
| 0B    | 20.833   | 10.417  | 5.208  | 2.604  | 2B    | 5.682 | 2.841 | 1.420 | 0.710 |
| 0C    | 19.231   | 9.615   | 4.808  | 2.404  | 2C    | 5.556 | 2.778 | 1.389 | 0.694 |
| 0D    | 17.857   | 8.929   | 4.464  | 2.232  | 2D    | 5.435 | 2.717 | 1.359 | 0.679 |
| 0E    | 16.667   | 8.333   | 4.167  | 2.083  | 2E    | 5.319 | 2.660 | 1.330 | 0.665 |
| 0F    | 15.625   | 7.813   | 3.906  | 1.953  | 2F    | 5.208 | 2.604 | 1.302 | 0.651 |
| 10    | 14.706   | 7.353   | 3.676  | 1.838  | 30    | 5.102 | 2.551 | 1.276 | 0.638 |
| 11    | 13.889   | 6.944   | 3.472  | 1.736  | 31    | 5.000 | 2.500 | 1.250 | 0.625 |
| 12    | 13.158   | 6.579   | 3.289  | 1.645  | 32    | 4.902 | 2.451 | 1.225 | 0.613 |
| 13    | 12.500   | 6.250   | 3.125  | 1.563  | 33    | 4.808 | 2.404 | 1.202 | 0.601 |
| 14    | 11.905   | 5.952   | 2.976  | 1.488  | 34    | 4.717 | 2.358 | 1.179 | 0.590 |
| 15    | 11.364   | 5.682   | 2.841  | 1.420  | 35    | 4.630 | 2.315 | 1.157 | 0.579 |
| 16    | 10.870   | 5.435   | 2.717  | 1.359  | 36    | 4.545 | 2.273 | 1.136 | 0.568 |
| 17    | 10.417   | 5.208   | 2.604  | 1.302  | 37    | 4.464 | 2.232 | 1.116 | 0.558 |
| 18    | 10.000   | 5.000   | 2.500  | 1.250  | 38    | 4.386 | 2.193 | 1.096 | 0.548 |
| 19    | 9.615    | 4.808   | 2.404  | 1.202  | 39    | 4.310 | 2.155 | 1.078 | 0.539 |
| 1A    | 9.259    | 4.630   | 2.315  | 1.157  | 3A    | 4.237 | 2.119 | 1.059 | 0.530 |
| 1B    | 8.929    | 4.464   | 2.232  | 1.116  | 3B    | 4.167 | 2.083 | 1.042 | 0.521 |
| 1C    | 8.621    | 4.310   | 2.155  | 1.078  | 3C    | 4.098 | 2.049 | 1.025 | 0.512 |
| 1D    | 8.333    | 4.167   | 2.083  | 1.042  | 3D    | 4.032 | 2.016 | 1.008 | 0.504 |
| 1E    | 8.065    | 4.032   | 2.016  | 1.008  | 3E    | 3.968 | 1.984 | 0.992 | 0.496 |
| 1F    | 7.813    | 3.906   | 1.953  | 0.977  | 3F    | 3.907 | 1.953 | 0.977 | 0.488 |

Table 16-1 buzzer frequency (kHz unit)

76

### MC80F1504/1604

## **17.INTERRUPTS**

TheMC80F1604/1504 interrupt circuits consist of Interrupt enable register (IENH, IENL), Interrupt request flags of IRQH, IRQL, Priority circuit, and Master enable flag ("I" flag of PSW). Fifteen interrupt sources are provided. The configuration of interrupt circuit is shown in Figure 17-1 and interrupt priority is shown in Table 17-1.

The External Interrupts  $INT0 \sim INT3$  each can be transition-activated (1-to-0 or 0-to-1 transition) by selection IEDS register.

The flags that actually generate these interrupts are bit INT0IF, INT1IF, INT2IF and INT3IF in register IRQH. When an external interrupt is generated, the generated flag is cleared by the hardware when the service routine is vectored to only if the interrupt was transition-activated.

The Timer 0  $\sim$  Timer 2 Interrupts are generated by T0IF, T1IF and T2IF which is set by a match in their respective timer/counter register.

The Basic Interval Timer Interrupt is generated by BITIF which is set by an overflow in the timer register.

The AD converter Interrupt is generated by ADCIF which is set by finishing the analog to digital conversion.

The Watchdog timer is generated by WDTIF and WTIF which is set by a match in Watchdog timer register.



Figure 17-1 Block Diagram of Interrupt







The Basic Interval Timer Interrupt is generated by BITIF which is set by a overflow in the timer counter register.

The interrupts are controlled by the interrupt master enable flag I-flag (bit 2 of PSW on Figure 8-3), the interrupt enable register (IENH, IENL), and the interrupt request flags (in IRQH and IRQL) except Power-on reset and software BRK interrupt. The Table 17-1 shows the Interrupt priority.

Vector addresses are shown in Figure 8-6. Interrupt enable registers are shown in Figure 17-2. These registers are composed of interrupt enable flags of each interrupt source and these flags determines whether an interrupt will be accepted or not. When enable flag is "0", a corresponding interrupt source is prohibited. Note that PSW contains also a master enable bit, I-flag, which disables all interrupts at once.

| Priority | Reset/Interrupt      | Number |
|----------|----------------------|--------|
| 1        | Hardware Reset       | INT15  |
| 2        | External Interrupt 0 | INT14  |
| 3        | External Interrupt 1 | INT13  |
| 4        | External Interrupt 2 | INT12  |
| 5        | External Interrupt 3 | INT11  |
| 6        | Timer/Counter 0      | INT7   |
| 7        | Timer/Counter 1      | INT6   |
| 8        | Timer/Counter 2      | INT5   |
| 9        | ADC Interrupt        | INT2   |
| 10       | Watchdog Timer       | INT1   |
| 11       | Basic Interval Timer | INT0   |

**Table 17-1 Interrupt Priority** 



Figure 17-2 Interrupt Enable Flag Register





Figure 17-3 Interrupt Request Flag Register

# **17.1 Interrupt Sequence**

An interrupt request is held until the interrupt is accepted or the interrupt latch is cleared to "0" by a reset or an instruction. Interrupt acceptance sequence requires 8 cycles of  $f_{XIN}$  (2µs at  $f_{XIN}$ =4MHz) after the completion of the

## 17.1.1 Interrupt acceptance

- 1. The interrupt master enable flag (I-flag) is cleared to "0" to temporarily disable the acceptance of any following maskable interrupts. When a non-maskable interrupt is accepted, the acceptance of any following interrupts is temporarily disabled.
- 2. The contents of the program counter (return address) and the program status word are saved (pushed) onto the

current instruction execution. The interrupt service task is terminated upon execution of an interrupt return instruction [RETI].

stack area. The stack pointer decreases 3 times.

- 3. The entry address of the interrupt service program is read from the vector table address and the entry address is loaded to the program counter.
- 4. The instruction stored at the entry address of the interrupt service program is executed.





#### Figure 17-4 Timing chart of Interrupt Acceptance and Interrupt Return Instruction



Correspondence between vector table address for BIT interrupt and the entry address of the interrupt service program.

## 17.1.2 Clearing Interrupt Request Flag

The Interrupt Request flag may not cleared itself during interrupt acceptance processing. After interrupt acceptance, it should be cleard as shown in interrupt service routine.

**Note:** The MC80F1504/1604 and HMS87C1102A is very similar in function, but the interrupt processing method is different. When replacing the HMS87C1102A to MC80F1504/1604, clearing interrupt request flag should be added.

### 17.1.3 Saving/Restoring General-purpose Register

During interrupt acceptance processing, the program counter and the program status word are automatically saved on the stack, but accumulator and other registers are not saved itself. These registers are saved by the software A interrupt request is not accepted until the I-flag is set to "1" even if a requested interrupt has higher priority than that of the current interrupt being serviced.

When nested interrupt service is required, the I-flag should be set to "1" by "EI" instruction in the interrupt service program. In this case, acceptable interrupt sources are selectively enabled by the individual interrupt enable flags.

#### **Example: Clearing Interrupt Request Flag**

| T1_INT: | CLR1         | Tlif     | ;CLEAR   | т1 | REQUEST |
|---------|--------------|----------|----------|----|---------|
|         | interrupt pr | ocessing |          |    |         |
|         | RETI         |          | ; RETURN | 1  |         |

if necessary. Also, when multiple interrupt services are nested, it is necessary to avoid using the same data memory area for saving registers.

The following method is used to save/restore the general-



purpose registers.

#### Example: Register save using push and pop instructions

| INTxx: | CLR1<br>PUSH<br>PUSH<br>PUSH | INTXXIF<br>A<br>X<br>Y | ;CLEAR REQUEST.<br>;SAVE ACC.<br>;SAVE X REG.<br>;SAVE Y REG.  |
|--------|------------------------------|------------------------|----------------------------------------------------------------|
|        | interrupt proc               | essing                 |                                                                |
|        | POP<br>POP<br>POP<br>RETI    | Y<br>X<br>A            | ;RESTORE Y REG.<br>;RESTORE X REG.<br>;RESTORE ACC.<br>;RETURN |

General-purpose register save/restore using push and pop

## 17.2 BRK Interrupt

Software interrupt can be invoked by BRK instruction, which has the lowest priority order.

Interrupt vector address of BRK is shared with the vector of TCALL 0 (Refer to Program Memory Section). When BRK interrupt is generated, B-flag of PSW is set to distinguish BRK from TCALL 0.

Each processing step is determined by B-flag as shown in Figure 17-5 .



instructions;



Figure 17-5 Execution of BRK/TCALL0

## **17.3 Shared Interrupt Vector**

In case of using interrupts of Watchdog Timer and Watch Timer together, it is necessary to check IFR in interrupt service routine to find out which interrupt is occurred, because the Watchdog timer and Watch timer is shared with interrupt vector address. These flag bits must be cleared by software after reading this register.

## 17.4 BRK Interrupt

Software interrupt can be invoked by BRK instruction, which has the lowest priority order.

Interrupt vector address of BRK is shared with the vector of TCALL 0 (Refer to Program Memory Section). When

BRK interrupt is generated, B-flag of PSW is set to distinguish BRK from TCALL 0.

Each processing step is determined by B-flag as shown in Figure 17-5 .





Figure 17-6 Execution of BRK/TCALL0

## 17.5 Multi Interrupt

If two requests of different priority levels are received simultaneously, the request of higher priority level is serviced. If requests of the interrupt are received at the same time simultaneously, an internal polling sequence determines by hardware which request is serviced. However, multiple processing through software for special features is possible. Generally when an interrupt is accepted, the Iflag is cleared to disable any further interrupt. But as user sets I-flag in interrupt routine, some further interrupt can be serviced even if certain interrupt is in progress.





:

**Example:** During Timer1 interrupt is in progress, INT0 interrupt serviced without any suspend.

| terrupt ser | viceu w                      | iniout any susp      | ena.                                                             | :                         |                          |                         |
|-------------|------------------------------|----------------------|------------------------------------------------------------------|---------------------------|--------------------------|-------------------------|
| TIMER1:     | CLR1<br>PUSH<br>PUSH<br>PUSH | T1IF<br>A<br>X<br>Y  | ; Clear Timer1 Request                                           | :<br>:<br>LDM<br>LDM      | IENH,#0FFH<br>IENL,#0FFH | ; Enable all interrupts |
|             | LDM<br>LDM<br>EI<br>:        | IENH,#80H<br>IENL,#0 | ; Enable INT0 only<br>; Disable other int.<br>; Enable Interrupt | POP<br>POP<br>POP<br>RETI | Y<br>X<br>A              |                         |



# 17.6 External Interrupt

The external interrupt on INT0, INT1, INT2 and INT3 pins are edge triggered depending on the edge selection register IEDS (address  $0EE_H$ ) as shown in Figure 17-7.

The edge detection of external interrupt has three transition activated mode: rising edge, falling edge, and both edge.





INT0 ~ INT3 are multiplexed with general I/O ports (R11, R12, R03, R00). To use as an external interrupt pin, the bit of port selection register PSR0 should be set to "1" correspondingly.

Example: To use as an INT0 and INT1



## **Response Time**

The INT0 ~ INT3 edge are latched into INT0IF ~ INT3IF at every machine cycle. The values are not actually polled by the circuitry until the next machine cycle. If a request is active and conditions are right for it to be acknowledged, a hardware subroutine call to the requested service routine will be the next instruction to be executed. The DIV itself takes twelve cycles. Thus, a minimum of twelve complete machine cycles elapse between activation of an external interrupt request and the beginning of execution of the first instruction of the service routine.

Figure 17-8 shows interrupt response timings.



Figure 17-9 Interrupt Response Timing Diagram







# **18.POWER SAVING OPERATION**

TheMC80F1504/1604 has two power-down modes. In power-down mode, power consumption is reduced considerably. For applications where power consumption is a critical factor, device provides two kinds of power saving functions, STOP mode and SLEEP mode. Table 18-1

## 18.1 Sleep Mode

In this mode, the internal oscillation circuits remain active. Oscillation continues and peripherals are operate normally but CPU stops. Movement of all peripherals is shown in Table 18-1. SLEEP mode is entered by setting the SSCR register to "0Fh". It is released by Reset or interrupt. To be shows the status of each Power Saving Mode. SLEEP mode is entered by the SSCR register to "0Fh"., and STOP mode is entered by STOP instruction after the SSCR register to "5Ah".

released by interrupt, interrupt should be enabled before SLEEP mode.





#### Release the SLEEP mode

The exit from SLEEP mode is hardware reset or all interrupts. Reset re-defines all the Control registers but does not change the on-chip RAM. Interrupts allow both on-chip RAM and Control registers to retain their values.

If I-flag = 1, the normal interrupt response takes place. If I-flag = 0, the chip will resume execution starting with the instruction following the SLEEP instruction. It will not vector to interrupt service routine. (refer to Figure 18-4)

When exit from SLEEP mode by reset, enough oscillation

stabilizing time is required to normal operation. Figure 18-3 shows the timing diagram. When released from the SLEEP mode, the Basic interval timer is activated on wake-up. It is increased from  $00_H$  until FF<sub>H</sub>. The count overflow is set to start normal operation. Therefore, before SLEEP instruction, user must be set its relevant prescaler divide ratio to have long enough time (more than 20msec). This guarantees that oscillator has started and stabilized. By interrupts, exit from SLEEP mode is shown in Figure 18-2 . By reset, exit from SLEEP mode is shown in Figure 18-3 .





Figure 18-2 SLEEP Mode Release Timing by External Interrupt



Figure 18-3 Timing of SLEEP Mode Release by Reset

# 18.2 Stop Mode

In the Stop mode, the main oscillator, system clock and peripheral clock is stopped, but RC-oscillated watchdog timer continue to operate. With the clock frozen, all functions are stopped, but the on-chip RAM and Control registers are held. The port pins out the values held by their respective port data register, port direction registers. Oscillator stops and the systems internal operations are all held up.

- The states of the RAM, registers, and latches valid immediately before the system is put in the STOP state are all held.
- The program counter stop the address of the instruction to be executed after the instruction

"STOP" which starts the STOP operating mode.

**Note:** The Stop mode is activated by execution of STOP instruction after setting the SSCR to " $5A_H$ ". (This register should be written by byte operation. If this register is set by bit manipulation instruction, for example "set1" or "clr1" instruction, it may occur undesired operation)

In the Stop mode of operation,  $V_{DD}$  can be reduced to minimize power consumption. Care must be taken, however, to ensure that  $V_{DD}$  is not reduced before the Stop mode is invoked, and that  $V_{DD}$  is restored to its normal operating level, before the Stop mode is terminated.



The reset should not be activated before  $V_{DD}$  is restored to its normal operating level, and must be held active long enough to allow the oscillator to restart and stabilize.

**Note:** After STOP instruction, at least two or more NOP instruction should be written.

|      | CKCTLR,#0FH ;more than 20ms<br>SCR,#5AH |
|------|-----------------------------------------|
| STOP |                                         |
| NOP  | ;for stabilization time                 |
| NOP  | ;for stabilization time                 |
|      | LDM S<br>STOP<br>NOP                    |

In the STOP operation, the dissipation of the power associated with the oscillator and the internal hardware is lowered; however, the power dissipation associated with the pin interface (depending on the external circuitry and program) is not directly determined by the hardware operation of the STOP feature. This point should be little current flows when the input level is stable at the power voltage level ( $V_{DD}/V_{SS}$ ); however, when the input level gets higher than the power voltage level (by approximately 0.3 to 0.5V), a current begins to flow. Therefore, if cutting off the output transistor at an I/O port puts the pin signal into the high-impedance state, a current flow across the ports input transistor, requiring to fix the level by pull-up or other means.

| Peripheral           | STOP Mode                                                                     | SLEEP Mode            |
|----------------------|-------------------------------------------------------------------------------|-----------------------|
| CPU                  | Stop                                                                          | Stop                  |
| RAM                  | Retain                                                                        | Retain                |
| Basic Interval Timer | Halted                                                                        | Operates Continuously |
| Watchdog Timer       | Stop (Only operates in RC-WDT mode)                                           | Operates Continuously |
| Timer/Counter        | Halted (Only when the event counter mode is enabled, timer operates normally) | Operates Continuously |
| ADC                  | Stop                                                                          | Stop                  |
| Buzzer               | Stop                                                                          | Operates Continuously |
| Oscillator           | Stop (X <sub>IN</sub> =L, X <sub>OUT</sub> =H)                                | Oscillation           |
| I/O Ports            | Retain                                                                        | Retain                |
| Control Registers    | Retain                                                                        | Retain                |
| Internal Circuit     | Stop mode                                                                     | Sleep mode            |
| Prescaler            | Retain                                                                        | Active                |
| Address Data Bus     | Retain                                                                        | Retain                |
| Release Source       | Reset, Timer(EC0), Watchdog Timer (RC-<br>WDT mode), External Interrupt       | Reset, All Interrupts |

#### Table 18-1 Peripheral Operation During Power Saving Mode

### **Release the STOP mode**

The source for exit from STOP mode is hardware reset, external interrupt, Timer(EC0), Watch Timer, WDT. Reset re-defines all the Control registers but does not change the on-chip RAM. External interrupts allow both on-chip RAM and Control registers to retain their values.

If I-flag = 1, the normal interrupt response takes place. If I-flag = 0, the chip will resume execution starting with the instruction following the STOP instruction. It will not vector to interrupt service routine. (refer to Figure 18-4)

When exit from Stop mode by external interrupt, enough oscillation stabilizing time is required to normal operation. Figure 18-5 shows the timing diagram. When released from the Stop mode, the Basic interval timer is activated on wake-up. It is increased from  $00_{\rm H}$  until FF<sub>H</sub>. The count overflow is set to start normal operation. Therefore, before STOP instruction, user must be set its relevant prescaler divide ratio to have long enough time (more than 20msec). This guarantees that oscillator has started and stabilized.

By reset, exit from Stop mode is shown in Figure 18-6.





Figure 18-4 STOP Releasing Flow by Interrupts

.



Figure 18-5 STOP Mode Release Timing by External Interrupt



Figure 18-6 Timing of STOP Mode Release by Reset

# 18.3 Stop Mode at Internal RC-Oscillated Watchdog Timer Mode

In the Internal RC-Oscillated Watchdog Timer mode, the on-chip oscillator is stopped. But internal RC oscillation circuit is oscillated in this mode. The on-chip RAM and Control registers are held. The port pins out the values held by their respective port data register, port direction registers.

The Internal RC-Oscillated Watchdog Timer mode is activated by execution of STOP instruction after setting the bit RCWDT of CKCTLR to "1". (This register should be written by byte operation. If this register is set by bit manipulation instruction, for example "set1" or "clr1" instruction, it may be undesired operation)

 Note:
 Caution: After STOP instruction, at least two or more NOP instruction should be written

 Ex)
 LDM WDTR,#1111\_1111B

 LDM CKCTLR,#0010\_1110B

 LDM SSCR,#0101\_1010B

 STOP

 NOP
 ;for stabilization time

 NOP
 ;for stabilization time

The exit from Internal RC-Oscillated Watchdog Timer mode is hardware reset or external interrupt or watchdog timer interrupt (at RC-watchdog timer mode). Reset re-defines all the Control registers but does not change the onchip RAM. External interrupts allow both on-chip RAM and Control registers to retain their values.

If I-flag = 1, the normal interrupt response takes place. In this case, if the bit WDTON of CKCTLR is set to "0" and the bit WDTE of IENH is set to "1", the device will execute the watchdog timer interrupt service routine(Figure 8-6). However, if the bit WDTON of CKCTLR is set to "1", the device will generate the internal Reset signal and execute the reset processing(Figure 18-8). If I-flag = 0, the chip will resume execution starting with the instruction following the STOP instruction. It will not vector to interrupt service routine.(refer to Figure 18-4)

When exit from Stop mode at Internal RC-Oscillated Watchdog Timer mode by external interrupt, the oscillation stabilization time is required to normal operation. Figure 18-7 shows the timing diagram. When release the Internal RC-Oscillated Watchdog Timer mode, the basic interval timer is activated on wake-up. It is increased from  $00_{\rm H}$  until FF<sub>H</sub>. The count overflow is set to start normal operation. Therefore, before STOP instruction, user must be set its relevant prescaler divide ratio to have long enough time (more than 20msec). This guarantees that oscillator has started and stabilized. By reset, exit from internal RC-Oscillated Watchdog Timer mode is shown in Figure 18-8





Figure 18-7 Stop Mode Release at Internal RC-WDT Mode by External Interrupt or WDT Interrupt



Figure 18-8 Internal RC-WDT Mode Releasing by Reset

# **18.4 Minimizing Current Consumption**

The Stop mode is designed to reduce power consumption. To minimize current drawn during Stop mode, the user should turn-off output drivers that are sourcing or sinking



current, if it is practical.



Figure 18-9 Application Example of Unused Input Port





**Note:** In the STOP operation, the power dissipation associated with the oscillator and the internal hardware is lowered; however, the power dissipation associated with the pin interface (depending on the external circuitry and program) is not directly determined by the hardware operation of the STOP feature. This point should be little current flows when the input level is stable at the power voltage level ( $V_{DD}/V_{SS}$ ); however, when the input level becomes higher than the power voltage level (by approximately 0.3V), a current begins to flow. Therefore, if cutting off the output transistor at an I/ O port puts the pin signal into the high-impedance state, a current flow across the ports input transistor, requiring it to fix the level by pull-up or other means.

It should be set properly in order that current flow through port doesn't exist.

First consider the port setting to input mode. Be sure that there is no current flow after considering its relationship with external circuit. In input mode, the pin impedance viewing from external MCU is very high that the current doesn't flow.

But input voltage level should be  $V_{SS}$  or  $V_{DD}$ . Be careful that if unspecified voltage, i.e. if uncertain voltage level (not  $V_{SS}$  or  $V_{DD}$ ) is applied to input pin, there can be little



current (max. 1mA at around 2V) flow.

If it is not appropriate to set as an input mode, then set to output mode considering there is no current flow. The port setting to High or Low is decided by considering its relationship with external circuit. For example, if there is external pull-up resistor then it is set to output mode, i.e. to High, and if there is external pull-down register, it is set to low.



# 19.RESET

The MC80F1504/1604 supports various kinds of reset as below.

- On-Chip Power-On Reset (POR)
- RESET (external reset circuitry)

- Watchdog Timer Timeout Reset
- Power-Fail Detection (PFD) Reset
- Address Fail Reset



#### Figure 19-1 RESET Block Diagram

The on-chip POR circuit holds down the device in RESET until  $V_{DD}$  has reached a high enough level for proper operation. It will eliminate external components such as reset IC or external resistor and capacitor for external reset circuit. In addition that the RESET pin can be used to normal input port R35 by setting "POR" and "R35EN" bit Configuration Area(20FFH) in the Flash programming. When the device starts normal operation, its operating parmeters (voltage, frequency, temperature...etc) must be met.

.Table 19-1 shows on-chip hardware initialization by reset action.

| On-chip Hardw     | /are  | Initial Value                               | On-chip Hardw       |
|-------------------|-------|---------------------------------------------|---------------------|
| Program counter   | (PC)  | (FFFF <sub>H</sub> ) - (FFFE <sub>H</sub> ) | Peripheral clock    |
| RAM page register | (RPR) | 0                                           | Watchdog timer      |
| G-flag            | (G)   | 0                                           | Control registers   |
| Operation mode    |       | Main-frequency clock                        | Power fail detector |

#### Table 19-1 Initializing Internal Status by Reset Action

The reset input is the  $\overline{\text{RESET}}$  pin, which is the input to a Schmitt Trigger. A reset in accomplished by holding the  $\overline{\text{RESET}}$  pin low for at least 8 oscillator periods, within the operating voltage range and oscillation stable, it is applied, and the internal state is initialized. After reset, 65.5ms (at 4 MHz) add with 7 oscillator periods are required to start execution as shown in Figure 19-2.

Internal RAM is not affected by reset. When  $V_{DD}$  is turned

on, the RAM content is indeterminate. Therefore, this RAM should be initialized before read or tested it.

When the  $\overline{\text{RESET}}$  pin input goes to high, the reset operation is released and the program execution starts at the vector address stored at addresses FFFE<sub>H</sub> - FFFF<sub>H</sub>.

A connection for simple external reset circuit is shown in Figure 19-1 .





Figure 19-1 Simple External Reset Circuit



Figure 19-2 Timing Diagram after Reset

The Address Fail Reset is the function to reset the system by checking code access of abnormal and unwished address caused by erroneous program code itself or external noise, which could not be returned to normal operation and would become malfunction state. If the CPU tries to fetch the instruction from ineffective code area or RAM area, the address fail reset is occurred. Please refer to Figure 11-2 for setting address fail option.



# 20.POWER FAIL PROCESSOR

TheMC80F1504/1604 has an on-chip power fail detection circuitry to immunize against power noise. A configuration register, PFDR, can enable or disable the power fail detect circuitry. Whenever  $V_{DD}$  falls close to or below power fail voltage for 100ns, the power fail situation may reset or freeze MCU according to PFDM bit of PFDR as

shown in Figure 20-1

In the in-circuit emulator, power fail function is not implemented and user can not experiment with it. Therefore, after final development of user program, this function may be experimented or evaluated.



Figure 20-1 Power Fail Voltage Detector Register



Figure 20-2 Example S/W of Reset flow by Power fail





Figure 20-3 Power Fail Processor Situations (at 4MHz operation)





# **21.DEVICE CONFIGURATION AREA**

The Device Configuration Area can be programmed or left unprogrammed to select device configuration such as POR, ONP, CLK option and security bit. This area is not accessible during normal execution but is readable and writable during FLASH program / verify mode.

**Note:** The Configuration Option may not be read exactly when VDD rising time is very slow. It is recommended to adjust the VDD rising time faster than 40ms/V (200ms from 0V to 5V).



Figure 21-1 Device Configuration Area

These various options shown in Figure 21-1 can be selected by checking option field listed in writer (ISP,PGM Plus,

SIGMA or GANG4) software after selecting device name.



# 22.EMULATOR EVA. BOARD SETTING





March 8, 2012 Ver 1.33



# 22.1 DIP Switch and VR Setting

Before execute the user program, keep in your mind the be-

low configuration

| DIP S    | / <b>W</b> | Description                                                                                           | ON/OFF Setting                                                                                                                                                                                                                                                      |
|----------|------------|-------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1        | -          | This connector is only used for a device under 32 PIN.                                                | For the MC80F1504/1604                                                                                                                                                                                                                                              |
| 2<br>sw6 | -          | Device select switch Low pin .                                                                        | Must be <b>Low Pin</b> position.<br><b>High Pin</b> : For the MC80F0208/16/24.<br><b>Low Pin</b> : For the MC80F1504/1604.                                                                                                                                          |
|          | 1<br>2     | → ON<br>→ OFF<br>Use Eva. V <sub>DD</sub><br>AV <sub>DD</sub> select switch to Eva. V <sub>DD</sub> . | These switches select the AV <sub>DD</sub> source for<br>high pin devices and should be set to use<br>Eva. VDD.<br><b>ON &amp; OFF</b> : Use Eva. V <sub>DD</sub>                                                                                                   |
| 3<br>sw2 | 3          | This switch select the /Reset source.                                                                 | Normally OFF.<br>EVA. chip can be reset by external user tar-<br>get board.<br>ON : Reset is available by either user target<br>system board or Emulator RESET switch.<br>OFF : Reset the MCU by Emulator RESET<br>switch. Does not work from user target<br>board. |
|          | 4          | This switch select the Xout signal on/off.                                                            | Normally <b>OFF</b> .<br>MCU XOUT pin is disconnected internally<br>in the Emulator. User may connect this cir-<br>cuit with this switch.<br><b>ON</b> : Output XOUT signal<br><b>OFF</b> : Disconnect circuit                                                      |
| 4<br>sw3 | 1          | This switch select Eva. B/D Power supply source.                                                      | Normally <b>MDS</b> .<br>This switch select Eva. B/D Power supply<br>source.                                                                                                                                                                                        |
| 5<br>sw4 | 1<br>2     | This switch select the R22 or $SX_{OUT}$ .<br>This switch select the R21 or $SX_{IN}$ .               | These switches select the Normal I/O port (off) or Sub-Clock (on).<br>It is reserved for the MC80F0448.<br><b>ON</b> : $SX_{OUT}$ , $SX_{IN}$<br><b>OFF</b> : R22, R21<br>(This switch shoud be OFF mode with MC80F1504/1604 )                                      |



| DIP S    | / <b>W</b> | Description                                                                                                                                                                                              | ON/OFF Setting                                                                                                                                                                                      |
|----------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 1<br>2     | These switches select the R33 or $X_{IN}$<br>$\rightarrow$ $\square$ $ON$ $\leftarrow$ $\square$ $OFF$<br>$\rightarrow$ $OFF$ $\rightarrow$ $OFF$ $ON$<br>Select R33 port Select XIN (NC)                | This switch select the Normal I/O port (off) or XIN(NC) select (on).<br>ON & OFF : R33 Port selected.<br>OFF & ON : $X_{IN}(NC)$ selected.<br>( This switch shoud be Xin mode with MC80F1504/1604 ) |
| 6<br>sw5 | 3<br>4     | These switches select the R34 or $X_{OUT}$<br>$\rightarrow$ $\square$                                          | This switch select the Normal I/O port (off) or XOUT select (on).<br>ON & OFF : R34 Port selected.<br>OFF & ON : $X_{OUT}$ selected.<br>(This switch shoud be Xout mode with MC80F1504/1604)        |
|          | 5<br>6     | These switches select the R35 or $X_{OUT}$<br>$\rightarrow$ $\square$ $ON$ $\leftarrow$ $\square$ $OFF$<br>$\rightarrow$ $\square$ $OFF$ $\rightarrow$ $\square$ $ON$<br>Select R35 port $Select /Reset$ | This switch select the Normal I/O port (off)<br>or /Reset select (on).<br><b>ON &amp; OFF</b> : R35 Port selected.<br><b>OFF &amp; ON</b> : /Reset selected.                                        |
| 7        | -          | This is External oscillation socket (CAN Type. OSC)                                                                                                                                                      | This is for External Clock (CAN Type. OSC).                                                                                                                                                         |



# 23.IN-SYSTEM PROGRAMMING (ISP)

## 23.1 Getting Started / ISP Installation

The In-System Programming (ISP) is performed without removing the microcontroller from the system. The In-System Programming(ISP) facility consists of a series of internal hardware resources coupled with internal firmware through the serial port. The In-System Programming (ISP) facility has made in-circuit programming in an embedded application possible with a minimum of additional expense in components and circuit board area. The following section details the procedure for accomplishing the installation procedure.

- 1. Power off a target system.
- 2. Configure a target system as ISP mode.

- Refer to section 1.3. Hardware Conditions to enter the ISP mode at Chanpter 23.3.

- 3. Attach a USB-SIO-ISP B/D into a target system.
- 4. Run the ABOV USB-SIO-ISP software.
  - Down load the ISP S/W from http://www.abov.co.kr.
  - Unzip the download file and run USB-SIO-ISP.exe
- 5. Select a device in the USB-SIO-ISP S/W.
- 6. Power on a target system.

7. Execute ISP command such as read, program, auto... by pressing buttons on the USB-SIO-ISP S/W.



Figure 23-1 ISP software



# 23.2 Basic ISP S/W Information

The Figure 23-1 is the ISP software based on Windows<sup>TM</sup>. This software is only supporting devices with SIO.

| Function         | Description                                                                                                                     |
|------------------|---------------------------------------------------------------------------------------------------------------------------------|
| Load HEX File    | Load the data from the selected file storage into the memory buffer.                                                            |
| Save HEX File    | Save the current data in your memory buffer to a disk storage by using the Intel Motorola HEX format.                           |
| Blank Check      | Verify whether or not a device is in an erased or unprogrammed state.                                                           |
| Program          | This button enables you to place new data from the memory buffer into the target device.                                        |
| Read             | Read the data in the target MCU into the buffer for examination. The checksum will be displayed on the checksum box.            |
| Verify           | Assures that data in the device matches data in the memory buffer. If your device is secured, a verification error is detected. |
| Erase            | Erase the data in your target MCU before programming it.                                                                        |
| Option Selection | Set the configuration data of target MCU. The security locking is set with this button.                                         |
| Option Write     | Progam the configuration data of target MCU. The security locking is performed with this button.                                |
| AUTO             | Following sequence is performed ; 1.Erase 2.Program 3.Verify 4.Option Write                                                     |
| Edit Buffer      | Modify the data in the selected address in your buffer memory                                                                   |
| Fill Buffer      | Fill the selected area with a data.                                                                                             |
| Goto             | Display the selected page.                                                                                                      |
| Start            | Starting address                                                                                                                |
| End              | End address                                                                                                                     |
| Checksum         | Display the checksum(Hexdecimal) after reading the target device.                                                               |
| Select Device    | Select target device.                                                                                                           |

### **Table 23-1 ISP Function Description**

**Note:** MCU Configuration value is erased after erase operation. It must be configured to match with user target board. Otherwise, it is failed to enter ISP mode, or its operation is not desirable.

# 23.3 Hardware Conditions to Enter the ISP Mode

The boot loader can be executed by holding ALEB high, RST/

V<sub>PP</sub> as +9V.



Figure 23-1 Hardware Conditions to Enter the ISP Mode



Figure 23-2 Used Pins

RC



### 23.4 Sequence to enter ISP mode/user mode



Figure 23-1 Timing diagram to enter the ISP mode

**Note:** Vpp is needed to rise within 64ms@4Mhz after Vdd is high.

Sequence to enter ISP mode from user mode.

- 1. Power off a target system.
- 2. Configure a target system as ISP mode.
- 3. Attach a ISP B/D into a target system.
- 4. Run the ISP S/W
- 5. Select the target device.
- 6. Power on a target system.

Sequence to enter user mode from ISP mode.

- 1. Close the ISP S/W..
- 2. Power off a target system.
- 3. Configure a target system as user mode
- 4. Detach a ISP B/D from a target system.
- 5. Power on.



## 23.5 USB-SIO-ISP Board



Figure 23-1 USB-SIO-ISP Board







# A. INSTRUCTION

# A.1 Terminology List

| Terminology       | Description                                                        |
|-------------------|--------------------------------------------------------------------|
| A                 | Accumulator                                                        |
| Х                 | X - register                                                       |
| Y                 | Y - register                                                       |
| PSW               | Program Status Word                                                |
| #imm              | 8-bit Immediate data                                               |
| dp                | Direct Page Offset Address                                         |
| !abs              | Absolute Address                                                   |
| []                | Indirect expression                                                |
| {}                | Register Indirect expression                                       |
| { }+              | Register Indirect expression, after that, Register auto-increment  |
| .bit              | Bit Position                                                       |
| A.bit             | Bit Position of Accumulator                                        |
| dp.bit            | Bit Position of Direct Page Memory                                 |
| M.bit             | Bit Position of Memory Data (000 <sub>H</sub> ~0FFF <sub>H</sub> ) |
| rel               | Relative Addressing Data                                           |
| upage             | U-page (0FF00 <sub>H</sub> ~0FFF <sub>H</sub> ) Offset Address     |
| n                 | Table CALL Number (0~15)                                           |
| +                 | Addition                                                           |
| x                 | Upper Nibble Expression in Opcode                                  |
| у                 | Upper Nibble Expression in Opcode                                  |
| _                 | Subtraction                                                        |
| ×                 | Multiplication                                                     |
| /                 | Division                                                           |
| ()                | Contents Expression                                                |
| ^                 | AND                                                                |
| V                 | OR                                                                 |
| $\oplus$          | Exclusive OR                                                       |
| ~                 | NOT                                                                |
| <i>←</i>          | Assignment / Transfer / Shift Left                                 |
| $\rightarrow$     | Shift Right                                                        |
| $\leftrightarrow$ | Exchange                                                           |
| =                 | Equal                                                              |
| ≠                 | Not Equal                                                          |



### A.2 Instruction Map

| LOW<br>HIGH | 00000<br>00 | 00001<br>01    | 00010<br>02      | 00011<br>03       | 00100<br>04    | 00101<br>05 | 00110<br>06 | 00111<br>07 | 01000<br>08 | 01001<br>09 | 01010<br>0A | 01011<br>0B   | 01100<br>0C | 01101<br>0D  | 01110<br>0E | 01111<br>0F    |
|-------------|-------------|----------------|------------------|-------------------|----------------|-------------|-------------|-------------|-------------|-------------|-------------|---------------|-------------|--------------|-------------|----------------|
| 000         | -           | SET1<br>dp.bit | BBS<br>A.bit,rel | BBS<br>dp.bit,rel | ADC<br>#imm    | ADC<br>dp   | ADC<br>dp+X | ADC<br>!abs | ASL<br>A    | ASL<br>dp   | TCALL<br>0  | SETA1<br>.bit | BIT<br>dp   | POP<br>A     | PUSH<br>A   | BRK            |
| 001         | CLRC        | "              | **               | "                 | SBC<br>#imm    | SBC<br>dp   | SBC<br>dp+X | SBC<br>!abs | ROL<br>A    | ROL<br>dp   | TCALL<br>2  | CLRA1<br>.bit | COM<br>dp   | POP<br>X     | PUSH<br>X   | BRA<br>rel     |
| 010         | CLRG        | "              | £6               | £6                | CMP<br>#imm    | CMP<br>dp   | CMP<br>dp+X | CMP<br>!abs | LSR<br>A    | LSR<br>dp   | TCALL<br>4  | NOT1<br>M.bit | TST<br>dp   | POP<br>Y     | PUSH<br>Y   | PCALL<br>Upage |
| 011         | DI          | "              | **               | ££                | OR<br>#imm     | OR<br>dp    | OR<br>dp+X  | OR<br>!abs  | ROR<br>A    | ROR<br>dp   | TCALL<br>6  | OR1<br>OR1B   | CMPX<br>dp  | POP<br>PSW   | PUSH<br>PSW | RET            |
| 100         | CLRV        | "              | ££               | **                | AND<br>#imm    | AND<br>dp   | AND<br>dp+X | AND<br>!abs | INC<br>A    | INC<br>dp   | TCALL<br>8  | AND1<br>AND1B | CMPY<br>dp  | CBNE<br>dp+X | TXSP        | INC<br>X       |
| 101         | SETC        | "              | ££               | cc                | EOR<br>#imm    | EOR<br>dp   | EOR<br>dp+X | EOR<br>!abs | DEC<br>A    | DEC<br>dp   | TCALL<br>10 | EOR1<br>EOR1B | DBNE<br>dp  | XMA<br>dp+X  | TSPX        | DEC<br>X       |
| 110         | SETG        | "              | **               | 66                | LDA<br>#imm    | LDA<br>dp   | LDA<br>dp+X | LDA<br>!abs | TXA         | LDY<br>dp   | TCALL<br>12 | LDC<br>LDCB   | LDX<br>dp   | LDX<br>dp+Y  | XCN         | DAS<br>(N/A)   |
| 111         | EI          | u              | 66               | "                 | LDM<br>dp,#imm | STA<br>dp   | STA<br>dp+X | STA<br>!abs | TAX         | STY<br>dp   | TCALL<br>14 | STC<br>M.bit  | STX<br>dp   | STX<br>dp+Y  | XAX         | STOP           |

| LOW<br>HIGH | 10000<br>10 | 10001<br>11    | 10010<br>12      | 10011<br>13       | 10100<br>14 | 10101<br>15   | 10110<br>16   | 10111<br>17   | 11000<br>18 | 11001<br>19 | 11010<br>1A | 11011<br>1B  | 11100<br>1C   | 11101<br>1D | 11110<br>1E  | 11111<br>1F   |
|-------------|-------------|----------------|------------------|-------------------|-------------|---------------|---------------|---------------|-------------|-------------|-------------|--------------|---------------|-------------|--------------|---------------|
| 000         | BPL<br>rel  | CLR1<br>dp.bit | BBC<br>A.bit,rel | BBC<br>dp.bit,rel | ADC<br>{X}  | ADC<br>!abs+Y | ADC<br>[dp+X] | ADC<br>[dp]+Y | ASL<br>!abs | ASL<br>dp+X | TCALL<br>1  | JMP<br>!abs  | BIT<br>!abs   | ADDW<br>dp  | LDX<br>#imm  | JMP<br>[!abs] |
| 001         | BVC<br>rel  | **             | **               | "                 | SBC<br>{X}  | SBC<br>!abs+Y | SBC<br>[dp+X] | SBC<br>[dp]+Y | ROL<br>!abs | ROL<br>dp+X | TCALL<br>3  | CALL<br>!abs | TEST<br>!abs  | SUBW<br>dp  | LDY<br>#imm  | JMP<br>[dp]   |
| 010         | BCC<br>rel  | ££             | ££               | "                 | CMP<br>{X}  | CMP<br>!abs+Y | CMP<br>[dp+X] | CMP<br>[dp]+Y | LSR<br>!abs | LSR<br>dp+X | TCALL<br>5  | MUL          | TCLR1<br>!abs | CMPW<br>dp  | CMPX<br>#imm | CALL<br>[dp]  |
| 011         | BNE<br>rel  | ££             | ££               | "                 | OR<br>{X}   | OR<br>!abs+Y  | OR<br>[dp+X]  | OR<br>[dp]+Y  | ROR<br>!abs | ROR<br>dp+X | TCALL<br>7  | DBNE<br>Y    | CMPX<br>!abs  | LDYA<br>dp  | CMPY<br>#imm | RETI          |
| 100         | BMI<br>rel  | ££             | ££               | "                 | AND<br>{X}  | AND<br>!abs+Y | AND<br>[dp+X] | AND<br>[dp]+Y | INC<br>!abs | INC<br>dp+X | TCALL<br>9  | DIV          | CMPY<br>!abs  | INCW<br>dp  | INC<br>Y     | TAY           |
| 101         | BVS<br>rel  | ££             | ££               | "                 | EOR<br>{X}  | EOR<br>!abs+Y | EOR<br>[dp+X] | EOR<br>[dp]+Y | DEC<br>!abs | DEC<br>dp+X | TCALL<br>11 | XMA<br>{X}   | XMA<br>dp     | DECW<br>dp  | DEC<br>Y     | TYA           |
| 110         | BCS<br>rel  | ££             | ££               | "                 | LDA<br>{X}  | LDA<br>!abs+Y | LDA<br>[dp+X] | LDA<br>[dp]+Y | LDY<br>!abs | LDY<br>dp+X | TCALL<br>13 | LDA<br>{X}+  | LDX<br>!abs   | STYA<br>dp  | XAY          | DAA<br>(N/A)  |
| 111         | BEQ<br>rel  | ű              | "                | "                 | STA<br>{X}  | STA<br>!abs+Y | STA<br>[dp+X] | STA<br>[dp]+Y | STY<br>!abs | STY<br>dp+X | TCALL<br>15 | STA<br>{X}+  | STX<br>!abs   | CBNE<br>dp  | XYX          | NOP           |



### A.3 Instruction Set

# Arithmetic / Logic Operation

| NO. | MNEMONIC     | OP<br>CODE | BYTE<br>NO | CYCLE<br>NO | OPERATION                                            | FLAG<br>NVGBHIZC |
|-----|--------------|------------|------------|-------------|------------------------------------------------------|------------------|
| 1   | ADC #imm     | 04         | 2          | 2           |                                                      |                  |
| 2   | ADC dp       | 05         | 2          | 3           |                                                      |                  |
| 3   | ADC dp + X   | 06         | 2          | 4           |                                                      |                  |
| 4   | ADC labs     | 07         | 3          | 4           | Add with carry.<br>A $\leftarrow$ (A) + (M) + C      | NVH-ZC           |
| 5   | ADC !abs + Y | 15         | 3          | 5           |                                                      | NVH-ZC           |
| 6   | ADC [dp + X] | 16         | 2          | 6           |                                                      |                  |
| 7   | ADC [dp]+Y   | 17         | 2          | 6           |                                                      |                  |
| 8   | ADC {X}      | 14         | 1          | 3           |                                                      |                  |
| 9   | AND #imm     | 84         | 2          | 2           |                                                      |                  |
| 10  | AND dp       | 85         | 2          | 3           |                                                      |                  |
| 11  | AND dp + X   | 86         | 2          | 4           |                                                      |                  |
| 12  | AND !abs     | 87         | 3          | 4           | Logical AND                                          | NZ-              |
| 13  | AND !abs + Y | 95         | 3          | 5           | $A \leftarrow (A) \land (M)$                         | N7-              |
| 14  | AND [dp + X] | 96         | 2          | 6           |                                                      |                  |
| 15  | AND [dp]+Y   | 97         | 2          | 6           |                                                      |                  |
| 16  | AND {X}      | 94         | 1          | 3           |                                                      |                  |
| 17  | ASL A        | 08         | 1          | 2           | Arithmetic shift left                                |                  |
| 18  | ASL dp       | 09         | 2          | 4           | C 7 6 5 4 3 2 1 0                                    |                  |
| 19  | ASL dp + X   | 19         | 2          | 5           | C 7 0 5 4 3 2 1 0 C 7 0 5 4 3 2 1 0                  | NZC              |
| 20  | ASL !abs     | 18         | 3          | 5           |                                                      |                  |
| 21  | CMP #imm     | 44         | 2          | 2           |                                                      |                  |
| 22  | CMP dp       | 45         | 2          | 3           |                                                      |                  |
| 23  | CMP dp + X   | 46         | 2          | 4           |                                                      |                  |
| 24  | CMP !abs     | 47         | 3          | 4           | Compare accumulator contents with memory contents    |                  |
| 25  | CMP !abs + Y | 55         | 3          | 5           | (A)-(M)                                              | NZC              |
| 26  | CMP [dp + X] | 56         | 2          | 6           |                                                      |                  |
| 27  | CMP [dp]+Y   | 57         | 2          | 6           |                                                      |                  |
| 28  | CMP {X}      | 54         | 1          | 3           |                                                      |                  |
| 29  | CMPX #imm    | 5E         | 2          | 2           |                                                      |                  |
| 30  | CMPX dp      | 6C         | 2          | 3           | Compare X contents with memory contents<br>(X) - (M) | NZC              |
| 31  | CMPX !abs    | 7C         | 3          | 4           |                                                      |                  |
| 32  | CMPY #imm    | 7E         | 2          | 2           |                                                      |                  |
| 33  | CMPY dp      | 8C         | 2          | 3           | Compare Y contents with memory contents<br>(Y) - (M) | NZC              |
| 34  | CMPY !abs    | 9C         | 3          | 4           |                                                      |                  |
| 35  | COM dp       | 2C         | 2          | 4           | 1'S Complement : ( dp ) $\leftarrow \sim$ ( dp )     | NZ-              |
| 36  | DAA          | -          | -          | -           | Unsupported                                          | -                |
| 37  | DAS          | -          | -          | -           | Unsupported                                          | -                |
| 38  | DEC A        | A8         | 1          | 2           |                                                      |                  |
| 39  | DEC dp       | A9         | 2          | 4           |                                                      |                  |
| 40  | DEC dp + X   | B9         | 2          | 5           | Decrement                                            |                  |
| 41  | DEC !abs     | B8         | 3          | 5           | M ← (M) - 1                                          | NZ-              |
| 42  | DEC X        | AF         | 1          | 2           |                                                      |                  |
| 43  | DEC Y        | BE         | 1          | 2           |                                                      |                  |
| 44  | DIV          | 9B         | 1          | 12          | Divide : YA / X Q: A, R: Y                           | NVH-Z-           |



| NO.      | MNEMONIC               | OP         | BYTE    | CYCLE   | OPERATION                                                                           | FLAG     |
|----------|------------------------|------------|---------|---------|-------------------------------------------------------------------------------------|----------|
| 45       | EOR #imm               | CODE<br>A4 | NO<br>2 | NO<br>2 |                                                                                     | NVGBHIZC |
| 46       | EOR dp                 | A5         | 2       | 3       |                                                                                     |          |
| 47       | EOR dp + X             | A6         | 2       | 4       |                                                                                     |          |
| 48       | EOR !abs               | A7         | 3       | 4       | Exclusive OR                                                                        |          |
| 49       | EOR !abs + Y           | B5         | 3       | 5       | $A \leftarrow (A) \oplus (M)$                                                       | NZ-      |
| 50       | EOR [dp + X]           | B6         | 2       | 6       |                                                                                     |          |
| 51       | EOR [dp]+Y             | B7         | 2       | 6       |                                                                                     |          |
| 52       | EOR {X}                | B4         | 1       | 3       |                                                                                     |          |
| 53       | INC A                  | 88         | 1       | 2       |                                                                                     |          |
| 54       | INC dp                 | 89         | 2       | 4       |                                                                                     |          |
| 55       | INC dp + X             | 99         | 2       | 5       | Increment                                                                           | N 77     |
| 56       | INC labs               | 98         | 3       | 5       | M ← (M) + 1                                                                         | NZ-      |
| 57       | INC X                  | 8F         | 1       | 2       |                                                                                     |          |
| 58       | INC Y                  | 9E         | 1       | 2       |                                                                                     |          |
| 59       | LSR A                  | 48         | 1       | 2       | Logical shift right                                                                 |          |
| 60       | LSR dp                 | 49         | 2       | 4       | 76543210 C                                                                          | NZC      |
| 61       | LSR dp + X             | 59         | 2       | 5       | "0"                                                                                 | N 20     |
| 62       | LSR !abs               | 58         | 3       | 5       |                                                                                     |          |
| 63       | MUL                    | 5B         | 1       | 9       | Multiply : $YA \leftarrow Y \times A$                                               | NZ-      |
| 64       | OR #imm                | 64         | 2       | 2       |                                                                                     |          |
| 65       | OR dp                  | 65         | 2       | 3       |                                                                                     |          |
| 66       | OR dp + X              | 66         | 2       | 4       |                                                                                     |          |
| 67       | OR labs                | 67         | 3       | 4       | Logical OR                                                                          | NZ-      |
| 68       | OR !abs + Y            | 75         | 3       | 5       | $A \leftarrow (A) \lor (M)$                                                         |          |
| 69       | OR [dp + X]            | 76         | 2       | 6       |                                                                                     |          |
| 70       | OR [dp]+Y              | 77         | 2       | 6       |                                                                                     |          |
| 71       | OR {X}                 | 74         | 1       | 3       |                                                                                     |          |
| 72       | ROL A                  | 28         | 1       | 2       | Rotate left through carry                                                           |          |
| 73       | ROL dp<br>ROL dp + X   | 29         | 2       | 4       | C 7 6 5 4 3 2 1 0                                                                   | NZC      |
| 74<br>75 | ROL dp + X<br>ROL !abs | 39<br>38   | 2<br>3  | 5<br>5  | <u> </u>                                                                            |          |
| 75       | ROL IADS               | 68         | 3<br>1  | 2       | Rotate right through carry                                                          |          |
| 70       | ROR dp                 | 69         | 2       | 4       |                                                                                     |          |
| 78       | ROR dp + X             | 79         | 2       | 5       | 7 6 5 4 3 2 1 0 C                                                                   | NZC      |
|          |                        |            |         |         |                                                                                     |          |
| 79       | ROR !abs               | 78         | 3       | 5       |                                                                                     |          |
| 80       | SBC #imm               | 24         | 2       | 2       |                                                                                     |          |
| 81       | SBC dp                 | 25         | 2       | 3       |                                                                                     |          |
| 82       | SBC dp + X             | 26         | 2       | 4       |                                                                                     |          |
| 83       | SBC !abs               | 27         | 3       | 4       | Subtract with carry                                                                 | NVHZC    |
| 84       | SBC !abs + Y           | 35         | 3       | 5       | A ← (A)-(M)-~(C)                                                                    |          |
| 85       | SBC [dp + X]           | 36         | 2       | 6       |                                                                                     |          |
| 86       | SBC [dp]+Y             | 37         | 2       | 6       |                                                                                     |          |
| 87       | SBC {X}                | 34         | 1       | 3       |                                                                                     |          |
| 88       | TST dp                 | 4C         | 2       | 3       | Test memory contents for negative or zero<br>( dp ) - 00 <sub>H</sub>               | NZ-      |
| 89       | XCN                    | CE         | 1       | 5       | Exchange nibbles within the accumulator $A_7 \sim A_4 \leftrightarrow A_3 \sim A_0$ | NZ-      |



# Register / Memory Operation

| NO. | MNEMONIC     | OP<br>CODE | BYTE<br>NO | CYCLE<br>NO | OPERATION                                                               | FLAG<br>NVGBHIZC |
|-----|--------------|------------|------------|-------------|-------------------------------------------------------------------------|------------------|
| 1   | LDA #imm     | C4         | 2          | 2           |                                                                         |                  |
| 2   | LDA dp       | C5         | 2          | 3           |                                                                         |                  |
| 3   | LDA dp + X   | C6         | 2          | 4           |                                                                         |                  |
| 4   | LDA !abs     | C7         | 3          | 4           | Load accumulator                                                        |                  |
| 5   | LDA !abs + Y | D5         | 3          | 5           | A ← ( M )                                                               | NZ-              |
| 6   | LDA [dp + X] | D6         | 2          | 6           |                                                                         |                  |
| 7   | LDA [dp]+Y   | D7         | 2          | 6           |                                                                         |                  |
| 8   | LDA {X}      | D4         | 1          | 3           |                                                                         |                  |
| 9   | LDA { X }+   | DB         | 1          | 4           | X- register auto-increment : A $\leftarrow$ (M), X $\leftarrow$ X + 1   |                  |
| 10  | LDM dp,#imm  | E4         | 3          | 5           | Load memory with immediate data : (M) $\leftarrow$ imm                  |                  |
| 11  | LDX #imm     | 1E         | 2          | 2           |                                                                         |                  |
| 12  | LDX dp       | CC         | 2          | 3           | Load X-register                                                         |                  |
| 13  | LDX dp + Y   | CD         | 2          | 4           | $X \leftarrow (M)$                                                      | NZ-              |
| 14  | LDX labs     | DC         | 3          | 4           |                                                                         |                  |
| 15  | LDY #imm     | 3E         | 2          | 2           |                                                                         |                  |
| 16  | LDY dp       | C9         | 2          | 3           | Load Y-register                                                         |                  |
| 17  | LDY dp + X   | D9         | 2          | 4           | Y ← ( M )                                                               | NZ-              |
| 18  | LDY labs     | D8         | 3          | 4           |                                                                         |                  |
| 19  | STA dp       | E5         | 2          | 4           |                                                                         |                  |
| 20  | STA dp + X   | E6         | 2          | 5           |                                                                         |                  |
| 21  | STA !abs     | E7         | 3          | 5           |                                                                         |                  |
| 22  | STA !abs + Y | F5         | 3          | 6           | Store accumulator contents in memory                                    |                  |
| 23  | STA [dp + X] | F6         | 2          | 7           | ( M ) ← A                                                               |                  |
| 24  | STA [dp]+Y   | F7         | 2          | 7           |                                                                         |                  |
| 25  | STA {X}      | F4         | 1          | 4           |                                                                         |                  |
| 26  | STA {X}+     | FB         | 1          | 4           | X- register auto-increment : ( M ) $\leftarrow$ A, X $\leftarrow$ X + 1 |                  |
| 27  | STX dp       | EC         | 2          | 4           |                                                                         |                  |
| 28  | STX dp + Y   | ED         | 2          | 5           | Store X-register contents in memory                                     |                  |
| 29  | STX !abs     | FC         | 3          | 5           | $(M) \leftarrow X$                                                      |                  |
| 30  | STY dp       | E9         | 2          | 4           |                                                                         |                  |
| 31  | STY dp + X   | F9         | 2          | 5           | Store Y-register contents in memory                                     |                  |
| 32  | STY !abs     | F8         | 3          | 5           | $(M) \leftarrow Y$                                                      |                  |
| 33  | TAX          | E8         | 1          | 2           | Transfer accumulator contents to X-register : $X \leftarrow A$          | NZ-              |
| 34  | TAY          | 9F         | 1          | 2           | Transfer accumulator contents to Y-register : $Y \leftarrow A$          | NZ-              |
| 35  | TSPX         | AE         | 1          | 2           | Transfer stack-pointer contents to X-register : $X \leftarrow sp$       | NZ-              |
| 36  | TXA          | C8         | 1          | 2           | Transfer X-register contents to accumulator: $A \leftarrow X$           | NZ-              |
| 37  | TXSP         | 8E         | 1          | 2           | Transfer X-register contents to stack-pointer: sp $\leftarrow$ X        | NZ-              |
| 38  | TYA          | BF         | 1          | 2           | Transfer Y-register contents to accumulator: $A \leftarrow Y$           | NZ-              |
| 39  | XAX          | EE         | 1          | 4           | Exchange X-register contents with accumulator :X $\leftrightarrow$ A    |                  |
| 40  | XAY          | DE         | 1          | 4           | Exchange Y-register contents with accumulator :Y $\leftrightarrow$ A    |                  |
| 41  | XMA dp       | BC         | 2          | 5           | Exchange memory contents with accumulator                               |                  |
| 42  | XMA dp+X     | AD         | 2          | 6           | $(M) \leftrightarrow A$                                                 | NZ-              |
| 43  | XMA {X}      | BB         | 1          | 5           |                                                                         |                  |
| 44  | XYX          | FE         | 1          | 4           | Exchange X-register contents with Y-register : $X \leftrightarrow Y$    |                  |
| L   |              | 1          |            | 1           |                                                                         | -                |



#### **16-BIT Operation**

| NO. | MNEMONIC | OP<br>CODE | BYTE<br>NO | CYCLE<br>NO | OPERATION                                                              | FLAG<br>NVGBHIZC |
|-----|----------|------------|------------|-------------|------------------------------------------------------------------------|------------------|
| 1   | ADDW dp  | 1D         | 2          | 5           | 16-Bits add without carry<br>YA $\leftarrow$ ( YA ) + ( dp +1 ) ( dp ) | NVH-ZC           |
| 2   | CMPW dp  | 5D         | 2          | 4           | Compare YA contents with memory pair contents : $(YA) - (dp+1)(dp)$    | NZC              |
| 3   | DECW dp  | BD         | 2          | 6           | Decrement memory pair<br>( dp+1)( dp) $\leftarrow$ ( dp+1) ( dp) - 1   | NZ-              |
| 4   | INCW dp  | 9D         | 2          | 6           | Increment memory pair<br>( dp+1) ( dp) $\leftarrow$ ( dp+1) ( dp ) + 1 | NZ-              |
| 5   | LDYA dp  | 7D         | 2          | 5           | Load YA<br>YA ← (dp +1)( dp )                                          | NZ-              |
| 6   | STYA dp  | DD         | 2          | 5           | Store YA<br>( dp +1 ) ( dp ) ← YA                                      |                  |
| 7   | SUBW dp  | 3D         | 2          | 5           | 16-Bits substact without carry YA $\leftarrow$ (YA) - (dp +1) (dp)     | NVH-ZC           |

#### **Bit Manipulation**

| NO. | MNEMONIC    | OP<br>CODE | BYTE<br>NO | CYCLE<br>NO | OPERATION                                                                         | FLAG<br>NVGBHIZC |
|-----|-------------|------------|------------|-------------|-----------------------------------------------------------------------------------|------------------|
| 1   | AND1 M.bit  | 8B         | 3          | 4           | Bit AND C-flag $: C \leftarrow (C) \land (M.bit)$                                 | C                |
| 2   | AND1B M.bit | 8B         | 3          | 4           | Bit AND C-flag and NOT $: C \leftarrow (C) \land \sim (M .bit)$                   | C                |
| 3   | BIT dp      | 0C         | 2          | 4           | Bit test A with memory :                                                          | MMZ-             |
| 4   | BIT !abs    | 1C         | 3          | 5           | $Z \leftarrow (A) \land (M), \ N \leftarrow (M_7), \ V \leftarrow (M_6)$          | MMZ-             |
| 5   | CLR1 dp.bit | y1         | 2          | 4           | Clear bit : (M.bit) $\leftarrow$ "0"                                              |                  |
| 6   | CLRA1 A.bit | 2B         | 2          | 2           | Clear A bit ∶ ( A.bit )← "0"                                                      |                  |
| 7   | CLRC        | 20         | 1          | 2           | Clear C-flag : $C \leftarrow "0"$                                                 | 0                |
| 8   | CLRG        | 40         | 1          | 2           | Clear G-flag : $G \leftarrow "0"$                                                 | 0                |
| 9   | CLRV        | 80         | 1          | 2           | Clear V-flag : V $\leftarrow$ "0"                                                 | -00              |
| 10  | EOR1 M.bit  | AB         | 3          | 5           | Bit exclusive-OR C-flag $: C \leftarrow (C) \oplus (M.bit)$                       | C                |
| 11  | EOR1B M.bit | AB         | 3          | 5           | Bit exclusive-OR C-flag and NOT : C $\leftarrow$ ( C ) $\oplus$ ~(M .bit)         | C                |
| 12  | LDC M.bit   | CB         | 3          | 4           | Load C-flag : $C \leftarrow (M.bit)$                                              | C                |
| 13  | LDCB M.bit  | CB         | 3          | 4           | Load C-flag with NOT $: C \leftarrow \sim (M .bit)$                               | C                |
| 14  | NOT1 M.bit  | 4B         | 3          | 5           | Bit complement : ( M .bit ) $\leftarrow \sim$ ( M .bit )                          |                  |
| 15  | OR1 M.bit   | 6B         | 3          | 5           | Bit OR C-flag : C $\leftarrow$ ( C ) $\lor$ ( M .bit )                            | C                |
| 16  | OR1B M.bit  | 6B         | 3          | 5           | Bit OR C-flag and NOT $: C \leftarrow (C) \lor \sim (M.bit)$                      | C                |
| 17  | SET1 dp.bit | x1         | 2          | 4           | Set bit : (M.bit) $\leftarrow$ "1"                                                |                  |
| 18  | SETA1 A.bit | 0B         | 2          | 2           | Set A bit : (A.bit) $\leftarrow$ "1"                                              |                  |
| 19  | SETC        | A0         | 1          | 2           | Set C-flag : $C \leftarrow "1"$                                                   | 1                |
| 20  | SETG        | C0         | 1          | 2           | Set G-flag ∶ G ← "1"                                                              | 1                |
| 21  | STC M.bit   | EB         | 3          | 6           | Store C-flag ∶ ( M .bit ) ← C                                                     |                  |
| 22  | TCLR1 !abs  | 5C         | 3          | 6           | Test and clear bits with A : A - ( M ) , ( M ) $\leftarrow$ ( M ) $\wedge$ ~( A ) | NZ-              |
| 23  | TSET1 !abs  | 3C         | 3          | 6           | Test and set bits with A :<br>A - (M), (M) $\leftarrow$ (M) $\lor$ (A)            | NZ-              |



### Branch / Jump Operation

| NO. | MNEMONIC       | OP<br>CODE | BYTE<br>NO | CYCLE<br>NO | OPERATION                                                                                                                                                                                                                                                     | FLAG<br>NVGBHIZC |
|-----|----------------|------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 1   | BBC A.bit,rel  | y2         | 2          | 4/6         | Branch if bit clear :                                                                                                                                                                                                                                         |                  |
| 2   | BBC dp.bit,rel | у3         | 3          | 5/7         | if (bit) = 0, then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                 |                  |
| 3   | BBS A.bit,rel  | x2         | 2          | 4/6         | Branch if bit set :                                                                                                                                                                                                                                           |                  |
| 4   | BBS dp.bit,rel | x3         | 3          | 5/7         | if (bit) = 1, then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                 |                  |
| 5   | BCC rel        | 50         | 2          | 2/4         | Branch if carry bit clear                                                                                                                                                                                                                                     |                  |
| 5   | BCC Tel        | 50         | 2          | 2/4         | if (C) = 0, then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                   |                  |
| 6   | BCS rel        | D0         | 2          | 2/4         | Branch if carry bit set if ( C ) = 1 , then $pc \leftarrow (pc) + rel$                                                                                                                                                                                        |                  |
| 7   | BEQ rel        | F0         | 2          | 2/4         | Branch if equal                                                                                                                                                                                                                                               |                  |
|     |                |            |            |             | if $(Z) = 1$ , then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                |                  |
| 8   | BMI rel        | 90         | 2          | 2/4         | Branch if minus                                                                                                                                                                                                                                               |                  |
|     |                |            |            |             | if $(N) = 1$ , then $pc \leftarrow (pc) + rel$<br>Branch if not equal                                                                                                                                                                                         |                  |
| 9   | BNE rel        | 70         | 2          | 2/4         | if (Z) = 0, then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                   |                  |
| 10  |                | 10         | •          |             | Branch if minus                                                                                                                                                                                                                                               |                  |
| 10  | BPL rel        | 10         | 2          | 2/4         | if (N) = 0, then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                   |                  |
| 11  |                | 2F         | 2          | 4           | Branch always                                                                                                                                                                                                                                                 |                  |
| 11  | BRA rel        | 21         | 2          | 4           | $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                                    |                  |
| 12  | BVC rel        | 30         | 2          | 2/4         | Branch if overflow bit clear                                                                                                                                                                                                                                  |                  |
|     |                |            |            |             | if (V) = 0, then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                   |                  |
| 13  | BVS rel        | B0         | 2          | 2/4         | Branch if overflow bit set                                                                                                                                                                                                                                    |                  |
| 14  |                | 3B         | 3          | 8           | if $(V) = 1$ , then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                |                  |
| 14  | CALL !abs      | 30         | 3          | 0           | Subroutine call                                                                                                                                                                                                                                               |                  |
| 15  | CALL [dp]      | 5F         | 2          | 8           | $ \begin{array}{l} M(sp) \leftarrow (pc_{H} \ ),  sp \leftarrow sp - 1,  M(sp) \leftarrow (pc_{L}),  sp \leftarrow sp - 1, \\ if  !abs, \ pc \leftarrow abs \ ; \ if  [dp], \ pc_{L} \leftarrow ( \ dp \ ), \ pc_{H} \leftarrow ( \ dp + 1 \ ). \end{array} $ |                  |
| 16  | CBNE dp,rel    | FD         | 3          | 5/7         | Compare and branch if not equal :                                                                                                                                                                                                                             |                  |
| 17  | CBNE dp+X,rel  | 8D         | 3          | 6/8         | if (A) $\neq$ (M), then pc $\leftarrow$ (pc) + rel.                                                                                                                                                                                                           |                  |
| 18  | DBNE dp,rel    | AC         | 3          | 5/7         | Decrement and branch if not equal :                                                                                                                                                                                                                           |                  |
| 19  | DBNE Y,rel     | 7B         | 2          | 4/6         | if ( M ) $\neq$ 0, then pc $\leftarrow$ ( pc ) + rel.                                                                                                                                                                                                         |                  |
| 20  | JMP !abs       | 1B         | 3          | 3           |                                                                                                                                                                                                                                                               |                  |
| 21  | JMP [!abs]     | 1F         | 3          | 5           | Unconditional jump                                                                                                                                                                                                                                            |                  |
| 22  | JMP [dp]       | 3F         | 2          | 4           | pc ← jump address                                                                                                                                                                                                                                             |                  |
| 23  | PCALL upage    | 4F         | 2          | 6           | $ \begin{array}{l} $ $ U$-page call $ $ M(sp) \leftarrow (pc_H), sp \leftarrow sp - 1, M(sp) \leftarrow (pc_L), $ $ sp \leftarrow sp - 1, pc_L \leftarrow (upage), pc_H \leftarrow "0FF_H". $ \end{array} $                                                   |                  |
| 24  | TCALL n        | nA         | 1          | 8           | Table call : (sp) $\leftarrow$ ( pc <sub>H</sub> ), sp $\leftarrow$ sp - 1,<br>M(sp) $\leftarrow$ ( pc <sub>L</sub> ),sp $\leftarrow$ sp - 1,<br>pc <sub>L</sub> $\leftarrow$ (Table vector L), pc <sub>H</sub> $\leftarrow$ (Table vector H)                 |                  |



#### Control Operation & Etc.

| NO. | MNEMONIC | OP<br>CODE | BYTE<br>NO | CYCLE<br>NO | OPERATION                                                                                                                                                                                                                                                                            | FLAG<br>NVGBHIZC |
|-----|----------|------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 1   | BRK      | 0F         | 1          | 8           | Software interrupt : $B \leftarrow "1"$ , $M(sp) \leftarrow (pc_H)$ , $sp \leftarrow sp-1$ ,<br>$M(s) \leftarrow (pc_L)$ , $sp \leftarrow sp - 1$ , $M(sp) \leftarrow (PSW)$ , $sp \leftarrow sp - 1$ ,<br>$pc_L \leftarrow (0FFDE_H)$ , $pc_H \leftarrow (0FFDF_H)$ .               | 1-0              |
| 2   | DI       | 60         | 1          | 3           | Disable interrupts ∶ I ← "0"                                                                                                                                                                                                                                                         | 0                |
| 3   | EI       | E0         | 1          | 3           | Enable interrupts ∶ I ← "1"                                                                                                                                                                                                                                                          | 1                |
| 4   | NOP      | FF         | 1          | 2           | No operation                                                                                                                                                                                                                                                                         |                  |
| 5   | POP A    | 0D         | 1          | 4           | $sp \leftarrow sp + 1, A \leftarrow M(sp)$                                                                                                                                                                                                                                           |                  |
| 6   | POP X    | 2D         | 1          | 4           | $sp \leftarrow sp + 1, X \leftarrow M(sp)$                                                                                                                                                                                                                                           |                  |
| 7   | POP Y    | 4D         | 1          | 4           | $sp \leftarrow sp + 1, Y \leftarrow M(sp)$                                                                                                                                                                                                                                           |                  |
| 8   | POP PSW  | 6D         | 1          | 4           | $sp \leftarrow sp + 1$ , $PSW \leftarrow M(sp)$                                                                                                                                                                                                                                      | restored         |
| 9   | PUSH A   | 0E         | 1          | 4           | $M(sp) \leftarrow A, sp \leftarrow sp - 1$                                                                                                                                                                                                                                           |                  |
| 10  | PUSH X   | 2E         | 1          | 4           | $M(sp) \leftarrow X, sp \leftarrow sp - 1$                                                                                                                                                                                                                                           |                  |
| 11  | PUSH Y   | 4E         | 1          | 4           | $M(sp) \leftarrow Y, sp \leftarrow sp - 1$                                                                                                                                                                                                                                           |                  |
| 12  | PUSH PSW | 6E         | 1          | 4           | M( sp ) $\leftarrow$ PSW , sp $\leftarrow$ sp - 1                                                                                                                                                                                                                                    |                  |
| 13  | RET      | 6F         | 1          | 5           | $\begin{array}{l} \mbox{Return from subroutine} \\ \mbox{sp} \leftarrow \mbox{sp +1, pc}_L \leftarrow \mbox{M( sp ), sp} \leftarrow \mbox{sp +1, pc}_H \leftarrow \mbox{M( sp )} \end{array}$                                                                                        |                  |
| 14  | RETI     | 7F         | 1          | 6           | $\begin{array}{l} \text{Return from interrupt} \\ \text{sp} \leftarrow \text{sp +1, } \text{PSW} \leftarrow \text{M(sp ), sp} \leftarrow \text{sp + 1,} \\ \text{pc}_{L} \leftarrow \text{M(sp ), sp} \leftarrow \text{sp + 1, } \text{pc}_{H} \leftarrow \text{M(sp )} \end{array}$ | restored         |
| 15  | STOP     | EF         | 1          | 3           | Stop mode (halt CPU, stop oscillator)                                                                                                                                                                                                                                                |                  |

