# LG Semicon 8-bit Microcontrollers

# GMS81604/08

# **Revision History**

Rev 1.2 (Dec. 1998)

Redraw package dimension on page 5~6.

Rev 1.1 (Nov. 1998)

Operating Voltage, 2.7~5.5V is extended with 2.4~5.5V.

Operating Temperature, -20~80°C is extended with -20~85°C.

Add the "Typical Characteristics" on page 16, 17.

Add the unused port guidance on page 48.

Revision the information for the OTP programming guidance, recommand using "Intelligent Mode" on page 49. Add the chapter for OTP programming specification as an appendix.

Rev 1.0 (Nov. 1997)

First Edition

# **Second Edition**

Published by MCU Application Team

©1998 LG Semicon Co., Ltd. All right reserved.

Additional information of this manual may be served by LG Semicon offices in Korea or Distributors and Representatives listed at address directory.

LG Semicon 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, LG Semicon Co,. Ltd. is in no way responsible for any violations of patents or other rights of the third party generated by the use of this manual.

# **Table of Contents**

| OVERVIEW                    | . 1  |
|-----------------------------|------|
| BLOCK DIAGRAM               | . 3  |
| PIN ASSIGNMENT              | . 4  |
| PACKAGES                    | . 5  |
| PIN DESCRIPTIONS            | . 7  |
| PORT STRUCTURES             | . 9  |
| ELECTRICAL CHARACTERISTICS  | . 12 |
| MEMORY ORGANIZATION         | . 18 |
| Registers                   | . 18 |
| Program Memory              | . 20 |
| Data Memory                 | . 21 |
| I/O PORTS                   | . 23 |
| BASIC INTERVAL TIMER        | . 26 |
| TIMER/COUNTER               | . 27 |
| 8-bit Timer/Counter Mode    | . 29 |
| 16-bit Timer/Counter Mode   | . 31 |
| 8-bit Capture Mode          | . 32 |
| 16-bit Capture Mode         | . 33 |
| ANALOG TO DIGITAL CONVERTER | . 34 |
| How to Use A/D Converter    | . 34 |
| BUZZER FUNCTION             | . 36 |
| INTERRUPTS                  | . 37 |
| External Interrupt          | . 38 |
| BRK Interrupt               | . 40 |
| Multiple Interrupt          | . 40 |
| WATCHDOG TIMER              | . 41 |

| STOP MODE                                     | 42 |
|-----------------------------------------------|----|
| Release Stop Mode                             | 42 |
| Minimizing Current Consumption in Stop Mode   | 43 |
| RESET                                         | 44 |
| POWER FAIL PROCESSOR                          | 45 |
| OSCILLATOR CIRCUIT                            | 47 |
| UNUSED PORTS                                  | 48 |
| GMS81608T (OTP) PROGRAMMING                   | 49 |
| 1. Using the Universal programmer             | 49 |
| 2. Using the general EPROM(27C256) programmer | 49 |
| GMS81608T PROGRAMMING MANUAL                  | 50 |

# **APPENDIX**

- A. INSTRUCTION SET
- **B. MASK ORDER SHEET**

# GMS81604 / GMS81608 CMOS SINGLE-CHIP 8-BIT MICROCONTROLLER

#### **OVERVIEW**

### Description

The GMS81604/08 is a high-performance CMOS 8-bit microcontroller with 4K or 8K bytes of ROM. The device is one of GMS800 family. The LG Semicon GMS81604/08 is a powerful microcontroller which provides a highly flexible and cost effective solution to many embedded control applications. The GMS81604/08 provides the following standard features: 8K bytes of ROM, 256 bytes of RAM, 35 I/O lines(33 lines for 40PDIP), 16-bit or 8-bit timer/counter, a precision analog to digital converter, on-chip oscillator and clock circuitry. In addition, the GMS81604/08 supports power saving modes to reduce power consumption. The Stop Mode saves the RAM contents but freezes the oscillator disabling all other chip functions until the next hardware reset or external interrupt.

#### **Features**

- 4K/8K On-chip Program Memory
- 256 Bytes of On-Chip Data RAM
- Instruction execution time: 0.5us at 8MHz
- 2.4V to 5.5V Operating Range
- 1~8 MHz Operating frequency
- Basic Interval Timer
- Four 8-Bit Timer/ Counters (can be used as two 16-bit)
- Four external interrupt ports
- Two Programmable Clock Out

#### **Memory Proliferation**

| Device    | ROM Bytes | RAM Bytes |  |
|-----------|-----------|-----------|--|
| GMS81604  | 4K        | 256       |  |
| GMS81608  | 8K        | 256       |  |
| GMS81608T | 8K EPROM  | 256       |  |

# **Development Tools**

The GMS800 family is supported by a full-featured macro assembler, an in-circuit emulators CHOICE-Jr. TM, socket adapters for OTP device.

The availability of OTP devices are especially useful for customers expecting frequent code changes and updates. The OTP devices, packaged in plastic pack-

- One Buzzer Driving port
- 31 Programmable I/O, 4 Input pins,
- Twelve Interrupt Sources
- All LED Direct Drive Output Ports
- 8-Channel 8-Bit On-Chip Analog to Digital Converter
- Power Fail Processor (Noise immunity circuit)
- Power Down Mode (Stop Mode)

ages permit the user to program them once. In addition to the program memory, the configuration fuses must be programmed.

|                                       | GMS81604, GMS81608                                                        |
|---------------------------------------|---------------------------------------------------------------------------|
| In-Circuit<br>Emulators               | CHOICE-Jr. TM                                                             |
| OTP devices                           | GMS81608T (40 DIP)<br>GMS81608T K (42 SDIP)<br>GMS81608T PL (44 pin PLCC) |
| Socket<br>Adapters for<br>OTP Devices | OA816A-40PD (40 DIP)<br>OA816A-42SD (42 SDIP)<br>OA816A-44PL (44 PLCC)    |
| Assembler                             | LGS Macro Assembler                                                       |

# **Device Selection Guide**

| ROM size       | Package | Ordering code |
|----------------|---------|---------------|
| 4K bytes       | 40DIP   | GMS81604      |
|                | 42SDIP  | GMS81604 K    |
|                | 44PLCC  | GMS81604 PL   |
| 8K bytes       | 40DIP   | GMS81608      |
|                | 42SDIP  | GMS81608 K    |
|                | 44PLCC  | GMS81608 PL   |
| 8K bytes (OTP) | 40DIP   | GMS81608T     |
|                | 42SDIP  | GMS81608T K   |
|                | 44PLCC  | GMS81608T PL  |

# **BLOCK DIAGRAM**



Figure 1. Block Diagram

### **PIN ASSIGNMENT**



Figure 2. Pin Connections

# **PACKAGES**

| Part        | Package Type |
|-------------|--------------|
| GMS8160X    | 40DIP        |
| GMS8160X K  | 42SDIP       |
| GMS8160X PL | 44PLCC       |

 $\leftarrow$  "X" means 4(4K bytes) or 8(8K bytes).

# **PACKAGE**







#### PIN DESCRIPTIONS

VDD: Supply voltage.

 $V_{SS}$ : Circuit Ground.

 $\overline{\textbf{TEST}}:$  For test purposes only. Connect it to  $V_{DD}.$ 

**RESET**: Reset the MCU.

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

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

**R00~R07**: R0 is an 8-bit, CMOS, bidirectional I/O port. As an output port each pin can sink several LS TTL inputs. R0 pins that have 1 or 0 written to their Port Direction Mode Register, can be used as outputs or inputs.

**R10~R17**: R1 is an 8-bit, CMOS, bidirectional I/O port. As an output port each pin can sink several LS TTL inputs. R1 pins that have 1 or 0 written to their Port Direction Mode Register, can be used as outputs or inputs.

**R40~R47**: R4 is an 8-bit, CMOS, bidirectional I/O port. As an output port each pin can sink several LS TTL inputs. R4 pins that have 1 or 0 written to their Port Direction Mode Register, can be used as outputs or inputs.

In addition, Port 4 serves the functions of the various following special features.

| Port Pin   | Alternate Function                                         |
|------------|------------------------------------------------------------|
| R40        | INT0 (External Interrupt 0)                                |
| R41        | INT1 (External Interrupt 1)                                |
| R42<br>R43 | INT2 (External Interrupt 2)<br>INT3 (External Interrupt 3) |
| R44        | EC0 (External Count Input to Timer/                        |
| R45        | Counter 0) EC2 (External Count Input to Timer/ Counter 2)  |
| R46<br>R47 | T1O (Timer 1 Clock-Out)<br>T3O (Timer 3 Clock-Out)         |

**R50, R51, R55**: R5 is a 3-bit, CMOS, bidirectional I/O port. As an output port each pin can sink several LS TTL inputs. R5 pins that have 1 or 0 written to their Port Direction Mode Register, can be used as outputs or inputs. R50 and R51 differs in having internal pull-ups.

Port R55 serves the functions of special features.

| Port Pin | Alternate Function                          |
|----------|---------------------------------------------|
| R55      | BUZ (Square wave output for Buzzer driving) |

**R60~R67**: R6 is an 8-bit, CMOS, I/O port. R60~R63 can be used as only input, can not be output, R64~R67 are bidirectional I/O port. As an output port each pin can sink several LS TTL inputs. R64~R67 pins that have 1 or 0 written to their Port Direction Mode Register, can be used as outputs or inputs.

R6 serves the functions of following special features.

| Port Pin | Alternate Function |
|----------|--------------------|
| R60      | ANO (ADC input 0)  |
| R61      | AN1 (ADC input 1)  |
| R62      | AN2 (ADC input 2)  |
| R63      | AN3 (ADC input 3)  |
| R64      | AN4 (ADC input 4)  |
| R65      | AN5 (ADC input 5)  |
| R66      | AN6 (ADC input 6)  |
| R67      | AN7 (ADC input 7)  |

 $AV_{DD}$ : Supply voltage to the ladder resistor of ADC circuit. To enhance the resolution of analog to digital converter, use independent power source as well as possible, other than digital power source.

| Port Pin                                                                                                 | 1/0                                           | Descriptions                    |                                                                                                                                                                 | Pull-up/                                            | RESET               | STOP       |
|----------------------------------------------------------------------------------------------------------|-----------------------------------------------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|---------------------|------------|
| 1 01111111                                                                                               | 1,0                                           | Primary Functions               | Secondary Functions                                                                                                                                             | Pull-down                                           | KESEI               | Mode       |
| V <sub>DD</sub>                                                                                          | -                                             | Power supply to MCU             | -                                                                                                                                                               | -                                                   | -                   | -          |
| Vss                                                                                                      | -                                             | Ground                          | -                                                                                                                                                               | -                                                   | -                   | -          |
| AVDD                                                                                                     | -                                             | Power supply for ADC            | -                                                                                                                                                               | -                                                   | -                   | -          |
| TEST                                                                                                     | I                                             | Test mode                       | -                                                                                                                                                               | -                                                   | -                   | -          |
| RESET                                                                                                    | I                                             | Reset the MCU                   | -                                                                                                                                                               | Pull-up                                             | Low                 | Last state |
| XIN                                                                                                      | - 1                                           | Oscillation input               | -                                                                                                                                                               | -                                                   | Oscillation         | Low        |
| Хоит                                                                                                     | 0                                             | Oscillation output              | -                                                                                                                                                               | -                                                   | Oscillation         | High       |
| R00~R07                                                                                                  | I/O                                           | General I/O                     | -                                                                                                                                                               | -                                                   | Input 3)            | Last state |
| R10~R17                                                                                                  | I/O                                           | General I/O                     | -                                                                                                                                                               | -                                                   | Input 3)            | Last state |
| R40/INT0<br>R41/INT1<br>R42/INT2<br>R43/ <u>INT3</u><br>R44/ <u>EC0</u><br>R45/EC2<br>R46/T10<br>R47/T30 | I/O<br>I/O<br>I/O<br>I/O<br>I/O<br>I/O<br>I/O | General I/O " " " " " "         | External interrupt 0 External interrupt 1 External interrupt 2 External interrupt 3 External count input 0 External count input 2 Timer 1 output Timer 3 output | -                                                   | Input <sup>3)</sup> | Last state |
| R50 <sup>1)</sup><br>R51 <sup>1)</sup><br>R55/BUZ                                                        | I/O<br>I/O<br>I/O                             | General I/O                     | -<br>-<br>Buzzer driving output                                                                                                                                 | Pull-up <sup>2)</sup><br>Pull-up <sup>2)</sup><br>- | Input <sup>3)</sup> | Last state |
| R60/AN0<br>R61/AN1<br>R62/AN2<br>R63/AN3<br>R64/AN4<br>R65/AN5<br>R66/AN6<br>R67/AN7                     |                                               | General Input " " General I/O " | Analog input 0 Analog input 1 Analog input 2 Analog input 3 Analog input 4 Analog input 5 Analog input 6 Analog input 7                                         | -                                                   | Input <sup>3)</sup> | Last state |

- R50 and R51 are not physically served on 40 pin package.
   When input mode is selected, pull-up is activated. In output mode, pull-up is de-activated.
   In reset status, status of R50,R51 are weak high (Typ. impedance 50~100kΩ). Other pin impedance is very high(High-Z).

# **PORT STRUCTURES**

# R00~R07, R10~R17



# R40/INT0, R41/INT1, R42/INT2, R43/INT3, R44/EC0, R45/EC2



# R46/T1O, R47/T3O, R55/BUZ



# R50, R51



# R60/AN0, R61/AN1, R62/AN2, R63/AN3



# R64/AN4, R65/AN5, R66/AN6, R67/AN7



# RESET



# TEST



# $\mathbf{X}_{\text{IN}},\,\mathbf{X}_{\text{OUT}}$



### **ELECTRICAL CHARACTERISTICS**

# **Absolute Maximum Ratings**

| Supply Voltage $$ 0.3 to +6.0 $V$                                                   |
|-------------------------------------------------------------------------------------|
| Storage Temperature $\ \dots \dots \dots \dots -40$ to +125 °C                      |
| Voltage on any pin with                                                             |
| respect to Ground (VSS) $$ 0.3 to VDD+0.3 V                                         |
| Maximum current out of $V_{SS}$ pin                                                 |
| $Maximum \ current \ into \ V_{DD} \ pin  . \ . \ . \ . \ . \ . \ . \ . \ 100 \ mA$ |
| Maximum current sunk by (I $_{OL}$ per I/O Pin) 20 $mA$                             |
| Maximum output current sourced                                                      |
| by (I $_{OH}$ per I/O Pin) 8 mA                                                     |
| Maximum current (S $I_{OL})$ $\ \ldots$ $\ \ldots$ $\ 120$ mA                       |
| Maximum current (S IOH)                                                             |

Notice: Stresses above those listed under "Absolute Maxi-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 these of 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.

## **Recommended Operating Conditions**

| Parameter             | Symbol           | Condition                                                | Specifications |            | Unit  |
|-----------------------|------------------|----------------------------------------------------------|----------------|------------|-------|
| Farameter             |                  |                                                          | Min.           | Max.       | Oiiit |
| Supply Voltage        | V <sub>DD</sub>  | $f_{XIN} = 8 \text{ MHz}$<br>$f_{XIN} = 4 \text{ MHz}$   | 4.5<br>2.4     | 5.5<br>5.5 | V     |
| Operating Frequency   | f <sub>XIN</sub> | V <sub>DD</sub> = 4.5~5.5V<br>V <sub>DD</sub> = 2.4~5.5V | 1<br>1         | 8<br>4.2   | MHz   |
| Operating Temperature | T <sub>OPR</sub> |                                                          | -20            | 85         | °C    |

# DC Characteristics (5V)

 $(V_{DD} = 5.0V \pm 10\%, \ V_{SS} = 0V, \ T_A = -20 \sim 85 \ ^{\circ}C, \ f_{XIN} = 8 \ MHz)$ 

| Parameter                    | Pin                                 | Symbol                                | Test Condition                                   | Sp                   | ecificatio           | ns                 | Unit |
|------------------------------|-------------------------------------|---------------------------------------|--------------------------------------------------|----------------------|----------------------|--------------------|------|
| Farameter                    | FIII                                | Symbol                                | rest Condition                                   | Min.                 | Typ.*                | Max.               | Oiii |
| Input High Voltage           | X <sub>IN</sub> , RESET,<br>R40~R45 | V <sub>IH1</sub>                      | -                                                | 0.8V <sub>DD</sub>   | -                    | V <sub>DD</sub>    | ٧    |
| input riigii voltage         | R0,R1,R46,R47<br>R5,R6              | V <sub>IH2</sub>                      | -                                                | 0.7V <sub>DD</sub>   | -                    | V <sub>DD</sub>    | >    |
| Input Low Voltage            | X <sub>IN,</sub> RESET,<br>R40~R45  | V <sub>IL1</sub>                      | -                                                | 0                    | -                    | 0.2V <sub>DD</sub> | >    |
| input Low Voltage            | R0,R1,R46,R47<br>R5,R6              | V <sub>IL2</sub>                      | -                                                | 0                    | -                    | 0.3V <sub>DD</sub> | >    |
| Output High Voltage          | R0,R1,R4,R5,R6                      | Voн                                   | $V_{DD} = 5V$ $I_{OH} = -2mA$                    | V <sub>DD</sub> -1.0 | V <sub>DD</sub> -0.4 | -                  | >    |
| Output Low Voltage           | R0,R1,R4,R5,R6                      | VoL                                   | $V_{DD} = 5V$ $I_{OL} = 10 \text{ mA}$           | -                    | 0.6                  | 1.0                | >    |
| Power Fail Detect<br>Voltage | $V_{DD}$                            | V <sub>PFD</sub>                      | V <sub>DD</sub> =3~4V                            | 3.0                  | -                    | 4.0                | >    |
| Input Leakage                | RESET, R0, R1,                      | l <sub>IH</sub>                       | $V_I = V_{DD}$                                   | -5.0                 | -                    | 5.0                | uA   |
| Current                      | R4, R5, R6                          | IιL                                   | $V_I = 0V$                                       | -5.0                 | -                    | 5.0                | uA   |
| Input Pull-up Current        | RESET                               | I <sub>P1</sub>                       | $V_{DD} = 5V$                                    | -180                 | -120                 | -30                | uA   |
| input Full-up Current        | R50, R51                            | I <sub>P2</sub>                       | $V_{DD} = 5V$                                    | -90                  | -60                  | -15                | uA   |
| Power Current                | Operating mode                      | I <sub>DD</sub>                       | f <sub>XIN</sub> =4MHz<br>f <sub>XIN</sub> =8MHz | -                    | 4.5<br>8             | 8<br>15            | mΑ   |
|                              | STOP mode                           | I <sub>STOP</sub>                     | $V_{DD} = 5V$                                    | -                    | 2                    | 20                 | uA   |
| Hysteresis                   | RESET,<br>R40~R45                   | V <sub>T</sub> +<br>~V <sub>T</sub> - | V <sub>DD</sub> = 5V                             | 0.5                  | 0.8                  | -                  | V    |

 $<sup>^{\</sup>star}$  : Data in "Typ" column is at 5 V,  $25^{\circ}$ C unless otherwise stated. These parameters are for design guidance only and are not tested.

# A/D Converter Characteristics (5V)

 $(V_{DD} = 5.0V \pm 10\%, \ V_{AIN} = 5.0V, \ V_{SS} = 0V, \ T_A = 25\ ^{\circ}C)$ 

| Parameter                          | Symbol            |      | Specifications |                   |      |  |
|------------------------------------|-------------------|------|----------------|-------------------|------|--|
| rarameter                          | - Cymbol          | Min. | Тур.*          | Max.              | Unit |  |
| Analog Input Range                 | V <sub>AIN</sub>  | Vss  | -              | V <sub>AVDD</sub> | V    |  |
| Non-linearity Error                | N <sub>LE</sub>   | -    | 0.7            | ± 1.5             | LSB  |  |
| Differential Non-linearity Error   | N <sub>DIF</sub>  | -    | 0.1            | ± 0.5             | LSB  |  |
| Zero Offset Error                  | Noff              | -    | 1.5            | ± 2.5             | LSB  |  |
| Full Scale Error                   | N <sub>FS</sub>   | -    | 1.0            | ± 1.5             | LSB  |  |
| Accuracy                           | Acc               | -    | 2.0            | ± 3.0             | LSB  |  |
| AV <sub>DD</sub> Input Current     | I <sub>AVDD</sub> | -    | 0.5            | 1.0               | m A  |  |
| Conversion Time                    | T <sub>CONV</sub> | -    | -              | 40                | uS   |  |
| Analog power supply Input<br>Range | V <sub>AVDD</sub> | 4.5  | 5.0            | 5.5               | V    |  |

 $<sup>^{\</sup>star}$ : Data in "Typ" column is at 5 V,  $25^{\circ}$ C unless otherwise stated. These parameters are for design guidance only and are not tested.

# DC Characteristics (3V)

 $(V_{DD}=3.0V\pm10\%,\ V_{SS}=0V,\ T_{A}=\text{-20}\sim85\ ^{\circ}\text{C},\ f_{XIN}=4\ \text{MHz})$ 

| Parameter                      | Pin                                 | Symbol                                | Test Condition                         | Sp                   | Unit                 |                    |      |
|--------------------------------|-------------------------------------|---------------------------------------|----------------------------------------|----------------------|----------------------|--------------------|------|
| Farameter                      | FIII                                | Symbol                                | rest condition                         | Min.                 | Typ.*                | Max.               | Onit |
| Input High Voltage             | X <sub>IN</sub> , RESET,<br>R40~R45 | V <sub>IH1</sub>                      | -                                      | 0.8V <sub>DD</sub>   | ı                    | $V_{DD}$           | ٧    |
| input riigii voitage           | R0,R1,R46,R47<br>R5,R6              | V <sub>IH2</sub>                      | -                                      | 0.7V <sub>DD</sub>   | ı                    | $V_{DD}$           | ٧    |
| Input Low Voltage              | X <sub>IN</sub> , RESET,<br>R40~R45 | V <sub>IL1</sub>                      | -                                      | 0                    | 1                    | 0.2V <sub>DD</sub> | ٧    |
| mput Low voltage               | R0,R1,R46,R47<br>R5,R6              | V <sub>IL2</sub>                      | -                                      | 0                    | -                    | 0.3V <sub>DD</sub> | ٧    |
| Output High Voltage            | R0,R1,R4,R5,R6                      | Vон                                   | $V_{DD} = 3V$ $I_{OH} = -1 \text{ mA}$ | V <sub>DD</sub> -0.5 | V <sub>DD</sub> -0.3 | -                  | ٧    |
| Output Low Voltage             | R0,R1,R4,R5,R6                      | VoL                                   | $V_{DD} = 3V$ $I_{OL} = 5mA$           | -                    | 0.5                  | 0.7                | ٧    |
| Power Fail Detect<br>Voltage** | -                                   | -                                     | -                                      | -                    | =                    | =                  | ٧    |
| Input Leakage                  | RESET, R0, R1,                      | l <sub>IH</sub>                       | $V_I = V_{DD}$                         | -3.0                 | -                    | 3.0                | uA   |
| Current                        | R4, R5, R6                          | I <sub>IL</sub>                       | $V_I = 0V$                             | -3.0                 | 1                    | 3.0                | uA   |
| Input Pull-up                  | RESET                               | I <sub>P1</sub>                       | $V_{DD} = 3V$                          | -60                  | -40                  | -15                | uA   |
| Current                        | R50, R51                            | I <sub>P2</sub>                       | $V_{DD} = 3V$                          | -30                  | -20                  | -7.5               | uA   |
| Power Current                  | Operating mode                      | I <sub>DD</sub>                       | f <sub>XIN</sub> =4MHz                 | -                    | 2                    | 5                  | mΑ   |
| 1 Ower Current                 | STOP mode                           | Іѕтор                                 | $V_{DD} = 3V$                          | -                    | 1                    | 10                 | uA   |
| Hysteresis                     | RESET,<br>R40~R45                   | V <sub>T</sub> +<br>~V <sub>T</sub> - | $V_{DD} = 3V$                          | 0.3                  | 0.6                  | -                  | V    |

<sup>\*:</sup> Data in "Typ" column is at 3 V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.
\*\*: Power Fail Detection function is not available on 3V operation.

# A/D Converter Characteristics (3V)

 $(V_{DD}=3.0V\pm10\%,\ V_{AIN}=3.0V,\ V_{SS}=0V,\ T_{A}=25\ ^{\circ}C)$ 

| Parameter                          | Symbol            | :    | Specifications |                   |      |
|------------------------------------|-------------------|------|----------------|-------------------|------|
| i arameter                         | Symbol            | Min. | Typ.*          | Max.              | Unit |
| Analog Input Range                 | V <sub>AIN</sub>  | Vss  | -              | V <sub>AVDD</sub> | V    |
| Non-linearity Error                | N <sub>LE</sub>   | -    | 0.2            | ±1.0              | LSB  |
| Differential Non-linearity Error   | N <sub>DIF</sub>  | -    | 0.1            | ±0.5              | LSB  |
| Zero Offset Error                  | Noff              | -    | 2.0            | ± 2.5             | LSB  |
| Full Scale Error                   | N <sub>FS</sub>   | -    | 1.0            | ± 1.5             | LSB  |
| Accuracy                           | Acc               | -    | 2.0            | ±3.0              | LSB  |
| AV <sub>DD</sub> Input Current     | l <sub>AVDD</sub> | -    | 0.3            | 0.5               | mA   |
| Conversion Time                    | T <sub>CONV</sub> | -    | -              | 40                | uS   |
| Analog power supply Input<br>Range | V <sub>AVDD</sub> | 2.7  | 3.0            | 3.3               | V    |

<sup>\*:</sup> Data in "Typ" column is at 3 V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

# **AC Characteristics**

 $(V_{DD}=2.7{\sim}5.5V,~V_{SS}=0V,~T_{A}=-20~\sim85~^{\circ}C)$ 

| Parameter                          | Pin                                | Symbol                              | Sp   | Unit |      |       |  |
|------------------------------------|------------------------------------|-------------------------------------|------|------|------|-------|--|
| r arameter                         | 1 111                              | Symbol                              | Min. | Typ. | Max. | 0     |  |
| Main clock frequency               | X <sub>IN</sub>                    | f <sub>XIN</sub>                    | 1    | -    | 8    | MHz   |  |
| Oscillation stabilization Time     | X <sub>IN</sub> , X <sub>OUT</sub> | tsT                                 | 20   | -    | -    | ms    |  |
| External Clock Pulse Width         | X <sub>IN</sub>                    | t <sub>CPW</sub>                    | 80   | -    | -    | ns    |  |
| External Clock Transition Time     | X <sub>IN</sub>                    | t <sub>RCP</sub> , t <sub>FCP</sub> | -    | -    | 20   | ns    |  |
| Interrupt Pulse Width              | INTO, INT1, INT2, INT3             | t <sub>IW</sub>                     | 2    | -    | -    | tsys* |  |
| RESET Input Low Width              | RESET                              | t <sub>RST</sub>                    | 8    | -    | -    | tsys* |  |
| Event Counter Input Pulse<br>Width | ECO, EC2                           | t <sub>ECW</sub>                    | 2    | -    | -    | tsys* |  |
| Event Counter Transition Time      | EC0, EC2                           | t <sub>REC</sub> , t <sub>FEC</sub> | -    | -    | 20   | ns    |  |

<sup>\*:</sup>  $t_{\text{SYS}}$  is  $2/f_{\text{XIN}}$ .

# **Timing Chart**



# TYPICAL CHARACTERISTICS

These parameters are for design guidance only and are not tested. \\





 $V_{DD}=5V$ 







 $V_{DD}=3.0V$ 





#### **MEMORY ORGANIZATION**

The GMS81604 has separate address spaces for Program and Data Memory. Program memory can only be read, not written to. It can be up to 4K (8K for GMS81608) bytes of Program Memory. Data memory can be read and written to up to 256 bytes including the stack area.

#### 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 3. Configuration of Registers

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

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



Figure 4. Configuration of YA 16-bit register

**X register, Y register**: In the addressing modes which use these index registers, the register contents are added to the specified address and this becomes the actual address. These modes are extremely effective for referencing subroutine tables and memory tables.

The index registers also have increment, decrement, compare 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. The stack can be located at any position within  $100_{\rm H}$  to  $13F_{\rm H}$  of the internal data memory. Data store and restore sequence to(from) stack area is shown in Figure 0.





Figure 5. Stack Pointer

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

**Program Status Word**: The Program Status Word (PSW) contains several status bits that reflect the current state of the CPU. The PSW shown in Figure 6. It contains the Negative flag, the Overflow flag, the Direct page flag, the Break flag, the Half Carry (for BCD operations), the Interrupt enable flag, the Zero flag and the Carry bit.

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

[Interrupt disable flag I] This flag enables/disables all interrupts except interrupt caused by Reset or software



Figure 6. PSW (Program Status Word) Register

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, cleared by the DI instruction.

### [Half carry flag H]

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

## [Break flag B]

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

#### [Direct page flag G]

This flag assign direct page for direct addressing mode. In the direct addressing mode, addressing area is

within zero page  $00_H$  to  $FF_H$  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.

#### [Overflow flag V]

This flag is set to "1" when an overflow occurs in the result of an arithmetic operation involving signs. An overflow occurs when the result of an addition or subtraction exceeds  $+127(7F_{\rm H})$  or  $-128(80_{\rm H})$ .

The CLRV instruction clears the overflow flag. There is no set instruction. When the BIT instruction is executed, for other than the above, bit 6 of memory is copy 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 copy to this flag



Figure 7. Stack Operation

## **Program Memory**

A 16-bit program counter is capable of addressing up to 64K bytes, but this devices have 4K bytes (8K for GMS81608) program memory space only the physically implemented. Accessing a location above  $FFFF_{\rm H}$  will cause a wrap-around to  $0000_{\rm H}.$ 

Figure 8, shows a map of the upper part of the Program Memory. After reset, the CPU begins execution from reset vector which is stored in address  $FFFE_H$ ,  $FFFF_H$ .

As shown in Figure 8, each area is assigned a fixed location in Program Memory. Program Memory area contains the user program, Page Call (PCALL) area contains subroutine program, to reduce program byte length because of using by 2 bytes PCALL instead of 3 bytes CALL instruction. If it is frequently called, more useful to save program byte length.



Figure 8. Program Memory

Table Call (TCALL) causes the CPU to jump to each TCALL address, where it commences execution of the service routine. The Table Call service locations are spaced at 2-byte interval : FFC0 $_{\rm H}$  for TCALL15, FFC2 $_{\rm H}$  for TCALL14, etc.

| Address | TCALL Name                |
|---------|---------------------------|
| FFC0H   | TCALL15                   |
| FFC2H   | TCALL14                   |
| FFC4H   | TCALL13                   |
| FFC6H   | TCALL12                   |
| FFC8H   | TCALL11                   |
| FFCAH   | TCALL10                   |
| FFCCH   | TCALL9                    |
| FFCEH   | TCALL8                    |
| FFD0H   | TCALL7                    |
| FFD2H   | TCALL6                    |
| FFD4H   | TCALL5                    |
| FFD6H   | TCALL4                    |
| FFD8H   | TCALL3                    |
| FFDAH   | TCALL2                    |
| FFDCH   | TCALL1                    |
| FFDEH   | TCALLO/ BRK <sup>1)</sup> |

1) The BRK software interrupt is using same address with TCALLO.

The interrupt causes the CPU to jump to specific location, where it commences execution of the service routine. The External interrupt 0, for example, is assigned to location FFFAH. The interrupt service locations are spaced at 2-byte interval: FFF8H for External Interrupt 1, FFFAH for External Interrupt 0, etc.

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

| Address | Vector Name                 |
|---------|-----------------------------|
| FFE0H   | -                           |
| FFE2H   | -                           |
| FFE4H   | -                           |
| FFE6H   | Basic Interval Timer        |
| FFE8H   | Watch Dog Timer             |
| FFEAH   | Analog to Digital Converter |
| FFECH   | Timer/ Counter 3            |
| FFEEH   | Timer/ Counter 2            |
| FFF0H   | Timer/ Counter 1            |
| FFF2H   | Timer/ Counter 0            |
| FFF4H   | External Interrupt 3        |
| FFF6H   | External Interrupt 2        |
| FFF8H   | External Interrupt 1        |
| FFFAH   | External Interrupt 0        |
| FFFCH   | -                           |
| FFFEH   | RESET                       |

#### **Data Memory**

Figure 9 shows the internal Data Memory space available. Data Memory are divided into three groups, a user RAM, control registers and Stack.



Figure 9. Data Memory

Internal Data Memory addresses are always one byte wide, which implies an address space of 256 bytes including the stack area. To access above  $FF_{\rm H},~G\text{-flag}$  should be set to "1" before, because after MCU reset, G-flag is "0".

The stack pointer should be initialized within  $00_{\rm H}$  to  $3F_{\rm H}$  by software because of implemented area of internal data memory.

The control registers are used by the CPU and Peripheral functions 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, I/O ports. The control registers are in address  $\text{CO}_{\text{H}}$  to  $\text{FF}_{\text{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 detail informations of each register are explained in each peripheral sections.

#### Caution:

Write only registers can not be accessed by bit manipulation instruction.

| Address            | Symbol | R/W    | Power-on<br>Reset Value |
|--------------------|--------|--------|-------------------------|
| СОн                | R0     | R/W    | X                       |
| C1H                | R0DD   | W 1)   | 00000000                |
| С2н                | R1     | R/W    | X                       |
| СЗН                | R1DD   | W 1)   | 00000000                |
| С8н                | R4     | R/W    | X                       |
| С9н                | R4DD   | W 1)   | 00000000                |
| САн                | R5     | R/W    | X                       |
| СВн                | R5DD   | W 1)   | 0 00                    |
| ССн                | R6     | R/W    | X                       |
| СДН                | R6DD   | W 1)   | 00000000                |
| D0н                | PMR4   | W 1)   | 00000000                |
| D1H                | PMR5   | W 1)   | 0                       |
| D3H <sup>2)</sup>  | BITR   | R      | 00000000                |
| D3H <sup>2</sup> ) | CKCTLR | W 1)   | 010111                  |
| E0 <sub>H</sub>    | WDTR   | W 1)   | - 0111111               |
| Е2н                | TM0    | R/W    | 00000000                |
| ЕЗН                | TM2    | R/W    | 00000000                |
| Е4н                |        | R/W    | X                       |
| Е5н                |        | R/W    | X                       |
| Е6н                |        | R/W    | X                       |
| E7H                |        | R/W    | X                       |
| Е8н                | ADCM   | R/W 4) | 000001                  |
| Е9н                | ADR    | R      | X                       |
| ЕСн                | BUR    | W 1)   | X                       |
| EDH                | PFDR   | R/W    | 100                     |
| F4H                | IENL   | R/W    | 000                     |
| F5H                | IRQL   | R/W    | 000                     |
| F6H                | IENH   | R/W    | 00000000                |
| F7H                | IRQH   | R/W    | 00000000                |
| F8H                | IEDS   | W 1)   | 00000000                |

Legend - = Unimplemented locations.

#### NOTES:

- The all write only registers can not be accessed by bit manipulation instruction.
- The register BITR and CKCTLR are located at same address. Address D3H is read as BITR, as written to CKCTLR.
- Several names are given at same address. Refer to below table.

| Address | When              | When write |             |
|---------|-------------------|------------|-------------|
| Addiess | Timer mode Captur |            | Wileii Wile |
| E4H     | T0                | CDR0       | TDR0        |
| E5H     | T1                | CDR1       | TDR1        |
| E6H     | T2                | CDR2       | TDR2        |
| E7H     | Т3                | CDR3       | TDR3        |

<sup>4)</sup> Only bit 0 of ADCM can be read.

X= Undefined value.

# Control Registers for the GMS81604/08

| Address           | Name           | Bit 7                              | Bit 6                                    | Bit 5       | Bit 4       | Bit 3      | Bit 2        | Bit 1 | Bit 0 |
|-------------------|----------------|------------------------------------|------------------------------------------|-------------|-------------|------------|--------------|-------|-------|
| СОН               | R0             | R0 port                            | data regist                              | er          | I.          |            | I.           |       | I.    |
| С1н               | R0DD           | R0 port                            | R0 port direction register               |             |             |            |              |       |       |
| C2 <sub>H</sub>   | R1             | R1 port                            | data regist                              | er          |             |            |              |       |       |
| СЗН               | R1DD           | R1 port                            | direction re                             | egister     |             |            |              |       |       |
| С8н               | R4             | R4 port                            | data regist                              | er          |             |            |              |       |       |
| С9н               | R4DD           | R4 port                            | direction re                             | egister     |             |            |              |       |       |
| САн               | R5             | R5 port                            | data regist                              | er          |             |            |              |       |       |
| СВн               | R5DD           | R5 port                            | direction re                             | egister     |             |            |              |       |       |
| ССн               | R6             | R6 port                            | data regist                              | er          |             |            |              |       |       |
| СДН               | R6DD           | R6 port                            | R6 port direction register               |             |             |            |              |       |       |
| D0H               | PMR4           | T3S                                | T1S                                      | EC2S        | EC0S        | INT3S      | INT2S        | INT1S | INT0S |
| D1 <sub>H</sub>   | PMR5           | -                                  |                                          | BUZS        | -           | -          | -            | -     | -     |
| D3H <sup>1)</sup> | BITR           | Basic Interval Timer data register |                                          |             |             |            |              |       |       |
| D3H <sup>1)</sup> | CKCTLR         | -                                  | -                                        | WDTON       | ENPCK       | BTCL       | BTS2         | BTS1  | BTS0  |
| ЕОн               | WDTR           | -                                  | - WDTCL 6-bit Watch Dog Counter register |             |             |            |              |       |       |
| E2 <sub>H</sub>   | TM0            | CAP0                               | T1ST                                     | T1SL1       | T1SL0       | TOST       | T0CN         | T0SL1 | T0SL0 |
| ЕЗН               | TM2            | CAP2                               | T3ST                                     | T3SL1       | T3SL0       | T2ST       | T2CN         | T2SL1 | T2SL0 |
| E4H               | T0/ TDR0/ CDR0 | Timer 0                            | register/ T                              | imer data ı | register 0/ | Capture da | ata registe  | r 0   |       |
| Е5н               | T1/ TDR1/ CDR1 | Timer 1                            | register/ T                              | imer data ı | register 1/ | Capture da | ata registe  | r 1   |       |
| Е6н               | T2/ TDR2/ CDR2 | Timer 2                            | register/ T                              | imer data ı | register 2/ | Capture da | ata registe  | r 2   |       |
| E7 <sub>H</sub>   | T3/ TDR3/ CDR3 | Timer 3                            | register/ T                              | imer data ı | register 3/ | Capture da | ata register | r 3   |       |
| E8H               | ADCM           | -                                  | -                                        | ADEN        | ADS2        | ADS1       | ADS0         | ADST  | ADSF  |
| Е9н               | ADR            | ADC res                            | sult data re                             | egister     |             | 1          | •            |       |       |
| ECH               | BUR            | BUCK1                              | BUCK0                                    | BU5         | BU4         | BU3        | BU2          | BU1   | BU0   |
| EDH <sup>2)</sup> | PFDR           | -                                  | -                                        | -           | -           | -          | PFD          | PFR   | PFS   |
| F4 <sub>H</sub>   | IENL           | AE                                 | WDTE                                     | BITE        | -           | -          | -            | -     | -     |
| F5 <sub>H</sub>   | IRQL           | AIF                                | WDTIF                                    | BITIF       | -           | -          | -            | -     | -     |
| F6H               | IENH           | INT0E                              | INT1E                                    | INT2E       | INT3E       | T0E        | T1E          | T2E   | T3E   |
| F7 <sub>H</sub>   | IRQH           | INT0IF                             | INT1IF                                   | INT2IF      | INT3IF      | TOIF       | T1IF         | T2IF  | T3IF  |
| F8H               | IEDS           | IED3H                              | IED3L                                    | IED2H       | IED2L       | IED1H      | IED1L        | IED0H | IED0L |

Legend - = Unimplemented locations.

NOTES:

1) The register BITR and CKCTLR are located at same address. Address D3<sub>H</sub> is read as BITR, written to CKCTLR.

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

#### I/O PORTS

The GMS81604/08 have five ports, R0, R1, R4, R5, R6. These ports pins may be multiplexed with an alternate function for the peripheral features on the device. In general, when a initial reset state, all ports are used as a general purpose input port.

All pins have data direction registers which can configure these pins as output or input.

A "1" in the port direction register configures 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 R1 as output ports and the odd numbered bits as input ports, write " $55_{\rm H}$ " to address C1\_H (R0 direction register) during initial setting as shown in Figure 10.



Figure 10. Example port I/O assignment

Reading data register reads the status of the pins whereas writing to it will write to the port latch.

**R0 and R0DD registers:** R0 is a 8-bit bidirectional I/O port (address  $C0_H$ ). Each pin is individually configurable as input and output through the R0DD register (address  $C1_H$ ).



**R1 and R1DD registers:** R1 is an 8-bit bidirectional I/O port (address  $C2_H$ ). Each pin is individually configurable as input and output through the R1DD register (address  $C3_H$ ).



**R4 and R4DD registers:** R4 is an 8-bit bidirectional I/O port (address  $C8_H$ ). Each pin is individually configurable as input and output through the R4DD register (address  $C9_H$ ).

In addition, Port R4 is multiplexed with various special features. The control register PMR4 (address  $D0_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 External counter or Timer clock out, write "1" to the corresponding bit of PMR4.

| Port Pin   | Alternate Function                                                                 |
|------------|------------------------------------------------------------------------------------|
| R40        | INT0 (External Interrupt 0)                                                        |
| R41        | INT1 (External Interrupt 1)                                                        |
| R42        | INT2 (External Interrupt 2)                                                        |
| R43        | INT3 (External Interrupt 3)                                                        |
| R44<br>R45 | EC0 (External Count Input to Timer/ Counter 0) EC2 (External Count Input to Timer/ |
|            | Counter 2)                                                                         |
| R46<br>R47 | T1O (Timer 1 Clock-Out)<br>T3O (Timer 3 Clock-Out)                                 |

Regardless of the direction register R4DD, PMR4 is selected to use as alternate functions, port pin can be used as a corresponding alternate features.



**R5 and R5DD registers:** R5 is a 3-bit bidirectional I/O port (address CA<sub>H</sub>). R50, R51 and R55 only are physically implemented on this device.

R50, R51 have internal pullups which is activated on input but deactivated on output. As input, these pins that are externally pull low will source current (IP2 on the DC characteristics) because of the internal pullups.

#### Caution:

Pins R50, R51 are present on 42SDIP, 44PLCC package only, but not on 40DIP. Refer to Pin assignment.

Each pin is individually configurable as input and output through the R5DD register (address  $CB_{\rm H}$ ).

| Port Pin | Alternate Function                          |
|----------|---------------------------------------------|
| R55      | BUZ (Square-wave output for Buzzer driving) |

The control register PMR5 (address  $D1_H$ ) controls the selection alternate function. After reset, this value is "0", port may be used as general I/O ports. To use buzzer function, write "1" to the PMR5.



**R6 and R6DD registers:** R6 is an 8-bit port (address CC<sub>H</sub>). Pins R64~R67 are individually configurable as input and output through the R6DD register (address CD<sub>H</sub>), but pins R60~R63 are input only.

| Port Pin | Alternate Function |  |  |
|----------|--------------------|--|--|
| R60      | AN0 (ADC input 0)  |  |  |
| R61      | AN1 (ADC input 1)  |  |  |
| R62      | AN2 (ADC input 2)  |  |  |
| R63      | AN3 (ADC input 3)  |  |  |
| R64      | AN4 (ADC input 4)  |  |  |
| R65      | AN5 (ADC input 5)  |  |  |
| R66      | AN6 (ADC input 6)  |  |  |
| R67      | AN7 (ADC input 7)  |  |  |

R6DD (address CD<sub>H</sub>) controls the direction of the R6 pins, even when they are being used as analog inputs. The user must make sure to keep the pins configured as inputs when using them as analog inputs.

On the initial RESET, R60 can not be used digital input port, because this port is selected as an analog input port by ADCM register. To use this port as a digital I/O port, change the value of lower 4 bits of ADCM (address 0E8H).

On the other hand, R6 port, all eight pins can not be used as digital I/O port simultaneousely. At least one pin is used as an analog input.



#### **BASIC INTERVAL TIMER**

The GMS81604 has one 8-bit Basic Interval Timer that is free-run, can not stop. Block diagram is shown in Figure 11.

The 8-bit Basic interval timer register (BITR) is incremented every internal count pulse which is divided by prescaler. Since prescaler has divided ratio by 16 to 2048, the count rate is 1/16 to 1/2048 of the oscillator frequency. As the count overflows from FFH to  $00_{\rm H},$  this overflow causes to generate the Basic interval timer interrupt. The BITR is interrupt request flag of

Basic interval timer.

#### Caution:

All control bits of Basic interval timer are in CKCTLR register which is located at same address of BITR (address D3H). Address D3H is read as BITR, written to CKCTLR.

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



Figure 11. Block Diagram of The Basic Interval Timer



Figure 12. CKCTLR: Control Clock Register

#### TIMER/COUNTER

The GMS81604 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 are can be used either the two 8-bit Timer/Counter or one 16-bit Timer/Counter to combine them. Also Timer 2 and Timer 3 are same.

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

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

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

It has four operating modes: "8-bit timer/counter",

"16-bit timer/counter", "8-bit capture", "16-bit capture" which are selected by bit in Timer mode register TM0 and TM2 as shown in right Table.

In operation of Timer 2, Timer 3, their operations are same with Timer 0, Timer 1, respectively.

#### TMO FOR TIMER 0, TIMER 1

| CAPO | T1SL1 | T1SL0 | Timer 0              | Timer 1     |
|------|-------|-------|----------------------|-------------|
| 0    | 0     | 0     | 16-bit Timer/Counter |             |
| 1    | 0     | 0     | 16-bit Capture       |             |
| 0    | Х     | Х     | 8-bit Timer          | 8-bit Timer |
| 1    | Х     | Х     | 8-bit Capture        | 8-bit Timer |

#### TM2 FOR TIMER 2, TIMER 3

| CAP2 | T3SL1 | T3SL0 | Timer 2              | Timer 3     |
|------|-------|-------|----------------------|-------------|
| 0    | 0     | 0     | 16-bit Timer/Counter |             |
| 1    | 0     | 0     | 16-bit Capture       |             |
| 0    | Х     | Х     | 8-bit Timer          | 8-bit Timer |
| 1    | Х     | Х     | 8-bit Capture        | 8-bit Timer |



Figure 13. TM0: Timer 0, Timer 1 Mode Register



Figure 14. TM2: Timer 2, Timer 3 Mode Register



Figure 15. TDRx: Timer x Data Register

#### 8-bit Timer/Counter Mode

The GMS81604 has four 8-bit Timer/Counters, Timer 0, Timer 1, Timer 2, Timer 3. The Timer 0, Timer 1 only as shown in Figure 16. because other timer/counters are same with Timer 0 and Timer 1.

The "timer" or "counter" function is selected by control registers TM0, TM2 as shown in Figure 13 and Figure 14. To use as an 8-bit timer/counter mode, bit CAP0 of TM0 is cleared to "0" and bits T1SL1, T1SL0 of TM0 or bits T3SL1, T3SL0 of TM2 should not set to zero (Figure 16).

These timers have each 8-bit count register and data register. The count register is incremented by every internal or external clock input. The internal clock has a prescaler divide ratio option of 4, 16, 64 (selected by control bits TxSL1, TxSL0 of register TMx).

In the Timer 0, timer register T0 increments from 00H

until it matches TDR0 and then reset to  $00_{H}\,.$  The match output of Timer 0 generates Timer 0 interrupt (latched in T0IF bit)

As TDRx and Tx register are in same address, when reading it as a Tx, written to TDRx.

#### Caution:

The contents of Timer data register TDRx should be initialized 1H~FFH except 0H, because it is undefined after reset.

In counter function, the counter is <u>incremented</u> every 1-to 0 (falling edge) transition of EC0 or EC2 pin. In order to use counter function, the bit EC0S, EC2S of the Port mode register PMR4 are <u>set to "1"</u>. The Timer 0 can be used as a counter by pin EC0 input, but  $T\underline{imer}$  1 can not. Similarly, Timer 2 can be used by pin EC2 input but Timer 3 can not.



Figure 16. 8-bit Timer/Counter Mode

To pulse out, the timer match can goes to port pin as shown in Figure 16. Thus, pulse out is generated by the timer match. These operation is implemented to pin, T1O and T3O. The pin T1O is output from Timer 1, the T3O is from Timer 3. Operation of T3O is omitted in this document, but still presents and same architecture with T1O.

$$f_{TxO}(Hz) = \frac{OscillatorFrequency}{2 \cdot Prescaler \cdot TDR}$$



Figure 17. PMR4: R4 Port Mode Register



Figure 18. Timer Count Example

### 16-bit Timer/Counter Mode

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

The clock source of the Timer 0 is selected either internal or external clock by bit TOSL1, TOSL0.

Even if the Timer 0 (including the Timer 1) is used as a 16-bit timer, the Timer 2 and Timer 3 can still be used as either two 8-bit timer or one 16-bit timer by setting the TM2. Reversely, even if the Timer 2 (including the Timer 3) is used as a 16-bit timer, the Timer 0 and Timer 1 can still be used as 8-bit timer independently.



Figure 19. 16-bit Timer/Counter Mode



Figure 20. Timer Count Operation

#### 8-bit Capture Mode

The Timer 0 capture mode is set by bit CAP0 of timer mode register TM0 (bit CAP2 of timer mode register TM2 for Timer 2) as shown in Figure 21. In this mode, Timer 1 still operates as an 8-bit timer/counter.

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

In 8-bit capture mode, Timer 1 and Timer 3 are can not be used as a capture mode.

The Timer/Counter register is incremented in response internal or external input. This counting function is same with normal timer mode, but Timer interrupt is not generated. 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,T2), to be captured into registers CDRx (CDR0, CDR2), respectively. After captured, Timer x register is cleared and restarts by hardware.

#### Caution:

The CDRx and TDRx are in same address.

In the capture mode, reading operation is read the CDRx, not TDRx because path is opened to the CDRx

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.



Figure 21. 8-bit Capture Mode

#### 16-bit Capture Mode

 $16\hbox{-bit capture mode is the same as 8-bit capture, except } that the Timer register is being run will 16 bits.$ 



Figure 22. 16-bit Capture Mode

#### **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 supply voltage is connected to  $\rm AV_{DD}$  of ladder resistance of A/D module.

The A/D module has two registers which are the control register ADCM and A/D result register ADR. The register ADCM, shown in Figure 24, controls the operation of the A/D converter module. The port pins can be configured as analog inputs or digital I/O. To use analog inputs, I/O is selected input mode by R6DD

direction register.

#### How to Use A/D Converter

The processing of conversion is start when the start bit ADST is set to "1". After one cycle, it is cleared by hardware. The register ADR contains the results of the A/D conversion. When the conversion is completed, the result is loaded into the ADR, the A/D conversion status bit ADSF is set to "1", and the A/D interrupt flag AIF is set. The block diagram of the A/D module is shown in Figure 23. 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 40 uS (at  $f_{\rm XIN}$ =4 MHz).



Figure 23. A/D Block Diagram



Figure 24. ADCM: A/D Converter Control Register

#### **BUZZER FUNCTION**

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 (250 Hz~125 kHz at  $f_{\rm XIN}{=}4$  MHz) by user programmable counter.

Pin R55 is assigned for output port of Buzzer driver by setting the bit 5 of PMR5 (address  $D1_H$ ) to "1". At this time, the pin R55 must be defined as output mode (the bit 5 of R5DD=1)

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

Frequency calculation is following below.

$$f_{BUZ}$$
 (Hz) =  $\frac{f_{XIN}}{2 \cdot Prescaler\ ratio \cdot BUR\ value}$ 

f<sub>BUZ</sub>: Buzzer frequency f<sub>XIN</sub>: Min oscillator frequency Prescaler: Prescaler divide ratio by BUCK1, BUCK0 BUR:Lower 6-bit of BUR. Buzzer period data value

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



Figure 25. Buzzer Driver

The 6-bit buzzer counter is cleared and start the counting by writing signal to the register BUR. It is increment from  $00_{\rm H}$  until it matches 6-bit register BUR.

#### Caution:

The register BUR contains undefined value after reset. It must be initialized none  $0_H(1_{H^{\sim}}3F_H)$ .



Figure 26. BUR: Buzzer Period Data Register



Figure 27. PMR5: Port 5 Mode Register

register.

#### **INTERRUPTS**

The GMS81604/08 interrupt circuits consist of Interrupt enable register (IENH, IENL), Interrupt request flags of IRQH, IRQL, priority circuit and Master enable flag(I flag of PSW). The configuration of interrupt circuit is shown in Figure 28.

12 interrupt sources are provided including the Reset.

| Interrupt source     | Symbol | Priority |
|----------------------|--------|----------|
| Hardware RESET       | RST    | 1        |
| External Interrupt 0 | INTOIF | 2        |
| External Interrupt 1 | INT1IF | 3        |
| External Interrupt 2 | INT2IF | 4        |
| External Interrupt 3 | INT3IF | 5        |
| Timer/Counter 0      | TOIF   | 6        |
| Timer/Counter 1      | T1IF   | 7        |
| Timer/Counter 2      | T2IF   | 8        |
| Timer/Counter 3      | T3IF   | 9        |
| AD Converter         | AIF    | 10       |
| Watch dog timer      | WDTIF  | 11       |
| Basic interval timer | BITIF  | 12       |

<sup>\*</sup>Vector addresses are shown in Program Memory section.

The External Interrupts INT0~INT3 can each be transition-activated, depending on interrupt edge selection register.

The Timer  $0\sim$ Timer 3 Interrupts are generated by T0IF  $\sim$ T3IF, which are set by a match in their respective timer/counter register.

The AD converter Interrupt is generated by AIF 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. The Basic Interval Timer Interrupt is generated by BITIF which are set by a overflow in the timer/counter

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 29. These registers are composed of interrupt enable flags of each interrupt source, these flags determines



Figure 28. Block Diagram of Interrupt Function



Figure 29. IENH, IENL: Interrupt Enable Registers

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.

When an interrupt is responded to, the I-flag is cleared to disable any further interrupt, the return address is 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 flag bits.

The interrupt flag bit(s) must be cleared in software before reenabling interrupts to avoid recursive interrupts. The Interrupt Request flags are able to be read and write.

#### **External Interrupt**

External interrupt on INTO-INT3 pins are edge triggered depending the edge selection register IEDS.

The edge detection of external interrupt has three transition activated mode: rising edge, falling edge, both edge. INT0 $\sim$ INT3 are multiplexed with general I/O ports (R40 $\sim$ R43). To use external interrupt pin, set

bit 0 to bit 3 of the port mode register PMR4.

The PMR4 and IEDS registers are shown in Figure 32.



Figure 30. External Interrupt



Figure 31. INT Pin Interrupt Timing



Figure 32. PMR4 and IEDS Registers

#### **BRK Interrupt**

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

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

Each processing step is determined by B-flag as shown below.



Figure 33. Execution of BRK/ TCALL0

#### Multiple Interrupt

If two requests of different priority levels are received simultaneously, the request of higher priority level is serviced. If requests of the same priority level are received simultaneously, an internal polling sequence determines by hardware which request is serviced. Hardware interrupt priority is shown in Page37.

However, multiple processing through software for special features is possible. Generally when an interrupt is accepted, the I-flag is cleared to disable any further interrupt. But as user set I-flag in interrupt routine, some further interrupt can be serviced even if certain interrupt is in progress.



Figure 34. Execution of Multi-Interrupt

#### **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 consists of 6-bit binary counter, 6-bit comparator and the watchdog timer data register. When the value of 6-bit binary counter is equal to the lower 6 bits of WDTR, the match is generated to go to reset the CPU.

The 6-bit binary counter is cleared by WDTCL=1.

#### Caution:

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.

This watchdog timer can also be used as a simple 6-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 \cdot Interval \ of \ BIT$ 



Figure 35. Block Diagram of Watch-dog Timer



Figure 36. WDTR: Watch-dog Timer Data Register

#### STOP MODE

For applications where power consumption is a critical factor, device provides reduced power of STOP.

An instruction that STOP causes that to be the last instruction executed before going into the 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 Rx, port direction register RxDD. The status of peripherals during Stop mode is shown below.

| Peripheral        | Status |
|-------------------|--------|
| RAM               | Retain |
| Control registers | Retain |
| I/O               | Retain |
| Oscillation       | Stop   |
| X <sub>IN</sub>   | Low    |
| Хоит              | High   |

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 (minimum 20 msec).

# Caution: The NOP instruction have to be written more than two to next line of the STOP instruction. EX) STOP

NOP NOP

#### Release Stop Mode

The exit from Stop mode is hardware reset or external interrupt. Reset redefines 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.

When exit from Stop mode by external interrupt from Stop mode, enough oscillation stabilization time is required to normal operation. Figure 37 shows the timing diagram. When release the Stop mode, the



Figure 37. Timing of Stop Release by External Interrupt

#### Wake-up and Reset Function Table

|                            | Chip Status                          | Chip function           | Chip function after event |  |
|----------------------------|--------------------------------------|-------------------------|---------------------------|--|
| Event                      | before event                         | PC Oscillato<br>Circuit |                           |  |
| RESET                      | Do not care                          | Vector                  | on                        |  |
| STOP instruction           | Normal operation                     | N+1                     | off                       |  |
| External Interrupt         | Normal operation                     | Vector                  | on                        |  |
| External Interrupt Wake-up | Stop, I-flag = 1<br>Stop, I-flag = 0 | Vector<br>N+1           | on<br>on                  |  |

PC: Program Counter contents after the event.

N: Address of STOP instruction.

Basic interval timer is activated on wake-up. It is incremented from  $00_{\rm H}$  until  $FF_{\rm H}$  then  $00_{\rm H}$ . 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 crystal oscillator has started and stabilized.

By reset, exit from Stop mode is shown in Figure 38.

# Minimizing Current Consumption in Stop Mode

The Stop mode is designed to reduce power consumption. To minimize current drawn during Stop mode, the user should turn-off output drivers that are sourcing or sinking current, if it is practical. Weak pull-ups on port pins should be turned off, if possible. All inputs should be either as  $V_{\rm SS}$  or at  $V_{\rm DD}$  (or as close to rail as possible). An intermediate voltage on an input pin causes the input buffer to draw a significant amount of current.



Figure 38. Timing of Stop Mode Release by Reset

#### **RESET**

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

Internal RAM is not affected by reset. When  $V_{\rm DD}$  is turned on, the RAM content is indeterminate. Initial state of each register is as follow. Therefore, this RAM should be initialized before reading or testing it.



Figure 39. Example of Reset circuit





Figure 40. Timing Diagram after Reset

#### **POWER FAIL PROCESSOR**

The GMS81604/08 have 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_{\rm DD}$  falls below  $3.0{\sim}4.0V$  range for longer than 100 ns, the Power fail situation may reset MCU according to PFR bit of PFDR.

#### Caution:

Power fail processor function is not available on 3V operation, because this function will detect power fail all the time.

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 41. PFDR: Power Fail Detector Register



Figure 42. Example S/W of Reset flow by Power Fail



Figure 43. Power Fail Processor Situations

#### **OSCILLATOR CIRCUIT**

 $X_{\rm IN}$  and  $X_{\rm OUT}$  are the input and output, respectively, of a inverting amplifier which can be configured for use as an on-chip oscillator, as shown in Figure 44.



Figure 44. Oscillator Connections

To drive the device from an external clock source,  $X_{OUT}$  should be left unconnected while  $X_{IN}$  is driven as shown in Figure 45. 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.



Figure 45. External Clock Drive Configuration



Figure 46. Layout of Crystal

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

In addition, see Figure 46. for the layout of the crystal. In all cases, an external clock operation is available.

#### **UNUSED PORTS**

All unused ports should be set properly that current flow through the port does not 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 does not flow.

But input voltage level should be  $V_{SS}$  or  $V_{DD}.\ Be$  careful that if unspecified voltage, i.e. if unfirmed

voltage level is applied to input pin, there can be little current (  $\max. 1mA$  at around 2V) flow.

If it is not appropriate to set to 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.

#### **GMS81608T (OTP) PROGRAMMING**

The GMS81608T is one-time PROM (OTP) microcontroller with 8K bytes electrically programmable read only memory for the GMS81604/08 system evaluation, first production and fast mass production.

The programming to the OTP device, user can have two way. One is using the universal programmer which is support LGS microcontrollers, other is using the general EPROM programmer.

#### 1. Using the Universal programmer

Third party universal programmer support to program the GMS81608T microcontrollers and lists are shown as below.

Manufacturer: **Advantech**Web site: http://www.aec.com.tw
Programmer: LabTool-48

Manufacturer: Hi-Lo systems

Web site: http://www.hilosystems.com.tw Programmer: ALL-11, GANG-08

Socket adapters are supported by third party programmer manufacturer.

# 2. Using the general EPROM(27C256) programmer

The programming algorithm is simmilar with the standart EPROM 27C256. It give some convience that user can use standard EPROM programmer. *Make sure that 1ms programming pulse must be used, it generally called "Intelligent Mode"*. Do not use 100us programming pulse mode, "Quick Pulse Mode".

When user use general EPROM programmer, socket adaper is essencially required. It convert pin to fit the pin of general 27C256 EPROM.

Three type socket adapters are provided according to package variation as below table.

| Socket Adapter | Package Type |
|----------------|--------------|
| OA816A-40SD    | 40 pin DIP   |
| OA816A-42SD    | 42 pin SDIP  |
| OA816A-42PL    | 44 pin PLCC  |

With these socket adapters, the GMS81608T can easy be programming and verifying using 27C256 EPROM mode on general-purpose PROM programmer.

In assembler and file type, two files are generated after compiling. One is "\*.HEX", another is "\*.OTP". The "\*.HEX" file is used for emulation in circuit emulator (CHOICE- $\mathrm{Dr^{TM}}$ ) or CHOICE- $\mathrm{Jr^{TM}}$ ) and "\*.OTP" file is used for programming to the OTP device.

#### **Programming Procedure**

- 1. Select the EPROM device and manufacturer on EPROM programmer (Intel 27C256).
- Select the programming algorithm as an Intelligent mode (apply 1ms writing pulse), not a Quick pulse mode.
- 3. Load the file (\*.OTP) to the programmer.
- 4. Set the programming address range as below table.

| Address              | Set Value         |
|----------------------|-------------------|
| Buffer start address | 6000 <sub>H</sub> |
| Buffer end address   | 7FFF <sub>H</sub> |
| Device start address | 6000 <sub>H</sub> |

- 5. Mount the socket adapter with the GMS81608T on the PROM programmer.
- Start the PROM programmer to programming/ verifying.

# GMS81608T PROGRAMMING MANUAL

#### **GMS815045T PACKAGE**

| DEVICE NAME  | PACKAGE |
|--------------|---------|
| GMS81608T    | 40DIP   |
| GMS81608T K  | 42SDIP  |
| GMS81608T PL | 44PLCC  |

#### **PIN CONFIGURATION**





#### 40DIP Package for GMS81608T

| - Committee of the comm |                 |     |                 |     |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----|-----------------|-----|--|
| Pin No.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | MCU Mode        |     | OTP M           | ode |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | TEST            | 1   | VPP             | -   |  |
| 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | AVDD            | -   | (1)             | -   |  |
| 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R67/AN7         | I/O | (1)             | -   |  |
| 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R66/AN6         | I/O | (1)             | -   |  |
| 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R65/AN5         | I/O | (1)             | -   |  |
| 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R64/AN4         | I/O | (1)             | -   |  |
| 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R63/AN3         | 1   | (1)             | -   |  |
| 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R62/AN2         | 1   | (1)             | -   |  |
| 9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R61/AN1         | 1   | (1)             | -   |  |
| 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R60/AN0         | 1   | (1)             | -   |  |
| 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R47/T3O         | I/O | A4              | 1   |  |
| 12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R46/T1O         | I/O | (1)             | -   |  |
| 13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R45/EC2         | I/O | CE              | 1   |  |
| 14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R44/EC0         | I/O | ŌE              | 1   |  |
| 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R43/INT3        | I/O | А3              | 1   |  |
| 16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R42/INT2        | I/O | A2              | 1   |  |
| 17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R41/INT1        | I/O | A1              | I   |  |
| 18                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R40/INT0        | I/O | A0              | I   |  |
| 19                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R55/BUZ         | I/O | (1)             | -   |  |
| 20                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | V <sub>DD</sub> | -   | V <sub>DD</sub> | -   |  |

| Pin No. | MCU Mode |     | ОТР М | ode |
|---------|----------|-----|-------|-----|
| 21      | R17      | I/O | A12   | I   |
| 22      | R16      | I/O | A11   | I   |
| 23      | R15      | I/O | A10   | I   |
| 24      | R14      | I/O | A9    | I   |
| 25      | R13      | I/O | A8    | I   |
| 26      | R12      | I/O | A7    | 1   |
| 27      | R11      | I/O | A6    | I   |
| 28      | R10      | I/O | A5    | 1   |
| 29      | R07      | I/O | 07    | 0   |
| 30      | R06      | I/O | 06    | 0   |
| 31      | R05      | I/O | O5    | 0   |
| 32      | R04      | I/O | 04    | 0   |
| 33      | R03      | I/O | О3    | 0   |
| 34      | R02      | I/O | 02    | 0   |
| 35      | R01      | I/O | 01    | 0   |
| 36      | R00      | I/O | 00    | 0   |
| 37      | RESET    | I   | (1)   | -   |
| 38      | Хоит     | 0   | (3)   | -   |
| 39      | XIN      | I   | (1)   | -   |
| 40      | Vss      | -   | (1)   | -   |

#### NOTES:

- (1) Pins must be connected to V<sub>SS</sub>, because these pins are input ports during programming, program verify and reading
- (2) Pins must be connected to V<sub>DD</sub>.(3) X<sub>OUT</sub> pin must be opened during programming.

I/O: Input/Output Pin

I: Input Pin

O: Output Pin

#### 42SDIP Package for GMS81608T

| 120211 1 dokugo 101 0 m 00 1000 1 |          |     |                 |     |
|-----------------------------------|----------|-----|-----------------|-----|
| Pin No.                           | MCU Mode |     | OTP M           | ode |
| 1                                 | TEST     | 1   | Vpp             | -   |
| 2                                 | AVDD     | -   | (1)             | -   |
| 3                                 | R67/AN7  | I/O | (1)             | -   |
| 4                                 | R66/AN6  | I/O | (1)             | -   |
| 5                                 | R65/AN5  | I/O | (1)             | -   |
| 6                                 | R64/AN4  | I/O | (1)             | -   |
| 7                                 | R63/AN3  | 1   | (1)             | -   |
| 8                                 | R62/AN2  | 1   | (1)             | -   |
| 9                                 | R61/AN1  | 1   | (1)             | -   |
| 10                                | R60/AN0  | 1   | (1)             | -   |
| 11                                | R47/T3O  | I/O | A4              | 1   |
| 12                                | R46/T1O  | I/O | (1)             | -   |
| 13                                | R45/EC2  | I/O | CE              | 1   |
| 14                                | R44/EC0  | I/O | OE              | I   |
| 15                                | R43/INT3 | I/O | А3              | 1   |
| 16                                | R42/INT2 | I/O | A2              | I   |
| 17                                | R41/INT1 | I/O | A1              | 1   |
| 18                                | R40/INT0 | I/O | Α0              | 1   |
| 19                                | R55/BUZ  | I/O | (1)             | -   |
| 20                                | $V_{DD}$ | -   | V <sub>DD</sub> | -   |
| 21                                | R51      | I/O | (2)             | -   |

| Pin No. | MCU Mc | ode | OTP Mo | de |
|---------|--------|-----|--------|----|
| 22      | R50    | I/O | (2)    | -  |
| 23      | R17    | I/O | A12    | ı  |
| 24      | R16    | I/O | A11    | 1  |
| 25      | R15    | I/O | A10    | 1  |
| 26      | R14    | I/O | A9     | 1  |
| 27      | R13    | I/O | A8     | 1  |
| 28      | R12    | I/O | A7     | 1  |
| 29      | R11    | I/O | A6     | 1  |
| 30      | R10    | I/O | A5     | 1  |
| 31      | R07    | I/O | 07     | 0  |
| 32      | R06    | I/O | 06     | 0  |
| 33      | R05    | I/O | O5     | 0  |
| 34      | R04    | I/O | 04     | 0  |
| 35      | R03    | I/O | О3     | 0  |
| 36      | R02    | I/O | 02     | 0  |
| 37      | R01    | I/O | 01     | 0  |
| 38      | R00    | I/O | 00     | 0  |
| 39      | RESET  | 1   | (1)    | -  |
| 40      | Хоит   | 0   | (3)    | -  |
| 41      | XIN    | - 1 | (1)    | -  |
| 42      | Vss    | -   | (1)    | -  |

NOTES:

I/O: Input/Output Pin
I: Input Pin

O: Output Pin

<sup>(1)</sup> Pins must be connected to  $V_{\mbox{SS}}$ , because these pins are input ports during programming, program verify and reading

<sup>(2)</sup> Pins must be connected to  $V_{\mbox{\scriptsize DD}}$ .

<sup>(3)</sup>  $X_{\mbox{OUT}}$  pin must be opened during programming.

44PLCC Package for GMS81608T

| 14FLCC Fackage for GM3816081 |                  |     |                 |     |  |
|------------------------------|------------------|-----|-----------------|-----|--|
| Pin No.                      | MCU Mode         |     | ОТР М           | ode |  |
| 1                            | N.C.             | -   | N.C.            | -   |  |
| 2                            | TEST             | 1   | VPP             | -   |  |
| 3                            | AVDD             | -   | (1)             | -   |  |
| 4                            | R67/AN7          | I/O | (1)             | -   |  |
| 5                            | R66/AN6          | I/O | (1)             | -   |  |
| 6                            | R65/AN5          | I/O | (1)             | -   |  |
| 7                            | R64/AN4          | I/O | (1)             | -   |  |
| 8                            | R63/AN3          | 1   | (1)             | -   |  |
| 9                            | R62/AN2          | 1   | (1)             | -   |  |
| 10                           | R61/AN1          | 1   | (1)             | -   |  |
| 11                           | R60/AN0          | 1   | (1)             | -   |  |
| 12                           | R47/T3O          | I/O | A4              | 1   |  |
| 13                           | R46/T1O          | I/O | (1)             | -   |  |
| 14                           | R45/EC2          | I/O | CE              | 1   |  |
| 15                           | R44/EC0          | I/O | OE              | 1   |  |
| 16                           | R43/INT3         | I/O | А3              | 1   |  |
| 17                           | N.C.             | -   | N.C.            | -   |  |
| 18                           | R42/INT2         | I/O | A2              | 1   |  |
| 19                           | R41/INT1         | I/O | A1              | 1   |  |
| 20                           | R40/INT0         | I/O | A0              | I   |  |
| 21                           | R55/BUZ          | I/O | (1)             | -   |  |
| 22                           | V <sub>D</sub> D | -   | V <sub>DD</sub> | -   |  |

| Pin No. | MCU M | MCU Mode |     | ode |
|---------|-------|----------|-----|-----|
| 23      | R51   | I/O      | (2) | -   |
| 24      | R50   | I/O      | (2) | -   |
| 25      | R17   | I/O      | A12 | 1   |
| 26      | R16   | I/O      | A11 | 1   |
| 27      | R15   | I/O      | A10 | 1   |
| 28      | R14   | I/O      | A9  | 1   |
| 29      | R13   | I/O      | A8  | 1   |
| 30      | R12   | I/O      | A7  | 1   |
| 31      | R11   | I/O      | A6  | 1   |
| 32      | R10   | I/O      | A5  | 1   |
| 33      | R07   | I/O      | 07  | 0   |
| 34      | R06   | I/O      | 06  | 0   |
| 35      | R05   | I/O      | O5  | 0   |
| 36      | R04   | I/O      | 04  | 0   |
| 37      | R03   | I/O      | О3  | 0   |
| 38      | R02   | I/O      | 02  | 0   |
| 39      | R01   | I/O      | 01  | 0   |
| 40      | R00   | I/O      | 00  | 0   |
| 41      | RESET | I        | (1) | -   |
| 42      | Хоит  | 0        | (3) | -   |
| 43      | XIN   | I        | (1) | -   |
| 44      | Vss   | -        | (1) | -   |

NOTES:

I/O: Input/Output Pin I: Input Pin O: Output Pin

<sup>(1)</sup> Pins must be connected to  $V_{\mbox{SS}}$ , because these pins are input ports during programming, program verify and reading

<sup>(2)</sup> Pins must be connected to V<sub>DD</sub>.(3) X<sub>OUT</sub> pin must be opened during programming.

#### PIN FUNCTION (OTP Mode)

#### **VPP** (Program Voltage)

 $V_{\mbox{\footnotesize{PP}}}$  is the input for the program voltage for programming the EPROM.

#### **CE** ( Chip Enable)

CE is the input for programming and verifying internal EPROM.

#### **OE** (Output Enable)

OE is the input of data output control signal for verify.

#### A<sub>0</sub>~A<sub>12</sub> (Address Bus)

 $A_0{\sim}A_{12}$  are address input pins for internal EPROM.

#### O<sub>0</sub>~O<sub>7</sub> (EPROM Data Bus)

These are data bus for internal EPROM.

#### **PROGRAMMING**

The GMS81608T has address  $A_0 \sim A_{12}$  pins. Therefore, the programmer just program 8K bytes data of addresses  $6000_H$  to  $7FFF_H$  into the GMS81608T OTP device. During the programming addresses  $A_{13}$ ,  $A_{14}$ ,  $A_{15}$  of programmer must be pulled to a logic high.

When the programmer write the data from  $6000_{\rm H}$  to  $7FFF_{\rm H}$ , consequently, the data actually will be written into addresses  $E000_{\rm H}$  to  $FFFF_{\rm H}$  of the OTP device.

#### **Programming Flow**

 $1. \ The \ data \ format \ to \ be \ programmed \ is \ made \ up \ of \ Motorola \ S1 \ format.$ 

```
Ex) "Motorola S1" format;
```

S00B00005741544348363038DF

 $S1246000E1FF3BFF04A13F8F06E1C1711BFF3F1B003E1B00371B00361BFF3D1B003C1BFF3385\\S12460211BFF321BFF351B92131B7FCC1BF3D61B17FD1BFCFC1B821B1BE01D1B8E191BFD18B1$ 

: \$1057FF2941FD6 \$1057FFEFF1F5F \$9030000FC

- 2. Down load above data into programmer from PC.
- 3. Programming the data from address  $6000_H$  to  $7FFF_H$  into the OTP MCU, the data must be turned over respectively, and then record the data into the OTP device. When read the data, it also must be turned over. Ex)  $00(00000000) \rightarrow FF(11111111)$ ,  $76(01110110) \rightarrow 89(10001001)$ ,  $FF(11111111) \rightarrow 00(00000000)$  etc.
- 4. Of course, the check sum is result of the sum of whole data from address  $6000_H$  to  $7FFF_H$  in the file (not reverse data of the OTP MCU).
- $^{*}$  When GMS81608T shipped, the blank data of GMS81608T is initially  $00_{\mathrm{H}}$  (not FF $_{\mathrm{H}}$ ).

#### **Programming Flow**



#### **Programming Example**



#### **DEVICE OPERATION MODE**

 $(T_A = 25^{\circ}C \pm 5^{\circ}C)$ 

| Mode           | CE  | OE     | A0~A15 | VPP      | VDD             | 00~07 |
|----------------|-----|--------|--------|----------|-----------------|-------|
| Read           | Х   |        | Х      | $V_{DD}$ | 5.0V            | Dout  |
| Output Disable | VIH | VIH    | Х      | $V_{DD}$ | 5.0V            | Hi-Z  |
| Programming    | VIL | ViH    | Х      | Vpp      | V <sub>DD</sub> | DIN   |
| Program Verify | Х   | $\neg$ | Х      | Vpp      | $V_{DD}$        | Dout  |

NOTES:

1.  $X = Either V_{IL} or V_{IH}$ 

3. See DC Characteristics Table for  $V_{\mbox{DD}}$  and  $V_{\mbox{PP}}$  voltages during programming.

#### DC CHARACTERISTICS

 $(V_{\rm SS}{=}0~{\rm V},~T_{\rm A}=25^{\circ}{\rm C}~\pm5^{\circ}{\rm C})$ 

| Symbol              | Item                           | Min                  | Тур | Max                 | Unit | Test condition            |
|---------------------|--------------------------------|----------------------|-----|---------------------|------|---------------------------|
| VPP                 | Vpp supply voltage             | 12.0                 | -   | 13.0                | V    |                           |
| V <sub>DD</sub> (1) | V <sub>DD</sub> supply voltage | 5.75                 | -   | 6.25                | V    |                           |
| I <sub>PP</sub> (2) | VPP supply current             |                      |     | 50                  | mΑ   | CE=VIL                    |
| I <sub>DD</sub> (2) | V <sub>DD</sub> supply current |                      |     | 30                  | mΑ   |                           |
| VIH                 | Input high voltage             | 0.8 V <sub>DD</sub>  |     |                     | V    |                           |
| VIL                 | Input low voltage              |                      |     | 0.2 V <sub>DD</sub> | V    |                           |
| Voн                 | Output high voltage            | V <sub>DD</sub> -1.0 |     |                     | V    | I <sub>OH</sub> = -2.5 mA |
| VoL                 | Output low voltage             |                      |     | 0.4                 | V    | I <sub>OL</sub> = 2.1 mA  |
| lıL                 | Input leakage current          |                      |     | 5                   | uA   |                           |

NOTES:

1.  $V_{\mbox{DD}}$  must be applied simultaneously or before  $V_{\mbox{PP}}$  and removed simultaneously or after  $V_{\mbox{PP}}$ .

2. The maximum current value is with outputs O<sub>0</sub> to O<sub>7</sub> unloaded.

#### **SWITCHING WAVEFORMS**

| WAVEFORM | INPUTS                           | OUTPUTS                                         |
|----------|----------------------------------|-------------------------------------------------|
|          | Must be steady                   | Will be steady                                  |
|          | May change<br>from H to L        | Will be changing from H to L                    |
|          | May change<br>from L to H        | Will be changing from L to H                    |
|          | Do not care any change permitted | Changing state unknown                          |
|          | Does not apply                   | Center line is<br>high impedance<br>"Off" state |

#### **READING WAVEFORMS**



- The input timing reference level is 1.0 V for a V<sub>IL</sub> and 4.0V for a V<sub>IH</sub> at V<sub>DD</sub>=5.0V
   To read the output data, transition requires on the OE from the high to the low after address setup time t<sub>AS</sub>.

#### PROGRAMMING ALGORITHM WAVEFORMS



#### NOTES:

1. The input timing reference level is 1.0 V for a V<sub>IL</sub> and 4.0V for a V<sub>IH</sub> at V<sub>DD</sub>=5.0V

#### **AC READING CHARACTERISTICS**

 $(V_{SS}=0~V,~T_A=25^{\circ}C~\pm5^{\circ}C)$ 

| Symbol | ltem                   | Min | Тур | Max | Unit | Test condition |
|--------|------------------------|-----|-----|-----|------|----------------|
| tas    | Address setup time     | 2   |     |     | us   |                |
| toE    | Data output delay time |     |     | 200 | ns   |                |
| tDН    | Data hold time         | 0   |     |     | ns   |                |

#### NOTES:

#### AC PROGRAMMING CHARACTERISTICS

(V  $_{SS}$  =0 V, T  $_{A}$  = 25 °C  $\,\pm\,5\,^{\circ}$  C; See DC Characteristics Table for V  $_{DD}$  and V  $_{PP}$  voltages.)

| Symbol | Item                                 | Min  | Тур | Max   | Unit | Condition*<br>(Note 1) |
|--------|--------------------------------------|------|-----|-------|------|------------------------|
| tas    | Address set-up time                  | 2    |     |       | us   |                        |
| toes   | OE set-up time                       | 2    |     |       | us   |                        |
| tos    | Data setup time                      | 2    |     |       | us   |                        |
| tAH    | Address hold time                    | 0    |     |       | us   |                        |
| tDH    | Data hold time                       | 1    |     |       | us   |                        |
| tDFP   | Output disable delay time            | 0    |     |       | us   |                        |
| typs   | V <sub>PP</sub> setup time           | 2    |     |       | us   |                        |
| tvps   | V <sub>DD</sub> setup time           | 2    |     |       | us   |                        |
| tpw    | Program pulse width                  | 0.95 | 1.0 | 1.05  | ms   |                        |
| topw   | CE pulse width when over programming | 2.85 |     | 78.75 | ms   | (Note 2)               |
| toE    | Data output delay time               |      |     | 200   | ns   |                        |

<sup>\*</sup>AC CONDITIONS OF TEST

#### NOTES:

- 1.  $\ensuremath{\text{V}_{\text{DD}}}$  must be applied simultaneously or before  $\ensuremath{\text{V}_{\text{PP}}}$  and removed simultaneously or after  $\ensuremath{\text{V}_{\text{PP}}}$ .
- 2. The length of the overprogram pulse may vary from 2.85 msec to 78.75 msec as a function of the iteration counter value X (Intelligent Programming Algorithm). Refer to flow chart of page 13.

<sup>1.</sup>  $V_{\mbox{DD}}$  must be applied simultaneously or before  $V_{\mbox{PP}}$  and removed simultaneously or after  $V_{\mbox{PP}}$ .

### **Intelligent Programming Algorithm**



# **APPENDIX**



# A. INSTRUCTION

# A.1 Terminology List

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



# A.2 Instruction Map

| LOW<br>HIGH | 00000 | 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,re<br>I | ADC<br>#imm        | ADC<br>dp   | ADC<br>dp+X | ADC<br>!abs | ASL<br>A    | ASL<br>dp   | TCALL<br>0  | SETA1         | 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,#im<br>m | 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        | 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 {X}     | STA<br>!abs+Y | STA<br>[dp+X] | STA<br>[dp]+Y | STY<br>!abs | STY<br>dp+X | TCALL<br>15 | STA<br>{X}+  | STX<br>!abs  | CBNE<br>dp  | XYX          | NOP           |



## A.3 Instruction Set

# **Arithmetic / Logic Operation**

| No. | Mnemonic     | Op<br>Code | Byte<br>No | Cycle<br>No | Operation                                     | Flag<br>NVGBHIZC |
|-----|--------------|------------|------------|-------------|-----------------------------------------------|------------------|
| 1   | ADC #imm     | 04         | 2          | 2           | 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           |                                               |                  |
| 20  | ASL !abs     | 18         | 3          | 5           |                                               |                  |
| 21  | CMP #imm     | 44         | 2          | 2           |                                               |                  |
| 22  | CMP dp       | 45         | 2          | 3           |                                               |                  |
| 23  | CMP dp + X   | 46         | 2          | 4           |                                               |                  |
| 24  | CMP !abs     | 47         | 3          | 4           | Compare accumulator contents with memory con- | NZC              |
| 25  | CMP !abs + Y | 55         | 3          | 5           | tents<br>(A)-(M)                              |                  |
| 26  | CMP [dp + X] | 56         | 2          | 6           | (//) (W)                                      |                  |
| 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 ) ← ~( 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                                     | NZC              |



| No. | Mnemonic     | Op<br>Code | Byte<br>No | Cycle<br>No | Operation                                             | Flag<br>NVGBHIZC |
|-----|--------------|------------|------------|-------------|-------------------------------------------------------|------------------|
| 39  | DEC dp       | A9         | 2          | 4           | M ← (M)-1                                             | NZ-              |
| 40  | DEC dp + X   | B9         | 2          | 5           |                                                       | NZ-              |
| 41  | DEC !abs     | B8         | 3          | 5           |                                                       | NZ-              |
| 42  | DEC X        | AF         | 1          | 2           |                                                       | NZ-              |
| 43  | DEC Y        | BE         | 1          | 2           |                                                       | NZ-              |
| 44  | DIV          | 9B         | 1          | 12          | Divide: YA / X Q: A, R: Y                             | NVH-Z-           |
| 45  | EOR #imm     | A4         | 2          | 2           | Exclusive OR                                          |                  |
| 46  | EOR dp       | A5         | 2          | 3           | $A \leftarrow (A) \oplus (M)$                         |                  |
| 47  | EOR dp + X   | A6         | 2          | 4           |                                                       |                  |
| 48  | EOR !abs     | A7         | 3          | 4           |                                                       | NZ-              |
| 49  | EOR !abs + Y | B5         | 3          | 5           |                                                       |                  |
| 50  | EOR [dp + X] | B6         | 2          | 6           |                                                       |                  |
| 51  | EOR [dp]+Y   | B7         | 2          | 6           |                                                       |                  |
| 52  | EOR {X}      | B4         | 1          | 3           |                                                       |                  |
| 53  | INC A        | 88         | 1          | 2           | Increment                                             | NZC              |
| 54  | INC dp       | 89         | 2          | 4           | M ← (M) + 1                                           | NZ-              |
| 55  | INC dp + X   | 99         | 2          | 5           |                                                       | NZ-              |
| 56  | INC !abs     | 98         | 3          | 5           |                                                       | NZ-              |
| 57  | INC X        | 8F         | 1          | 2           |                                                       | NZ-              |
| 58  | INC Y        | 9E         | 1          | 2           |                                                       | NZ-              |
| 59  | LSR A        | 48         | 1          | 2           | Logical shift right                                   |                  |
| 60  | LSR dp       | 49         | 2          | 4           | 7 6 5 4 3 2 1 0 C                                     | NZC              |
| 61  | LSR dp + X   | 59         | 2          | 5           | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ |                  |
| 62  | LSR !abs     | 58         | 3          | 5           |                                                       |                  |
| 63  | MUL          | 5B         | 1          | 9           | Multiply: $YA \leftarrow Y \times A$                  | NZ-              |
| 64  | OR #imm      | 64         | 2          | 2           | Logical OR                                            |                  |
| 65  | OR dp        | 65         | 2          | 3           | $A \leftarrow (A) \lor (M)$                           |                  |
| 66  | OR dp + X    | 66         | 2          | 4           |                                                       |                  |
| 67  | OR !abs      | 67         | 3          | 4           |                                                       | NZ-              |
| 68  | OR !abs + Y  | 75         | 3          | 5           |                                                       |                  |
| 69  | OR [dp + X]  | 76         | 2          | 6           |                                                       |                  |
| 70  | OR [dp]+Y    | 77         | 2          | 6           |                                                       |                  |
| 71  | OR {X}       | 74         | 1          | 3           |                                                       |                  |
| 72  | ROL A        | 28         | 1          | 2           | Rotate left through Carry                             |                  |
| 73  | ROL dp       | 29         | 2          | 4           | C 76543210                                            | NZC              |
| 74  | ROL dp + X   | 39         | 2          | 5           |                                                       |                  |
| 75  | ROL !abs     | 38         | 3          | 5           |                                                       |                  |
| 76  | ROR A        | 68         | 1          | 2           | Rotate right through Carry                            |                  |
| 77  | ROR dp       | 69         | 2          | 4           | 7 6 5 4 3 2 1 0 C                                     | NZC              |
| 78  | ROR dp + X   | 79         | 2          | 5           |                                                       |                  |
| 79  | ROR !abs     | 78         | 3          | 5           |                                                       |                  |
| 80  | SBC #imm     | 24         | 2          | 2           | Subtract with Carry                                   |                  |



| No. | Mnemonic     | Op<br>Code | Byte<br>No | Cycle<br>No | Operation                                                                                                              | Flag<br>NVGBHIZC |
|-----|--------------|------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------|------------------|
| 81  | SBC dp       | 25         | 2          | 3           | A ← (A)-(M)-~(C)                                                                                                       |                  |
| 82  | SBC dp + X   | 26         | 2          | 4           |                                                                                                                        |                  |
| 83  | SBC !abs     | 27         | 3          | 4           |                                                                                                                        | NVHZC            |
| 84  | SBC !abs + Y | 35         | 3          | 5           |                                                                                                                        |                  |
| 85  | SBC [dp + X] | 36         | 2          | 6           |                                                                                                                        |                  |
| 86  | SBC [dp]+Y   | 37         | 2          | 6           |                                                                                                                        |                  |
| 87  | SBC {X}      | 34         | 1          | 3           |                                                                                                                        |                  |
| 88  | TST dp       | 4C         | 2          | 3           | Test memory contents for negative or zero, ( dp ) - $00_{\mbox{\scriptsize H}}$                                        | NZ-              |
| 89  | XCN          | CE         | 1          | 5           | Exchange nibbles within the accumulator $A_7 \!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!$ | NZ-              |



# **Register / Memory Operation**

| No. | Mnemonic     | Op<br>Code | Byte<br>No | Cycle<br>No | Operation                                                                | Flag<br>NVGBHIZC |
|-----|--------------|------------|------------|-------------|--------------------------------------------------------------------------|------------------|
| 1   | LDA #imm     | C4         | 2          | 2           | 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 ) ← imm                            |                  |
| 11  | LDX #imm     | 1E         | 2          | 2           | Load X-register                                                          |                  |
| 12  | LDX dp       | СС         | 2          | 3           | $X \leftarrow (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 ← sp                   | NZ-              |
| 36  | TXA          | C8         | 1          | 2           | Transfer X-register contents to accumulator: A ← X                       | NZ-              |
| 37  | TXSP         | 8E         | 1          | 2           | Transfer X-register contents to stack-pointer: sp ← 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 ↔ A                     |                  |



| 40 | XAY      | DE | 1 | 4 | Exchange Y-register contents with accumulator :Y $\leftrightarrow$ A |     |
|----|----------|----|---|---|----------------------------------------------------------------------|-----|
| 41 | XMA dp   | вс | 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$ |     |

# 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 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 $(dp+1)(dp) \leftarrow (dp+1)(dp) - 1$      | NZ-              |
| 4   | INCW dp  | 9D         | 2          | 6           | Increment memory pair ( dp+1) ( dp) ← ( dp+1) ( dp ) + 1          | NZ-              |
| 5   | LDYA dp  | 7D         | 2          | 5           | Load YA<br>YA ← ( dp +1 ) ( dp )                                  | NZ-              |
| 6   | STYA dp  | DD         | 2          | 5           | Store YA<br>( dp +1 ) ( dp ) ← YA                                 |                  |
| 7   | SUBW dp  | 3D         | 2          | 5           | 16-Bits subtract without carry YA ← ( YA ) - ( dp +1) ( dp)       | NVH-ZC           |

## **Bit Manipulation**

| No. | Mnemonic    | Op<br>Code | Byte<br>No | Cycle<br>No | Operation                                                                 | Flag<br>NVGBHIZC |
|-----|-------------|------------|------------|-------------|---------------------------------------------------------------------------|------------------|
| 1   | AND1 M.bit  | 8B         | 3          | 4           | Bit AND C-flag : $C \leftarrow (C) \land (M.bit)$                         | C                |
| 2   | AND1B M.bit | 8B         | 3          | 4           | Bit AND C-flag and NOT : $C \leftarrow (C) \land \sim (M.bit)$            | C                |
| 3   | BIT dp      | 0C         | 2          | 4           | Bit test A with memory :                                                  | MMZ-             |
| 4   | BIT !abs    | 1C         | 3          | 5           | $Z \leftarrow (A) \land (M), N \leftarrow (M_7), V \leftarrow (M_6)$      |                  |
| 5   | CLR1 dp.bit | y1         | 2          | 4           | Clear bit : ( M.bit ) ← "0"                                               |                  |
| 6   | CLRA1 A.bit | 2B         | 2          | 2           | Clear A bit : ( A.bit ) ← "0"                                             |                  |
| 7   | CLRC        | 20         | 1          | 2           | Clear C-flag : C ← "0"                                                    | 0                |
| 8   | CLRG        | 40         | 1          | 2           | Clear G-flag : G ← "0"                                                    | 0                |
| 9   | CLRV        | 80         | 1          | 2           | Clear V-flag : V ← "0"                                                    | -00              |
| 10  | EOR1 M.bit  | AB         | 3          | 5           | Bit exclusive-OR C-flag $: C \leftarrow (C) \oplus (M.bit)$               | C                |
| 11  | EOR1B M.bit | AB         | 3          | 5           | Bit exclusive-OR C-flag and NOT : C $\leftarrow$ ( C ) $\oplus$ ~(M .bit) | C                |
| 12  | LDC M.bit   | СВ         | 3          | 4           | Load C-flag : C ← ( M .bit )                                              | C                |
| 13  | LDCB M.bit  | СВ         | 3          | 4           | Load C-flag with NOT : $C \leftarrow \sim (M \cdot bit)$                  | C                |
| 14  | NOT1 M.bit  | 4B         | 3          | 5           | Bit complement : ( M .bit ) ← ~( M .bit )                                 |                  |
| 15  | OR1 M.bit   | 6B         | 3          | 5           | Bit OR C-flag : $C \leftarrow (C) \lor (M .bit)$                          | C                |
| 16  | OR1B M.bit  | 6B         | 3          | 5           | Bit OR C-flag and NOT : $C \leftarrow (C) \lor \sim (M .bit)$             | C                |



| 17 | SET1 dp.bit | x1 | 2 | 4 | Set bit : ( M.bit ) ← "1"                                                    |     |
|----|-------------|----|---|---|------------------------------------------------------------------------------|-----|
| 18 | SETA1 A.bit | 0B | 2 | 2 | Set A bit : ( A.bit ) ← "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 ) ← C                                                |     |
| 22 | TCLR1 !abs  | 5C | 3 | 6 | Test and clear bits with A : $A - (M)$ , $(M) \leftarrow (M) \land \neg (A)$ | NZ- |
| 23 | TSET1 !abs  | 3C | 3 | 6 | Test and set bits with A:<br>A-(M), (M) $\leftarrow$ (M) $\vee$ (A)          | NZ- |



## **Branch / Jump Operation**

| No. | Mnemonic       | Op<br>Code | Byte<br>No | Cycle<br>No | Operation                                                                                                                                                                                                                                                              | Flag<br>NVGBHIZC |
|-----|----------------|------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 1   | BBC A.bit,rel  | y2         | 2          | 4/6         | Branch if bit clear :                                                                                                                                                                                                                                                  |                  |
| 2   | BBC dp.bit,rel | уЗ         | 3          | 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 | х3         | 3          | 5/7         | if ( bit ) = 1 , then pc ← ( pc ) + rel                                                                                                                                                                                                                                |                  |
| 5   | BCC rel        | 50         | 2          | 2/4         | Branch if carry bit clear if ( C ) = 0 , then $pc \leftarrow (pc) + rel$                                                                                                                                                                                               |                  |
| 6   | BCS rel        | D0         | 2          | 2/4         | Branch if carry bit set if (C) = 1, then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                    |                  |
| 7   | BEQ rel        | D0         | 2          | 2/4         | Branch if equal if $(Z) = 1$ , then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                         |                  |
| 8   | BMI rel        | 90         | 2          | 2/4         | Branch if minus if $(N) = 1$ , then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                         |                  |
| 9   | BNE rel        | 70         | 2          | 2/4         | Branch if not equal 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<br>pc ← ( pc ) + rel                                                                                                                                                                                                                                     |                  |
| 12  | BVC rel        | 30         | 2          | 2/4         | Branch if overflow bit clear if $(V) = 0$ , then $pc \leftarrow (pc) + rel$                                                                                                                                                                                            |                  |
| 13  | BVS rel        | В0         | 2          | 2/4         | Branch if overflow bit set if $(V) = 1$ , then $pc \leftarrow (pc) + rel$                                                                                                                                                                                              |                  |
| 14  | CALL !abs      | 3B         | 3          | 8           | Subroutine call                                                                                                                                                                                                                                                        |                  |
| 15  | CALL [dp]      | 5F         | 2          | 8           | $\begin{split} &M(sp) \leftarrow (pc_H), sp \leftarrow sp  \text{-}  1, M(sp) \leftarrow (pc_L), sp \leftarrow sp \\ &\text{-}  1,\\ &\text{if !abs, } pc \leftarrow  abs \; ; \; \text{if [dp], } pc_L \leftarrow (dp), \; pc_H \leftarrow (dp + 1) \; . \end{split}$ |                  |
| 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           | $\label{eq:U-page} \begin{split} &\text{U-page call} \\ &\text{M(sp)} \leftarrow \!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!$                                                                                                               |                  |
| 24  | TCALL n        | nA         | 1          | 8           | Table call : (sp) $\leftarrow$ ( pc <sub>H</sub> ), sp $\leftarrow$ sp - 1,<br>M(sp) $\leftarrow$ ( pc <sub>L</sub> ),sp $\leftarrow$ sp - 1,<br>pc <sub>L</sub> $\leftarrow$ (Table vector L), pc <sub>H</sub> $\leftarrow$ (Table vector H)                          |                  |



## **Control Operation & Etc.**

| No. | Mnemonic | Op<br>Code | Byte<br>No | Cycle<br>No | Operation                                                                                                                                                                                                                                                                                                                                                                 | Flag<br>NVGBHIZC |
|-----|----------|------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 1   | BRK      | 0F         | 1          | 8           | $\begin{split} & \text{Software interrupt}: B \leftarrow \text{"1", M(sp)} \leftarrow (pc_H), \text{ sp} \\ & \leftarrow \text{sp-1,} \\ & M(s) \leftarrow (pc_L), \text{sp} \leftarrow \text{sp-1, M(sp)} \leftarrow (PSW), \text{sp} \leftarrow \text{sp-1,} \\ & \text{sp-1,} \\ & pc_L \leftarrow (\text{ OFFDE}_H),  pc_H \leftarrow (\text{ OFFDF}_H). \end{split}$ | 1-0              |
| 2   | DI       | 60         | 1          | 3           | Disable all interrupts : I ← "0"                                                                                                                                                                                                                                                                                                                                          | 0                |
| 3   | El       | E0         | 1          | 3           | Enable all interrupt : I ← "1"                                                                                                                                                                                                                                                                                                                                            | 1                |
| 4   | NOP      | FF         | 1          | 2           | No operation                                                                                                                                                                                                                                                                                                                                                              |                  |
| 5   | POP A    | 0D         | 1          | 4           | $sp \leftarrow sp + 1, A \leftarrow M(sp)$                                                                                                                                                                                                                                                                                                                                |                  |
| 6   | POP X    | 2D         | 1          | 4           | $sp \leftarrow sp + 1, X \leftarrow M(sp)$                                                                                                                                                                                                                                                                                                                                |                  |
| 7   | POP Y    | 4D         | 1          | 4           | $sp \leftarrow sp + 1, Y \leftarrow M(sp)$                                                                                                                                                                                                                                                                                                                                |                  |
| 8   | POP PSW  | 6D         | 1          | 4           | $sp \leftarrow sp + 1$ , $PSW \leftarrow M(sp)$                                                                                                                                                                                                                                                                                                                           | restored         |
| 9   | PUSH A   | 0E         | 1          | 4           | $M(sp) \leftarrow A, sp \leftarrow sp - 1$                                                                                                                                                                                                                                                                                                                                |                  |
| 10  | PUSH X   | 2E         | 1          | 4           | $M(sp) \leftarrow X, sp \leftarrow sp - 1$                                                                                                                                                                                                                                                                                                                                |                  |
| 11  | PUSH Y   | 4E         | 1          | 4           | $M(sp) \leftarrow Y, sp \leftarrow sp - 1$                                                                                                                                                                                                                                                                                                                                |                  |
| 12  | PUSH PSW | 6E         | 1          | 4           | $M(sp) \leftarrow PSW, sp \leftarrow sp - 1$                                                                                                                                                                                                                                                                                                                              |                  |
| 13  | RET      | 6F         | 1          | 5           | Return from subroutine $sp \leftarrow sp +1, pc_L \leftarrow M(\ sp\ ), sp \leftarrow sp +1, pc_H \leftarrow M(\ sp\ )$ $sp\ )$                                                                                                                                                                                                                                           |                  |
| 14  | RETI     | 7F         | 1          | 6           | $\begin{aligned} & \text{Return from interrupt} \\ & \text{sp} \leftarrow \text{sp +1, PSW} \leftarrow \text{M(sp), sp} \leftarrow \text{sp + 1,} \\ & \text{pc}_L \leftarrow \text{M(sp), sp} \leftarrow \text{sp + 1, pc}_H \leftarrow \text{M(sp)} \end{aligned}$                                                                                                      | restored         |
| 15  | STOP     | EF         | 1          | 3           | Stop mode ( halt CPU, stop oscillator )                                                                                                                                                                                                                                                                                                                                   |                  |

#### **MASK ORDER & VERIFICATION SHEET** GMS81604-HC Customer should write inside thick line box. 1. Customer Information 2. Device Information Company Name Package **40DIP** 42SDIP 44PLCC Application YYYY ММ DD Mask Data | File Name: ( .OTP) Order Date Check Sum: ( Hitel Tel: Fax: 0000H Name & Chollian Set "FF" in Signature: this area Internet 6FFFH 7000H ROM (4K) 7FFFH 3. Marking Specification (Please check mark into **LGS** GMS81604-HC Customer's part number YYWW **KOREA** 4. Delivery Schedule **LG** Confirmation Quantity Date MM YYYY DD **Customer Sample** pcs YYYY MM DD Risk Order pcs 5. ROM Code Verification This box is written after "5. Verification". YYYY MM DD MM YYYY DD Verification Date: Approval Date: Please confirm our verification data. I agree with your verification data and confirm you to make mask set. Tel: Fax: Check Sum: Name & Fax: Tel: Signature: Name & Signature: **LG Semicon**

#### MASK ORDER & VERIFICATION SHEET GMS81608-HC Customer should write inside thick line box. 1. Customer Information 2. Device Information Company Name Package **40DIP** 42SDIP 44PLCC Application YYYY ММ DD Mask Data | File Name: ( .OTP) Order Date Check Sum: ( Hitel Tel: Fax: 0000H Name & Chollian Set "FF" in Signature: this area Internet 5FFFH 6000H ROM (8K) 3. Marking Specification 7FFFH (Please check mark into **LGS** GMS81608-HC Customer's part number YYWW **KOREA** 4. Delivery Schedule Quantity **LG** Confirmation Date MM YYYY DD **Customer Sample** pcs YYYY MM DD Risk Order pcs 5. ROM Code Verification This box is written after "5. Verification". YYYY MM DD MM DD YYYY Verification Date: Approval Date: Please confirm our verification data. I agree with your verification data and confirm you to make mask set. Tel: Fax: Check Sum: Name & Fax: Tel: Signature: Name & Signature: **LG Semicon**