MAGNACHIP SEMICONDUCTOR LTD. 8-BIT SINGLE-CHIP MICROCONTROLLERS

# HMS87C1808B/16B HMS87C1708B/16B HMS87C1608B/16B HMS87C1508B/16B HMS87C1404B/08B/16B

User's Manual (Ver. 1.03)



#### **REVISION HISTORY**

#### VERSION 1.03 (SEP. 2004) This book

The company name, Hynix Semiconductor Inc. changed to MagnaChip Semiconductor Ltd.

#### VERSION 1.02 (MAR. 2004)

Correct the external RC oscillation characteristics Fixed some errata.

## **VERSION 1.01 (MAY. 2003)**

Fixed some errata.

Version 1.03 Published by MCU Application Team ©2004 MagnaChip Semiconductor Ltd. All right reserved.

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

MagnaChip 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, MagnaChip 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.

# MagnaChip

| 1. OVERVIEW          | 1  | 8-bit Timer/Counter Mode      |
|----------------------|----|-------------------------------|
| Description          | 1  | 16-bit Timer/Counter Mod      |
| Features             | 1  | 8-bit Compare Output (16      |
| Development Tools    | 2  | 8-bit Capture Mode            |
| Ordering Information | 3  | 16-bit Capture Mode           |
| 2. BLOCK DIAGRAM     | 4  | PWM Mode                      |
| 3. PIN ASSIGNMENT    | 5  | 13. Serial Peripheral Interfa |
| 4. PACKAGE DRAWING   | 7  | 14. Buzzer Output function    |
| 5. PIN FUNCTION      | 10 | 15. ANALOG TO DIGITAL (       |
|                      | 10 | 16. INTERRUPTS                |

| 4. PACKAGE DRAWING               | .7 |
|----------------------------------|----|
| 5. PIN FUNCTION                  | 10 |
| 6. PORT STRUCTURES               | 12 |
| 7. ELECTRICAL CHARACTERISTICS    | 17 |
| Absolute Maximum Ratings         | 17 |
| Recommended Operating Conditions | 17 |
| A/D Converter Characteristics    | 17 |
| DC Electrical Characteristics    | 18 |
| AC Characteristics               | 19 |
| Typical Characteristics          | 20 |
| 8. MEMORY ORGANIZATION           | 23 |
| Registers                        | 23 |
| Program Memory                   | 25 |
| Data Memory                      | 28 |
| Addressing Mode                  | 32 |
| 9. I/O PORTS                     | 36 |
| RA and RAIO registers            | 36 |
| RB and RBIO registers            | 37 |
| RC and RCIO registers            | 39 |
| RD and RDIO registers            | 40 |
| RE and REIO registers            | 40 |
| 10. CLOCK GENERATOR              | 41 |
| Oscillation Circuit              | 41 |
| 11. Basic Interval Timer         | -  |
| 12. TIMER / COUNTER              | 44 |

## HMS87C1X04B/08B/16B

| 8-bit Timer/Counter Mode        | 45 |
|---------------------------------|----|
| 16-bit Timer/Counter Mode       | 46 |
| 8-bit Compare Output (16-bit)   | 47 |
| 8-bit Capture Mode              | 47 |
| 16-bit Capture Mode             | 50 |
| PWM Mode                        | 50 |
| 13. Serial Peripheral Interface |    |
| 14. Buzzer Output function      | 55 |
| 15. ANALOG TO DIGITAL CONVERTER | 56 |
| 16. INTERRUPTS                  | 59 |
| Interrupt Sequence              | 61 |
| BRK Interrupt                   | 62 |
| Multi Interrupt                 | 62 |
| External Interrupt              | 64 |
| 17. WATCHDOG TIMER              | 66 |
| 18. Power Saving Mode           | 67 |
| Stop Mode                       | 67 |
| STOP Mode using Internal RCWDT  | 69 |
| Wake-up Timer Mode              | 70 |
| Minimizing Current Consumption  | 71 |
| 19. RESET                       | 73 |
| 20. POWER FAIL PROCESSOR        | 75 |
| 21. COUNTERMEASURE OF NOISE     | 77 |
| Oscillation Noise Protector     | 77 |
| Oscillation Fail Processor      | 78 |
| Device Configuration Area       |    |
| Examples of ONP                 | 79 |
| 22. OTP PROGRAMMING             | 80 |
| EPROM Mode                      | 80 |
| 23. APPENDIX                    |    |
| A. INSTRUCTION MAP              |    |
| B. INSTRUCTION SET              | ii |

# HMS87C1808B / 16B HMS87C1708B / 16B HMS87C1608B / 16B HMS87C1508B / 16B HMS87C1404B / 08B / 16B

# CMOS SINGLE-CHIP 8-BIT MICROCONTROLLER

## 1. OVERVIEW

## **1.1 Description**

The HMS87C1X04B/08B/16B is an advanced CMOS 8-bit microcontroller with 4K/8K/16K bytes of ROM. The MagnaChip semiconductor's HMS87C1X04B/08B/16B is a powerful microcontroller which provides a highly flexible and cost effective solution to many embedded control applications. The HMS87C1X04B/08B/16B provides the following standard features: 4K/8K/16K bytes of ROM, 448 bytes of RAM, 8-bit timer/counter, 8-bit A/D converter, 10-bit high speed PWM output, programmable buzzer driving port, 8-bit serial communication port, on-chip oscillator and clock circuitry. In addition, the HMS87C1X04B/08B/16B support power saving modes to reduce power consumption.

This document is only explained for the base HMS87C1816B, the other's eliminated functions are same as below.

| Device name | EPROM         | RAM      | EXT.INT | BUZ | Operating<br>Voltage | I/O | Package         |
|-------------|---------------|----------|---------|-----|----------------------|-----|-----------------|
| HMS87C14XXB | 4,8,16K bytes |          |         |     |                      | 23  | 28 SKDIP or SOP |
| HMS87C15XXB |               |          |         |     |                      | 27  | 32 PDIP         |
| HMS87C16XXB | 8,16K bytes   | 448bytes | 4       | 0   | 2.3 ~ 5.5V           | 35  | 40 PDIP         |
| HMS87C17XXB |               |          |         |     |                      | 37  | 42 SDIP         |
| HMS87C18XXB |               |          |         |     |                      | 39  | 44 QFP          |

## 1.2 Features

- 4K/8K/16 Bytes On-chip Program Memory
- 448 Bytes of On-chip Data RAM (Included stack memory)
- Instruction Cycle Time:
  250nS at 8MHz
- Programmable I/O pins (LED direct driving can be source and sink)
  - HMS87C14XXB : 23
  - HMS87C15XXB : 27
  - HMS87C16XXB : 35
  - HMS87C17XXB : 37
  - HMS87C18XXB : 39
- Operating Voltage & Frequency
   2.3V ~ 5.5V (at 1 ~ 4.2MHz)

- 4.5V ~ 5.5V (at 1 ~ 8.0MHz)

- Eight 8-bit A/D Converter
- Four External Interrupt Ports.
- One 8-bit Basic Interval Timer
- Four 8-bit Timer / Counters
- Two 10-bit High Speed PWM Outputs
- Watchdog timer (can be operate with internal RC-oscillation)
- One 8-bit Serial Peripheral Interface
- Twelve Interrupt sources
  External input: 4
  - A/D Conversion: 1

- Serial Peripheral Interface: 1
- Timer: 6
- One Programmable Buzzer Driving port
   500Hz ~ 130kHz
- Noise Immunity Circuit
  - Power Fail Processor
  - Oscillation Noise Protector
  - Oscillation Fail Processor

## **1.3 Development Tools**

The HMS87C1X04B/08B/16B is supported by a full-featured macro assembler, C compiler and an in-circuit emulator CHOICE-Dr<sup>TM</sup> and OTP programmers.

The macro assembler and C compiler operate under the MS-Windows 95/98, 2000,  $XP^{TM}$ .

The OTP programmer can be supplied three types of programmer such as emulator add-on board type single programmer (PGM-plus<sup>TM</sup>), universal stand-alone type single programmer (CHOICE-SIGMA<sup>TM</sup>) and gang type programmer (CHOICE-GANG4<sup>TM</sup>).

| In Circuit<br>Emulators | CHOICE-Dr. <sup>TM</sup>                              |  |
|-------------------------|-------------------------------------------------------|--|
| Assembler               | MagnaChip Macro Assembler                             |  |
|                         | Single Programmer : PGM-plus <sup>TM</sup>            |  |
| OTP<br>Programmer       | Universal Programmer : CHOICE-<br>SIGMA <sup>TM</sup> |  |
|                         | Gang Programmer : CHOICE-GANG4 <sup>TM</sup>          |  |



Figure 1-1 In Circuit Emulator CHOICE-Dr.<sup>™</sup>

- Oscillator Type
  - Crystal
  - Ceramic Resonator
  - RC Oscillator ( C can be omitted )
  - Internal Oscillator (approx. 4MHz)
- Power Down Mode
  - STOP mode
  - Wake-up Timer mode



Figure 1-2 OTP Single Programmer PGM-plus<sup>TM</sup>



Figure 1-3 OTP Gang Programmer CHOICE-GANG4<sup>™</sup>

# 1.4 Ordering Information

| ROM Size         | Package Type | Ordering Device Code    | Operating Temperature |
|------------------|--------------|-------------------------|-----------------------|
| 4K bytes (OTP)   | 28 SKDIP     | 28 SKDIP HMS87C1404B SK |                       |
|                  | 28 SOP       | HMS87C1404B D           |                       |
|                  | 28 SKDIP     | HMS87C1408B SK          |                       |
|                  | 28 SOP       | HMS87C1408B D           |                       |
| 8K bytes (OTP)   | 32 PDIP      | HMS87C1508B             |                       |
| or bytes (OTP)   | 40 PDIP      | HMS87C1608B             |                       |
|                  | 42 SDIP      | HMS87C1708B K           | -40 ~ +85°C           |
|                  | 44 MQFP      | HMS87C1808B Q           | -40 - 105 C           |
|                  | 28 SKDIP     | HMS87C1416B SK          |                       |
|                  | 28 SOP       | HMS87C1416B D           |                       |
| 16K bytes (OTP)  | 32 PDIP      | HMS87C1516B             |                       |
| Tory bytes (OTT) | 40 PDIP      | HMS87C1616B             |                       |
|                  | 42 SDIP      | HMS87C1716B K           |                       |
|                  | 44 MQFP      | HMS87C1816B Q           |                       |

## 2. BLOCK DIAGRAM



## **3. PIN ASSIGNMENT**

#### HMS87C14XXB SK

## HMS87C14XXB D

HMS87C16XXB





## HMS87C15XXB



#### HMS87C17XXB K



## HMS87C18XXB Q

44 MQFP



## 4. PACKAGE DRAWING





# MagnaChip



## **5. PIN FUNCTION**

V<sub>DD</sub>: Supply voltage.

V<sub>SS</sub>: Circuit ground.

**RESET**: Reset the MCU.

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

**X<sub>OUT</sub>**: Output from the inverting oscillator amplifier.

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

| Port pin | Alternate function               |  |  |  |
|----------|----------------------------------|--|--|--|
| RA0      | EC0 (Event Counter Input Source) |  |  |  |
| RA1      | AN1 (Analog Input Port 1)        |  |  |  |
| RA2      | AN2 (Analog Input Port 2)        |  |  |  |
| RA3      | AN3 (Analog Input Port 3)        |  |  |  |
| RA4      | AN4 (Analog Input Port 4)        |  |  |  |
| RA5      | AN5 (Analog Input Port 5)        |  |  |  |
| RA6      | AN6 (Analog Input Port 6)        |  |  |  |
| RA7      | AN7 (Analog Input Port 7)        |  |  |  |

#### Table 5-1 RA Port

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

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

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

| Port pin | Alternate function                     |
|----------|----------------------------------------|
| RB0      | AN0 (Analog Input Port 0)              |
|          | AVref (External Analog Reference Pin)  |
| RB1      | BUZ (Buzzer Driving Output Port)       |
| RB2      | INT0 (External Interrupt Input Port 0) |
| RB3      | INT1 (External Interrupt Input Port 1) |
| RB4      | PWM0 (PWM0 Output)                     |
|          | COMP0 (Timer1 Compare Output)          |
| RB5      | PWM1 (PWM1 Output)                     |
|          | COMP1 (Timer3 Compare Output)          |
| RB6      | EC1 (Event Counter Input Source)       |
| RB7      | TMR2OV (Timer2 Overflow Output)        |

#### Table 5-2 RB Port

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

RC serves the functions of the serial interface following special features in Table 5-3 .

| Port pin | Alternate function            |
|----------|-------------------------------|
| RC0      |                               |
| RC1      |                               |
| RC2      |                               |
| RC3      | SRDYIN (SPI Ready Input)      |
|          | SRDYOUT (SPI Ready Output)    |
| RC4      | SCKI (SPI CLK Input)          |
|          | SCKO (SPI CLK Output)         |
| RC5      | SIN (SPI Serial Data Input)   |
| RC6      | SOUT (SPI Serial Data Output) |
| RC7      |                               |

#### Table 5-3 RC Port

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

RD serves the functions of the external interrupt following special features in Table 5-4

| Port pin | Alternate function                     |
|----------|----------------------------------------|
| RD0      | INT2 (External Interrupt Input Port 2) |
| RD1      | INT3 (External Interrupt Input Port 3) |
| RD2      |                                        |
| RD3      |                                        |
| RD4      |                                        |
| RD5      |                                        |
| RD6      |                                        |
| RD7      |                                        |

#### Table 5-4 RD Port

**RE0~RE6**: RE is a 7-bit, CMOS, bidirectional I/O port. RC pins can be used as outputs or inputs according to "1" or "0" written the their Port Direction Register (REIO).

| PIN NAME        | Pin No. | In/Out | Function       |
|-----------------|---------|--------|----------------|
| V <sub>DD</sub> | 43      | -      | Supply voltage |
| V <sub>SS</sub> | 34      | -      | Circuit ground |

Table 5-5 Pin Description

| PIN NAME             | Pin No. | In/Out              | Function           |                                        |
|----------------------|---------|---------------------|--------------------|----------------------------------------|
| RESET                | 33      | I                   | Reset signal input |                                        |
| X <sub>IN</sub>      | 31      | I                   | Oscillation Input  |                                        |
| X <sub>OUT</sub>     | 32      | 0                   | Oscillation Output |                                        |
| RA0 (EC0)            | 35      |                     |                    | External Event Counter input 0         |
| RA1 (AN1)            | 36      |                     |                    | Analog Input Port 1                    |
| RA2 (AN2)            | 37      |                     |                    | Analog Input Port 2                    |
| RA3 (AN3)            | 38      | 10 (lease)          |                    | Analog Input Port 3                    |
| RA4 (AN4)            | 39      | I/O (Input)         |                    | Analog Input Port 4                    |
| RA5 (AN5)            | 40      |                     |                    | Analog Input Port 5                    |
| RA6 (AN6)            | 41      |                     |                    | Analog Input Port 6                    |
| RA7 (AN7)            | 42      |                     |                    | Analog Input Port 7                    |
| RB0 (AVref/AN0)      | 44      | I/O (Input/Input)   |                    | Analog Reference / Analog Input Port 0 |
| RB1 (BUZ)            | 1       | I/O (Output)        |                    | Buzzer Driving Output                  |
| RB2 (INT0)           | 2       | I/O (Input)         |                    | External Interrupt Input 0             |
| RB3 (INT1)           | 3       | I/O (Input)         |                    | External Interrupt Input 1             |
| RB4 (PWM0/COMP0)     | 4       | I/O (Output/Output) |                    | PWM0 Output or Timer1 Compare Output   |
| RB5 (PWM1/COMP1)     | 5       | I/O (Output/Output) | Normal I/O Ports   | PWM1 Output or Timer3 Compare Output   |
| RB6 (EC1)            | 6       | I/O (Input)         |                    | External Event Counter input 1         |
| RB7 (TMR2OV)         | 7       | I/O (Output)        |                    | Timer2 Overflow Output                 |
| RC0 ~ RC2            | 15 ~ 17 | I/O                 |                    |                                        |
| RC3 (SRDYIN/SRDYOUT) | 18      | I/O (Input/Output)  |                    | SPI READY Input/Output                 |
| RC4 (SCK)            | 19      | I/O (Input/Output)  |                    | SPI CLK Input/Output                   |
| RC5 (SIN)            | 20      | I/O (Input)         |                    | SPI DATA Input                         |
| RC6 (SOUT)           | 21      | I/O (Output)        |                    | SPI DATA Output                        |
| RC7                  | 22      | I/O                 |                    |                                        |
| RD0 (INT2)           | 23      | I/O (Input)         |                    | External Interrupt Input 2             |
| RD1 (INT3)           | 24      | I/O (Input)         |                    | External Interrupt Input 3             |
| RD2                  | 25      |                     |                    |                                        |
| RD3 ~ RD7            | 26 ~ 30 | I/O                 |                    |                                        |
| RE0 ~ RE6            | 14 ~8   |                     |                    |                                        |

Table 5-5 Pin Description

## 6. PORT STRUCTURES

## • RESET



## • Xin, Xout (Crystal or Ceramic Resonator)



• Xin, Xout (RC or R oscillation)



## • RA0/EC0, RB6/EC1



## • RA1/AN1 ~ RA7/AN7



• RB1/BUZ, RB4/PWM0/COMP0, RB5/PWM1/

## COMP1, RB7/TMR2OV, RC6/SOUT



## • RB0 / AN0 / AVref



## • RB2/INT0, RB3/INT1, RD0/INT2, RD1/INT3



## • RC5/SIN



## • RC0~2, RC7, RD2~7, RE0~6



## • RC3 / SRDYIN / SRDYOUT, RC4 / SCKIN / SCK-



Unit

V V MHz

MHz °C

## 7. ELECTRICAL CHARACTERISTICS

## 7.1 Absolute Maximum Ratings

| Supply voltage0.3 to +6.0 V                                                                 |
|---------------------------------------------------------------------------------------------|
| Storage Temperature40 to +125 °C                                                            |
| Voltage on any pin with respect to Ground (V <sub>SS</sub> ) $-0.3$ to V <sub>DD</sub> +0.3 |
| Maximum current out of V <sub>SS</sub> pin 200 mA                                           |
| Maximum current into V <sub>DD</sub> pin150 mA                                              |
| Maximum current sunk by (I <sub>OL</sub> per I/O Pin)25 mA                                  |
| Maximum output current sourced by (I <sub>OH</sub> per I/O Pin)                             |
| Maximum current ( $\Sigma I_{OL}$ )                                                         |

Maximum current (SI<sub>OH</sub>)...... 100 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.

4.2

85

1

-40

| Demonstern     | Querra ha d     | O a realitie re           | Specifications |      |  |
|----------------|-----------------|---------------------------|----------------|------|--|
| Parameter      | Symbol          | Condition                 | Min.           | Max. |  |
|                |                 | f <sub>XIN</sub> =8MHz    | 4.5            | 5.5  |  |
| Supply Voltage | V <sub>DD</sub> | f <sub>XIN</sub> =4.2MHz  | 2.3            | 5.5  |  |
|                |                 | V <sub>DD</sub> =4.5~5.5V | 1              | 8    |  |

V<sub>DD</sub>=2.3~5.5V

## 7.2 Recommended Operating Conditions

## 7.3 A/D Converter Characteristics

**Operating Frequency** 

**Operating Temperature** 

 $(T_A=25^{\circ}C, V_{SS}=0V, V_{DD}=5.12V @f_{XIN}=8MHz, V_{DD}=3.072V @f_{XIN}=4MHz)$ 

f<sub>XIN</sub>

TOPR

| Banamatan                               | 0h.e.l            | 0                      | S        | pecificatior | าร               | 11 14 |
|-----------------------------------------|-------------------|------------------------|----------|--------------|------------------|-------|
| Parameter                               | Symbol            | Condition              | Min.     | Тур.         | Max.             | Unit  |
|                                         | V                 | AVREFS=0               | $V_{SS}$ | -            | $V_{DD}$         | V     |
| Analog Input Voltage Range              | V <sub>AIN</sub>  | AVREFS=1               | $V_{SS}$ | -            | V <sub>REF</sub> | v     |
|                                         | V                 | V <sub>DD</sub> =5V    | 3        | -            | $V_{DD}$         | V     |
| Analog Power Supply Input Voltage Range | V <sub>REF</sub>  | V <sub>DD</sub> =3V    | 2.4      | -            | V <sub>DD</sub>  | V     |
| Overall Accuracy                        | N <sub>ACC</sub>  |                        | -        | ±0.7         | ±1.5             | LSB   |
| Non-Linearity Error                     | N <sub>NLE</sub>  |                        | -        | ±0.8         | ±1.5             | LSB   |
| Differential Non-Linearity Error        | N <sub>DNLE</sub> |                        | -        | ±1.0         | ±1.5             | LSB   |
| Zero Offset Error                       | N <sub>ZOE</sub>  |                        | -        | ±1.0         | ±1.5             | LSB   |
| Full Scale Error                        | N <sub>FSE</sub>  |                        | -        | ±0.25        | ±0.5             | LSB   |
| Gain Error                              | N <sub>NLE</sub>  |                        | -        | ±1.0         | ±1.5             | LSB   |
|                                         | т                 | f <sub>XIN</sub> =8MHz | -        | -            | 10               | 0     |
| Conversion Time                         | T <sub>CONV</sub> | f <sub>XIN</sub> =4MHz | -        | -            | 20               | μS    |
| AV <sub>REF</sub> Input Current         | I <sub>REF</sub>  | AVREFS=1               | -        | 0.5          | 1.0              | mA    |

## 7.4 DC Electrical Characteristics

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

| Demonstern                     | o                   | Dia                                          | O a malifi a m                                | Sp                  | ecificatio | 11                  |      |
|--------------------------------|---------------------|----------------------------------------------|-----------------------------------------------|---------------------|------------|---------------------|------|
| 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 <sub>P</sub>      | RB2, RB3, RD0, RD1                           | V <sub>DD</sub> =5V                           | -150                | -          | -70                 | μA   |
| Input High                     | I <sub>IH1</sub>    | 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                           | -                   | -          | 15                  | μA   |
| Input Low                      | I <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                           | -15                 | -          | -                   | μA   |
| Hysteresis                     | V <sub>T</sub>      | Hysteresis Input <sup>1</sup>                | V <sub>DD</sub> =5V                           | 0.5                 | -          | -                   | V    |
| PFD Voltage                    | V <sub>PFD</sub>    | V <sub>DD</sub>                              |                                               | 2.1                 | -          | 3.1                 | V    |
| Internal RC WDT                | т                   | ×                                            | V <sub>DD</sub> =5.5V                         | 30                  | -          | 100                 | 0    |
| Period                         | T <sub>RCWDT</sub>  | RCWDT X <sub>OUT</sub> V <sub>DD</sub> =3.0V |                                               | 60                  | -          | 180                 | μS   |
| Operating Current <sup>2</sup> | I <sub>DD</sub>     | V <sub>DD</sub>                              | V <sub>DD</sub> =5.5V, f <sub>XIN</sub> =8MHz | -                   | 4          | 6.5                 | mA   |
|                                | עטי                 | <u>م</u>                                     | V <sub>DD</sub> =3.0V, f <sub>XIN</sub> =4MHz | -                   | 2          | 3                   | ША   |
| Wake-up Timer                  | I <sub>WKUP</sub>   | V <sub>DD</sub>                              | V <sub>DD</sub> =5.5V, f <sub>XIN</sub> =8MHz | -                   | 1          | 2                   | mA   |
| Mode Current                   | WING                |                                              | V <sub>DD</sub> =3.0V, f <sub>XIN</sub> =4MHz | -                   | 0.3        | 1                   |      |
| RCWDT Mode<br>Current at STOP  | I <sub>RCWDT</sub>  | V <sub>DD</sub>                              | V <sub>DD</sub> =5.5V                         | -                   | 30         | 70                  | μA   |
| Mode                           | RCWDI               | <u>م</u>                                     | V <sub>DD</sub> =3.0V                         | -                   | 5          | 50                  | μΛ   |
| Stop Mode Current              | lazaz               | V                                            | V <sub>DD</sub> =5.5V, f <sub>XIN</sub> =8MHz | -                   | 0.5        | 3                   |      |
|                                | ISTOP               | V <sub>DD</sub>                              | V <sub>DD</sub> =3.0V, f <sub>XIN</sub> =4MHz | -                   | 0.2        | 1                   | μA   |
| INT Input Noise<br>Cancel Time | T <sub>INT_NC</sub> | RB2, RB3, RD0, RD1                           | V <sub>DD</sub> =5V                           | 0.2                 | -          | 0.5                 | μS   |
| External RC                    | f <sub>RC-OSC</sub> | $f_{XOUT} = f_{RC-OSC} / 4$                  | V <sub>DD</sub> =5.5V<br>R=30kΩ, C=10pF       | 0.7                 | -          | 1.5                 | MHz  |
| Oscillator Frequency           | f <sub>R-OSC</sub>  | f <sub>XOUT</sub> = f <sub>R-OSC</sub> / 4   | V <sub>DD</sub> =5.5V<br>R=30kΩ               | 2                   | -          | 4                   | MHz  |

1. Hysteresis Input: RA0, RB2, RB3, RB6, RC3, RC4, RC5, RD0, RD1

2. This parameter is measured in internal EPROM operation at the all I/O port defined input mode.

## 7.5 AC Characteristics

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

| Deremeter                      | Cumb al                            | Pins                               | S         | Unit |      |                  |
|--------------------------------|------------------------------------|------------------------------------|-----------|------|------|------------------|
| Parameter                      | Symbol Pins                        |                                    | Min. Typ. |      | Max. | Unit             |
| Operating Frequency            | f <sub>CP</sub>                    | X <sub>IN</sub>                    | 1         | -    | 8    | MHz              |
| External Clock Pulse Width     | t <sub>CPW</sub>                   | X <sub>IN</sub>                    | 50        | -    | -    | nS               |
| External Clock Transition Time | t <sub>RCP</sub> ,t <sub>FCP</sub> | X <sub>IN</sub>                    | -         | -    | 20   | nS               |
| Oscillation Stabilizing Time   | t <sub>ST</sub>                    | X <sub>IN</sub> , X <sub>OUT</sub> | -         | -    | 20   | mS               |
| External Input Pulse Width     | t <sub>EPW</sub>                   | INT0, INT1, INT2, INT3<br>EC0, EC1 | 2         | -    | -    | t <sub>SYS</sub> |
| RESET Input Width              | t <sub>RST</sub>                   | RESET                              | 8         | -    | -    | t <sub>SYS</sub> |



Figure 7-1 Timing Chart

## 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.

**Operating Area**  $f_{XIN}$ (MHz Ta= 25°C 10 8 6 4 2 0  $V_{DD}$ (V) 2 3 4 5 6



RC-WDT in Stop Mode



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









5

4



V<sub>DD</sub> 6 (V)

V<sub>DD</sub>

6 (V)







1

2 3



**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:** The external RC oscillation frequencies of the HMS87C1X04B/08B/16B may be different from that of the HMS81C1X04B/08B/16B. The user should modify the value of R and C components to get the proper frequency in exchanging OTP device to mask device.

## 8. MEMORY ORGANIZATION

The HMS87C1X04B/08B/16B has separate address spaces for Program memory and Data Memory. The Program memory can only be read, not written to. It can be up to 4K / 8K / 16K bytes of

## 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). Program memory. The Data memory can be read and written to up to 448 bytes including the stack area.

Generally, SP is automatically updated when a subroutine 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  $00_{\rm H}$  to BF<sub>H</sub> 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 "BF<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

| ampie. To m | ilialize lite SP |                                   |
|-------------|------------------|-----------------------------------|
| LDX         | #0BFH            |                                   |
| TXSP        |                  | ; SP $\leftarrow$ BF <sub>H</sub> |

**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_I: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, Direct page select 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 select flag G]

This flag assigned direct page for direct addressing mode. In the direct addressing mode, addressing area is within zero page  $00_H$  to FF<sub>H</sub> when this flag is "0". If it is set to "1", addressing area is  $100_H$  to  $1FF_H$ .

It is set by SETG instruction, and cleared by CLRG instruction.

#### [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.

## 8.2 Program Memory

A 16-bit program counter is capable of addressing up to 64K bytes, but these devices have 4K/8K/16K bytes program memory space only physically implemented. Accessing a location above FFFF<sub>H</sub> will cause a wrap-around to  $0000_{\rm H}$ .

Figure 8-4 , shows a map of Program Memory. After reset, the CPU begins execution from reset vector which is stored in address  $\rm FFFE_{H}$  and  $\rm FFFF_{H}$  as shown in Figure 8-5 .

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



Figure 8-4 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-6.

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  $0FFFA_H$ . The interrupt service locations spaces 2-byte interval:  $0FFF8_H$  and  $0FFF9_H$  for External Interrupt 1,  $0FFFA_H$  and  $0FFFB_H$  for External Interrupt 0, etc.

As for the area from  $0FF00_H$  to  $0FFFF_H$ , if any area of them is not going to be used, its service location is available as general purpose Program Memory.





Figure 8-5 Interrupt Vector Area

|                    |                   | Address                  | Program Memory                                                                         |
|--------------------|-------------------|--------------------------|----------------------------------------------------------------------------------------|
|                    |                   | 0FFC0 <sub>H</sub><br>C1 | TCALL 15                                                                               |
|                    |                   | C2<br>C3                 | TCALL 14                                                                               |
|                    |                   | C4                       | TCALL 13                                                                               |
| Address            | PCALL Area Memory | C5                       |                                                                                        |
| 0FF00 <sub>H</sub> |                   | C6                       | TCALL 12                                                                               |
|                    |                   | C7<br>C8                 |                                                                                        |
|                    |                   | C9                       | TCALL 11                                                                               |
|                    | PCALL Area        | CA                       |                                                                                        |
|                    | (256 Bytes)       | СВ                       | TCALL 10                                                                               |
|                    | (200 2),000)      | CC                       | TCALL 9                                                                                |
|                    |                   | CD                       |                                                                                        |
|                    |                   | CE                       | TCALL 8                                                                                |
| 0FFFF <sub>H</sub> |                   | CF                       |                                                                                        |
|                    |                   | D0<br>D1                 | TCALL 7                                                                                |
|                    |                   | D1<br>D2                 |                                                                                        |
|                    |                   | D3                       | TCALL 6                                                                                |
|                    |                   | D4                       | TCALL 5                                                                                |
|                    |                   | D5                       | TCALL 5                                                                                |
|                    |                   | D6                       | TCALL 4                                                                                |
|                    |                   | D7                       |                                                                                        |
|                    |                   | D8<br>D9                 | TCALL 3                                                                                |
|                    |                   | D9<br>DA                 |                                                                                        |
|                    |                   | DB                       | TCALL 2                                                                                |
|                    |                   | DC                       |                                                                                        |
|                    |                   | DD                       | TCALL 1                                                                                |
|                    |                   | DE                       | TCALL 0 / BRK *                                                                        |
|                    |                   | DF                       |                                                                                        |
|                    |                   | * n                      | <b>DTE:</b><br>neans that the BRK software interrupt is us<br>ime address with TCALL0. |

## Figure 8-6 PCALL and TCALL Memory Area

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

4F35 PCALL 35H



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

4A TCALL 4



## MagnaChip•

;

;

;

;

Example: The usage software example of Vector address and the initialize part.

ORG OFFEOH DW NOT USED; (OFFEO) NOT\_USED; (OFFE2) DW SPI\_INT; (OFFE4) Serial Peripheral Interface BIT\_INT; (OFFE6) Basic Interval Timer WDT\_INT; (OFFE8) Watchdog Timer DW DW DW AD INT; (OFFEA) A/D DW TMR3\_INT; (OFFEC) Timer-3 DW TMR2\_INT; (OFFEC) Timer-2 INT3; (OFFFC) Int.3 DW DW INT2; (OFFF2) Int.2 TMR1\_INT; (OFFF4) Timer-1 TMR0\_INT; (OFFF6) Timer-0 DW DW DW INT1; (OFFF8) Int.1 INT0; (OFFFA) Int.0 DW DW DW NOT USED; (OFFFC) DW RESET; (OFFFE) Reset 0F000H ORG MAIN PROGRAM \* RESET: DI ; Disable All Interrupts LDX #0 #0;RAM Clear(!0000H->!00BFH) RAM CLR: LDA STA {X}+;0-page Clear CMPX #0C0H BNE RAM CLR SETG LDX #0 RAM CL1: LDA #0;RAM Clear(!0100H->!01FFH) STA {X}+;1-page Clear CMPX #0 BNE RAM CL1 CLRG LDX #OBFH;Stack Pointer Initialize TXSP CALL INITIAL; LDM RA, #0;Normal Port A LDM RAIO, #1000\_0010B; Normal Port Direction RB, #0;Normal Port B T.DM LDM RBIO, #1000\_0010B; Normal Port Direction LDM PFDR, #0; Enable Power Fail Detector •

## 8.3 Data Memory

Figure 8-7 shows the internal Data Memory space available. Data Memory is divided into two groups, a user RAM (including Stack) and control registers.



Figure 8-7 Data Memory Map

#### **User Memory**

The HMS87C1X04B/08B/16B have  $448 \times 8$  bits for the user memory (RAM).

#### **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 register 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.

Example; To write at CKCTLR

LDM CKCTLR, #09H ; Divide ratio ÷16

| Address                                                                                                      | Symbol                                                                                                     | R/W                                                                                  | RESET<br>Value                                                                                                                                    | Addressing mode                                                                                                                                                   |
|--------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0C0H<br>0C1H<br>0C2H<br>0C3H<br>0C4H<br>0C5H<br>0C6H<br>0C7H<br>0C8H<br>0C9H<br>0CAH<br>0CBH<br>0CCH<br>0CCH | RA<br>RAIO<br>RB<br>RBIO<br>RC<br>RCIO<br>RD<br>RDIO<br>RE<br>REIO<br>RAFUNC<br>RBFUNC<br>PUPSEL<br>RDFUNC | R/W<br>W<br>R/W<br>W<br>R/W<br>W<br>R/W<br>W<br>W<br>W<br>W<br>W<br>W<br>W<br>W<br>W | Undefined<br>0000_0000<br>Undefined<br>0000_0000<br>Undefined<br>0000_0000<br>Undefined<br>-000_0000<br>0000_0000<br>0000_0000<br>0000<br>00      | byte, bit <sup>1</sup><br>byte <sup>2</sup><br>byte, bit<br>byte, bit<br>byte, bit<br>byte, bit<br>byte, bit<br>byte, bit<br>byte<br>byte<br>byte<br>byte<br>byte |
| 0D0H<br>0D1H<br>0D1H<br>0D2H<br>0D3H<br>0D3H<br>0D4H<br>0D4H<br>0D4H<br>0D4H                                 | TM0<br>T0<br>TDR0<br>CDR0<br>TM1<br>TDR1<br>T1PPR<br>T1<br>CDR1<br>T1PDR<br>PWM0HR                         | R/W<br>R<br>W<br>R/W<br>W<br>R<br>R<br>R/W<br>W<br>W                                 | 00_0000<br>0000_0000<br>1111_1111<br>0000_0000<br>0000_0000<br>1111_1111<br>1111_1111<br>0000_0000<br>0000_0000<br>0000_0000<br>0000              | byte, bit<br>byte<br>byte<br>byte, bit<br>byte<br>byte<br>byte<br>byte<br>byte<br>byte<br>byte                                                                    |
| 0D6H<br>0D7H<br>0D7H<br>0D7H<br>0D8H<br>0D9H<br>0D9H<br>0DAH<br>0DAH<br>0DAH<br>0DAH                         | TM2<br>T2<br>TDR2<br>CDR2<br>TM3<br>TDR3<br>T3PPR<br>T3<br>CDR3<br>T3PDR<br>PWM1HR                         | R/W<br>R<br>R/W<br>W<br>R<br>R/W<br>R<br>R/W<br>W                                    | 00_0000<br>0000_0000<br>1111_1111<br>0000_0000<br>0000_0000<br>1111_1111<br>1111_1111<br>1111_1111<br>0000_0000<br>0000_0000<br>0000_0000<br>0000 | byte, bit<br>byte<br>byte<br>byte, bit<br>byte<br>byte<br>byte<br>byte<br>byte<br>byte<br>byte                                                                    |
| 0DEH<br>0E0H<br>0E1H                                                                                         | BUR<br>SIOM<br>SIOR                                                                                        | W<br>R/W<br>R/W                                                                      | 1111_1111<br>0000_0001<br>Undefined                                                                                                               | byte<br>byte, bit<br>byte, bit                                                                                                                                    |

**Table 8-1 Control Registers** 

## MagnaChip•

| 0E2H<br>0E3H | IENH<br>IENL | R/W<br>R/W | 0000_0000 | byte, bit<br>byte, bit |
|--------------|--------------|------------|-----------|------------------------|
| 0E4H         | IRQH         | R/W        | 0000_0000 | byte, bit              |
| 0E5H         | IRQL         | R/W        | 0000      | byte, bit              |
| 0E6H         | IEDS         | R/W        | 0000_0000 | byte, bit              |
| 0EAH         | ADCM         | R/W        | 00 0001   | byte, bit              |
| 0EBH         | ADCR         | R          | Undefined | byte                   |
| 0ECH         | BITR         | R          | 0000_0000 | byte                   |
| 0ECH         | CKCTLR       | W          | -001 0111 | byte                   |
| 0EDH         | WDTR         | R          | 0000_0000 | byte                   |
| 0EDH         | WDTR         | W          | 0111 1111 | byte                   |
| 0EFH         | PFDR         | R/W        | 0100      | byte, bit              |

#### Table 8-1 Control Registers

1. "byte, bit" means that register can be addressed by not only bit but byte manipulation instruction.

 "byte" means that register can be addressed by only byte manipulation instruction. On the other hand, do not use any read-modify-write instruction such as bit manipulation for clearing bit.

Note: Several names are given at same address. Refer to

below table.

|       | ,             | When read     | When  | write         |             |
|-------|---------------|---------------|-------|---------------|-------------|
| Addr. | Timer<br>Mode | Timer Capture |       | Timer<br>Mode | PWM<br>Mode |
| D1H   | Т0            | CDR0          | -     | TDR0          | -           |
| D3H   |               | -             | TDR1  | T1PPR         |             |
| D4H   | T1            | CDR1          | T1PDR | -             | T1PDR       |
| D7H   | 'H T2 CDR2    |               | -     | TDR2          | -           |
| D9H   |               | -             | •     | TDR3          | T3PPR       |
| DAH   | Т3            | CDR3          | T3PDR | -             | T3PDR       |
| ECH   |               | BITR          | СКС   | TLR           |             |

#### Table 8-2 Various Register Name in Same Address

#### 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.

| Address | Name              | Bit 7                      | Bit 6          | Bit 5        | Bit 4        | Bit 3        | Bit 2   | Bit 1   | Bit 0   |  |
|---------|-------------------|----------------------------|----------------|--------------|--------------|--------------|---------|---------|---------|--|
| C0H     | RA                | RA Port Da                 | ta Register    | L            | L            | 1            |         | 1       |         |  |
| C1H     | RAIO              | RA Port Direction Register |                |              |              |              |         |         |         |  |
| C2H     | RB                | RB Port Da                 | ta Register    |              |              |              |         |         |         |  |
| СЗН     | RBIO              | RB Port Dir                | ection Regis   | ster         |              |              |         |         |         |  |
| C4H     | RC                | RC Port Da                 | ta Register    |              |              |              |         |         |         |  |
| C5H     | RCIO              | RC Port Dir                | ection Regis   | ster         |              |              |         |         |         |  |
| C6H     | RD                | RD Port Da                 | ta Register    |              |              |              |         |         |         |  |
| C7H     | RDIO              | RD Port Dir                | ection Regis   | ster         |              |              |         |         |         |  |
|         | RE                | RE Port Da                 | ta Register    |              |              |              |         |         |         |  |
| C9H     | REIO              | RE Port Dir                | ection Regis   | ster         |              |              |         |         |         |  |
| CAH     | RAFUNC            | ANSEL7                     | ANSEL6         | ANSEL5       | ANSEL4       | ANSEL3       | ANSEL2  | ANSEL1  | ANSEL0  |  |
| CBH     | RBFUNC            | TMR2OV                     | EC1I           | PWM10        | PWM0O        | INT1I        | INT0I   | BUZO    | AVREFS  |  |
| ССН     | PUPSEL            | -                          | -              | -            | -            | PUPSEL3      | PUPSEL2 | PUPSEL1 | PUPSEL0 |  |
| CDH     | RDFUNC            | -                          | -              | -            | -            | -            | -       | INT3I   | INT2I   |  |
| D0H     | TM0               | -                          | -              | CAP0         | T0CK2        | T0CK1        | T0CK0   | TOCN    | TOST    |  |
| D1H     | T0/TDR0/<br>CDR0  | Timer0 Reg                 | jister / Time  | r0 Data Regi | ster / Captu | re0 Data Re  | gister  |         |         |  |
| D2H     | TM1               | POL                        | 16BIT          | PWM0E        | CAP1         | T1CK1        | T1CK0   | T1CN    | T1ST    |  |
| D3H     | TDR1/<br>T1PPR    | Timer1 Dat                 | a Register /   | PWM0 Peric   | od Register  |              |         |         |         |  |
| D4H     | T1/CDR1/<br>T1PDR | Timer1 Reg                 | jister / Captu | ure1 Data Re | egister / PW | M0 Duty Reg  | jister  |         |         |  |
| D5H     | PWM0HR            | PWM0 High                  | n Register     |              |              |              |         |         |         |  |
| D6H     | TM2               | -                          | -              | CAP2         | T2CK2        | T2CK1        | T2CK0   | T2CN    | T2ST    |  |
| D7H     | T2/TDR2/<br>CDR2  | Timer2 Reg                 | jister / Time  | r2 Data Regi | ster / Captu | re2 Data Reg | gister  |         |         |  |
| D8H     | TM3               | POL                        | 16BIT          | PWM1E        | CAP3         | T3CK1        | T3CK0   | T3CN    | T3ST    |  |
| D9H     | TDR3/<br>T3PPR    | Timer3 Dat                 | a Register /   | PWM1 Peric   | od Register  |              |         |         |         |  |
| DAH     | T3/CDR3/<br>T3PDR | Timer3 Reg                 | jister / Captu | ure3 Data Re | egister / PW | M1Duty Reg   | ister   |         |         |  |
| DBH     | PWM1HR            | PWM1 High                  | Register       |              |              |              |         |         |         |  |
| DEH     | BUR               | BUCK1                      | BUCK0          | BUR5         | BUR4         | BUR3         | BUR2    | BUR1    | BUR0    |  |
| E0H     | SIOM              | POL                        | SRDY           | SM1          | SM0          | SCK1         | SCK0    | SIOST   | SIOSF   |  |
| E1H     | SIOR              | SPI DATA I                 | REGISTER       |              |              |              |         |         | ·       |  |
| E2H     | IENH              | INT0E                      | INT1E          | T0E          | T1E          | INT2E        | INT3E   | T2E     | T3E     |  |
| E3H     | IENL              | ADE                        | WDTE           | BITE         | SPIE         | -            | -       | -       | -       |  |
| E4H     | IRQH              | INT0IF                     | INT1IF         | TOIF         | T1IF         | INT2IF       | INT3IF  | T2IF    | T3IF    |  |

## Table 8-3 Control Registers of HMS87C1X04B/08B/16B

These registers of shaded area can not be accessed by bit manipulation instruction as "SET1, CLR1", but should be accessed by register operation instruction as "LDM dp, #imm".

# MagnaChip

| E5H | IRQL                | ADIF         | WDTIF                           | BITIF       | SPIF  | -      | -     | -     | -     |  |
|-----|---------------------|--------------|---------------------------------|-------------|-------|--------|-------|-------|-------|--|
| E6H | IEDS                | IED3H        | IED3L                           | IED2H       | IED2L | IED1H  | IED1L | IED0H | IED0L |  |
| EAH | ADCM                | -            | -                               | ADEN        | ADS2  | ADS1   | ADS0  | ADST  | ADSF  |  |
| EBH | ADCR                | ADC Resul    | ADC Result Data Register        |             |       |        |       |       |       |  |
| ECH | BITR <sup>1</sup>   | Basic Interv | val Timer Da                    | ta Register |       |        |       |       |       |  |
| ECH | CKCTLR <sup>1</sup> | -            | WAKEUP                          | RCWDT       | WDTON | BTCL   | BTS2  | BTS1  | BTS0  |  |
| EDH | WDTR                | WDTCL        | 7-bit Watchdog Counter Register |             |       |        |       |       |       |  |
| EFH | PFDR <sup>2</sup>   | -            | -                               | -           | -     | PFDOPR | PFDIS | PFDM  | PFDS  |  |

#### Table 8-3 Control Registers of HMS87C1X04B/08B/16B

These registers of shaded area can not be accessed by bit manipulation instruction as "SET1, CLR1", but should be accessed by register operation instruction as "LDM dp, #imm".

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

2. The register PFDR only be implemented on devices, not on In-circuit Emulator.

## 8.4 Addressing Mode

The HMS87C1X04B/08B/16B uses six addressing modes;

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

## (1) Register Addressing

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

## (2) Immediate Addressing $\rightarrow$ #imm

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

#### Example:

0435 ADC #35H



#### E45535 LDM 35H,#55H



#### (3) Direct Page Addressing $\rightarrow$ dp

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

C535 LDA 35H ;A ←RAM[35H]



## (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;

0735F0 ADC !0F035H ;A ←ROM[0F035H]



## MagnaChip•

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

Example; Addressing accesses the address 0035<sub>H</sub>.

983500 INC !0035H ;A ←RAM[035H]



## 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; X=35<sub>H</sub> DB LDA {X}+



### (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>

D4 LDA  $\{X\}$ ; ACC  $\leftarrow$  RAM[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; X=015<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



### (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;

#### 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; X=10<sub>H</sub>

1625 ADC [25H+X]



# MagnaChip

### 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; Y=10<sub>H</sub>

1725 ADC [25H]+Y



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

JMP

Example;

1F25E0 JMP [!0C025H]





## 9. I/O PORTS

The HMS87C1816B has five ports, RA, RB, RC,RD and RE. These ports pins may be multiplexed with an alternate function for the peripheral features on the device. In general, when initial reset state, all ports are used as a general purpose input port.

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

Reading data register reads the status of the pins whereas writing

## 9.1 RA and RAIO registers

RA is an 8-bit bidirectional I/O port (address  $C0_H$ ). Each port can be set individually as input and output through the RAIO register (address  $C1_H$ ).

RA7~RA1 ports are multiplexed with Analog Input Port (AN7~AN1) and RA0 port is multiplexed with Event Counter Input Port (EC0).



Figure 9-2 Registers of Port RA



Figure 9-1 Example of port I/O assignment

The control register RAFUNC (address CA<sub>H</sub>) controls to select alternate function. After reset, this value is "0", port may be used as general I/O ports. To select alternate function such as Analog Input or External Event Counter Input, write "1" to the corresponding bit of RAFUNC.Regardless of the direction register RAIO, RAFUNC is selected to use as alternate functions, port pin can be used as a corresponding alternate features (RA0/EC0 is controlled by T0CK2~0 of TM0)

| PORT                 | RAFUNC.7~0 | Description           |
|----------------------|------------|-----------------------|
|                      | 0          | RA7 (Normal I/O Port) |
| RA7/AN7              | 1          | AN7 (ADS2~0=111)      |
| RA6/AN6              | 0          | RA6 (Normal I/O Port) |
| KA0/ANO              | 1          | AN6 (ADS2~0=110)      |
| DAGANG               | 0          | RA5 (Normal I/O Port) |
| RA5/AN5              | 1          | AN5 (ADS2~0=101)      |
|                      | 0          | RA4 (Normal I/O Port) |
| RA4/AN4              | 1          | AN4 (ADS2~0=100)      |
| DAGANO               | 0          | RA3 (Normal I/O Port) |
| RA3/AN3              | 1          | AN3 (ADS2~0=011)      |
| RA2/AN2              | 0          | RA2 (Normal I/O Port) |
| RAZ/ANZ              | 1          | AN2 (ADS2~0=010)      |
| RA1/AN1              | 0          | RA1 (Normal I/O Port) |
| KA I/AN I            | 1          | AN1 (ADS2~0=001)      |
| RA0/EC0 <sup>1</sup> |            | RA0 (Normal I/O Port) |
| KAU/ECU'             |            | EC0 (T0CK2~0=111)     |

 This port is not an Analog Input port, but Event Counter clock source input port. ECO is controlled by setting TOCK2~0 = 111. The bit RAFUNC.0 (ANSEL0) controls the RB0/AN0/AVref port (Refer to Port RB).

## 9.2 RB and RBIO registers

RB is an 8-bit bidirectional I/O port (address  $C2_H$ ). Each pin can be set individually as input and output through the RBIO register (address  $C3_H$ ). In addition, Port RB is multiplexed with various special features. The control register RBFUNC (address  $CB_H$ ) controls to select alternate function. After reset, this value is "0", port may be used as general I/O ports. To select alternate function such as External interrupt or Timer compare output, write "1" to the corresponding bit of RBFUNC.





Regardless of the direction register RBIO, RBFUNC is selected to use as alternate functions, port pin can be used as a correspond-

ing alternate features.

| PORT           | RBFUNC.4~0     | Description                              |
|----------------|----------------|------------------------------------------|
| RB7/           | 0              | RB7 (Normal I/O Port)                    |
| TMR2OV         | 1              | Timer2 Overflow Output                   |
| RB6/FC1        | 0              | RB6 (Normal I/O Port)                    |
| RB0/ECT        | 1              | Event Counter 1 Input                    |
| RB5/           | 0              | RB5 (Normal I/O Port)                    |
| PWM1/<br>COMP1 | 1              | PWM1 Output /<br>Timer3 Compare Output   |
| RB4/           | 0              | RB4 (Normal I/O Port)                    |
| PWM0/<br>COMP0 | 1              | PWM0 Output /<br>Timer1 Compare Output   |
|                | 0              | RB3 (Normal I/O Port)                    |
| RB3/INT1       | 1              | External Interrupt Input 1               |
|                | 0              | RB2 (Normal I/O Port)                    |
| RB2/INT0       | 1              | External Interrupt Input 0               |
|                | 0              | RB1 (Normal I/O Port)                    |
| RB1/BUZ        | 1              | Buzzer Output                            |
| RB0/AN0/       | 01             | RB0 (Normal I/O Port)/<br>AN0 (ANSEL0=1) |
| AVref          | 1 <sup>2</sup> | External Analog Reference<br>Voltage     |

1. When ANSEL0 = "0", this port is defined for normal I/O port (RB0).

When ANSEL0 = "1" and ADS2~0 = "000", this port can be used Analog Input Port (AN0). 2. When this bit set to "1", this port defined for AVref, so it can

 When this bit set to "1", this port defined for AVref, so it can not be used Analog Input Port AN0 and Normal I/O Port RB0.

### 9.3 RC and RCIO registers

RC is an 8-bit bidirectional I/O port (address  $C4_H$ ). Each pin can be set individually as input and output through the RCIO register (address  $C5_H$ ).

In addition, Port RC is multiplexed with Serial Peripheral Interface (SPI).

The control register SIOM (address  ${\rm E0}_{\rm H})$  controls to select Serial Peripheral Interface function.

After reset, the RCIO register value is "0", port may be used as general I/O ports. To select Serial Peripheral Interface function, write "1" to the corresponding bit of SIOM.



### Figure 9-4 Registers of Port RC

| DODT         | <b>Function</b> |      | SIOM     |            | Deceristics                   |
|--------------|-----------------|------|----------|------------|-------------------------------|
| PORT         | Function        | SRDY | SM [1:0] | SCK [1:0]  | Description                   |
| RC6/         | RC6             | х    | X:0      | X:X        | RC6 (Normal I/O Port)         |
| SOUT         | SOUT            | х    | X:1      | X:X        | SPI Serial Data Output        |
| RC5/         | RC5             | х    | 0:X      | X:X        | RC5 (Normal I/O Port)         |
| SIN          | SIN             | х    | 1:X      | X:X        | SPI Serial Data Input         |
|              | RC4             | х    | 0:0      | X:X        | RC4 (Normal I/O Port)         |
| RC4/<br>SCK  | SCKO            | х    | 0:0      | 00, 01, 10 | SPI Synchronous Clock Output  |
| 0011         | SCKI            | х    | 0:0      | 1:1        | SPI Synchronous Clock Input   |
|              | RC3             | 0    | X:X      | X:X        | RC3 (Normal I/O Port)         |
| RC3/<br>SRDY | SRDYIN          | 1    | X:X      | 00, 01, 10 | SPI Ready Input (Master Mode) |
| C. (D)       | SRDYOUT         | 1    | X:X      | 1:1        | SPI Ready Output (Slave Mode) |

Table 9-1 Serial Communication Functions in RC Port

## 9.4 RD and RDIO registers

RD is an 8-bit bidirectional I/O port (address  $C6_H$ ). Each pin can be set individually as input and output through the RDIO register

(address C7<sub>H</sub>).



Figure 9-5 Registers of Port RD

In addition, Port RD is multiplexed with external interrupt input function. The control register RDFUNC (address  $CD_H$ ) controls to select alternate function. After reset, this value is "0", port may be used as general I/O ports. To select alternate function, write "1" to the corresponding bit of RDFUNC.

## 9.5 RE and REIO registers

RE is a 7-bit bidirectional I/O port (address  $C8_{H}$ ). Each pin can be set individually as input and output through the REIO register

Regardless of the direction register RDIO, RDFUNC is selected to use as external interrupt input function, port pin can be used as a interrupt input feature.

(address C9<sub>H</sub>).



Figure 9-6 Registers of Port RE

## **10. CLOCK GENERATOR**

The clock generator produces the basic clock pulses which provide the system clock to be supplied to the CPU and peripheral hardware. The main system clock oscillator oscillates with a crystal resonator or a ceramic resonator connected to the Xin and Xout pins. External clocks can be input to the main system clock oscillator. In this case, input a clock signal to the Xin pin and open the Xout pin.



Figure 10-1 Block Diagram of Clock Pulse Generator

### **10.1 Oscillation Circuit**

 $\rm X_{IN}$  and  $\rm 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-2 .



Figure 10-2 Oscillator Connections

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 compo-



**Figure 10-3 External Clock Connections** 

**Note:** When using a system clock oscillator, carry out wiring in the broken line area in Figure 10-2 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.

In addition, the HMS87C1X04B/08B/16B has an ability for the external RC oscillated operation. It offers additional cost savings for **timing insensitive applications**. The RC oscillator frequency is a function of the supply voltage, the external resistor ( $R_{EXT}$ ) and capacitor ( $C_{EXT}$ ) values, and the operating temperature.

### HMS87C1X04B/08B/16B

The user needs to take into account variation due to tolerance of external R and C components used.

Figure 10-4 shows how the RC combination is connected to the HMS87C1X04B/08B/16B.



Figure 10-4 RC Oscillator Connections

External capacitor ( $C_{EXT}$ ) can be omitted for more cost saving. However, the characteristics of external R only oscillation are more variable than external RC oscillation.



Figure 10-5 R Oscillator Connections

The oscillator frequency, divided by 4, is output from the Xout pin, and can be used for test purpose or to synchronize other logic.

To set the RC oscillation, it should be programmed RC\_osc bit of the configuration memory (CONFIG : 707Fh) to "1". ( Refer to Section "21.3". )

In addition to external crystal/resonator and external RC/R oscillation, the HMS81C1X04B/08B/16B provides the internal 4MHz oscillation. The internal 4MHz oscillation needs no external parts.





Figure 10-6 Internal 4MHz Connections

To use the internal 4MHz oscillation, it should be programmed ONPb bit and IN\_CLK bit of the configuration memory (CON-FIG : 707FH) to "0" and "1" respectively. ( Refer to Section "21.3". )

## 11. Basic Interval Timer

The HMS87C1X04B/08B/16B has one 8-bit Basic Interval Timer that is free-run, can not stop. Block diagram is shown in Figure 11-1 .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 overflows from  $FF_H$  to  $00_H$ , this overflow causes to generate the Basic interval timer interrupt. The BITIF is interrupt request flag of Basic interval timer.

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 WAKE-UP of CKCTLR, it goes into the wake-up timer mode. In this mode, all of the block is halted except the oscillator, prescaler (only fxin÷2048) and Timer0.

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

**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 | - WAKEUI                                                                                                         | RCWDT                                                                            | WDTON | BTCL | BTS2 | BTS1 | BTS0                             | ADDRESS : ECH<br>RESET VALUE : -001_0111<br>Bit Manipulation Not Availab |
|--------|------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|-------|------|------|------|----------------------------------|--------------------------------------------------------------------------|
|        |                                                                                                                  |                                                                                  |       |      |      |      | Basic Interv                     | al Timer Clock Selection                                                 |
| Symbol |                                                                                                                  | Function Description                                                             |       |      |      |      | 000 : fxin ÷                     | 8                                                                        |
| WAKEUP |                                                                                                                  | 1 : Enables Wake-up Timer<br>0 : Disables Wake-up Timer                          |       |      |      |      | 001 : fxin ÷<br>010 : fxin ÷     |                                                                          |
| RCWDT  |                                                                                                                  | 1 : Enables Internal RC Watchdog Timer<br>0 : Disables Internal RC Watchdog Time |       |      |      |      | 011 : fxin ÷<br>100 : fxin ÷     |                                                                          |
| WDTON  | 1 : Enables Watchdog Timer<br>0 : Operates as a 7-bit Timer                                                      |                                                                                  |       |      |      |      | 101 : fxin ÷ :<br>110 : fxin ÷ : |                                                                          |
| BTCL   | 1 : BITR is cleared and BTCL becomes "0" automatically<br>after one machine cycle, and BITR continue to count-up |                                                                                  |       |      | ,    |      | 111 : fxin ÷                     | 1024                                                                     |

Figure 11-2 CKCTLR: Clock Control Register

## 12. TIMER / COUNTER

The HMS87C1X04B/08B/16B has four 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 the two 8-bit Timer/Counter or one 16-bit Timer/Counter by combining them. Also Timer 2 and Timer 3 are same. In this document, explain Timer 0 and Timer 1 because Timer2 and Timer3 same with Timer 0 and Timer 1.

In the "timer" function, the register is increased every internal clock input. Thus, one can think of it as counting internal clock input. Since the least clock consists of 2 and the most clock consists of 2048 oscillator periods, the count rate is 1/2 to 1/2048 of the oscillator frequency in Timer0. And Timer1 can use the same clock source too. In addition, Timer1 has more fast clock source (1/1 to 1/8).

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(Timer 0) or EC1(Timer 2).

**Note:** In the external event counter function, the RA0/EC0 pin has not a schmitt trigger, but a normal input port. Therefore, it may be count more than input event signal if the noise interfere in slow transition input signal.

In addition the "capture" function, the register is increased in response external interrupt same with timer function. When external interrupt edge input, the count register is captured into capture data register CDRx.

Timer1 and Timer 3 are shared with "PWM" function and "Compare output" function

It has seven operating modes: "8-bit timer/counter", "16-bit timer/counter", "8-bit capture", "16-bit capture", "8-bit compare output", "16-bit compare output" and "10-bit PWM" which are selected by bit in Timer mode register TMx as shown in Figure 12-1 and Table 12-1.

| TM0(2)                 | -                                                                                                                                                                                      | -                                               | CAPx  | TxCK2        | TxCK1        | TxCK0                                       | TxCN                                        | TxST                                           | ADDRESS : D0H (D6H for TM2)<br>RESET VALUE :00_0000    |
|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|-------|--------------|--------------|---------------------------------------------|---------------------------------------------|------------------------------------------------|--------------------------------------------------------|
| CAP0<br>CAP2           | 0 : Disa                                                                                                                                                                               | <u>e mode sel</u><br>ables Captu<br>ables Captu | ure   |              |              | T0CN<br>T2CN                                | 0 : Sto                                     | nue control b<br>op counting<br>art counting o | _                                                      |
| T0CK[2:0]<br>T2CK[2:0] | Input clock selection<br>000 : fxin ÷ 2, 100 : fxin ÷ 128<br>001 : fxin ÷ 4, 101 : fxin ÷ 512<br>010 : fxin ÷ 8, 110 : fxin ÷ 2048<br>011 : fxin ÷ 32, 111 : External Event ( EC0(1) ) |                                                 |       |              | TOST<br>T2ST | 0 : Sto                                     | control bit<br>op counting<br>unter registe | r is cleared and start again                   |                                                        |
| Timer 1(3) Moc         | le Registe                                                                                                                                                                             | r                                               |       |              |              |                                             |                                             |                                                |                                                        |
| TM1(3)                 | POL                                                                                                                                                                                    | 16BIT                                           | PWMxE | CAPx         | TxCK1        | TxCK0                                       | TxCN                                        | TxST                                           | ADDRESS : D2H (D8H for TM3)<br>RESET VALUE : 0000_0000 |
| POL                    | <u>PWM Output Polarity</u><br>0 : Duty active low<br>1 : Duty active high                                                                                                              |                                                 |       |              |              | T1CK[2:0<br>T3CK[2:0                        | j 00 : fx                                   |                                                | on<br>) : fxin ÷ 8<br>: using the Timer 0 clock        |
| 16BIT                  | <u>16-bit mode selection</u><br>0 : 8-bit mode<br>1 : 16-bit mode                                                                                                                      |                                                 |       |              |              | T1CN<br>T3CN                                | 0 : Sto                                     | nue control b<br>op counting<br>art counting o | <u>it</u><br>continuously                              |
|                        | <u>PWM enable bit</u><br>0 : Disables PWM<br>1 : Enables PWM                                                                                                                           |                                                 |       | T1ST<br>T3ST | 0 : Sto      | control bit<br>op counting<br>unter registe | er is cleared and start again               |                                                |                                                        |
| PWM0E<br>PWM1E         | 1 : Enal                                                                                                                                                                               | Dies Pyvivi                                     |       |              |              |                                             |                                             |                                                | 0                                                      |

Figure 12-1 Timer Mode Register (TMx, x = 0~3)

# MagnaChip•

| 16BIT | CAP0           | CAP1 | PWME | T0CK[2:0] | T1CK[1:0] | PWMO | TIMER 0               | TIMER1               |
|-------|----------------|------|------|-----------|-----------|------|-----------------------|----------------------|
| 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         | 8-bit Compare output |
| 0     | X <sup>1</sup> | 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              | Х    | 0    | XXX       | 11        | 0    | 16-bit Capture        |                      |
| 1     | 0              | 0    | 0    | XXX       | 11        | 1    | 16-bit Compare output |                      |

### Table 12-1 Operating Modes of Timer 0 and Timer 1

1. X: The value "0" or "1" corresponding your operation.

## 12.1 8-bit Timer/Counter Mode

The HMS87C1X04B/08B/16B has four 8-bit Timer/Counters, Timer 0, Timer 1, Timer 2 and Timer 3, as shown in Figure 12-2 .

TMx as shown in Figure 12-1 and Table 12-1. To use as an 8-bit timer/counter mode, bit CAP0 of TM0 is cleared to "0" and bits 16BIT of TM1 should be cleared to "0"(Table 12-1).



Figure 12-2 8-bit Timer / Counter Mode

These timers have each 8-bit count register and data register. The

count register is increased by every internal or external clock in-

put. The internal clock has a prescaler divide ratio option of 2, 4, 8, 32,128, 512, 2048 (selected by control bits T0CK2, T0CK1 and T0CK0 of register TM0) and 1, 2, 8 (selected by control bits T1CK1 and T1CK0 of register TM1). In the Timer 0, timer register T0 increases from  $00_{\rm H}$  until it matches TDR0 and then reset to  $00_{\rm H}$ . The match output of Timer 0 generates Timer 0 interrupt (latched in T0F bit). As TDRx and Tx register are in same ad-

dress, when reading it as a Tx, written to TDRx.

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 RA0 of the RA Direction Register RAIO is set to "0". The Timer 0 can be used as a counter by pin EC0 input, but Timer 1 can not.



Figure 12-3 Counting Example of Timer Data Registers



Figure 12-4 Timer Count Operation

### 12.2 16-bit Timer/Counter Mode

The Timer register is being run with 16 bits. A 16-bit timer/coun-

ter register T0, T1 are increased from  $0000_{\rm H}$  until it matches

## MagnaChip•

TDR0, TDR1 and then resets to  $0000_{\text{H}}$ . The match output generates Timer 0 interrupt not Timer 1 interrupt.

In 16-bit mode, the bits T1CK1,T1CK0 and 16BIT of TM1 should be set to "1" respectively.

The clock source of the Timer 0 is selected either internal or external clock by bit T0CK2, T0CK1 and T0SL0.



Figure 12-5 16-bit Timer / Counter Mode

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

The HMS87C1X04B/08B/16B has a function of Timer Compare Output. To pulse out, the timer match can goes to port pin(COMP0) as shown in Figure 12-2 and Figure 12-5. Thus, pulse out is generated by the timer match. These operation is implemented to pin, RB4/COMP0/PWM.

This pin output the signal having a 50: 50 duty square wave, and

### 12.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 12-6.

As mentioned above, not only Timer 0 but Timer 1 can also be used as a capture mode.

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 output frequency is same as below equation.

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

In this mode, the bit PWMO of RB function register (RBFUNC) should be set to "1", and the bit PWME of timer1 mode register (TM1) should be set to "0".

In addition, 16-bit Compare output mode is available, also.

#### (T1) increases and matches TDR0 (TDR1).

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

For example, in Figure 12-8, the pulse width of captured signal is wider than the timer data value (FF<sub>H</sub>) over 2 times. When external interrupt is occurred, the captured value ( $13_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), to be captured into registers CDRx (CDR0, CDR1), 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 External interrupt section). In addition, the transition at INTx pin generate an interrupt.

**Note:** The CDRx, TDRx and Tx are in same address. In the capture mode, reading operation read the CDRx, not Tx because the reading path is opened to the CDRx, and TDRx is read while writing operation executed.



Figure 12-6 8-bit Capture Mode

# MagnaChip



Figure 12-7 Input Capture Operation





### 12.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 T0CK2, T0CK1 and T0CK0.

In 16-bit mode, the bits T1CK1,T1CK0 and 16BIT of TM1 should be set to "1" respectively.



Figure 12-9 16-bit Capture Mode

### 12.6 PWM Mode

The HMS87C1X04B/08B/16B has a two high speed PWM (Pulse Width Modulation) functions which shared with Timer1 (Timer 3). In this document, it will be explained only PWM0.

In PWM mode, pin RB4/COMP0/PWM0 outputs up to a 10-bit resolution PWM output. This pin should be configure as a PWM output by setting "1" bit PWM00 in RBFUNC register. (PWM1 output by setting "1" bit PWM10 in RBFUNC)

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

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

The T1PDR is configure as a double buffering for glitchless PWM output. In Figure 12-10, 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)

## PWM Period = [PWM0HR[3:2]T1PPR] X Source Clock PWM Duty = [PWM0HR[1:0]T1PDR] X Source Clock

The relation of frequency and resolution is in inverse proportion. Table 12-1 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(125nS) | T1CK[1:0] =<br>01(250nS) | T1CK[1:0] =<br>10(1uS) |  |  |
| 10-bit     | 7.8KHz                   | 3.9KHz                   | 0.98KHZ                |  |  |
| 9-bit      | 15.6KHz                  | 7.8KHz                   | 1.95KHz                |  |  |
| 8-bit      | 31.2KHz                  | 15.6KHz                  | 3.90KHz                |  |  |
| 7-bit      | 62.5KHz                  | 31.2KHz                  | 7.81KHz                |  |  |

### Table 12-1 PWM Frequency vs. Resolution at 8MHz

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 12-12. 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, the timer should be stop and set to PWM mode (PWME = 1) firstly, and then set period and duty register value. When user writes register values while timer is in operation, these register could be set with certain values. If user sets the T1PPR, T1PDR register value with PWM mode being disabled, the T1PPR and T1PDR can not be accessed because these registers act as TDR1 and T1/CDR1 register in non-PWM mode. Ex) LDM TM1,#0010 0000b

| LDM | TM1,#0010_0000b    |
|-----|--------------------|
| LDM | T1PPR,#0EH         |
| LDM | T1PDR,#05H         |
| LDM | PWM0HR,#00H        |
| LDM | RBFUNC,#0001_1100B |
| LDM | TM1,#1010_1011B    |
|     |                    |



Figure 12-10 PWM Mode

### HMS87C1X04B/08B/16B







Figure 12-12 Example of Changing the Period in Absolute Duty Cycle (@8MHz)

MagnaChip

## **13. Serial Peripheral Interface**

The Serial Peripheral Interface (SPI) module is a serial interface useful for communicating with other peripheral of microcontrol-

ler devices. These peripheral devices may be serial EEPROMs, shift registers, display drivers, A/D converters, etc.



Figure 13-1 SPI Registers and Block Diagram

### HMS87C1X04B/08B/16B

The SPI allows 8-bits of data to be synchronously transmitted and received. To accomplish communication, typically three pins are used:

| - Serial Data In  | RC5/SIN  |
|-------------------|----------|
| - Serial Data Out | RC6/SOUT |
| - Serial Clock    | RC4/SCK  |

- Serial Transfer Ready

In addition to those pins, a fourth pin may be used when in a master or a slave mode of operation:

RC3/SRDYIN/SRDYOUT

The serial data transfer operation mode is decided by setting the SM1 and SM0 of SPI Mode Control Register, and the transfer clock rate is decided by setting the SCK1 and SCK0 of SPI Mode Control Register as shown in Figure 13-1. And the polarity of transfer clock is selected by setting the POL.

The bit SRDY is used for master / slave selection. If this bit is set to "1" and SCK[1:0] is set to "11", the controller is performed to slave controller. As it were, the port RC3 is served for  $\overline{\text{SRDY-OUT.}}$ 



Figure 13-2 SPI Timing Diagram (without SRDY control)



Figure 13-3 SPI Timing Diagram (with SRDY control)

# MagnaChip•

The buzzer driver consists of 6-bit binary counter, the buzzer register BUR and the clock selector. It generates square-wave which is very wide range frequency (480 Hz $\sim$ 250 KHz at fxin = 4 MHz) by user programmable counter.

Pin RB1 is assigned for output port of Buzzer driver by setting the bit BUZO of RBFUNC to "1".

The 6-bit buzzer counter is cleared and start the counting by writing signal to the register BUR. It is increased from 00H until it matches 6-bit register BUR. Also, it is cleared by counter overflow and count up to output the square wave pulse of duty 50%.

The bit 0 to 5 of BUR determines output frequency for buzzer driving. Frequency calculation is following as shown below.

$$f_{BUZ}(Hz) = \frac{\text{Oscillator Frequency}}{2 \times \text{Prescaler Ratio} \times (BUR + 1)}$$

The bits BUCK1, BUCK0 of BUR selects the source clock from prescaler output.



Figure 14-1 Buzzer Driver

## **15. ANALOG TO DIGITAL CONVERTER**

The analog-to-digital converter (A/D) allows conversion of an analog input signal to a corresponding 8-bit digital value. The A/D module has eight 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 RBFUNC register. If external analog reference AVref is selected, the bit ANSEL0 should not be set to "1", because this pin is used to an analog reference of A/D converter.

The A/D module has two registers which are the control register ADCM and A/D result register ADCR. The ADCM register, shown in Figure 15-2, controls the operation of the A/D converter module. The port pins can be configure as analog inputs or digital I/O.

To use analog inputs, each port is assigned analog input port by setting the bit ANSEL[7:0] in RAFUNC register. And selected the corresponding channel to be converted by setting ADS[2:0].

The processing of conversion start when the start bit ADST is set to "1". After one cycle, it is cleared by hardware. The register ADCR contains the results of the A/D conversion. When the conversion is completed, the result is loaded into the ADCR, the A/ D conversion status bit ADSF is set to "1", and the A/D interrupt flag ADIF is set. The block diagram of the A/D module is shown in Figure 15-1. 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 maximum 10 uS (at fxin=8 MHz).



### Figure 15-1 A/D Converter Block Diagram

## MagnaChip•



Figure 15-2 A/D Converter Registers





#### A/D Converter Cautions

(1) Input range of AN0 to AN7

The input voltage of AN0 to AN7 should be within the specification range. In particular, if a voltage above VDD (or AVref) or below Vss 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 8-bit resolution, attention must be paid to noise on pins AVref (or VDD) and AN0 to AN7. Since the effect increases in proportion to the output impedance of the analog input source, it is recommended that a capacitor be connected externally as shown in Figure 15-4 in order to reduce noise.



### Figure 15-4 Analog Input Pin Connecting Capacitor

(3) Pins AN0/RB0 and AN1/RA1 to AN7/RA7

The analog input pins AN0 to AN7 also function as input/output

port (PORT RA and RB0) pins. When A/D conversion is performed with any of pins AN0 to AN7 selected, be sure not to execute a PORT input instruction 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) AVref pin input impedance

A series resistor string of approximately  $10K\Omega$  is connected between the AVref pin and the Vss pin.

Therefore, if the output impedance of the reference voltage source is high, this will result in parallel connection to the series resistor string between the AVref pin and the Vss pin, and there will be a large reference voltage error.

## **16. INTERRUPTS**

The HMS87C1X04B/08B/16B interrupt circuits consist of Interrupt enable register (IENH, IENL), Interrupt request flags of IRQH, IRQL, Interrupt Edge Selection Register (IEDS), priority circuit and Master enable flag("I" flag of PSW). The configuration of interrupt circuit is shown in Figure 16-1 and Interrupt priority is shown in Table 16-1.

The External Interrupts INT0, INT1, INT2 and INT3 can each be transition-activated (1-to-0, 0-to-1 and both transition).

The flags that actually generate these interrupts are bit INT0IF, INT1IF, INT2IF and INT3IF in Register IRQH. When an external interrupt is generated, the flag that generated it is cleared by

the hardware when the service routine is vectored to only if the interrupt was transition-activated.

The Timer 0, Timer 1, Timer 2 and Timer 3 Interrupts are generated by T0IF, T1IF, T2IF and T3IF, which are set by a match in their respective timer/counter register. The AD converter Interrupt is generated by ADIF which is set by finishing the analog to digital conversion. The Watch dog timer Interrupt is generated by WDTIF which set by a match in Watch dog timer register (when the bit WDTON is set to "0"). The Basic Interval Timer Interrupt is generated by BITIF which is set by a overflowing of the Basic Interval Timer Register(BITR).



Figure 16-1 Block Diagram of Interrupt Function

The interrupts are controlled by the interrupt master enable flag I-flag (bit 2 of PSW), the interrupt enable register (IENH, IENL) and the interrupt request flags (in IRQH, IRQL) except Power-on reset and software BRK interrupt.

Interrupt enable registers are shown in Figure 16-2. These registers are composed of interrupt enable flags of each interrupt source, 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.

| Reset/Interrupt      | Symbol  | Priority | Vector Addr.      |
|----------------------|---------|----------|-------------------|
| Hardware Reset       | RESET   | -        | FFFE <sub>H</sub> |
| External Interrupt 0 | INT0    | 1        | FFFA <sub>H</sub> |
| External Interrupt 1 | INT1    | 2        | FFF8 <sub>H</sub> |
| Timer 0              | Timer 0 | 3        | FFF6 <sub>H</sub> |
| Timer 1              | Timer 1 | 4        | FFF4 <sub>H</sub> |
| External Interrupt 2 | INT2    | 5        | FFF2 <sub>H</sub> |
| External Interrupt 3 | INT3    | 6        | FFF0 <sub>H</sub> |
| Timer 2              | Timer 2 | 7        | FFEE <sub>H</sub> |
| Timer 3              | Timer 3 | 8        | FFECH             |
| A/D Converter        | A/D C   | 9        | FFEA <sub>H</sub> |
| Watch Dog Timer      | WDT     | 10       | FFE8 <sub>H</sub> |
| Basic Interval Timer | BIT     | 11       | FFE6 <sub>H</sub> |
| Serial Interface     | SPI     | 12       | FFE4 <sub>H</sub> |

Table 16-1 Interrupt Priority



Figure 16-2 Interrupt Enable Registers and Interrupt Request Registers

When an interrupt is occurred, the I-flag is cleared and disable any further interrupt, the return address and PSW are pushed into the stack and the PC is vectored to. Once in the interrupt service routine the source(s) of the interrupt can be determined by polling the interrupt request flag bits. The interrupt request flag bit(s) must be cleared by software before re-enabling interrupts to avoid recursive interrupts. The Interrupt Request flags are able to be read and written.

### **16.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  $f_{OSC}$  (2  $\mu$ s at  $f_{XIN}$ =4MHz) after the completion of the current instruction execution. The interrupt service task is terminated upon execution of an interrupt return instruction [RETI].

### 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. Interrupt request flag for the interrupt source accepted is cleared to "0".
- 3. The contents of the program counter (return address) and the program status word are saved (pushed) onto the stack area. The stack pointer decreases 3 times.
- 4. 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.
- 5. The instruction stored at the entry address of the interrupt service program is executed.



Figure 16-3 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.

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.

### 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 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



General-purpose register save/restore using push and pop instructions;

### 16.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 16-4 .





Figure 16-4 Execution of BRK/TCALL0

### 16.3 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 Iflag in interrupt routine, some further interrupt can be serviced even if certain interrupt is in progress.

# MagnaChip•



Figure 16-5 Execution of Multi Interrupt

Example: Even though Timer1 interrupt is in progress, INT0 interrupt serviced without any suspend.

| TIMER1: | PUSH<br>PUSH<br>PUSH<br>LDM<br>EI<br>:<br>: | A<br>X<br>Y<br>IENH,#80H<br>IENL,#0             | ; Enable INT0 only<br>; Disable other<br>; Enable Interrupt |
|---------|---------------------------------------------|-------------------------------------------------|-------------------------------------------------------------|
|         | :<br>:<br>LDM<br>POP<br>POP<br>POP<br>RETI  | <b>ienh,#Offh<br/>ienl,#Offh</b><br>Y<br>X<br>A | ; Enable all interrupts                                     |

## 16.4 External Interrupt

The external interrupt on INT0, INT1, INT2 and INT3 pins are edge triggered depending on the edge selection register IEDS (address  $0E6_{\rm H}$ ) as shown in Figure 16-6.

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



Figure 16-6 External Interrupt Block Diagram



Example: To use as an INT0 and INT2



### **Response Time**

The INT0, INT1,INT2 and INT3 edge are latched into INT0IF, INT1IF, INT2IF and 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.



shows interrupt response timings.



Figure 16-7 Interrupt Response Timing Diagram

## **17. WATCHDOG TIMER**

The purpose of the watchdog timer is to detect the malfunction (runaway) of program due to external noise or other causes and return the operation to the normal condition.

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 Xin pin. It means that the watchdog timer will run, even if the clock on the Xin 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 WDT 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 STOP ; enter the STOP mode NOP NOP ; RC-osc WDT running :

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

$$T_{RCWDT} = CLK_{RC} \times 2^{8} \times [WDTR.6 - 0] + (CLK_{RC} \times 2^{8})/2$$
  
where,  $CLK_{RC} = 40 - 120uS$ 

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

### $T_{WDT} = [WDTR.6 \sim 0] \times Interval of BIT$



Figure 17-1 Block Diagram of Watchdog Timer

## 18. Power Saving Mode

For applications where power consumption is a critical factor, this device provides two kinds of power saving functions, STOP mode and Wake-up Timer mode.

The power saving function is activated by execution of STOP in-

struction after setting the corresponding status (WAKEUP) of CKCTLR.

Table 18-1 shows the status of each Power Saving Mode.

| Peripheral                     | STOP                                | Wake-up Timer                                       |
|--------------------------------|-------------------------------------|-----------------------------------------------------|
| RAM                            | Retain                              | Retain                                              |
| Control Registers              | Retain                              | Retain                                              |
| I/O Ports                      | Retain                              | Retain                                              |
| CPU                            | Stop                                | Stop                                                |
| Timer0, Timer2                 | Stop                                | Operation                                           |
| Oscillation                    | Stop                                | Oscillation                                         |
| Prescaler                      | Stop                                | ÷ 2048 only                                         |
| Entering Condition<br>[WAKEUP] | 0                                   | 1                                                   |
| Release Sources                | RESET, RCWDT, INT0~3,<br>EC0~1, SPI | RESET, RCWDT, INT0~3,<br>EC0~1, SPI, TIMER0, TIMER2 |

### Table 18-1 Power Saving Mode

### 18.1 Stop Mode

In the Stop mode, the on-chip oscillator is stopped. 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.

The Stop mode is activated by execution of STOP instruction after clearing the bit WAKEUP of CKCTLR to "0". (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)

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.

| <b>Note:</b> After STOP instruction, at least two or more NOP instruction should be written |                           |                    |
|---------------------------------------------------------------------------------------------|---------------------------|--------------------|
| Ex)                                                                                         | LDM<br>STOP<br>NOP<br>NOP | CKCTLR,#0000_1110B |

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.

### Release the STOP mode

The exit from STOP mode is hardware reset or external interrupt. 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-1)

By reset, exit from Stop mode is shown in Figure 18-3 . When exit from Stop mode by external interrupt, enough oscillation stabilization time is required to normal operation. Figure 18-2 shows the timing diagram. When release the Stop 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 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.



Figure 18-1 STOP Releasing Flow by Interrupts



Figure 18-2 Timing of STOP Mode Release by External Interrupt



## 18.2 STOP Mode using Internal RCWDT

In the STOP mode using Internal RC-Oscillated Watchdog Timer, 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 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:** After STOP instruction, at least two or more NOP instruction should be written

| Ex) | LDM WDTR,#1111_1111B   |
|-----|------------------------|
|     | LDM CKCTLR,#0010_1110B |
|     | STOP                   |
|     | NOP                    |
|     | NOP                    |
|     |                        |

#### Release the STOP mode using internal RCWDT

The exit from STOP mode using Internal RC-Oscillated Watchdog Timer is hardware reset or external interrupt. 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. 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 18-4) 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-5)

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-1 )

When exit from STOP mode using Internal RC-Oscillated Watchdog Timer by external interrupt, the oscillation stabilization time is required to normal operation. Figure 18-4 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_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 using internal RC-Oscillated Watchdog Timer is shown in Figure 18-5 .



Figure 18-4 STOP Mode Releasing by External Interrupt or WDT Interrupt(using RCWDT)



18.3 Wake-up Timer Mode

In the Wake-up Timer mode, the on-chip oscillator is not stopped. Except the Prescaler(only 2048 devided ratio), Timer0 and Timer2, 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. The Wake-up Timer mode is activated by execution of STOP instruction after setting the bit WAKEUP 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)

MagnaChip•

Ex)

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

LDM TDR0,#0FFH LDM TM0,#0001\_1011B LDM CKCTLR,#0100\_1110B STOP NOP NOP

In addition, the clock source of timer0 and timer2 should be selected to 2048 devided ratio. Otherwise, the wake-up function can not work. And the timer0 and timer2 can be operated as 16-bit timer with timer1 and timer3(refer to timer function). The period of wake-up function is varied by setting the timer data register0, TDR0 or timer data register2, TDR2.

#### Release the Wake-up Timer mode

The exit from Wake-up Timer mode is hardware reset, Timer0(Timer2) overflow or external interrupt. Reset re-defines all the Control registers but does not change the on-chip RAM. External interrupts and Timer0(Timer2) overflow allow both onchip 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-1)

When exit from Wake-up Timer mode by external interrupt or timer0(Timer2) overflow, the oscillation stabilizing time is not required to normal operation. Because this mode do not stop the on-chip oscillator shown as Figure 18-6.



Figure 18-6 Wake-up Timer Mode Releasing by

### **18.4 Minimizing Current Consumption**

The Stop mode is designed to reduce power consumption. To minimize current drawn during Stop mode, the user should turnoff output drivers that are sourcing or sinking current, if it is practical.

**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.

External Interrupt or Timer0(Timer2) Interrupt

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

First conseider the 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. Setting to High or Low is decided 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.



#### Figure 18-7 Application Example of Unused Input Port



Figure 18-8 Application Example of Unused Output Port

# 19. RESET

The reset input is the RESET pin, which is the input to a Schmitt Trigger. A reset is accomplished by holding the RESET pin low for at least 8 oscillator periods, while the oscillator running. After reset, 64ms (at 4 MHz) add with 7 oscillator periods are required to start execution as shown in Figure 19-1.

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 reading or testing it.

Initial state of each register is shown as Table 8-1.



Figure 19-1 Timing Diagram after RESET

A power-up example where  $\overline{\text{RESET}}$  is connected to external reset circuit is shown in Figure 19-2. V<sub>DD</sub> is allowed to rise and stabi-

lize before bringing  $\overline{\text{RESET}}$  high. The chip will actually come out of reset and start the Basic Interval Timer after  $\overline{\text{RESET}}$  goes high.



Figure 19-2 Time-out Sequence On Power-up

**Note:** When the device starts normal operation (exits the reset condition), device operating parameters (voltage, frequency, temperature, etc.) must be meet to ensure operation. If these conditions are not met, the device must be held in reset until the operating conditions are met

#### HMS87C1X04B/08B/16B



## Figure 19-3 EXTERNAL POWERON RESET CIRCUIT (FOR SLOW V<sub>DD</sub> POWER-UP)

#### Address Fail Reset

The Address Fail Reset is the function to reset the system by checking abnormal address or unwished address cauased by external noise, which couldn't be returned to normal operation and would be malfunction state. If the CPU fetch the instruction from beyond area not in main user area address  $C000_{H} \sim FFFF_{H}$ , in that case the address fail reset is occurred.



Figure 19-4 The opreation of Address Fail RESET

# 20. POWER FAIL PROCESSOR

The HMS87C1X04B/08B/16B has an on-chip power fail detection circuitry to immunize against power noise. A configuration register, PFDR, can enable (if clear/programmed) or disable (if set) the Power-fail Detect circuitry. If  $V_{DD}$  falls below 2.1~3.0V range for longer than 50 nS, the Power fail situation may reset

MCU according to PFS bit of PFDR.

As below PFDR register is not implemented on the in-circuit emulator, user can not experiment with it. Therefore, after final development of user program, this function may be experimented..



Figure 20-1 Power Fail Detector Register



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

### HMS87C1X04B/08B/16B



Figure 20-3 Power Fail Processor Situations

# 21. COUNTERMEASURE OF NOISE

## **21.1 Oscillation Noise Protector**

The Oscillation Noise Protector(ONP) is used to supply stable internal system clock by excluding the noise which could be entered into oscillator and recovery the oscillation fail. This function could be enabled or disabled by the bit[5] of Configuration Memory (707Fh).

tion Memory (707Fh). The ONP function is like below.

- Recovery the oscillation wave crushed or loss caused

by high frequency noise.

- Change system clock to the internal oscillation clock when the high frequency noise is continuing.
- Change system clock to the internal oscillation clock when the  $X_{IN}/X_{OUT}$  is shorted or opened, the main oscillation is stopped except by stop instruction and the low frequency noise is entered.



Figure 21-1 Block Diagram of ONP & OFP and Respective Wave Forms

## 21.2 Oscillation Fail Processor

The oscillation fail processor (OFP) can change the clock source from external to internal oscillator when the oscillation fail occured. This function could be enabled or disabled by the bit[3] of Configuration Memory (707Fh).

And this function can recover the external clock source when the external clock is recovered to normal state.

#### Xin\_opt Option

The X<sub>IN</sub>\_opt is the function to control the amount of noise to be cancelled which entered into noise canceller in ONP, according to external oscillator frequency. If the amount of noise to be cancelled is selected to 40nS by X<sub>IN</sub>\_opt, the noise canceller in ONP cancels the clock over 12.5MHz as a noise. And if the amount of noise to be cancelled is selected to 80nS by X<sub>IN</sub>\_opt, the noise

## 21.3 Device Configuration Area

The Program Memory is consisted of configuration memory and user program memory. The configration memory is used to set the environment of system. The device configuration area can be programmed or left unprogrammed to select device configuration canceller in ONP cancels the clock over 6.25MHz as a noise.

### **IN\_CLK** Option

The IN\_CLK Option is the function to operate the device by using the internal oscillator clock in ONP block as system clock. There is no need to connect the x-tal, resonator, RC and R externaly. The user only to connect the  $X_{IN}$  pin to  $V_{DD}$ . This function could be selected by the bit[4] of Configuration Memory (707Fh). The characteristics of internal oscillator clock has the period of 250ns±5% at  $V_{DD}$ =5V and 250ns±10% at whole operating voltage. After selecting the IN\_CLK Option, the period of internal oscillator clock could be checked by  $X_{OUT}$  outputting clock divided the internal oscillator clock by 4.

such as oscillation noise protector, internal 4MHz, amount of noise to be cancelled, security, RC-oscillation select bits. This area is not accessible during normal execution but is readable and writable during program / verify.

|        |      |      |      |        |       |         |      |        | ADDRESS           |
|--------|------|------|------|--------|-------|---------|------|--------|-------------------|
| CONFIG | AFR1 | AFR0 | ONPb | IN_CLK | LF_on | Xin_opt | Lock | RC_osc | 707F <sub>H</sub> |

#### Figure 21-2 Device Configuration Area

|        | Option  | Bit Data | Operation                                          | Remark                           |
|--------|---------|----------|----------------------------------------------------|----------------------------------|
|        |         | 01 or 10 | Address Fail RESET Disable                         | RESET the system when illegal    |
|        | AFR1,0  | 00 or 11 | Address Fail RESET Enable                          | address generated                |
|        |         | 0        | OSC Noise Protector Enable                         | OSC Noise Protector(ONP)         |
|        | ONPb    | 1        | OSC Noise Protector Disable                        | Operation En/Disable Bit         |
|        |         | 0        | Use the Inter 4MHz clock as the Device Osc Disable | Using the internal 4MHz clock    |
|        | IN_CLK  | 1        | Use the Inter 4MHz clock as the Device Osc Enable  | without external clock           |
| CONFIC |         | 0        | ONP Low Pass Filter (clock changer) Disable        | Change the Inter clock when      |
| CONFIG | LF_on   | 1        | ONP Low Pass Filter (clock changer) Enable         | oscillation failed               |
|        | Vin ont | 0        | 40nS noise cancel (Xin : 8MHz)                     | To select the amount of noise of |
|        | Xin_opt | 1        | 80nS noise cancel (Xin : 4MHz)                     | to be cancelled in ONP OSC.      |
|        | Look    | 0        | EPROM Data Read/Pgm Enable                         | Unlock or lock EPROM data        |
|        | Lock    | 1        | EPROM Data Read/Pgm Disable                        |                                  |
|        |         | 0        | X-tal or Ceramic Oscillation                       | Coloct appillation course        |
|        | RC_osc  | 1        | External RC/ R Oscillation                         | Select oscillation source        |

Table 21-1 Explanation of configration bits

# 21.4 Examples of ONP

| ONPb | IN_CLK | LF_on | Xin_opt | Description                                                                                                           |
|------|--------|-------|---------|-----------------------------------------------------------------------------------------------------------------------|
| 0    | 0      | 0     | 0       | 40ns noise canceller                                                                                                  |
| 0    | 0      | 0     | 1       | 80ns noise canceller                                                                                                  |
| 0    | 0      | 1     | 0       | 40ns noise canceller + change the clock source from external to internal 4MHz clock when oscillation failure occured. |
| 0    | 0      | 1     | 1       | 80ns noise canceller + change the clock source from external to internal 4MHz clock when oscillation failure occured  |
| 0    | 1      | Х     | Х       | using internal 4MHz oscillator regardless of external oscillator                                                      |
| 1    | Х      | Х     | Х       | ONP disable                                                                                                           |

Table 21-1 Examples of ONP

# 22. OTP PROGRAMMING

## 22.1 EPROM Mode

|         |        |                        |      | Pin D | escripti | on              |                 |                 |         |
|---------|--------|------------------------|------|-------|----------|-----------------|-----------------|-----------------|---------|
| Mo      | de     | A_D7~A_D0              | CTL0 | CTL1  | CTL2     | EPROM<br>Enable | V <sub>PP</sub> | V <sub>DD</sub> | Remarks |
|         |        | High Addr.<br>(A15~A8) | 0    | 0     | 0        | Н               | 11.5V           | 5.0V            |         |
| Program | Write  | Low Addr.<br>(A7~A0)   | 0    | 0     | 1        | Н               | 11.5V           | 5.0V            |         |
| riogram |        | Data In<br>(D7~D0)     | 0    | 1     | 1        | Н               | 11.5V           | 5.0V            |         |
|         | Verify | Data Out<br>(D7~D0)    | 0    | 1     | 0        | Н               | 11.5V           | 5.0V            |         |
|         |        |                        | 0    | 0     | 0        | Н               | 11.5V           | 5.0V            |         |
| Read    |        | Low Addr.<br>(A7~A0)   | 0    | 0     | 1        | Н               | 11.5V           | 5.0V            |         |
|         |        |                        | 0    | 1     | 0        | Н               | 11.5V           | 5.0V            |         |

#### Table 22-1 Description of EPROM mode



Figure 22-1 Pin Assignment

|       |            | Pin No. |       |       | User Mode        |                                 | EPROM MO                                   | DE         |            |    |
|-------|------------|---------|-------|-------|------------------|---------------------------------|--------------------------------------------|------------|------------|----|
| 14XXB | 15XXB      | 16XXB   | 17XXB | 18XXB | Pin Name         | Pin Name                        | De                                         | scriptio   | n          |    |
| 1     | 1          | 1       | 1     | 39    | RA4 (AN4)        | A_D4                            |                                            | A12        | A4         | D4 |
| 2     | 2          | 2       | 2     | 40    | RA5 (AN5)        | A_D5                            | Address Input                              | A13        | A5         | D5 |
| 3     | 3          | 3       | 3     | 41    | RA6 (AN6)        | A_D6                            | Data Input/Output                          | A14        | A6         | D6 |
| 4     | 4          | 4       | 4     | 42    | RA7 (AN7)        | A_D7                            |                                            | A15        | A7         | D7 |
| 5     | 5          | 5       | 5     | 43    | V <sub>DD</sub>  | V <sub>DD</sub>                 | Connect to V <sub>DD</sub> (5.0            | V)         |            |    |
| 6     | 6          | 6       | 6     | 44    | RB0 (AVref/AN0)  | CTL0                            |                                            |            |            |    |
| 7     | 7          | 7       | 7     | 1     | RB1 (BUZ)        | CTL1                            | Read/Write Control<br>Address/Data Control |            |            |    |
| 8     | 8          | 8       | 8     | 2     | RB2 (INT0)       | CTL2                            | Address/Data Conti                         | 01         |            |    |
| 19    | 25         | 33      | 35    | 31    | X <sub>IN</sub>  | EPROM Enable                    | High Active, Latch A                       | ddress in  | falling ed | ge |
| 20    | 26         | 34      | 36    | 32    | X <sub>OUT</sub> | NC                              | No connection                              |            |            |    |
| 21    | 27         | 35      | 37    | 33    | RESET            | V <sub>PP</sub>                 | Programming Powe                           | r (0V, 11. | 5V)        |    |
| 22    | 28         | 36      | 38    | 34    | V <sub>SS</sub>  | V <sub>SS</sub>                 | Connect to V <sub>SS</sub> (0V)            | )          |            |    |
| 25    | 29         | 37      | 39    | 35    | RA0 (EC0)        | A_D0                            |                                            | A8         | A0         | D0 |
| 26    | 30         | 38      | 40    | 36    | RA1 (AN1)        | A_D1                            | Address Input A9 A1                        |            | D1         |    |
| 27    | 31         | 39      | 41    | 37    | RA2 (AN2)        | A_D2                            | Data Input/Output                          | A10        | A2         | D2 |
| 28    | 32         | 40      | 42    | 38    | RA3 (AN3)        | A_D3                            |                                            | A11        | A3         | D3 |
|       | Other Pins |         |       | -     | V <sub>DD</sub>  | Connect to V <sub>DD</sub> (5.0 | V)                                         |            |            |    |

Table 22-2 Pin Description in EPROM Mode



Figure 22-2 Timing Diagram in Program (Write & Verify) Mode



Figure 22-3 Timing Diagram in READ Mode

| Parameter                                                  | Symbol            | MIN                | ТҮР     | MAX         | Unit |
|------------------------------------------------------------|-------------------|--------------------|---------|-------------|------|
| Programming Supply Current                                 | I <sub>VPP</sub>  | -                  | -       | 50          | mA   |
| Supply Current in EPROM Mode                               | I <sub>VDDP</sub> | -                  | -       | 20          | mA   |
| V <sub>PP</sub> Level during Programming                   | V <sub>IHP</sub>  | 11.25              | 11.5    | 11.75       | V    |
| V <sub>DD</sub> Level in Program Mode                      | V <sub>DD1H</sub> | 4.75               | 5       | 5.25        | V    |
| V <sub>DD</sub> Level in Read Mode                         | V <sub>DD2H</sub> | -                  | 3.0     | -           | V    |
| CTL2~0 High Level in EPROM Mode                            | V <sub>IHC</sub>  | $0.8V_{DD}$        | -       | -           | V    |
| CTL2~0 Low Level in EPROM Mode                             | V <sub>ILC</sub>  | -                  | -       | $0.2V_{DD}$ | V    |
| A_D7~A_D0 High Level in EPROM Mode                         | V <sub>IHAD</sub> | 0.9V <sub>DD</sub> | -       | -           | V    |
| A_D7~A_D0 Low Level in EPROM Mode                          | V <sub>ILAD</sub> | -                  | -       | $0.1V_{DD}$ | V    |
| V <sub>DD</sub> Saturation Time                            | T <sub>VDDS</sub> | 1                  | -       | -           | mS   |
| V <sub>PP</sub> Setup Time                                 | T <sub>VPPR</sub> | -                  | -       | 1           | mS   |
| V <sub>PP</sub> Saturation Time                            | T <sub>VPPS</sub> | 1                  | -       | -           | mS   |
| EPROM Enable Setup Time after Data Input                   | T <sub>SET1</sub> |                    | 200±10% |             | nS   |
| EPROM Enable Hold Time after T <sub>SET1</sub>             | T <sub>HLD1</sub> |                    | 500±10% |             | nS   |
| EPROM Enable Delay Time after T <sub>HLD1</sub>            | T <sub>DLY1</sub> |                    | 200±10% |             | nS   |
| EPROM Enable Hold Time in Write Mode                       | T <sub>HLD2</sub> |                    | 50±10%  |             | nS   |
| EPROM Enable Delay Time after T <sub>HLD2</sub>            | T <sub>DLY2</sub> |                    | 200±10% |             | nS   |
| CTL2,1 Setup Time after Low Address input and Data input   | T <sub>CD1</sub>  |                    | 100±10% |             | nS   |
| CTL1 Setup Time before Data output in Read and Verify Mode | T <sub>CD2</sub>  |                    | 100±10% |             | nS   |

Table 22-3 AC/DC Requirements for Program/Read Mode



Figure 22-4 Programming Flow Chart



Figure 22-5 Reading Flow Chart



# APPENDIX

# A. 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        |                |                  |                   | 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        |                |                  |                   | 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        |                |                  |                   | 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            |
| 111         | EI          |                |                  |                   | 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           |
| 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           |

# **B. INSTRUCTION SET**

## 1. ARITHMETIC/ LOGIC OPERATION

| NO. | MNEMONIC       | OP<br>CODE | BYTE<br>NO | CYCLE<br>NO | OPERATION                                                       | FLAG<br>NVGBHIZC |
|-----|----------------|------------|------------|-------------|-----------------------------------------------------------------|------------------|
| 1   | ADC #imm       | 04         | 2          | 2           | Add with carry.                                                 |                  |
| 2   | ADC dp         | 05         | 2          | 3           | $A \leftarrow (A) + (M) + C$                                    |                  |
| 3   | ADC dp + X     | 06         | 2          | 4           |                                                                 |                  |
| 4   | ADC !abs       | 07         | 3          | 4           |                                                                 | NVH-ZC           |
| 5   | ADC !abs + Y   | 15         | 3          | 5           |                                                                 |                  |
| 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           | Logical AND                                                     |                  |
| 10  | AND dp         | 85         | 2          | 3           | $A \leftarrow (A) \land (M)$                                    |                  |
| 11  | AND dp + X     | 86         | 2          | 4           |                                                                 |                  |
| 12  | AND !abs       | 87         | 3          | 4           |                                                                 | NZ-              |
| 13  | AND !abs + Y   | 95         | 3          | 5           |                                                                 |                  |
| 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                                               | NZC              |
| 19  | ASL dp + X     | 19         | 2          | 5           | < <u> &lt; "0"</u> |                  |
| 20  | ASL !abs       | 18         | 3          | 5           |                                                                 |                  |
| 21  | CMP #imm       | 44         | 2          | 2           | Compare accumulator contents with memory contents               |                  |
| 22  | CMP dp         | 45         | 2          | 3           | (A) - (M)                                                       |                  |
| 23  | CMP dp + X     | 46         | 2          | 4           |                                                                 |                  |
| 24  | CMP !abs       | 47         | 3          | 4           |                                                                 | NZC              |
| 25  | CMP !abs + Y   | 55         | 3          | 5           |                                                                 |                  |
| 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           | Compare X contents with memory contents                         |                  |
| 30  | CMPX dp        | 6C         | 2          | 3           | (X)-(M)                                                         | NZC              |
| 31  | CMPX !abs      | 7C         | 3          | 4           |                                                                 |                  |
| 32  | CMPY #imm      | 7E         | 2          | 2           | Compare Y contents with memory contents                         |                  |
| 33  | CMPY dp        | 8C         | 2          | 3           | (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            | DF         | 1          | 3           | Decimal adjust for addition                                     | NZC              |
| 37  | DAS            | CF         | 1          | 3           | Decimal adjust for subtraction                                  | NZC              |
| 38  | DEC A          | A8         | 1          | 2           | Decrement                                                       | NZ-              |
| 39  | DEC dp         | A9         | 2          | 4           | M ← (M)- 1                                                      |                  |
| 40  | DEC dp + X     | B9         | 2          | 5           |                                                                 | NZ-              |
| 41  | DEC !abs       | B8         | 3          | 5           |                                                                 |                  |
| 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-           |

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

## 2. REGISTER / MEMORY OPERATION

| NO. | MNEMONIC     | OP<br>CODE | BYTE<br>NO | CYCLE<br>NO | OPERATION                                                               | FLAG<br>NVGBHIZC |
|-----|--------------|------------|------------|-------------|-------------------------------------------------------------------------|------------------|
| 1   | LDA #imm     | C4         | 2          | 2           | Load accumulator                                                        |                  |
| 2   | LDA dp       | C5         | 2          | 3           | $A \leftarrow (M)$                                                      |                  |
| 3   | LDA dp + X   | C6         | 2          | 4           |                                                                         |                  |
| 4   | LDA !abs     | C7         | 3          | 4           |                                                                         |                  |
| 5   | LDA !abs + Y | D5         | 3          | 5           |                                                                         | 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           | Load X-register                                                         |                  |
| 12  | LDX dp       | CC         | 2          | 3           | X ← ( M )                                                               | NZ-              |
| 13  | LDX dp + Y   | CD         | 2          | 4           |                                                                         |                  |
| 14  | LDX !abs     | DC         | 3          | 4           |                                                                         |                  |
| 15  | LDY #imm     | 3E         | 2          | 2           | Load Y-register                                                         |                  |
| 16  | LDY dp       | C9         | 2          | 3           | $Y \leftarrow (M)$                                                      | NZ-              |
| 17  | LDY dp + X   | D9         | 2          | 4           |                                                                         |                  |
| 18  | LDY !abs     | D8         | 3          | 4           |                                                                         |                  |
| 19  | STA dp       | E5         | 2          | 4           | Store accumulator contents in memory                                    |                  |
| 20  | STA dp + X   | E6         | 2          | 5           | ( M ) ← A                                                               |                  |
| 21  | STA !abs     | E7         | 3          | 5           |                                                                         |                  |
| 22  | STA !abs + Y | F5         | 3          | 6           |                                                                         |                  |
| 23  | STA [dp + X] | F6         | 2          | 7           |                                                                         |                  |
| 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           | Store X-register contents in memory                                     |                  |
| 28  | STX dp + Y   | ED         | 2          | 5           | (M) ← X                                                                 |                  |
| 29  | STX !abs     | FC         | 3          | 5           |                                                                         |                  |
| 30  | STY dp       | E9         | 2          | 4           | Store Y-register contents in memory                                     |                  |
| 31  | STY dp + X   | F9         | 2          | 5           | (M) ← Y                                                                 |                  |
| 32  | STY !abs     | F8         | 3          | 5           |                                                                         |                  |
| 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$    |                  |

## **3. 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 ← ( 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) ← ( dp+1) ( dp) - 1              | NZ-              |
| 4   | INCW dp  | 9D         | 2          | 6           | Increment memory pair<br>( dp+1) ( dp) ← ( dp+1) ( dp ) + 1            | NZ-              |
| 5   | LDYA dp  | 7D         | 2          | 5           | Load YA<br>YA $\leftarrow$ (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           |

## 4. 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)                                 | С                |
| 2   | AND1B M.bit | 8B         | 3          | 4           | Bit AND C-flag and NOT $: C \leftarrow (C) \land \sim (M.bit)$                      | С                |
| 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)$    |                  |
| 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)$                         | С                |
| 11  | EOR1B M.bit | AB         | 3          | 5           | Bit exclusive-OR C-flag and NOT : C $\leftarrow$ ( C ) $\oplus$ ~(M .bit)           | С                |
| 12  | LDC M.bit   | CB         | 3          | 4           | Load C-flag $: C \leftarrow (M.bit)$                                                | С                |
| 13  | LDCB M.bit  | CB         | 3          | 4           | Load C-flag with NOT $: C \leftarrow \sim (M .bit)$                                 | С                |
| 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)$                                     | С                |
| 16  | OR1B M.bit  | 6B         | 3          | 5           | Bit OR C-flag and NOT $: C \leftarrow (C) \lor \sim (M.bit)$                        | С                |
| 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 ← "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) $\leftarrow$ C                                               |                  |
| 22  | TCLR1 !abs  | 5C         | 3          | 6           | Test and clear bits with A :<br>A - ( M ), ( M ) $\leftarrow$ ( M ) $\wedge$ ~( A ) | NZ-              |
| 23  | TSET1 !abs  | 3C         | 3          | 6           | Test and set bits with A : A - (M), (M) $\leftarrow$ (M) $\vee$ (A)                 | NZ-              |

### 5. 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 | y3         | 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<br>if (C) = 0, then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                 |                  |
| 6   | BCS rel        | D0         | 2          | 2/4         | Branch if carry bit set<br>if ( C ) = 1 , then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                |                  |
| 7   | BEQ rel        | F0         | 2          | 2/4         | Branch if equal<br>if ( Z ) = 1 , then pc ← ( pc ) + rel                                                                                                                                                                                                                                 |                  |
| 8   | BMI rel        | 90         | 2          | 2/4         | Branch if minus<br>if ( N ) = 1 , then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                        |                  |
| 9   | BNE rel        | 70         | 2          | 2/4         | Branch if not equal<br>if ( Z ) = 0 , then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                    |                  |
| 10  | BPL rel        | 10         | 2          | 2/4         | Branch if minus if ( N ) = 0 , then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                           |                  |
| 11  | BRA rel        | 2F         | 2          | 4           | Branch always $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                                                 |                  |
| 12  | BVC rel        | 30         | 2          | 2/4         | Branch if overflow bit clear<br>if (V) = 0, then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                              |                  |
| 13  | BVS rel        | В0         | 2          | 2/4         | Branch if overflow bit set<br>if (V) = 1, then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                |                  |
| 14  | CALL !abs      | 3B         | 3          | 8           | 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, \\ \text{if !abs, } \ pc \leftarrow abs \ ; \ \text{if [dp], } \ pc_L \leftarrow (\ dp \ ), \ pc_H \leftarrow (\ dp \ \text{+-} \ 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           | Unconditional jump                                                                                                                                                                                                                                                                       |                  |
| 21  | JMP [!abs]     | 1F         | 3          | 5           | pc ← jump address                                                                                                                                                                                                                                                                        |                  |
| 22  | JMP [dp]       | 3F         | 2          | 4           |                                                                                                                                                                                                                                                                                          |                  |
| 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)                                           |                  |