# HYNIX SEMICONDUCTOR INC. 8-BIT SINGLE-CHIP MICROCONTROLLERS

# GMS81C5108

User's Manual (Ver. 1.0)



Version 1.0

Published by MCU Application Team

©2001 Hynix Semiconductor Inc. All rights reserved.

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

Hynix Semiconductor reserves the right to make changes to any information here in at any time without notice.

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

# **Table of Contents**

| 1. OVERVIEW1                                          | 8-Bit Capture Mode                   |    |
|-------------------------------------------------------|--------------------------------------|----|
| Description1                                          | 16-bit Capture Mode                  |    |
| Features1                                             | 8-Bit (16-Bit) Compare OutPut Mode   |    |
| Development Tools2                                    | PWM Mode                             |    |
| Ordering Information2                                 | 13. Watch Timer/Watch Dog Timer      |    |
| 2. BLOCK DIAGRAM3                                     | Watch Timer                          |    |
| 3. PIN ASSIGNMENT4                                    | Watch Dog Timer                      |    |
| 4. PACKAGE DIAGRAM5                                   | 14. Analog To Digital Converter      |    |
| 5. PIN FUNCTION6                                      | 15. Buzzer Output Function           | 60 |
| 6. PORT STRUCTURES8                                   | 16. Serial Communication Interface   | 62 |
|                                                       | Data Transmit/Receive Timing         |    |
| 7. ELECTRICAL CHARACTERISTICS11                       | The method of Serial I/O             | 64 |
| Absolute Maximum Ratings11                            | 17. INTERRUPTS                       | 65 |
| Recommended Operating Conditions11                    | Interrupt Sequence                   |    |
| DC Electrical Characteristics                         | BRK Interrupt                        |    |
| LCD Characteristics13 A/D Converter Characteristics13 | Multi Interrupt                      |    |
| AC Characteristics14                                  | External Interrupt                   |    |
| Serial I/O Characteristics15                          | 18. KEY SCAN                         | 70 |
| Typical Characteristics16                             | 19. LCD DRIVER                       | 71 |
| 8. MEMORY ORGANIZATION18                              | Configuration of LCD driver          |    |
| Registers18                                           | Control of LCD Driver Circuit        |    |
| Program Memory21                                      | LCD Display Memory                   |    |
| Data Memory 24                                        | Control Method of LCD Driver         |    |
| Addressing Mode                                       | 20. Remocon Carrier Generator        |    |
| 9. I/O PORTS31                                        | Remocon Signal Output Control        |    |
| Registers for Port31                                  | Carrier Frequency                    |    |
| I/O Ports Configuration32                             | 21. OSCILLATOR CIRCUIT               | 80 |
| 10. CLOCK GENERATOR34                                 | 22. RESET                            | 81 |
| Operation Mode36                                      | External Reset Input                 |    |
| Operation Mode Switching37                            | Watchdog Timer Reset                 |    |
| POWER SAVING OPERATION39                              | 23. SUPPLY VOLTAGE DETECTION         | 82 |
| 11. BASIC INTERVAL TIMER43                            |                                      |    |
| 12. Timer / Counter45                                 | 24. DEVEMOPMENT TOOLS                |    |
| 8-Bit Timer/Counter Mode48                            | OTP Programming Emulator S/W Setting |    |
| 16 Bit Timer/Counter Mode50                           | Emulator 5/W Setting                 | 04 |
| A CONTROL DECICED LICE                                | In admiration Man                    |    |
| A. CONTROL REGISTER LIST i                            | Instruction MapInstruction Set       | V  |
| B. INSTRUCTION iii                                    | C. MASK ORDER SHEET                  |    |
| Terminology List iii                                  | S. MINOR SINDLIN SINLL I             | AI |

ициіх

# GMS81C5108

# CMOS SINGLE-CHIP 8-BIT MICROCONTROLLER WITH LCD CONTROLLER/DRIVER AND INFRARED REMOTE CONTROL TRANSMITTERS

#### 1. OVERVIEW

#### 1.1 Description

The GMS81C5108 is an advanced CMOS 8-bit microcontroller with 8K bytes of ROM. The device is one of GMS800 family. The Hynix GMS81C5108 is a powerful microcontroller which provides a high flexibility and cost effective solution to many LCD applications. The GMS81C5108 provides the following standard features: 8K bytes of ROM, 192 bytes of RAM, 37 Nibbles of Display RAM, 8/16-bit timer/counter, on-chip oscillator and clock circuitry. In addition, the GMS81C5108 supports power saving modes to reduce power consumption.

This document is only explained for the base of GMS81C5108, the eliminated functions are same as below.

| Device name | ROM Size | OTP Size | RAM Size  | I/O | Package |
|-------------|----------|----------|-----------|-----|---------|
| GMS81C5108  | 8K bytes | -        | 192 bytes | 24  | 80QFP   |
| GMS87C5108  |          | 8K bytes | 192bytes  | 24  | 80QFP   |

#### 1.2 Features

- 8K Bytes of On-chip Program Memory
- 192 Bytes of On-chip Data RAM
- 37 Nibbles of Display RAM
- Instruction Cycle Time:
  - 1us at 4MHz (2 cycle NOP instruction)
- 24 Programmable I/O pins
- 2V to 4V Operating Range
- Dual Clock Operation

- main : 400kHz ~ 4.2MHz

- sub. : 32.768kHz

- One 8-bit Basic Interval Timer/Counter
- Key Scan Interrupt
- Two 8-bit Timer/ Counter (It can be used one 16-bit Timer/Counter)
- Watch Timer (2Hz, 4Hz, 16Hz, 1/64Hz)
- 8-bit Serial I/O (SIO)
- One 10-bit High Speed PWM Output

- Carrier Generator for Remote Controller
- 11 Interrupt sources
  - 3 External interrupts (INT0 ~ 2)
  - 8 Internal interrupts (BIT, Timer × 2, WT, A/DC, SIO, REM, Keyscan)
- 6-bit Buzzer Driving port
  - 500Hz ~ 250kHz (@4MHz)
- 4-channel 8-bit On-chip A/D Converter
- Power Saving Mode
  - STOP, SLEEP, Sub Active mode
- LCD display/controller (LCDC)
  - Static Mode (37Seg  $\times$  1Com, 1/3 Bias)
  - 1/2 Duty Mode (36Seg × 2Com, 1/3 Bias)
  - 1/3 Duty Mode (35Seg  $\times$  3Com, 1/3 Bias)
  - 1/4 Duty Mode (34Seg × 4Com, 1/3 Bias)
- LCD Display Voltage Booster
- Supply Voltage Detector(SVD)
  - 2 level detector (2.2V, 1.7V)

# 1.3 Development Tools

**Note:** There are several setting switches in the Emulator. User should read carefully and do setting properly before developing the program refer to "24.2 Emulator S/W Setting" on page 84. Otherwise, the Emulator may not work properly.

| Software               | - MS- Window base assembler<br>- Linker / Editor / Debugger        |
|------------------------|--------------------------------------------------------------------|
| Hardware<br>(Emulator) | - CHOICE-Dr.<br>- CHOICE-Dr. EVA 81C51 B/D                         |
| OTP Writer             | - CHOICE - SIGMA (Single writer)<br>- CHOICE - GANG4 (Gang writer) |

The GMS81C5108 is supported by a full-featured macro assembler, an in-circuit emulator CHOICE-Dr. TM and OTP programmers. There are two different type programmers such as single type and gang type. For mode detail, refer to OTP Programming chapter. Macro assembler operates under the MS-Windows 95/

98TM.

Please contact sales part of Hynix Semiconductor.



# 1.4 Ordering Information

|                  | Device name | Device name ROM Size (bytes) |           | Package |  |
|------------------|-------------|------------------------------|-----------|---------|--|
| Mask ROM version | GMS81C5108  | 8K bytes                     | 192 bytes | 80QFP   |  |
| OTP ROM version  | GMS87C5108  | 8K bytes OTP                 | 192 bytes | 80QFP   |  |

# 2. BLOCK DIAGRAM



# 3. PIN ASSIGNMENT



**И**ии**і**х GMS81C5108

# 4. PACKAGE DIAGRAM



Figure 4-1 Package Diagram

GMS81C5108 Ициіх

# 5. PIN FUNCTION

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

Vss: Circuit ground.

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

AV<sub>SS</sub>: ADC circuit ground

**RESET:** Reset the MCU.

**WDTOUT:** Output for detection of a program malfunction. If the user wants to use this pin, connect it to the RE-SET pin.

**REMOUT:** Signal output of an infrared remote controller.

**X**<sub>IN</sub>: Input to the inverting oscillator amplifier and input to the internal main clock operating circuit.

**X**OUT: Output from the inverting oscillator amplifier.

 $SX_{IN}$ : Input to the internal sub system clock operating circuit

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

**SEG0~SEG36:** Segment signal output pins for the LCD display. See "19. LCD DRIVER" on page 71 for details.

**COM0~COM3:** Common signal output pins for the LCD display. See "19. LCD DRIVER" on page 71 for details.

SEG34~SEG36 and COM1~COM3 are selected by LCDD of the LCR register.

**R00~R07:** R0 is an 8-bit CMOS bidirectional I/O port. R0 pins 1 or 0 written to the Port Direction Register can be used as outputs or inputs. Also, pull-up resistors and opendrain outputs can be assigned by software.

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

| Port pin | Alternate function          |
|----------|-----------------------------|
| R00      | INT0 (External interrupt 0) |
| R01      | INT1 (External interrupt 1) |
| R02      | INT2 (External interrupt 2) |
| R03      | Event counter input         |
| R04      | Buzzer Output               |
| R05      | SCK (SPI CLK Input/Output)  |
| R06      | SO (SPI Serial Data Output) |
| R07      | SI (SPI Serial Data Input)  |

**R10~R17:** R1 is an 8-bit CMOS bidirectional I/O port. R1 pins 1 or 0 written to the Port Direction Register can be

used as outputs or inputs or schmitt trigger inputs. Also, pullup resistors and open-drain outputs can be assigned by software.

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

| Port pin | Alternate function     |
|----------|------------------------|
| R10      | KS0 (Key scan input 0) |
| R11      | KS1 (Key scan input 1) |
| R12      | KS2 (Key scan input 2) |
| R13      | KS3 (Key scan input 3) |
| R14      | KS4 (Key scan input 4) |
| R15      | KS5 (Key scan input 5) |
| R16      | KS6 (Key scan input 6) |
| R17      | KS7 (Key scan input 7) |

**R20~R23:** R2 is a 4-bit CMOS bidirectional I/O port. Each pins 1 or 0 written to the Port Direction Register can be used as outputs or inputs. Also, pull-up resistors and opendrain outputs can be assigned by software.

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

| Port pin | Alternate function       |
|----------|--------------------------|
| R20      | AN0 (Analog Input Port0) |
| R21      | AN1 (Analog Input Port1) |
| R22      | AN2 (Analog Input Port2) |
| R23      | AN3 (Analog Input Port3) |

**R30~R33:** R3 is a 4-bit CMOS bidirectional I/O port. Each pins 1 or 0 written to the Port Direction Register can be used as outputs or inputs. Also, pull-up resistors and opendrain outputs can be assigned by software.

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

| Port pin | Alternate function |
|----------|--------------------|
| R31      | PWM (PWM Output)   |

**VCL0~VCL2:** Power supply pins for the LCD driver. The voltage on each pin is VCL2> VCL1> VCL0. See "19. LCD DRIVER" on page 71 for details.

**VLCDC:** LCD drive voltage booster reference.

**CAPH, CAPL:** LCD drive voltage booster capacitor.

**VREG:** Output of the voltage regular for the sub clock oscillation circuit. Connect external 0.1uF capacitor to this pin when using the sub system clock.

| DIN NAME Din No.                       |                        | Primary Function                    |                            | condary Function     | 01-1- @ D1          | 2                                |                         |  |
|----------------------------------------|------------------------|-------------------------------------|----------------------------|----------------------|---------------------|----------------------------------|-------------------------|--|
| PIN NAME                               | Pin No.                | I/O                                 | Description                | I/O                  | Description         | State @ Reset                    | State @ STOP            |  |
| V <sub>DD</sub>                        | 62                     | -                                   | Supply Voltage             | -                    | -                   | -                                | -                       |  |
| V <sub>SS</sub>                        | 33                     | -                                   | Circuit Ground             | -                    | -                   | -                                | -                       |  |
| AV <sub>DD</sub>                       | 35                     | -                                   | Supply Voltage for ADC     | -                    | -                   | -                                | -                       |  |
| AV <sub>SS</sub>                       | 40                     | -                                   | Ground for ADC             | -                    | -                   | -                                | -                       |  |
| RESET                                  | 65                     | I                                   | Reset (low active)         | -                    | -                   | 'L' input                        | 'H' input               |  |
| WDTOUT                                 | 67                     | 0                                   | Watch dog output           | -                    | -                   | Floating (To be connect Pull-up) | State of before STOP    |  |
| REMOUT                                 | 61                     | 0                                   | Remocon output             | -                    | -                   | 'L' o                            | utput                   |  |
| X <sub>IN,</sub> X <sub>OUT</sub>      | 63, 64                 | I,O                                 | Main clock oscillator      | -                    | -                   | Oscillation                      | 'L', 'L'                |  |
| SX <sub>IN</sub> , SX <sub>OUT</sub>   | 68, 69                 | I,O                                 | Sub clock oscillator       | -                    | -                   | Oscil                            | lation                  |  |
| V <sub>REG</sub>                       | 66                     | -                                   | Sub clock voltage          | -                    | -                   | -                                | -                       |  |
| VCL0~VCL2                              |                        |                                     | Internal VCL0<br>Connected | State of before STOP |                     |                                  |                         |  |
| VLCDC                                  | 71 - LCD drive voltage |                                     | -                          | -                    |                     |                                  |                         |  |
| CAPH,CAPL                              | 74,75                  | LCD drive voltage booster capacitor |                            | -                    | -                   | Internal VCL0<br>Connected       | State of before STOP    |  |
| SEG0 ~ SEG33                           | 34, 32~1               | 32~1 O LCD segment output           |                            | -                    | Segment output      |                                  |                         |  |
| СОМО                                   | 76                     | 0                                   | LCD common output          |                      | -                   | Common output                    |                         |  |
| SEG34/COM3<br>SEG35/COM2<br>SEG36/COM1 | 79~77                  | 0                                   | LCD common output.         | -                    | LCD segment output  | Common output                    |                         |  |
| R00/INT0                               | 41                     | I/O                                 |                            | I                    | Interrupt Input     |                                  |                         |  |
| R01/INT1                               | 54                     | I/O                                 |                            | I                    | Interrupt Input     |                                  |                         |  |
| R02/INT2                               | 55                     | I/O                                 |                            | I                    | Interrupt Input     |                                  |                         |  |
| R03/EC0                                | 56                     | I/O                                 |                            | I                    | Event counter input |                                  |                         |  |
| R04/BUZ                                | 57                     | I/O                                 |                            | 0                    | Buzzer output       |                                  |                         |  |
| R05/SCK                                | 58                     | I/O                                 |                            | I/O                  | Serial clock I/O    |                                  | State of before<br>STOP |  |
| R06/SO                                 | 59                     | I/O                                 | General I/O port           | 0                    | Serial Data Output  | Input port                       | 0.0.                    |  |
| R07/SI                                 | 110 ~ R17/             |                                     | I                          | Serial Data Input    |                     |                                  |                         |  |
| R10 ~ R17/<br>KS0 ~ KS7                |                        |                                     | I                          | Key wake-up input    |                     |                                  |                         |  |
| R20 ~ R23/<br>AN0 ~ AN3                | 36~39                  | I/O I A/D converter analog input    |                            |                      |                     |                                  |                         |  |
| R30,R32,R33                            | 50,52,53               | I/O                                 |                            | _                    | -                   |                                  |                         |  |
| R31/PWM                                | 51                     | I/O                                 |                            | 0                    | PWM output          |                                  |                         |  |

**Table 5-1 Port Function Description** 

# **6. PORT STRUCTURES**

# R00~R03/INT0~INT2, R03/EC0, R07/SI



#### R04/BUZ, R06/SO



#### R05/SCK



# R10~R17/KS0~KS7



# R20~R23/AN0~AN3



**Ы**µиіх GMS81C5108

# R30, R32, R33



# **R31**



# SEG0 ~ SEG33



# COM<sub>0</sub>



# COM1/SEG36, COM2/SEG35, COM3/SEG34



# VCL0 ~ VCL2, CAPH, CAPL



# **VLCDC, VREG**



ициіх

# **REMOUT**



# RESET



# WDTOUT



# XIN, XOUT (Crystal or Ceramic resonator Option)



# XIN, XOUT (RC Option)



# SXIN, SXOUT



**Ы**µиіх GMS81C5108

# 7. ELECTRICAL CHARACTERISTICS

# 7.1 Absolute Maximum Ratings

| Supply voltage0.3 to $+7.0\ V$                                  |
|-----------------------------------------------------------------|
| Storage Temperature40 to +125 $^{\circ}\text{C}$                |
| $\begin{array}{llllllllllllllllllllllllllllllllllll$            |
| Maximum current sunk by (I $_{OL}$ per I/O Pin)20 $mA$          |
| Maximum output current sourced by (I <sub>OH</sub> per I/O Pin) |
| Maximum current ( $\Sigma I_{OL}$ )100 mA                       |

| Maximum current (21()H) | Maximum currer | ıt (ΣΙ <sub>ΟΗ</sub> ) | 60 mA |
|-------------------------|----------------|------------------------|-------|
|-------------------------|----------------|------------------------|-------|

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

# 7.2 Recommended Operating Conditions

| Donomotor                | 0                 | O and distant                                          | 5    | Unit   |      |      |  |
|--------------------------|-------------------|--------------------------------------------------------|------|--------|------|------|--|
| Parameter                | Symbol Condition  |                                                        | Min. | Тур.   | Max. | Oill |  |
| Supply Voltage           | $V_{DD}$          | f <sub>MAIN</sub> =4MHz<br>f <sub>SUB</sub> =32.768kHz | 2.0  | -      | 4.0  | V    |  |
| Main Operating Frequency | f <sub>MAIN</sub> | V <sub>DD</sub> =2~4V                                  | 0.4  | -      | 4.2  | MHz  |  |
| Sub Operating Frequency  | f <sub>SUB</sub>  | V <sub>DD</sub> =2~4V                                  | -    | 32.768 | -    | kHz  |  |
| Operating Temperature    | T <sub>OPR</sub>  |                                                        | -20  | -      | 70   | °C   |  |

gмs81C5108 hyuix

# 7.3 DC Electrical Characteristics

 $(TA=-20\sim70^{\circ}C, V_{DD}=AV_{DD}=2\sim4V, V_{SS}=AV_{SS}=0V)$ 

| Parameter                      | Symbol           | Condition                                                                                                | Sp                   | ecificatio | ns                  | Unit |
|--------------------------------|------------------|----------------------------------------------------------------------------------------------------------|----------------------|------------|---------------------|------|
| Parameter                      | Symbol           | Condition                                                                                                | Min.                 | Тур.       | Max.                | Unit |
|                                | V <sub>IH1</sub> | R0~R3                                                                                                    | 0.7V <sub>DD</sub>   | -          | V <sub>DD</sub>     |      |
| Input High Voltage             | V <sub>IH2</sub> | RESET, X <sub>IN</sub> , INT0~INT2, EC0, SI, SCK                                                         | 0.8V <sub>DD</sub>   | -          | V <sub>DD</sub>     | V    |
|                                | V <sub>IH3</sub> | SX <sub>IN</sub>                                                                                         | 0.8VREG              | -          | VREG                |      |
|                                | V <sub>IL1</sub> | R0~R3                                                                                                    | 0                    | -          | 0.3 V <sub>DD</sub> |      |
| Input Low Voltage              | V <sub>IL2</sub> | RESET, X <sub>IN</sub> , INT0~INT2, EC0, SI, SCK                                                         | 0                    | -          | 0.2V <sub>DD</sub>  | V    |
|                                | V <sub>IL3</sub> | SX <sub>IN</sub>                                                                                         | 0                    | -          | 0.2VREG             |      |
|                                | V <sub>OH1</sub> | R0~R3, I <sub>OH1</sub> =-0.7mA                                                                          | V <sub>DD</sub> -0.3 | -          | -                   |      |
| Output High Voltage            | V <sub>OH2</sub> | X <sub>OUT</sub> , I <sub>OH2</sub> =-50μA                                                               | V <sub>DD</sub> -0.5 | -          | -                   | V    |
|                                | V <sub>OH3</sub> | SX <sub>OUT</sub> , I <sub>OH3</sub> =-5μA                                                               | VREG-0.3             | -          | -                   |      |
|                                | V <sub>OL1</sub> | R0~R3, WDTOUT, I <sub>OL1</sub> =1mA                                                                     | -                    | -          | 0.4                 |      |
| Output Low Voltage             | V <sub>OL2</sub> | X <sub>OUT</sub> , I <sub>OL2</sub> =50μA                                                                | -                    | -          | 0.5                 | V    |
|                                | V <sub>OL3</sub> | SX <sub>OUT</sub> , I <sub>OL3</sub> =5μA                                                                | -                    | -          | 0.5                 |      |
| Input High<br>Leakage Current  | I <sub>IH</sub>  | R0~R3, V <sub>IN</sub> =V <sub>DD</sub>                                                                  | -                    | -          | 1                   |      |
| Input Low<br>Leakage Current   | I <sub>IL</sub>  | R0~R3, V <sub>IN</sub> =0V                                                                               | -                    | -          | -1                  | μΑ   |
| Output High<br>Leakage Current | Іон              | REMOUT, V <sub>DD</sub> =3V, V <sub>OH</sub> = V <sub>DD</sub> -1.0V                                     | -30                  | -          | -5                  | A    |
| Output Low<br>Leakage Current  | I <sub>OL</sub>  | REMOUT, V <sub>DD</sub> =3V, V <sub>OL</sub> = 1.0V                                                      | 0.5                  | -          | 3                   | mA   |
|                                | R <sub>P1</sub>  | R0~R3, V <sub>DD</sub> =3V                                                                               | 50                   | 100        | 200                 |      |
| Pull-up Resister               | R <sub>P2</sub>  | RESET, V <sub>DD</sub> =3V<br>(GMS81C5108 Mask Option)                                                   | 30                   | 60         | 120                 | kΩ   |
| Fard David Davister            | R <sub>F1</sub>  | Main OSC Feedback Resister V <sub>DD</sub> =3V                                                           | 0.5                  | -          | 1.5                 | MO   |
| Feed Back Resister             | R <sub>F2</sub>  | Sub OSC Feedback Resister V <sub>DD</sub> =3V                                                            | 5.                   | -          | 15                  | ΜΩ   |
| RC Oscillator<br>Frequency     | F <sub>RC</sub>  | R=30k $\Omega$ , V <sub>DD</sub> =3V                                                                     | 1                    | 2          | 3                   | MHz  |
| VREG Voltage                   | VREG             | VREG=0.2uF                                                                                               | 2.0                  | 2.2        | 2.4                 | V    |
|                                | I <sub>DD1</sub> | Main Active Mode<br>V <sub>DD</sub> =4V±10%, X <sub>IN</sub> =4MHz, SX <sub>IN</sub> =0                  | -                    | 2.7        | 4.0                 |      |
|                                | I <sub>DD2</sub> | Main Sleep Mode<br>V <sub>DD</sub> =4V±10%, X <sub>IN</sub> =4MHz, SX <sub>IN</sub> =0                   | -                    | 0.47       | 1.2                 | mA   |
| Supply Current                 | I <sub>DD3</sub> | Stop Mode<br>V <sub>DD</sub> =4V±10%, X <sub>IN</sub> =0, SX <sub>IN</sub> =0                            | -                    | 2.0        | 10                  |      |
|                                | I <sub>DD4</sub> | Sub Active mode <sup>1</sup><br>V <sub>DD</sub> =3V±10%, X <sub>IN</sub> =0, S <sub>XIN</sub> =32.768kHz | -                    | 35(70)     | 80(150)             | μΑ   |
|                                | I <sub>DD5</sub> | Sub Sleep mode<br>V <sub>DD</sub> =4V±10%, X <sub>IN</sub> =0, S <sub>XIN</sub> =32.768kHz               | -                    | 6.0        | 15                  | -    |

<sup>1.</sup>  $I_{DD4}$  is tested by only nop operation. The value of ( ) is tested at OTP.

# 7.4 LCD Characteristics

 $(TA = -20 \sim 70^{\circ}C, V_{DD} = AV_{DD} = 2 \sim 4V, V_{SS} = AV_{SS} = 0V)$ 

| Parameter                       | Cumbal           | Condition                                         | Sp       | ecification | S    | Unit |
|---------------------------------|------------------|---------------------------------------------------|----------|-------------|------|------|
| Parameter                       | Symbol           | Condition                                         | Min.     | Тур.        | Max. | Unit |
| VLCDC Output Voltage            | VLCDC            | V <sub>DD</sub> =3V, TA=25°C,<br>R1=1MΩ, R2=300kΩ | 0.7      | 0.9         | 1.1  | V    |
| LCD Reference<br>Output Voltage | VCL0             | External Variable Resistance (0 to $1M\Omega$ )   | 0.9      | -           | 2.0  | V    |
| Double Output Voltage           | VCL1             | C1~C4=0.47uF                                      | 1.9VCL0  | 2.0VCL0     | -    | V    |
| Triple Output Voltage           | VCL2             | C1~C4=0.47uF                                      | 2.85VCL0 | 3.0VCL0     | 1    | V    |
| LCD Common<br>Output Current    | Ісом             | Output Voltage Deviation=0.2V                     | 30       | -           | -    |      |
| LCD Segment<br>Output Current   | I <sub>SEG</sub> | Output Voltage Deviation=0.2V                     | 5        | -           | _    | μΑ   |

# 7.5 A/D Converter Characteristics

 $(TA=25^{\circ}C,\,V_{DD}=3V,\,AV_{DD}=3.072V,\,V_{SS}=AV_{SS}=0V)$ 

| Parameter                                         | Cumbal            | Condition               | s                     | pecification | าร                    | Unit |
|---------------------------------------------------|-------------------|-------------------------|-----------------------|--------------|-----------------------|------|
| Parameter                                         | Symbol            | Condition               | Min.                  | Тур.         | Max.                  | Unit |
| Analog Power Supply Input Voltage Range           | $AV_{DD}$         | -                       | AV <sub>SS</sub>      | -            | $AV_{DD}$             | V    |
| Analog Input Voltage Range                        | V <sub>AN</sub>   | -                       | AV <sub>SS</sub> -0.3 | 1            | AV <sub>DD</sub> +0.3 | V    |
| Current Following Between $AV_{DD}$ and $AV_{SS}$ | IAV <sub>DD</sub> | -                       | -                     | -            | 200                   | μΑ   |
| Overall Accuracy                                  | CAIN              | -                       | -                     | ±1.0         | ±2.0                  |      |
| Non Linearity Error                               | NNLE              | -                       | -                     | ±1.0         | ±2.0                  |      |
| Differential Non Linearity Error                  | NDNLE             | -                       | -                     | ±1.0         | ±2.0                  | LSB  |
| Zero Offset Error                                 | NZOE              | -                       | -                     | ±0.5         | ±1.5                  | LOD  |
| Full Scale Error                                  | NFSE              | -                       | -                     | ±0.25        | ±0.5                  |      |
| Gain Error                                        | NGE               | -                       | -                     | ±1.0         | ±1.5                  |      |
| Conversion Time                                   | TCONV             | f <sub>MAIN</sub> =4MHz | -                     | -            | 30                    | μS   |

# 7.6 AC Characteristics

 $(TA=25^{\circ}C,\,V_{DD}=4V,\,AV_{DD}=4V,\,V_{SS}=AV_{SS}=0V)$ 

| B                                               | 0                 | <b>D</b>                             | S     | pecificatio | าร    |                  |
|-------------------------------------------------|-------------------|--------------------------------------|-------|-------------|-------|------------------|
| Parameter                                       | Symbol            | Pins                                 | Min.  | Тур.        | Max.  | Unit             |
| Main Operating Frequency                        | f <sub>MCP</sub>  | X <sub>IN</sub>                      | 0.455 | -           | 4.19  | MHz              |
| Sub Operating Frequency                         | f <sub>SCP</sub>  | SX <sub>IN</sub>                     | 30    | 32.768      | 35    | kHz              |
| System Clock Frequency <sup>1</sup>             | t <sub>SYS</sub>  | -                                    | 0.477 | -           | 4.395 | μS               |
| Main Oscillation<br>Stabilization Time (4MHz)   |                   |                                      | -     | -           | 20    |                  |
| Main Oscillation<br>Stabilization Time (910kHz) | t <sub>MST</sub>  | X <sub>IN</sub> , X <sub>OUT</sub>   | -     | -           | 60    | mS               |
| Main Oscillation<br>Stabilization Time (455kHz) |                   |                                      | -     | -           | 100   |                  |
| Sub Oscillation<br>Stabilization Time           | tsst              | SX <sub>IN</sub> , SX <sub>OUT</sub> | -     | 1           | 2     | S                |
| External Clock                                  | t <sub>MCPW</sub> | X <sub>IN</sub>                      | 80    | -           | -     | nS               |
| "H" or "L" Pulse Width                          | t <sub>SCPW</sub> | SX <sub>IN</sub>                     | 5     | -           | -     | μS               |
| Interrupt Pulse Width                           | t <sub>IW</sub>   | INT0, INT1, INT2                     | 2     | -           | -     | tsys             |
| RESET Input Pulse "L" Width                     | t <sub>RST</sub>  | RESET                                | 8     | -           | -     | t <sub>SYS</sub> |
| Event Counter Input<br>"H" or "L" Pulse Width   | t <sub>ECW</sub>  | EC0                                  | 2     | -           | -     | tsys             |

<sup>1.</sup>SCMR=XXXX000X that is f<sub>MAIN</sub>/2



Figure 7-1 AC Timing Chart

# 7.7 Serial I/O Characteristics

 $(TA=25^{\circ}C, V_{DD}=AV_{DD}=2\sim4V, V_{SS}=AV_{SS}=0V)$ 

| Davamata:                               | Comple ed         | Dina | S                      | pecification | s                  | l locit |
|-----------------------------------------|-------------------|------|------------------------|--------------|--------------------|---------|
| Parameter                               | Symbol            | Pins | Min.                   | Тур.         | Max.               | Unit    |
| SCK Input Clock Pulse Period            | t <sub>SCYC</sub> |      | 2t <sub>SYS</sub> +200 | -            | -                  |         |
| SCK Input Clock "H" or "L" Pulse Width  | tsckw             |      | t <sub>SYS</sub> +70   | -            | -                  |         |
| SCK Output Clock Cycle Time             | tscyc             | SCK  | 4t <sub>SYS</sub>      | -            | 16t <sub>SYS</sub> |         |
| SCK output Clock "H" or "L" Pulse Width | tsckw             |      | 2t <sub>SYS</sub> -30  | -            | -                  | ·- 0    |
| SCK output Clock Delay Time             | t <sub>DS</sub>   |      | -                      | -            | 100                | nS      |
| SI input Setup Time (External SCK)      | t <sub>ESUS</sub> |      | 100                    | -            | -                  |         |
| SI input Setup Time (Internal SCK)      | t <sub>ISUS</sub> | SI   | 100                    | -            | -                  |         |
| SI input Hold Time                      | t <sub>HS</sub>   | 1    | t <sub>SYS</sub> +100  | -            | -                  |         |



Figure 7-2 Serial I/O Timing Chart

# 7.8 Typical Characteristics

These graphs and tables are for design guidance only and are not tested or guaranteed.

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

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



















# **Operating Area**

















Sleep Mode (Sub opr.) I<sub>SLEEP</sub> (I<sub>DD5</sub>)-V<sub>DD</sub>



gмs81C5108 hyиix

# 8. MEMORY ORGANIZATION

The GMS81C5108 has separate address spaces for Program memory, Data Memory and Display memory. Program memory can only be read, not written to. It can be up

#### 8.1 Registers

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



Figure 8-1 Configuration of Registers

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

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



Figure 8-2 Configuration of YA 16-bit Register

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

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

to 8K bytes of Program memory. Data memory can be read and written to up to 192 bytes including the stack area. Display memory has prepared 37 bytes for LCD.

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

The stack can be located at any position within  $00_H$  to  $BF_H$  of the internal data memory. The SP is not initialized by hardware, requiring to write the initial value (the location with which the use of the stack starts) by using the initialization routine. Normally, the initial value of " $BF_{H}$ " is used.



#### Caution:

The Stack Pointer must be initialized by software because its value is undefined after RESET.

Example: To initialize the SP

LDX #0BFH TXSP ; SP  $\leftarrow$  BF<sub>H</sub>

**Program Counter:** The Program Counter is a 16-bit wide which consists of two 8-bit registers, PCH and PCL. This counter indicates the address of the next instruction to be executed. In reset state, the program counter has reset routine address (PC<sub>H</sub>:0FF<sub>H</sub>, PC<sub>L</sub>:0FE<sub>H</sub>).

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

[Carry flag C]

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

**Ы**µиіх GMS81C5108

#### [Zero flag Z]

or data transfer is "0" and is cleared by any other result.

This flag is set when the result of an arithmetic operation



Figure 8-3 PSW (Program Status Word) Register

#### [Interrupt disable flag I]

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

#### [Half carry flag H]

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

#### [Break flag B]

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

[Direct page flag G]

This flag assigns RAM page for direct addressing mode. In the direct addressing mode, addressing area is from zero page  $00_{\rm H}$  to  $0{\rm FF}_{\rm H}$  when this flag is "0". If it is set to "1", addressing area is assigned by RPR register (address  $0{\rm F3}_{\rm H}$ ). It is set by SETG instruction and cleared by CLRG.

#### [Overflow flag V]

This flag is set to "1" when an overflow occurs as the result of an arithmetic operation involving signs. An overflow occurs when the result of an addition or subtraction exceeds +127 (7F $_{\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, bit 6 of memory is copied to this flag.

#### [Negative flag N]

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



Figure 8-4 Stack Operation

**И**µиіх GMS81C5108

# 8.2 Program Memory

A 16-bit program counter is capable of addressing up to 64K bytes, but this device has 8K bytes program memory space only physically implemented. Accessing a location above FFFF<sub>H</sub> will cause a wrap-around to 0000<sub>H</sub>.

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

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



Figure 8-5 Program Memory Map

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

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

Example: Usage of TCALL



The interrupt causes the CPU to jump to specific location, where it commences the execution of the service routine. The External interrupt 0, for example, is assigned to location 0FFFA $_{\rm H}$ . The interrupt service locations spaces 2-byte interval: 0FFF8 $_{\rm H}$  and 0FFF9 $_{\rm H}$  for External Interrupt 1, 0FFFA $_{\rm H}$  and 0FFFB $_{\rm H}$  for External Interrupt 0, etc.

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



NOTE:

"-" means reserved area.

**Figure 8-6 Interrupt Vector Area** 



Figure 8-7 PCALL and TCALL Memory Area



#### TCALL→ n



# ициіх

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

```
ORG
                   OFFEOH
           DW
                   NOT_USED
           DW
                   NOT_USED
                   NOT_USED
NOT_USED
           DW
           DW
                                            ; Watch Timer
           DW
                   WT_INT
           DW
                   SIO
                                             ; Serial I/O
                   AD Con
                                             ; AD converter
           DW
                                            ; Carrier
; Int.2
           DW
                   Carrier_INT
           DW
                   INT2
           DW
                   TMR1_INT
                                            ; Timer-1
           DW
                   TMR0_INT
                                             ; Timer-0
                                             ; Int.1
           DW
                   INT1
                                             ; Int.0
                   INT0
           DW
                   BIT_INT
                                             ; BIT
           DW
           DW
                   KEY_INT
                                             ; Key Scan
           DW
                   RESET
                                             ; Reset
                   0F000H
           ORG
; *************
               MAIN PROGRAM
                                             ;Disable All Interrupts
RESET:
           DI
           CLRG
           LDX
                   #0
                   #0
                                             ;RAM Clear(!0000_{H}->!00BF_{H})
RAM_CLR:
           LDA
           STA
                    {X}+
           CMPX
                   #0C0H
           BNE
                   RAM_CLR
           LDX
                   #0BFH
                                             ;Stack Pointer Initialize
           TXSP
           CALL
                   LCD_CLR
                                             ;Clear LCD display memory
                   R0, #0
                                             ;Normal Port 0
           LDM
           LDM
                   RODR,#1000_0010B
                                             ;Normal Port Direction
                   R0PU,#1000_0010B
R0CR,#0000_0001B
                                             ;Pull Up Selection Set
;R0 port Open Drain control
           LDM
           LDM
           :
           LDM
                   SCMR, #1111_0000B
                                             ;System clock control
           :
```

gмs81C5108 hyиix

# 8.3 Data Memory

Figure 8-8 shows the internal Data Memory space available. Data Memory is divided into four groups, a user RAM, control registers, Stack, and LCD memory.



Figure 8-8 Data Memory Map

#### **User Memory**

The GMS81C5108 has  $192 \times 8$  bits for the user memory (RAM).

There are two page internal RAM. Page is selected by G-flag and RAM page selection register RPR. When G-flag is cleared to "0", always page 0 is selected regardless of RPR value. If G-flag is set to "1", page will be selected according to RPR value.



Figure 8-9 RAM page configuration

#### **Control Registers**

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

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

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

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

Example: To write at CKCTLR

LDM CKCTLR, #05H; Divide ratio ÷8

#### Stack Area

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

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

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

#### **LCD Display Memory**

LCD display data area is handled in LCD section.

See "19.3 LCD Display Memory" on page 73.

| Address | Register Name                          | Symbol | R/W | Initial Value   | Addressing             | Page |
|---------|----------------------------------------|--------|-----|-----------------|------------------------|------|
|         | 3.2.2.                                 | •      |     | 7 6 5 4 3 2 1 0 | Mode                   | 19   |
| 00C0    | R0 port data register                  | R0     | R/W | 00000000        | byte, bit <sup>1</sup> | 32   |
| 00C1    | R1 port data register                  | R1     | R/W | 000000000       | byte, bit              | 32   |
| 00C2    | R2 port data register                  | R2     | R/W | 0 0 0 0         | byte, bit              | 33   |
| 00C3    | R3 port data register                  | R3     | R/W | 0 0 0 0         | byte, bit              | 33   |
| 00C8    | R0 port I/O direction register         | R0DR   | W   | 00000000        | byte <sup>2</sup>      | 32   |
| 00C9    | R1 port I/O direction register         | R1DR   | W   | 000000000       | byte                   | 32   |
| 00CA    | R2 port I/O direction register         | R2DR   | W   | 0 0 0 0         | byte                   | 33   |
| 00CB    | R3 port I/O direction register         | R3DR   | W   | 0 0 0 0         | byte                   | 33   |
| 00D0    | R0 port pull-up register               | R0PU   | W   | 000000000       | byte                   | 32   |
| 00D1    | R1 port pull-up register               | R1PU   | W   | 00000000        | byte                   | 32   |
| 00D2    | R2 port pull-up register               | R2PU   | W   | 0 0 0 0         | byte                   | 33   |
| 00D3    | R3 port pull-up register               | R3PU   | W   | 0 0 0 0         | byte                   | 33   |
| 00D4    | R0 port open drain control register    | R0CR   | W   | 000000000       | byte                   | 32   |
| 00D5    | R1 port open drain control register    | R1CR   | W   | 000000000       | byte                   | 32   |
| 00D6    | R2 port open drain control register    | R2CR   | W   | 0 0 0 0         | byte                   | 33   |
| 00D7    | R3 port open drain control register    | R3CR   | W   | 0 0 0 0         | byte                   | 33   |
| 00D8    | Ext. interrupt edge selection register | IESR   | R/W | 0 0 0 0 0 0     | byte, bit              | 69   |
| 00D9    | Port selection register                | PMR    | R/W | - 0 - 0 0 0 0 0 | byte, bit              | 32   |
| 00DA    | Interrupt enable low register          | IENL   | R/W | - 0 0 0 0       | byte, bit              | 65   |
| 00DB    | Interrupt enable high register         | IENH   | R/W | - 0 0 0 0 0 0 0 | byte, bit              | 65   |
| 00DC    | Interrupt request flag low register    | IRQL   | R/W | - 0 0 0 0       | byte, bit              | 65   |
| 00DD    | Interrupt request flag high register   | IRQH   | R/W | - 0 0 0 0 0 0 0 | byte, bit              | 65   |
| 00DE    | Sleep mode register                    | SMR    | R/W | 0               | byte, bit              | 39   |
| 00E0    | Timer 0 mode register                  | TM0    | R/W | 0 0 0 0 0 0     | byte, bit              | 45   |
|         | Timer 0 counter register               | T0     | R   | 000000000       | byte, bit              | 45   |
| 00E1    | Timer 0 data register                  | TDR0   | W   | 1 1 1 1 1 1 1 1 | byte                   | 45   |
|         | Timer 0 input capture register         | CDR0   | R   | 000000000       | byte, bit              | 45   |
| 00E2    | Timer 1 mode register                  | TM1    | R/W | 00000000        | byte, bit              | 45   |
| 0050    | Timer 1 data register                  | TDR1   | W   | 1 1 1 1 1 1 1 1 | byte                   | 45   |
| 00E3    | PWM0 pulse period register             | T1PPR  | W   | 1 1 1 1 1 1 1 1 | byte                   | 45   |
|         | Timer 1 counter register               | T1     | R   | 00000000        | byte, bit              | 45   |
| 00E4    | Timer 1 input capture register         | CDR1   | R   | 00000000        | byte, bit              | 45   |
|         | PWM0 pulse duty register               | T1PDR  | R/W | 00000000        | byte, bit              | 45   |
| 00E5    | PWM0 high register                     | PWMHR  | W   | 0 0 0 0         | byte                   | 45   |
| 00EC    | A/D converter mode register            | ADMR   | R/W | - 0 0 0 0 1     | byte, bit              | 58   |
| 00ED    | A/D converter data register            | ADDR   | R   | x x x x x x x x | byte, bit              | 58   |

**Table 8-1 Control Registers** 

ициіх GMS81C5108

| Address | Dogiotov Nome                    | Cumbal | R/W  |   | ln | iti | al | ٧ | alı | ue | • | Addressing | Dogo |
|---------|----------------------------------|--------|------|---|----|-----|----|---|-----|----|---|------------|------|
| Address | Register Name                    | Symbol | R/VV | 7 | 6  | 5   | 4  | 3 | 2   | 1  | 0 | Mode       | Page |
| 00EF    | Watch timer mode register        | WTMR   | R/W  | - | 0  | 0   | 0  | 0 | 0   | 0  | 0 | byte, bit  | 56   |
| 00F0    | Key scan mode register           | KSMR   | R/W  | 0 | 0  | 0   | 0  | 0 | 0   | 0  | 0 | byte, bit  | 70   |
| 00F1    | LCD control register             | LCR    | R/W  | 0 | 0  | 0   | 0  | 0 | 0   | 0  | 0 | byte, bit  | 72   |
| 00F3    | RAM paging register              | RPR    | R/W  | - | -  | -   | -  | - | -   | 0  | 0 | byte, bit  | 73   |
| 0054    | Basic interval timer register    | BITR   | R    | 0 | 0  | 0   | 0  | 0 | 0   | 0  | 0 | byte, bit  | 43   |
| 00F4    | Clock control register           | CKCTLR | W    | - | -  | -   | -  | 0 | 1   | 1  | 1 | byte       | 43   |
| 00F5    | System clock mode register       | SCMR   | R/W  | 0 | 0  | 0   | 0  | 0 | 0   | 0  | 0 | byte, bit  | 34   |
| 00F6    | Remocon mode register            | RMR    | R/W  | - | 0  | 0   | 0  | 0 | 0   | 0  | 0 | byte, bit  | 76   |
| 00F7    | Carrier frequency high selection | CFHS   | W    | - | -  | 1   | 1  | 1 | 1   | 1  | 1 | byte       | 76   |
| 00F8    | Carrier frequency low selection  | CFLS   | W    | - | -  | 1   | 1  | 1 | 1   | 1  | 1 | byte       | 76   |
| 00F9    | Remocon data high register       | RDHR   | W    | 1 | 1  | 1   | 1  | 1 | 1   | 1  | 1 | byte       | 76   |
| 0054    | Remocon data low register        | RDLR   | W    | 1 | 1  | 1   | 1  | 1 | 1   | 1  | 1 | byte       | 76   |
| 00FA    | Remocon data counter             | RDC    | R    | 0 | 0  | 0   | 0  | 0 | 0   | 0  | 0 | byte, bit  | 76   |
| 00FB    | Remocon output data register     | RODR   | R/W  | - |    | -   | -  | - | -   | -  | 0 | byte, bit  | 76   |
| 00FC    | Remocon output buffer            | ROB    | R/W  | - | -  | -   | -  | _ | -   | -  | 0 | byte, bit  | 76   |
| 00FD    | Buzzer data register             | BDR    | W    | 0 | 0  | 0   | 0  | 0 | 0   | 0  | 0 | byte       | 60   |
| 00FE    | Serial I/O mode register         | SIOM   | R/W  | 0 | 0  | 0   | 0  | 0 | 0   | 0  | 1 | byte, bit  | 62   |
| 00FF    | Serial I/O data register         | SIOD   | R/W  | х | х  | х   | х  | х | х   | х  | х | byte, bit  | 62   |

**Table 8-1 Control Registers** 

 <sup>&</sup>quot;byte", "bit" means that register can be addressed by not only bit but byte manipulation instruction.
 "byte" means that register can be addressed by only byte manipulation instruction. On the other hand, do not use any read-modify-write instruction such as bit manipulation.

# 8.4 Addressing Mode

The GMS81C5108 uses six addressing modes;

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

#### (1) Register Addressing

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

# (2) Immediate Addressing → #imm

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

#### Example:

0435 ADC #35<sub>H</sub>



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

Example: G=1, RPR=01<sub>H</sub>

E45535 LDM 35<sub>H</sub>, #55<sub>H</sub>



#### (3) Direct Page Addressing → dp

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

Example; G=0

C535 LDA  $35_{H}$  ;A  $\leftarrow$ RAM[ $35_{H}$ ]



### (4) Absolute Addressing → !abs

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

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

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

Example;

0735F0 ADC  $!0F035_{H}$  ; A  $\leftarrow ROM[0F035_{H}]$ 



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

Example; Addressing accesses the address  $0135_{\mbox{\scriptsize H}}$  regardless of G-flag and RPR.

981501 INC  $!0115_{H}$  ; A  $\leftarrow ROM[115_{H}]$ 



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

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

LDA, STA

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

DB LDA {X}+



#### (5) Indexed Addressing

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

In this mode, a address is specified by the X register.

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

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

D4 LDA  $\{X\}$ ; ACC $\leftarrow$ RAM[X].



#### X indexed direct page (8 bit offset) → dp+X

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

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

Example; G=0, X=0F5H

C645 LDA 45<sub>H</sub>+X



**Ы**µиіх GMS81C5108

# Y indexed direct page (8 bit offset) → dp+Y

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

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

#### Y indexed absolute → !abs+Y

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

Example; Y=55<sub>H</sub>

D500FA LDA !OFA00H+Y



# (6) Indirect Addressing

# Direct page indirect → [dp]

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

JMP, CALL

Example; G=0





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

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

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

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

1625 ADC [25<sub>H</sub>+X]



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

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

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

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

1725 ADC [25<sub>H</sub>]+Y



# Absolute indirect → [!abs]

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

JMP

Example; G=0

1F25E0 JMP [!0E025<sub>H</sub>]



**Ы**µиіх GMS81C5108

# **9. I/O PORTS**

The GMS81C5108 has seven ports (R0, R1, R2 and R3), and LCD segment port (SEG0~SEG36), and LCD common port (COM0~COM3).

# 9.1 Registers for Port

#### **Port Data Registers**

The Port Data Registers (R0, R1, R2, R3) are represented as a D-Type flip-flop, which will clock in a value from the internal bus in response to a "write to data register" signal from the CPU. The Q output of the flip-flop is placed on the internal bus in response to a "read data register" signal from the CPU. The level of the port pin itself is placed on the internal bus in response to "read data register" signal from the CPU. Some instructions that read a port activating the "read register" signal, and others activating the "read pin" signal.

#### **Port Direction Registers**

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

All the port direction registers in the GMS81C5108 have 0 written to them by reset function. On the other hand, its initial status is input.



Figure 9-1 Example of port I/O assignment

# **Pull-up Control Registers**

The R0, R1,R2 and R3 ports have internal pull-up resistors. Figure 9-2 shows a functional diagram of a typical

These ports pins may be multiplexed with an alternate function for the peripheral features on the device.

pull-up port. It is connected or disconnected by Pull-up Control register (RnPU). The value of that resistor is typically 100kΩ. Refer to DC characteristics for more details.

When a port is used as key input, input logic is firmly either low or high, therefore external pull-down or pull-up resisters are required practically. The GMS81C5108 has internal pull-up, it can be logic high by pull-up that can be able to configure either connect or disconnect individually by pull-up control registers RnPU.

When ports are configured as inputs and pull-up resistor is selected by software, they are pulled to high.



Figure 9-2 Pull-up Port Structure

#### **Open drain port Registers**

The R0, R1, R2 and R3 ports have open drain port resistors R0CR~R3CR.

Figure 9-3 shows an open drain port configuration by control register. It is selected as either push-pull port or open-drain port by ROCR, R1CR, R2CR and R3CR.



Figure 9-3 Open-drain Port Structure

# 9.2 I/O Ports Configuration

#### **R0 Ports**

R0 is an 8-bit CMOS bidirectional I/O port (address  $0C0_H$ ). Each I/O pin can independently used as an input or an output through the R0DR register (address  $0C8_H$ ).

R0 has internal pull-ups that is independently connected or disconnected by R0PU. The control registers for R0 are shown below.

| R0 Dat          | a Register                                | ADDRESS: 0C0 <sub>H</sub><br>RESET VALUE: 00 <sub>H</sub>        |
|-----------------|-------------------------------------------|------------------------------------------------------------------|
| R0              | R07 R06 R05                               |                                                                  |
| R0 Dir          | ection Register                           | ADDRESS: 0C8 <sub>H</sub><br>RESET VALUE: 00 <sub>H</sub>        |
| R0DR            |                                           |                                                                  |
|                 |                                           | Port Direction<br>0: Input<br>1: Output                          |
| R0 Pu<br>Select | ll-up<br>ion Register                     | ADDRESS:0D0 <sub>H</sub><br>RESET VALUE:00 <sub>H</sub>          |
| R0PU            |                                           |                                                                  |
|                 |                                           | Pull-up select<br>0: Without pull-up<br>1: With pull-up          |
|                 | en Drain<br>ion Register                  | ADDRESS :0D4 <sub>H</sub><br>RESET VALUE : 00 <sub>H</sub>       |
| R0CR            |                                           | Open Drain select<br>0: No Open Drain<br>1: Open Drain           |
|                 | lode Register                             | ADDRESS :0D9 <sub>H</sub><br>RESET VALUE : -0-00000 <sub>B</sub> |
| Port N          |                                           |                                                                  |
| PORT N          | - PWMO -                                  | BUZ EC0 INT2 INT1 INT0                                           |
|                 | PWMO (PWM Output<br>0: R31 Port<br>1: PWM | : : : :                                                          |
|                 | PWMO (PWM Output<br>0: R31 Port           | t) BUZ (Buzzer Output) 0: R04 Port 1: BUZ                        |

In addition, Port R0 and R3 are multiplexed with various special features. The control register PMR (address 0D9H) controls the selection of alternate function. After reset, this value is "0", port may be used as normal I/O port.

To use alternate function such as External Interrupt rather than normal I/O, write "1" in the corresponding bit of PMR0.

| Port Pin | Alternate Function          |
|----------|-----------------------------|
| R00      | INT0 (External Interrupt 0) |
| R01      | INT1 (External Interrupt 1) |
| R02      | INT2 (External Interrupt 2) |
| R03      | EC0 (Timer0 Event Input)    |
| R04      | BUZ (Buzzer Output)         |
| R31      | PWM (PWM Output)            |

#### **R1 Ports**

R1 is an 8-bit CMOS bidirectional I/O port (address  $0C1_H$ ). Each I/O pin can independently used as an input or an output through the R1DR register (address  $0C9_H$ ).

R1 has internal pull-ups that is independently connected or disconnected by register R1PU. If the key scan function is used, these pin can input the key switch signal without external pull-up registers. For more details refer to "18. KEY SCAN" on page 70.

The control registers for R1 are shown below.

| R1 Dat          | a Register            | ADDRESS : 0C1 <sub>H</sub><br>RESET VALUE : 00 <sub>F</sub>                        |
|-----------------|-----------------------|------------------------------------------------------------------------------------|
| R1              | R17 R16 R15 R14       | R13 R12 R11 R10                                                                    |
| R1 Dir          | ection Register       | ADDRESS: 0C9 <sub>H</sub><br>RESET VALUE: 00 <sub>1</sub>                          |
| R1DR            |                       |                                                                                    |
|                 |                       | Port Direction<br>0: Input<br>1: Output                                            |
| R1 Pu<br>Select | II-up<br>ion Register | ADDRESS : 0D1 <sub>H</sub><br>RESET VALUE : 00                                     |
| R1PU            |                       |                                                                                    |
|                 |                       | Pull-up select<br>0: Without pull-up<br>1: With pull-up                            |
| P1 On           | en Drain              | ADDRESS :0D5 <sub>H</sub>                                                          |
|                 | ion Register          | RESET VALUE: 00                                                                    |
| Select          | ion Register          |                                                                                    |
| Select          | ion Register          | Open Drain selec                                                                   |
| Select          | CAN Mode Register     | Open Drain selec 0: No Open Drain 1: Open Drain ADDRESS: 0F0H RESET VALUE: 00      |
| Select          |                       | Open Drain selec<br>0: No Open Drain<br>1: Open Drain<br>ADDRESS :0F0 <sub>H</sub> |

**И**µиіх GMS81C5108

Port R1 is multiplexed with various special features. The control registers controls the selection of alternate function. After reset, this value is "0", port may be used as normal I/O port. The way to select alternate function such as comparator input or buzzer will be shown in each peripheral section.

In addition, R1 port is used as key scan function which operate with normal input port.

Input or output is configured automatically by each function register (KSMR) regardless of R1DR.

#### **R2 Port**

R2 is a 4-bit CMOS bidirectional I/O port (address  $0C2_H$ ). Each I/O pin can independently used as an input or an output through the R2DR register (address  $0CA_H$ ).

R2 has internal pull-ups that is independently connected or disconnected by R2PU (address 0D2<sub>H</sub>). The control registers for R2 are shown as below.



#### **R3 Port**

R3 is a 4-bit CMOS bidirectional I/O port (address  $0C3_H$ ). Each I/O pin can independently used as an input or an output through the R3DR register (address  $0CB_H$ ).



#### SEG0~SEG36

Segment signal output pins for the LCD display. See "19. LCD DRIVER" on page 71 for details.

#### COM0~COM3

Common signal output pins for the LCD display. See "19. LCD DRIVER" on page 71 for details.

SEG34~SEG36 and COM1~COM3 are selected by LCDD of the LCR register.

# 10. CLOCK GENERATOR

As shown in Figure 10-1, the clock generator produces the basic clock pulses which provide the system clock to be supplied to the CPU and the peripheral hardware. It contains two oscillators: a main-frequency clock oscillator and a sub-frequency clock oscillator. Power consumption can be reduced by switching them to the low power operation frequency clock can be easily obtained by attaching a resonator between the  $X_{\rm IN}$  and  $X_{\rm OUT}$  pin and the  $SX_{\rm IN}$  and  $SX_{\rm OUT}$  pin, respectively. The system clock can also be obtained from the external oscillator.

The clock generator produces the system clocks forming clock pulse, which are supplied to the CPU and the peripheral hardware. The internal system clock can be selected by bit2, and bit3 of the system clock mode register (SC-MR). The registers are shown in Figure 10-2.

| CDU alask | Instruction cycle time   |                              |  |  |  |
|-----------|--------------------------|------------------------------|--|--|--|
| CPU clock | f <sub>MAIN</sub> = 4MHz | f <sub>SUB</sub> = 32.768kHz |  |  |  |
| ÷2        | 0.5 us                   | 61 us                        |  |  |  |
| ÷ 8       | 2.0 us                   | 244 us                       |  |  |  |
| ÷ 16      | 4.0 us                   | 488 us                       |  |  |  |
| ÷ 64      | 16.0 us                  | 1953 us                      |  |  |  |

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



Figure 10-1 Block Diagram of Clock Generator

The system clock is decided by bit1 of the system clock mode register, SCMR. In selection Sub clock, to oscillate or stop the Main clock is decided by bit0 of SCMR.

On the initial reset, internal system clock is PS1 which is the fastest and other clock can be provided by bit2 and bit3 of SCMR.



Figure 10-2 SCMR: System Clock Control Registers

# 10.1 Operation Mode

The system clock controller starts or stops the main-frequency clock oscillator and switches between the sub frequency clock. The operating mode is generally divided into the main active mode and the sub active mode, which are controlled by System clock mode register (SCMR). Figure 10-3 shows the operating mode transition diagram.

System clock control is performed by the system clock mode register, SCMR. During reset, this register is initialized to "0" so that the main-clock operating mode is selected.

#### Main Active mode

This mode is fast-frequency operating mode.

The CPU and the peripheral hardwares are operated on the high-frequency clock. At reset release, this mode is invoked.

#### **Sub Active mode**

This mode is low-frequency operating mode In this mode, the CPU and the peripheral hardware clock are provided by low-frequency clock oscillation, so power consumption can be reduced.

#### **SLEEP mode**

In this mode, the CPU clock stops while peripherals and the oscillation source continue to operate normally.

#### STOP mode

In this mode, the system operations are all stopped, holding the internal states valid immediately before the stop at the low power consumption level.



Figure 10-3 Operating Mode

# 10.2 Operation Mode Switching

In the Main active mode, only the high-frequency clock oscillator is used.

In the Sub active mode, the low-frequency clock oscillation is used, so the low power voltage operation or the low power consumption operation can be enabled. Instruction execution does not stop during the change of operation mode. In this case, some peripheral hardware capabilities may be affected. For details, refer to the description of the relevant operation.

The following describes the switching between the Main active mode and the Sub active mode. During reset, the system clock mode register is initialized at the Main active mode. It must be set to the Sub active mode for reducing the power consumption.

#### Switching from Main active to Sub active

First, write " $02_{H}$ " into lower 2 bits of SCMR to switch the main system clock to the sub-frequency clock. Next, write " $03_{H}$ " to turn off main frequency oscillation.

#### Example:

```
: : : : LDM SCMR, \#02_{\rm H} ; Switch to sub active LDM SCMR, \#03_{\rm H} ; Turn off main clock : :
```

#### Returning from Sub active to Main active

First, write "02<sub>H</sub>" into lower 2 bits of the SCMR to turn on the main-frequency oscillation. This time, the stabilization (warm-up) time needs to be taken by the software delay routine. Sub active mode can also be released by setting the RESET pin to low, which immediately performs the reset operation. After reset, the GMS81C5108 is placed in Main active mode.

#### Example:

```
:
:
:
LDM SCMR,#02<sub>H</sub> ;Turn on main-clock
CALL DELAY ;Wait until stable
LDM SCMR,#0 ;Move to main active
```

```
:
:about 65ms software delay
DELAY: LDA #0
DELAY0: INC A
CMP #85H
BCC DELAY0
RET
```

# Shifting from the Normal operation to the SLEEP mode

By setting bit 0 of SMR, the CPU clock stops and the SLEEP mode is invoked. The CPU stops while other peripherals are operate normally.

The way of release from this mode is RESET and all available interrupts.

For more detail, See "SLEEP Mode" on page 39

# Shifting from the Normal operation to the STOP mode

By executing STOP instruction, the main-frequency clock oscillation stops and the STOP mode is invoked. But subfrequency clock oscillation is operated continuously. After the STOP operation is released by reset, the operation mode is changed to Main active mode.

The methods of release are RESET, Key scan interrupt, Watch Timer interrupt, Timer/Event counter1 (EC0 pin), SIO (External clock) and External Interrupt.

For more details, see "STOP Mode" on page 40.

**Note:** In the STOP and SLOW operating modes, the power consumption by the oscillator and the internal hardware is reduced. However, the power for the pin interface (depending on external circuitry and program) is not directly associated with the low-power consumption operation. This must be considered in system design as well as interface circuit design.

ициіх



Figure 10-4 System Clock Switching Timing

**Ы**µµ**i**х GMS81C5108

# 10.3 Power Saving Operation

GMS81C5108 has 2 power-saving mode. In power-saving mode, power consumption is reduced considerably that in Battery operation Battery life can be extended a lot.

Sleep mode is entered by setting bit 0 of Sleep Mode Register (SMR), and STOP Mode is entered by STOP instruction.

#### **SLEEP Mode**

In this mode, the internal oscillation circuits remain active.

Oscillation continues and peripherals are operate normally but CPU stops. Movement of all Peripherals is shown in Table 10-1. Sleep mode is entered by setting bit 0 of SMR (address  $0DE_H$ ).

It is released by RESET or interrupt. To be released by interrupt, interrupt should be enabled before Sleep mode.



Figure 10-5 SLEEP Mode Register



Figure 10-6 Sleep Mode Release Timing by External Interrupt



Figure 10-7 SLEEP Mode Release Timing by RESET pin

#### **STOP Mode**

For applications where power consumption is a critical factor, device provides STOP mode for reducing power consumption.

#### **Start The Stop Operation**

The STOP mode can be entered by STOP instruction dur-

ing program execution. In Stop mode, the on-chip mainfrequency oscillator, system clock, and peripheral clock are stopped (Watch timer clock is oscillating continuously:. With the clock frozen, all functions are stopped, but the on-chip RAM and Control registers are held. The port pins output the values held by their respective port data register, the port direction registers. The status of peripherals during Stop mode is shown below.

| Peripheral                                                                                                        | STOP Mode                                                                         | Sleep Mode                                    |  |  |
|-------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|-----------------------------------------------|--|--|
| CPU                                                                                                               | All CPU operations are disabled                                                   | All CPU operations are disabled               |  |  |
| RAM                                                                                                               | Retain                                                                            | Retain                                        |  |  |
| LCD driver                                                                                                        | Operates continuously                                                             | Operates continuously                         |  |  |
| Basic Interval Timer                                                                                              | Halted                                                                            | Operates continuously                         |  |  |
| Timer/Event counter 0,1                                                                                           | Halted (Only when the Event counter mode is enabled, Timer 0,1 operates normally) | Timer/Event counter 0,1 operates continuously |  |  |
| Watch Timer                                                                                                       | Operates continuously                                                             | Operates continuously                         |  |  |
| Key Scan                                                                                                          | Active                                                                            | Active                                        |  |  |
| Main-oscillation                                                                                                  | Stop (X <sub>IN</sub> =L, X <sub>OUT</sub> =L)                                    | Oscillation <sup>1</sup>                      |  |  |
| Sub-oscillation                                                                                                   | Oscillation                                                                       | Oscillation                                   |  |  |
| I/O ports                                                                                                         | Retain                                                                            | Retain                                        |  |  |
| Control Registers                                                                                                 | Retain                                                                            | Retain                                        |  |  |
| by RESET, Key Scan interrupt, SIO interrupt, Watch Timer interrupt, Timer interrupt (EC0), and External interrupt |                                                                                   | by RESET, All interrupts                      |  |  |

Table 10-1 Peripheral Operation during Power Saving Mode

#### 1. refer to the Table 10-2

| Operating<br>Clock source | Main<br>Operating Mode | Main<br>Sleep Mode | Sub<br>Operating Mode                                                            | Sub<br>Sleep Mode                                                                | Stop Mode   |
|---------------------------|------------------------|--------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------|-------------|
| Main Clock                | Oscillation            | Oscillation        | SCMR<1:0> $00,01,10 \rightarrow \text{Oscillation}$ $11 \rightarrow \text{Stop}$ | SCMR<1:0> $00,01,10 \rightarrow \text{Oscillation}$ $11 \rightarrow \text{Stop}$ | Stop        |
| Sub Clock                 | Oscillation            | Oscillation        | Oscillation                                                                      | Oscillation                                                                      | Oscillation |
| System Clock              | Active                 | Stop               | Active                                                                           | Stop                                                                             | Stop        |
| Peri. Clock               | Active                 | Active             | Active                                                                           | Active                                                                           | Stop        |

Table 10-2 Clock Operation of STOP and SLEEP mode

**Note:** Since the  $X_{IN}$  pin is connected internally to GND to avoid current leakage due to the crystal oscillator in STOP mode, do not use STOP instruction when an external clock is used as the main system clock.

In the Stop mode of operation,  $V_{DD}$  can be reduced to minimize power consumption. Be careful, however, 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. And after STOP instruction, at least two or more NOP instruction should be written as shown in example below.

```
Example)
:
LDM CKCTLR,#0000_1111B
STOP
NOP
NOP
.
```

The Interval Timer Register CKCTLR should be initialized by software in order that oscillation stabilization time should be longer than 20ms before STOP mode.

#### Release the STOP mode

The exit from STOP mode is using hardware reset or external interrupt, watch timer, SIO interrupt, key scan or timer interrupt (EC0).

To release STOP mode, corresponding interrupt should be enabled before STOP mode.

Specially as a clock source of Timer/Event counter, EC0 pin can release it by Timer/Event counter Interrupt request.

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.

Start-up is performed to acquire the time for stabilizing oscillation. During the start-up, the internal operations are all stopped.



Figure 10-8 STOP Mode Release Timing by External Interrupt



Figure 10-9 STOP Mode Release Timing by RESET

### **Minimizing Current Consumption**

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

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

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

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

But input voltage level should be  $V_{SS}$  or  $V_{DD}$ . Be careful that if unspecified voltage, i.e. if unfirmed voltage level (not  $V_{SS}$  or  $V_{DD}$ ) is applied to input pin, there can be little current (max. 1mA at around 2V) flow.

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





Figure 10-10 Application Example of Unused Input Port





Figure 10-11 Application Example of Unused Output Port

## 11. BASIC INTERVAL TIMER

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

The Basic Interval Timer Register (BITR) is increased every internal count pulse which is divided by prescaler. Since prescaler has divided ratio by 8 to 1024, the count rate is 1/8 to 1/1024 of the oscillator frequency. After reset, the BCK bits are all set, so the longest oscillation stabilization time is obtained.

It also provides a Basic interval timer interrupt (BITF). The count overflow of BITR from  $FF_H$  to  $00_H$  causes the

interrupt to be generated. The Basic Interval Timer is controlled by the clock control register (CKCTLR) shown in Figure 11-2.

Source clock can be selected by lower 3 bits of CKCTLR. When write "1" to bit BCL of CKCTLR, BITR register is cleared to "0" and restart to count up. The bit BCL becomes "0" automatically after one machine cycle by hardware.

BITR and CKCTLR are located at same address, and address 0F4<sub>H</sub> is read as a BITR, and written to CKCTLR.



Figure 11-1 Block Diagram of Basic Interval Timer

| ВСК   | Source                             | clock                             | Interrupt (overflow) Period |                                |  |  |
|-------|------------------------------------|-----------------------------------|-----------------------------|--------------------------------|--|--|
| <2:0> | SCMR[1:0]=<br>00 or 01             | SCMR[1:0]=<br>10 or 11            | At f <sub>MAIN</sub> =4MHz  | At f <sub>SUB</sub> =32.768kHz |  |  |
| 000   | f <sub>MAIN</sub> ÷2 <sup>3</sup>  | f <sub>SUB</sub> ÷2 <sup>3</sup>  | 0.512 ms                    | 62.5 ms                        |  |  |
| 001   | f <sub>MAIN</sub> ÷2 <sup>4</sup>  | f <sub>SUB</sub> ÷2 <sup>4</sup>  | 1.024                       | 125.0                          |  |  |
| 010   | f <sub>MAIN</sub> ÷2 <sup>5</sup>  | f <sub>SUB</sub> ÷2 <sup>5</sup>  | 2.048                       | 250.0                          |  |  |
| 011   | f <sub>MAIN</sub> ÷2 <sup>6</sup>  | f <sub>SUB</sub> ÷2 <sup>6</sup>  | 4.096                       | 500.0                          |  |  |
| 100   | f <sub>MAIN</sub> ÷2 <sup>7</sup>  | f <sub>SUB</sub> ÷2 <sup>7</sup>  | 8.192                       | 1000.0                         |  |  |
| 101   | f <sub>MAIN</sub> ÷2 <sup>8</sup>  | f <sub>SUB</sub> ÷2 <sup>8</sup>  | 16.384                      | 2000.0                         |  |  |
| 110   | f <sub>MAIN</sub> ÷2 <sup>9</sup>  | f <sub>SUB</sub> ÷2 <sup>9</sup>  | 32.768                      | 4000.0                         |  |  |
| 111   | f <sub>MAIN</sub> ÷2 <sup>10</sup> | f <sub>SUB</sub> ÷2 <sup>10</sup> | 65.536                      | 8000.0                         |  |  |

**Table 11-1 Basic Interval Timer Interrupt Time** 



Figure 11-2 BITR: Basic Interval Timer Mode Register

#### Example 1:

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

```
LDM CKCTLR,#0CH
SET1 BITE
EI
:
```

# 12. Timer / Counter

Timer/Event Counter consists of prescaler, multiplexer, 8-bit timer data register, 8-bit counter register, mode register, input capture register and Comparator as shown in Figure 12-3. And the PWM high register for PWM is consisted separately.

The timer/counter has seven operating modes.

- 8 Bit Timer/Counter Mode
- 8 Bit Capture Mode
- 8 Bit Compare Output Mode
- 16 Bit Timer/Counter Mode
- 16 Bit Capture Mode
- 16 Bit Compare Output Mode
- PWM Mode

In the "timer" function, the register is increased every internal clock input. Thus, one can think of it as counting in-

## Example 1:

```
Timer 0 = 8-bit timer mode, 8ms interval at 4MHz
Timer 1 = 8-bit timer mode, 4ms interval at 4MHz
```

```
LDM
       SCMR, #0
                         ;Main clock mode
       TDR0, #249
T<sub>1</sub>DM
LDM
       TM0, #0001_0011B
       TDR1,#124
LDM
       TM1, #0000_1111B
LDM
SET1
       TOE
SET1
       T1E
ΕI
```

## Example 2:

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

```
LDM
       SCMR, #0
                        ;Main clock mode
       TDR0, #23H
T.DM
LDM
       TDR1,#0F4H
LDM
       TMO, #OFH
                        ;F_{MAIN}/32, 8us
T.DM
       TM1, #4CH
SET1
       TOE
ET
 :
 :
```

ternal clock input. Since a least clock consists of 2 and most clock consists of 1024 oscillator periods, the count rate is 1/2 to 1/1024 of the oscillator frequency in Timer0. And Timer1 can use the same clock source too. In addition, Timer1 has more fast clock source (1/1 to 1/8).

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

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

Timer1 is shared with "PWM" function and "Compare output" function.

#### Example 3:

Timer0 = 8-bit event counter, 2ms interval at 4MHz Timer1 = 8-bit capture mode, 2us sampling count.

```
LDM
       TDR0,#99
                           ;99+1, 100 count
T-DM
       TM0,#01FH
                           ; event counter
LDM
       RODR, #XXXX_1XXXB
                           ;R03input
LDM
       IESR, #XXXX_01XXB
                            ;FALLING
       PMR, #XXXX_1X1XB
T<sub>1</sub>DM
                            ; ECO. INT1
T<sub>1</sub>DM
       TDR1,#0FFH
LDM
       TM1,#0001_1011B
                            ;2us
SET1
       TOE; ENABLE TIMER 0
       T1E; ENABLE TIMER 1
SET1
       INT1E; ENABLE EXT. INT1
SET1
ΕI
```

X: don't care.

#### Example 4:

Timer0 = 16-bit capture mode, 8us sampling count. at 4MHz

```
TDR0, #0FFH
T<sub>1</sub>DM
        TDR1,#0FFH
T.DM
LDM
       TM0, #02FH
LDM
       TM1,#04FH
T<sub>1</sub>DM
        IESR, #XXXX_XX01B
                                 ; AS INTO
LDM
       PMR, #XXXX_XXX1B
       TOE; ENABLE TIMER 0
SET1
SET1
        INTOE; ENABLE EXT. INTO
ET
```

X: don't care.



Figure 12-1 Timer0,1 Registers



Figure 12-2 Related Registers with Timer/Counter

| 16BIT | CAP0 | CAP1           | PWME | T0CK[2:0] | T1CK[1:0] | PWMO | Timer 0               | Timer 1              |
|-------|------|----------------|------|-----------|-----------|------|-----------------------|----------------------|
| 0     | 0    | 0              | 0    | XXX       | XX        | 0    | 8 Bit Timer           | 8 Bit Timer          |
| 0     | 0    | 1              | 0    | 111       | XX        | 0    | 8 Bit Event Counter   | 8 Bit Capture        |
| 0     | 1    | 0              | 0    | XXX       | XX        | 1    | 8 Bit Capture         | 8 Bit Compare Output |
| 0     | 0    | 0              | 1    | XXX       | XX        | 1    | 8 Bit Timer/Counter   | 10 Bit PWM           |
| 1     | 0    | 0              | 0    | XXX       | 11        | 0    | 16 Bit Timer          |                      |
| 1     | 0    | 0              | 0    | 111       | 11        | 0    | 16 Bit Event Counter  |                      |
| 1     | 1    | X <sup>1</sup> | 0    | XXX       | 11        | 0    | 16 Bit Capture        |                      |
| 1     | 0    | 0              | 0    | XXX       | 11        | 1    | 16 Bit Compare Output |                      |

<sup>1.</sup> X: The value "0" or "1" corresponding your operation.

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

#### 12.1 8-Bit Timer/Counter Mode

The GMS81C5108 has two 8-bit Timer/Counters, Timer 0, Timer 1, as shown in Figure 12-3.

The "timer" or "counter" function is selected by mode registers TMx as shown in Figure 12-1 and Table 12-1. To use

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



Figure 12-3 Block Diagram of Timer/Event Counter

These timers have each 8-bit count register and data register. The count register is increased by every internal or external clock input. The internal clock has a prescaler divide ratio option of 2, 4, 8, 32,128, 512, 1024 (selected by control bits T0CK2, T0CK1 and T0CK0 of register TM0) and 1, 2, 8 (selected by control bits T1CK1 and T1CK0 of register TM1).

In the Timer, timer register  $T_X$  increases from  $00_H$  until it matches  $TDR_X$  and then reset to  $00_H$ . If the value of  $T_X$  is equal with  $TDR_X$ , Timer  $_X$  interrupt is occurred (latched in  $T_XIF$  bit). TDR0 and T0 register are in same address, so this register is read from T0 and written to TDR0.

In counter function, the counter is increased every 0-to 1 (rising edge) transition of EC0 pin. In order to use counter function, the bit R03 of the R0 Direction Register (R0DR) should be set to "0" and the bit EC0 of Port Mode Register (PMR) should set to "1". The Timer 0 can be used as a counter by pin EC0 input, but Timer 1 can not used as a counter.

**Note:** The contents of TDR0 and TDR1 must be initialized (by software) with the value between 1<sub>H</sub> and 0FF<sub>H</sub>, not 0<sub>H</sub>.



Figure 12-4 Counting Example of Timer Data Registers



**Figure 12-5 Timer Count Operation** 

#### 12.2 16 Bit Timer/Counter Mode

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

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

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



Figure 12-6 16-bit Timer / Counter Mode

# 12.3 8-Bit Capture Mode

The Timer 0 capture mode is set by bit CAP0 of timer mode register TM0 (bit CAP1 of timer mode register TM1 for Timer 1) as shown in Figure 12-7.

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

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

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

For example, in Figure 12-9, the pulse width of captured signal is wider than the timer data value (FF<sub>H</sub>) over 2 times. When external interrupt is occurred, the captured value ( $13_H$ ) is more little than wanted value. It can be obtained correct value by counting the number of timer over-

flow occurrence.

Timer/Counter still does the above, but with the added feature that a edge transition at external input INTx pin causes the current value in the Timer x register (T0,T1), to be captured into registers CDRx (CDR0, CDR1), respectively. After captured, Timer x register is cleared and restarts by hardware.

It has three transition modes: "falling edge", "rising edge", "both edge" which are selected by interrupt edge selection register IESR (Refer to External interrupt section). In addition, the transition at INTx pin generate an interrupt.

Note: The CDR0, TDR0 and T0 are in same address. In the capture mode, reading operation is read the CDR0 and in timer mode, reading operation is read the T0. TDR0 is only for writing operation.

The CDR1, T1 are in same address, the TDR1 is located in different address. In the capture mode, reading operation is read the CDR1



Figure 12-7 8-bit Capture Mode



Figure 12-8 Input Capture Operation



Figure 12-9 Excess Timer Overflow in Capture Mode

## 12.4 16-bit Capture Mode

16-bit capture mode is the same as 8-bit capture, except that the Timer register is running with 16 bits.

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

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



Figure 12-10 16-bit Capture Mode

# 12.5 8-Bit (16-Bit) Compare OutPut Mode

The GMS81C5108 has a function of Timer Compare Output. To pulse out, the timer match can goes to port pin (R31) as shown in Figure 12-3 and Figure 12-6. Thus, pulse out is generated by the timer match. These operation is implemented to pin, R31/PWM.

In this mode, the bit PWMO of Port Mode Register (PMR) should be set to "1", and the bit PWME of Timer1 Mode Register (TM1) should be cleared to "0".

# 12.6 PWM Mode

The GMS81C5108 has one high speed PWM (Pulse Width Modulation) function which shared with Timer1.

In PWM mode, the R31/PWM pin operates as a 10-bit resolution PWM output port. For this mode, the bit PWM of Port Mode Register (PMR) and the bit PWME of timer1 mode register (TM1) should be set to "1" respectively.

The period of the PWM output is determined by the T1PPR (PWM Period Register) and PWMHR[3:2] (bit3,2

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

This pin output the signal having a 50 : 50 duty square wave, and output frequency is same as below equation.

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

of PWM High Register) and the duty of the PWM output is determined by the T1PDR (PWM Duty Register) and PWMHR[1:0] (bit1,0 of PWM High Register).

The user can use PWM data by writing the lower 8-bit period value to the T1PPR and the higher 2-bit period value to the PWMHR[3:2]. And the duty value can be used with the T1PDR and the PWMHR[1:0] in the same way.

The T1PDR is configured as a double buffering for glitch-

less PWM output. In Figure 12-11, the duty data is transferred from the master to the slave when the period data matched to the counted value. (i.e. at the beginning of next duty cycle).

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

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

Note: If the user need to change mode from the Timer1 mode to the PWM mode, the Timer1 should be stopped firstly, and then set period and duty register value. If user writes register values and changes mode to PWM mode while Timer1 is in operation, the PWM data would be different from expected data in the beginning.

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

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

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

**Note:** If the duty value and the period value are same, the PWM output is determined by the bit POL0 (1: High, 0: Low). And if the duty value is set to "00H", the PWM output is determined by the bit POL0(1: Low, 0: High). The period value must be same or more than the duty value, and 00H cannot be used as the period value.

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

Table 12-2 PWM Frequency vs. Resolution at 4MHz



Figure 12-11 PWM Mode



Figure 12-12 Example of PWM at 4MHz



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

### **Example:**

```
Timer1 @4Mhz, 4kHz-20% duty PWM mode
        R3DR, #0000_XX1XB
   LDM
                             ;R31 output
        TM1,#0010_0000B
   LDM
                             ;pwm enable
        T1PWHR, #0000_1100B ;20% duty
   LDM
   LDM
        T1PPR,#1110_0111B
                             ;period 250uS
                             ;duty 50uS
   LDM
        T1PDR,#1100_0111B
        RSR, #X1XX_XXXXB
TM1, #0010_0011B
   LDM
                             ;set pwm port.
   LDM
                             ;timer1 start
```

X means don't care

gмs81C5108 hyиix

# 13. Watch Timer/Watch Dog Timer

This has two functions, one is the interrupt occurrence for watch time and the other is the signal generation of WDTOUTB for watch dog.

#### 13.1 Watch Timer

The watch timer consists of the clock selector, 21-bit binary counter and watch timer mode register. It is a multi-purpose timer. It is generally used for watch design.

The bit 1,2 of WTMR select the clock source of watch timer among sub-clock,  $f_{MAIN} \div 2^7$  of main-clock and  $f_{MAIN}$  of main-clock. The  $f_{MAIN}$  of main-clock is used usually for watch timer test, so generally it is not used for the clock source of watch timer. The  $f_{MAIN} \div 2^7$  of main-clock is used when the single clock system is organized. In  $f_{MAIN} \div 2^7$ 

clock source, if the CPU enters into stop mode, the mainclock is stopped and then watch timer is also stopped. If the sub-clock is the source clock, the watch timer count cannot be stopped. Therefore, the sub-clock does not stop but continues to oscillate even when the CPU is in the STOP mode. The timer counter consists of 21-bit binary counter and it can count to max 64 seconds at sub-clock.

The bit 2, 3 of WTMR select the interrupt request interval of watch timer among 2Hz, 4Hz, 16Hz and 1/64Hz.



Figure 13-1 Watch Timer Mode Register



Figure 13-2 Watch Timer Block Diagram

# 13.2 Watch Dog Timer

The watch dog timer (WDT) function is used for checking program malfunction. If the watch dog timer is not reset in a fixed time, the WDTOUTB pin outputs a low signal. Therefore, by connecting the WDTOUTB pin and the reset pin externally, the MCU can be reset when the malfunction is occurred.

Usually the stop mode is used to reduce the power consumption. When the stop mode is released by watch timer interrupt, it is recommend to set the WDTCL to clear the 2-Bit counter and enter the stop mode. If the clock source is 1/64Hz, the WDTCL cannot be cleared in 500ms. In this case, the user should disable the WDT by clearing the WDTEN or disconnect the WDTOUTB pin and reset pin.

#### **Usage of Watch Timer in STOP Mode**

When the system is off and the watch should be kept working, follow the steps below.

- Determines which mode is to be performed between main mode and sub mode when the MCU is released from Stop mode and set the clock source of watch timer to sub-clock.
- 2. Enters in STOP mode.
- 3. After released by watch timer interrupt, counts up timer and refreshes LCD Display. When the performing count up and refresh the LCD, the CPU operates either in main frequency mode or sub frequency mode.
- 4. Enters in STOP mode again.
- 5. Repeats 3 and 4.

When using STOP mode, if the watch timer interrupt interval is selected to 2Hz, the power consumption can be reduced considerably.



## 14. 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 four 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  $AV_{DD}$  of ladder resistance of A/D module.

The A/D module has two registers which are the A/D mode register (ADMR) and A/D data register (ADDR). The ADMR register, shown in Figure 14-1, 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, each port should be assigned analog input port by

setting input mode by R2DR direction register. And select the corresponding channel to be converted by setting ADAN[1:0].

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 ADDR contains the result of the A/D conversion. When the conversion is completed, the result is loaded into the ADDR, the A/D conversion status bit ADF is set to "1", and the A/D interrupt flag ADIF is set. The block diagram of the A/D module is shown in Figure 14-1. The A/D status bit ADF is automatically set when A/D conversion is completed, cleared when A/D conversion is in process. The conversion time takes maximum 30 uS (at  $f_{MAIN} = 4MHz$ ).



Figure 14-1 A/D Converter Block Diagram & Registers



Figure 14-2 A/D Converter Operation Flow

#### A/D Converter Cautions

## (1) Input range of AN0 to AN3

The input voltages of AN0 to AN3 should be within the specification range. In particular, if a voltage above  $AV_{DD}$  or below  $V_{SS}$  is input (even if within the absolute maximum rating range), the conversion value for that channel can not be indeterminated. The conversion values of the other channels may also be affected.

#### (2) Noise countermeasures

In order to maintain 8-bit resolution, attention must be paid

to noise on pins  $AV_{DD}$  and AN0 to AN3. Since the effect increases in proportion to the output impedance of the analog input source, it is recommended that a capacitor is connected externally as shown below in order to reduce noise.



Figure 14-3 Analog Input Pin Connecting Capacitor

#### (3) Pins AN0/R20 to AN3/R23

The analog input pins AN0 to AN3 also function as input/output port (PORT R2) pins. When A/D conversion is performed with any of pins AN0 to AN3 selected, be sure not to execute a PORT input instruction while conversion is in progress, as this may reduce the conversion resolution.

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

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

A series resistor string of approximately  $10K\Omega$  is connected between the  $AV_{DD}$  pin and the  $V_{SS}$  pin.

Therefore, if the output impedance of the reference voltage source is high, this will result in parallel connection to the series resistor string between the  $AV_{DD}$  pin and the  $V_{SS}$  pin, and there will be a large reference voltage error.

# 15. Buzzer Output Function

The buzzer driver consists of 6-bit binary counter, the buzzer data register BDR and the clock selector. It generates square-wave which is very wide range frequency (500 Hz~125 KHz at  $f_{MAIN}=4$ MHz) by user programmable counter.

Pin R04 is assigned for output port of Buzzer driver by setting the bit BUZ of Port Mode Register (PMR) to "1".

The 6-bit buzzer counter is cleared and start the counting by writing signal to the register BDR. It is increased from 00<sub>H</sub> until it matches with BDR[5:0].

Also, it is cleared by counter overflow and count up to output the square wave pulse of duty 50%.

The bit 0 to 5 of BDR determines output frequency for buzzer driving. BCD is undefined after reset, so it must be initialized to between  $0_{\rm H}$  and  $3F_{\rm H}$  by software. Note that BDR is a write-only register. Frequency calculation is following as shown below.

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

The bits BCK1, BCK0 of BDR select the source clock from prescaler output

fBUZ: BUZ pin frequency

Prescaler ratio: Prescaler divide ratio by BDR[7:6] BCD value: 6-bit compare data, BCD[5:0].



Figure 15-1 Buzzer Driver

Example: 2.5kHz output at 4MHz.

LDM RODR, #XXX1\_XXXXB LDM BDR, #1001\_1000B LDM PMR, #XXX1\_XXXXB ; Buzzer ON

X means don't care

**Ы**µµ**i**х GMS81C5108

# **Buzzer Output Frequency**

When main-frequency is 4MHz, buzzer frequency is shown as below and if sub-frequency is selected as clock

source, buzzer frequency is used after dividing by 128.

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

**Table 15-1 Buzzer Output Frequency** 

## 16. Serial Communication Interface

The SCI module allows 8-bits of data to be synchronously transmitted and received. This is useful for communication with other peripheral of microcontroller devices. This con-

sists of serial I/O data register, serial I/O mode register, clock selection circuit octal counter and control circuit as shown in Figure 16-1.



Figure 16-1 SCI Registers and Block Diagram

To accomplish communication, typically three pins are used:

Serial Data In R07/SI
 Serial Data Out R06/SO
 Serial Clock R05/SCK

The serial data transfer operation mode is decided by set-

ting the SIO1 and SIO0 and the transfer clock rate is decided by setting the SICK1 and SICK0 of SCI Mode Control Register as shown in Figure 16-1. And the polarity of transfer clock is selected by setting the POL. The MSBS bit is used to select which bit would be sending or receiving.

| SIG4 | CIOO | Function Coloction   | Port Selection |        |        |  |
|------|------|----------------------|----------------|--------|--------|--|
| SIO1 | SIO0 | Function Selection   | R05/SCK        | R06/SO | R07/SI |  |
| 0    | 0    | -                    | R05            | R06    | R07    |  |
| 0    | 1    | Transmit Mode        | SCK            | so     | R07    |  |
| 1    | 0    | Receive Mode         | SCK            | R06    | SI     |  |
| 1    | 1    | Transmit and Receive | SCK            | so     | SI     |  |

# 16.1 Data Transmit/Receive Timing

The SCI operation is executed by setting the SIOST bit to "1". The SIOST bit is cleared to "0" automatically after 1 machine cycle. The Serial output data is shift in or shift out

at edge decided by POL. Interrupt is occurred when the eight in/out datas is counted by octal counter.



Figure 16-2 SCI Timing Diagram

# 16.2 The method of Serial I/O

1. Select transmission/receiving mode

When external clock is used, the frequency should be less than 1MHz and recommended duty is 50%.

- 2. In case of sending mode, write data to be send to SIOD.
- 3. Set SIOST to "1" to start serial transmission.

If both transmission mode is selected and transmission is performed simultaneously it would be made error.

- 4. The SIO interrupt is generated at the completion of SIO and SIOSF is set to "1".
- 5. In case of receiving mode, the received data is acquired by reading the SIOD.



Figure 16-3 SCI Timing Diagram at POL=1

## 17. INTERRUPTS

The GMS81C5108 interrupt circuits consist of Interrupt enable register (IENH, IENL), Interrupt request flag (IRQH, IRQL), Interrupt Edge Selection Register (IESR), priority circuit and Master enable flag ("I" flag of PSW). The configuration of interrupt circuit is shown in Figure 17-1 and Interrupt priority is shown in Table 17-1.

The flags that actually generate these interrupts are bit INT0F, INT1F and INT2F in Register IRQH. When an external interrupt is generated, the flag that generated it is cleared by the hardware when the service routine is vectored to only if the interrupt was transition-activated.

The Timer 0 and Timer 2 Interrupts are generated by T0IF and T1IF, which are set by a match in their respective timer/counter register. The AD converter Interrupt is generated by ADIF which is set by finishing the analog to digital conversion. The Basic Interval Timer Interrupt is generat-

ed by BITIF which is set by overflow of the Basic Interval Timer Register (BITR).

| Reset/Interrupt       | Symbol | Priority | Vector Addr.      |
|-----------------------|--------|----------|-------------------|
| Hardware Reset        | RESET  | -        | FFFE <sub>H</sub> |
| Key Scan Interrupt    | KS     | 1        | FFFC <sub>H</sub> |
| BIT Interrupt         | BIT    | 2        | FFFA <sub>H</sub> |
| External Interrupt 0  | INT0   | 3        | FFF8 <sub>H</sub> |
| External Interrupt 1  | INT1   | 4        | FFF6 <sub>H</sub> |
| Timer 0 Interrupt     | T0     | 5        | FFF4 <sub>H</sub> |
| Timer 1 Interrupt     | T1     | 6        | FFF2 <sub>H</sub> |
| External Interrupt 2  | INT2   | 7        | FFF0 <sub>H</sub> |
| Remocon Interrupt     | REM    | 8        | FFEE <sub>H</sub> |
| AD Interrupt          | AD     | 9        | FFECH             |
| SIO Interrupt         | SIO    | 10       | FFEA <sub>H</sub> |
| Watch Timer Interrupt | WT     | 11       | FFE8 <sub>H</sub> |

**Table 17-1 Interrupt Priority** 



Figure 17-1 Block Diagram of Interrupt Function

The External Interrupts INT0, INT1 and INT2 can each be transition-activated (1-to-0, 0-to-1 and both transiton). 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 flag (IRQH, IRQL) except Power-on reset and software BRK interrupt.

Interrupt enable registers are shown in Figure 17-2. These registers are composed of interrupt enable flags of each interrupt source, these flags determine 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 occurred, the I-flag is cleared and disable any further interrupt, the return address and PSW are pushed into the stack and the PC is vectored to. Once in the interrupt service routine the source(s) of the interrupt can be determined by polling the interrupt request flag bits.

The interrupt request flag bit(s) must be cleared by software before re-enabling interrupts to avoid recursive interrupts. The Interrupt Request flags are able to be read and written.



Figure 17-2 Interrupt Enable Registers and Interrupt Request Registers

## 17.1 Interrupt Sequence

An interrupt request is held until the interrupt is accepted or the interrupt latch is cleared to "0" by a reset or an instruction. Interrupt acceptance sequence requires 8  $f_{OSC}$  (2  $\mu s$  at  $f_{MAIN}{=}4MHz$ ) after the completion of the current instruction execution. The interrupt service task is terminated upon execution of an interrupt return instruction [RETI].

#### Interrupt acceptance

 The interrupt master enable flag (I-flag) is cleared to "0" to temporarily disable the acceptance of any following maskable interrupts. When a non-maskable interrupt is accepted, the acceptance of any following interrupts is temporarily disabled.

- 2. Interrupt request flag for the interrupt source accepted is cleared to "0".
- 3. The contents of the program counter (return address) and the program status word are saved (pushed) onto the stack area. The stack pointer decreases 3 times.
- 4. The entry address of the interrupt service program is read from the vector table address and the entry address is loaded to the program counter.
- 5. The instruction stored at the entry address of the interrupt service program is executed.



Figure 17-3 Timing chart of Interrupt Acceptance and Interrupt Return Instruction



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

An interrupt request is not accepted until the I-flag is set to "1" even if a requested interrupt has higher priority than that of the current interrupt being serviced.

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

#### Saving/Restoring General-purpose Register

During interrupt acceptance processing, the program counter and the program status word are automatically saved on the stack, but accumulator and other registers are not saved itself. If necessary, these registers should be saved by the software. Also, when multiple interrupt services are nested, it is necessary to avoid using the same data memory area for saving registers.

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

Example: Register saving

| INTxx: | PUSH<br>PUSH<br>PUSH      | A<br>X<br>Y | ;SAVE ACC.<br>;SAVE X REG.<br>;SAVE Y REG.                     |
|--------|---------------------------|-------------|----------------------------------------------------------------|
|        | interrupt pro             | cessing     |                                                                |
|        | POP<br>POP<br>POP<br>RETI | Y<br>X<br>A | ;RESTORE Y REG.<br>;RESTORE X REG.<br>;RESTORE ACC.<br>;RETURN |

General-purpose registers are saved or restored by using push and pop instructions.



## 17.2 BRK Interrupt

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

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

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



Figure 17-4 Execution of BRK/TCALL0

## 17.3 Multi Interrupt

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

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

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

```
TIMER1: PUSH
          PUSH
                  Χ
          PUSH
                  IENH, #80H
                                 ; Enable INT0 only
          T.DM
                                 ; Disable other
          LDM
                  IENL,#0
          ΕI
                                 ; Enable Interrupt
          :
                  IENH,#0FFH ; Enable all interrupts
          LDM
          LDM
                  IENL, #0F0H
          POP
                  Υ
          POP
                  Х
          POP
                  Α
          RETI
```



Figure 17-5 Execution of Multi Interrupt

# 17.4 External Interrupt

The external interrupt on INT0, INT1 and INT2 pins are edge triggered depending on the edge selection register IESR (address 0D8<sub>H</sub>) as shown in Figure 17-6.

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



Figure 17-6 External Interrupt Block Diagram

Example: To use as an INT0 and INT2

#### **Response Time**

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

Interrupt response timings are shown in Figure 17-7.



Figure 17-7 Interrupt Response Timing Diagram

### 18. KEY SCAN

The key-scan block consists of key scan mode register (KSMR) and R1 pull-up register (R1PU). When the key scan interrupt is used, key scan mode register KSMR (address  $0F0_H$ ) should be set properly as shown in Figure 18-1. The pins which is to be used as key scan input should be set by KSMR and the strobe output pins should be set as open drain. The strobe output pins could be selected from

among R0[7:0], R1[7:0], R2[3:0] and R3[3:0].

If the "L" signal is input to any one or more of key scan input pins, the KSIF request flag is set to "1". This generates an interrupt request. It also can be used in the way of release from STOP mode.



Figure 18-1 Key Scan Interrupt Block Diagram

### **Usage of Key Scan**

When key board scanning, it is recommended that set the output strobe to "L" first and then read R1 port after 60us

delay time. Because the rising time of the output strobe port from "L" to "H" is so long. The Figure 18-2 explain this reason.



Figure 18-2 Key Scan Timing

**Ы**µиіх GMS81C5108

### 19. LCD DRIVER

The GMS81C5108 has the circuit that directly drives the liquid crystal display (LCD) and its control circuit. The Segment/Common Driver directly drives the LCD panel, and the LCD Controller generates the segment/common signals according to the RAM which stores display data. In addition, VCL2 ~ VCL0 pin are provided as the drive power pins.

The GMS81C5108 has the following pins connected with LCD.

- 1. Segment output port 37 pins (SEG0-SEG36)
- 2.Common output port 4 pins (COM0-COM3)

#### 19.1 Configuration of LCD driver

Figure 19-1 shows the configuration of the LCD driver.



Figure 19-1 LCD Driver Block Diagram

GMS81C5108 Ициіх

#### 19.2 Control of LCD Driver Circuit

The LCD driver is controlled by the LCD Control Register (LCR). The LCR[1:0] determines the frequency of COM signal scanning of each segment output. RESET clears the LCD control register LCR values to logic zero. The LCD display can continue to operate during SLEEP and STOP modes if a sub-frequency clock is used as system clock source. The constant voltage booster circuit for using LCD driver is built in, so the definite voltage could supplied regardless of power source voltage fluctuations.

**Note:** The Sub clock is used as voltage booster source clock, so the stabilization time is need to use voltage booster. Normally, the stabilization time is need more than 500ms. The external bias registers cannot be used for LCD display supply voltage.



Figure 19-2 LCD Control Register

#### **Selecting Frame Frequency**

Frame frequency is set to the base frequency as shown in the following Table 19-1. The  $f_S$  is selected to  $f_{SUB}$  (sub

clock) which is 32.768kHz.

| L CD[4.0] | I CD alask           | Frame Frequency (Hz) |            |            |            |  |  |  |  |  |  |  |
|-----------|----------------------|----------------------|------------|------------|------------|--|--|--|--|--|--|--|
| LCR[1:0]  | LCD clock            | Duty = Static        | Duty = 1/2 | Duty = 1/3 | Duty = 1/4 |  |  |  |  |  |  |  |
| 00        | f <sub>S</sub> ÷ 32  | 1024                 | 512        | 341.3      | 256        |  |  |  |  |  |  |  |
| 01        | f <sub>S</sub> ÷ 64  | 512                  | 256        | 170.7      | 128        |  |  |  |  |  |  |  |
| 10        | f <sub>S</sub> ÷ 128 | 256                  | 128        | 85.3       | 64         |  |  |  |  |  |  |  |
| 11        | f <sub>S</sub> ÷ 256 | 128                  | 64         | 42.7       | 32         |  |  |  |  |  |  |  |

**Table 19-1 Setting of LCD Frame Frequency** 

#### The matters to be attended to use LCD driver

In reset state, LCD source clock is sub clock. So, when the power is supplied, the LCD display would be flickered before the oscillation of sub clock is stabilized. It is recommended to use LCD display on after the stabilization time of sub clock is considered enough. If the LCD is reset during display, the display would be blotted by the capacity of LCD power circuit. The external circuit of constant voltage booster for using LCD driver is shown at right.



Figure 19-3 LCD Power Booster Circuit

**Ы**µиіх GMS81C5108

#### 19.3 LCD Display Memory

Display data are stored to the display data area (page 1) in the data memory.

The display data stored to the display data area (address  $0100_{H}$ - $0124_{H}$ ) are read automatically and sent to the LCD driver by the hardware. The LCD driver generates the segment signals and common signals in accordance with the display data and drive method. Therefore, display patterns can be changed by only overwriting the contents of the display data area with a program. The table look up instruction is mainly used for this overwriting.

Figure 19.3 shows the correspondence between the display data area and the SEG/COM pins. The LCD lights when the display data is "1" and turn off when "0".

LCD display memory in this location that are not used for LCD display can be allocated for general purpose use.

The SEG data for display is controlled by RPR (RAM Paging Register).



Figure 19-4 Setting of RAM Paging Register



Figure 19-5 LCD Display Memory

#### 19.4 Control Method of LCD Driver

#### **Initial Setting**

Flow chart of initial setting is shown in Figure 19-6.

Example: Driving of LCD





Figure 19-6 Initial Setting of LCD Driver

### 

Figure 19-7 Example of Connection COM & SEG

### **Display Data**

Normally, display data are kept permanently in the program memory and then stored at the display data area by the table look-up instruction. This can be explained using character display with 1/4 duty LCD as an example as well as any LCD panel. The COM and SEG connections to the LCD and display data are the same as those shown is Figure 19-7. Following is showing the Programming example for displaying character.

**Note:** When power on RESET, sub oscillation start up time is required. Enable LCD display after sub oscillation is stabilized, or LCD may occur flicker at power on time shortly.

**Ы**µиіх GMS81C5108



#### **LCD Waveform**

The LCD duty can be selected by LCR register. The kinds of LCD waveforms are four totally. Among them, static

and 1/4 duty waveforms are shown Figure 19-8.



Figure 19-8 Example of LCD drive output

gмs81C5108 hyиix

### 20. REMOCON CARRIER GENERATOR

The GMS81C5108 has a circuit to generate carriers for the remote controller. This circuit consists of Remocon Mode Register (RMR), Carrier Frequency High Selection (CF-HS), Carrier Frequency Low Selection (CFLS), Remocon Data High Register (RDHR), Remocon Data Low Register (RDLR), Remocon Data Counter (RDC), Remocon Output

Data Register (RODR) and Remocon Output Buffer (ROB) as shown in Figure 20-1. A carrier duty and frequency are determined by the contents of these registers. A source clock input to the 6-bit counter is selected by diving the frequency of the system clock by two (main or sub clock).

### 20.1 Remocon Signal Output Control

The output of the REMOUT pin which outputs carriers is controlled by RODR and ROB register. While the Bit-0 of RODR is "1", the REMOUT pin outputs a carrier signal generated by the remote controller carrier generator. While this Bit is "0", the output of the REMOUT pin is low.

The content of the ROB is automatically transferred to the

RODR by an interrupt signal generated by the 8-Bit timer. The content of the RODR.0 is output to the REMOUT pin. Namely, the REMOUT pin outputs a high-level signal when RODR.0 is "1" and a low-level signal when RODR.0 is "0".



Figure 20-1 Remocon Carrier Generator Block Diagram



Figure 20-2 Remocon Registers

### 20.2 Carrier Frequency

The carrier frequency and the pulse of data are calculated by below formula. The the lengths of carrier frequency and pulse of data are shown in Figure 20-3. 
$$\begin{split} t_{H} &= \text{source clock}(RMR[5:4]) \times CFHS \\ t_{L} &= \text{source clock}(RMR[5:4]) \times CFHS \\ f_{C}\left(Carrier\ Frequency\right) &= 1/(t_{H} + t_{L}) \\ t_{DH} &= \text{source clock}(RMR[2:0]) \times RDHR \\ t_{DL} &= \text{source clock}(RMR[2:0]) \times RDLR \end{split}$$



Figure 20-3 Carrier Frequency & Pulse of Data

The Table 20-1 shows high and low length of carrier frequency according to CFLS and CFHS. This only shows

when the source clock is selected  $f_{MAIN}$  and  $f_{MAIN} \div 2^2$  at 4MHz.

| Set '           | Value           | Selectio            | n of PS0            | Selectio            | n of PS2            | Set             | Value           | Selectio            | n of PS0            | Selectio            | n of PS2            |
|-----------------|-----------------|---------------------|---------------------|---------------------|---------------------|-----------------|-----------------|---------------------|---------------------|---------------------|---------------------|
| CFHS            | CFLS            | t <sub>H</sub> (us) | t <sub>L</sub> (us) | t <sub>H</sub> (us) | t <sub>L</sub> (us) | CFHS            | CFLS            | t <sub>H</sub> (us) | t <sub>L</sub> (us) | t <sub>H</sub> (us) | t <sub>L</sub> (us) |
| 00 <sub>H</sub> | 00н             | -                   | -                   | -                   | -                   | 20 <sub>H</sub> | 20 <sub>H</sub> | 8.00                | 8.00                | 32.00               | 32.00               |
| 01 <sub>H</sub> | 01 <sub>H</sub> | 0.25                | 0.25                | 1.00                | 1.00                | 21 <sub>H</sub> | 21 <sub>H</sub> | 8.25                | 8.25                | 33.00               | 33.00               |
| 02 <sub>H</sub> | 02 <sub>H</sub> | 0.50                | 0.50                | 2.00                | 2.00                | 22 <sub>H</sub> | 22 <sub>H</sub> | 8.50                | 8.50                | 34.00               | 34.00               |
| 03 <sub>H</sub> | 03H             | 0.75                | 0.75                | 3.00                | 3.00                | 23 <sub>H</sub> | 23 <sub>H</sub> | 8.75                | 8.75                | 35.00               | 35.00               |
| 04 <sub>H</sub> | 04 <sub>H</sub> | 1.00                | 1.00                | 4.00                | 4.00                | 24 <sub>H</sub> | 24 <sub>H</sub> | 9.00                | 9.00                | 36.00               | 36.00               |
| 05 <sub>H</sub> | 05 <sub>H</sub> | 1.25                | 1.25                | 5.00                | 5.00                | 25 <sub>H</sub> | 25 <sub>H</sub> | 9.25                | 9.25                | 37.00               | 37.00               |
| 06 <sub>H</sub> | 06 <sub>H</sub> | 1.50                | 1.50                | 6.00                | 6.00                | 26 <sub>H</sub> | 26 <sub>H</sub> | 9.50                | 9.50                | 38.00               | 38.00               |
| 07 <sub>H</sub> | 07 <sub>H</sub> | 1.75                | 1.75                | 7.00                | 7.00                | 27 <sub>H</sub> | 27 <sub>H</sub> | 9.75                | 9.75                | 39.00               | 39.00               |
| 08 <sub>H</sub> | 08 <sub>H</sub> | 2.00                | 2.00                | 8.00                | 8.00                | 28 <sub>H</sub> | 28 <sub>H</sub> | 10.00               | 10.00               | 40.00               | 40.00               |
| 09 <sub>H</sub> | 09 <sub>H</sub> | 2.25                | 2.25                | 9.00                | 9.00                | 29 <sub>H</sub> | 29 <sub>H</sub> | 10.25               | 10.25               | 41.00               | 41.00               |
| 0A <sub>H</sub> | 0A <sub>H</sub> | 2.50                | 2.50                | 10.00               | 10.00               | 2A <sub>H</sub> | 2A <sub>H</sub> | 10.50               | 10.50               | 42.00               | 42.00               |
| 0B <sub>H</sub> | 0B <sub>H</sub> | 2.75                | 2.75                | 11.00               | 11.00               | 2B <sub>H</sub> | 2B <sub>H</sub> | 10.75               | 10.75               | 43.00               | 43.00               |
| 0C <sub>H</sub> | 0C <sub>H</sub> | 3.00                | 3.00                | 12.00               | 12.00               | 2C <sub>H</sub> | 2C <sub>H</sub> | 11.00               | 11.00               | 44.00               | 44.00               |
| 0D <sub>H</sub> | 0D <sub>H</sub> | 3.25                | 3.25                | 13.00               | 13.00               | 2D <sub>H</sub> | $2D_{H}$        | 11.25               | 11.25               | 45.00               | 45.00               |
| 0E <sub>H</sub> | 0E <sub>H</sub> | 3.50                | 3.50                | 14.00               | 14.00               | 2E <sub>H</sub> | 2E <sub>H</sub> | 11.50               | 11.50               | 46.00               | 46.00               |
| 0F <sub>H</sub> | 0F <sub>H</sub> | 3.75                | 3.75                | 15.00               | 15.00               | 2F <sub>H</sub> | 2F <sub>H</sub> | 11.75               | 11.75               | 47.00               | 47.00               |
| 10 <sub>H</sub> | 10 <sub>H</sub> | 4.00                | 4.00                | 16.00               | 16.00               | 30 <sub>H</sub> | 30 <sub>H</sub> | 12.00               | 12.00               | 48.00               | 48.00               |
| 11 <sub>H</sub> | 11 <sub>H</sub> | 4.25                | 4.25                | 17.00               | 17.00               | 31 <sub>H</sub> | 31 <sub>H</sub> | 12.25               | 12.25               | 49.00               | 49.00               |
| 12 <sub>H</sub> | 12 <sub>H</sub> | 4.50                | 4.50                | 18.00               | 18.00               | 32 <sub>H</sub> | 32 <sub>H</sub> | 12.50               | 12.50               | 50.00               | 50.00               |
| 13 <sub>H</sub> | 13 <sub>H</sub> | 4.75                | 4.75                | 19.00               | 19.00               | 33 <sub>H</sub> | 33 <sub>H</sub> | 12.75               | 12.75               | 51.00               | 51.00               |
| 14 <sub>H</sub> | 14 <sub>H</sub> | 5.00                | 5.00                | 20.00               | 20.00               | 34 <sub>H</sub> | 34 <sub>H</sub> | 13.00               | 13.00               | 52.00               | 52.00               |
| 15 <sub>H</sub> | 15 <sub>H</sub> | 5.25                | 5.25                | 21.00               | 21.00               | 35 <sub>H</sub> | 35 <sub>H</sub> | 13.25               | 13.25               | 53.00               | 53.00               |
| 16 <sub>H</sub> | 16 <sub>H</sub> | 5.50                | 5.50                | 22.00               | 22.00               | 36 <sub>H</sub> | 36 <sub>H</sub> | 13.50               | 13.50               | 54.00               | 54.00               |
| 17 <sub>H</sub> | 17 <sub>H</sub> | 5.75                | 5.75                | 23.00               | 23.00               | 37 <sub>H</sub> | 37 <sub>H</sub> | 13.75               | 13.75               | 55.00               | 55.00               |
| 18 <sub>H</sub> | 18 <sub>H</sub> | 6.00                | 6.00                | 24.00               | 24.00               | 38 <sub>H</sub> | 38 <sub>H</sub> | 14.00               | 14.00               | 56.00               | 56.00               |
| 19 <sub>H</sub> | 19 <sub>H</sub> | 6.25                | 6.25                | 25.00               | 25.00               | 39 <sub>H</sub> | 39 <sub>H</sub> | 14.25               | 14.25               | 57.00               | 57.00               |
| 1A <sub>H</sub> | 1A <sub>H</sub> | 6.50                | 6.50                | 26.00               | 26.00               | 3A <sub>H</sub> | 3A <sub>H</sub> | 14.50               | 14.50               | 58.00               | 58.00               |
| 1B <sub>H</sub> | 1B <sub>H</sub> | 6.75                | 6.75                | 27.00               | 27.00               | 3B <sub>H</sub> | 3B <sub>H</sub> | 14.75               | 14.75               | 59.00               | 59.00               |
| 1C <sub>H</sub> | 1C <sub>H</sub> | 7.00                | 7.00                | 28.00               | 28.00               | 3C <sub>H</sub> | 3C <sub>H</sub> | 15.00               | 15.00               | 60.00               | 60.00               |
| 1D <sub>H</sub> | 1D <sub>H</sub> | 7.25                | 7.25                | 29.00               | 29.00               | 3D <sub>H</sub> | 3D <sub>H</sub> | 15.25               | 15.25               | 61.00               | 61.00               |
| 1E <sub>H</sub> | 1E <sub>H</sub> | 7.50                | 7.50                | 30.00               | 30.00               | 3E <sub>H</sub> | 3E <sub>H</sub> | 15.50               | 15.50               | 62.00               | 62.00               |
| 1F <sub>H</sub> | 1F <sub>H</sub> | 7.75                | 7.75                | 31.00               | 31.00               | 3F <sub>H</sub> | 3F <sub>H</sub> | 15.75               | 15.75               | 63.00               | 63.00               |

Table 20-1 Length of Carrier Frequency (at 4MHz)

GMS81C5108

## ициіх

#### Example:

```
Carrier Frequency = 37.8kHz, high = 8.52ms, low = 4.24ms, @4MHz
Rem_sig: LDM
             RMR,#0001_0010B
                              ;carrier clock(PS1), remocon data clock(PS5)
                               ;carrier low(IR LED)=18*PS1(0.5us)=9us
       LDM
             CFHS, #18
        LDM
             CFLS, #35
                               ;carrier high(IR LED)=35*PS1(0.5us)=17.5us
       CLR1
             ROD0
       LDM
             R_bit,#1111_1000B
                               ;213*5*PS5(8us)=8.52ms
       LDM
             RDHR, #213
                               ;177*3*PS5(8us)=4.248ms
        LDM
             RDLR, #177
        LDX
             #9
       CALL
             DATA
             RMR.6
                               ;Remocon operation enable
        SET1
        SET1
             RMR.3
                              ;Remocon data pulse enable
        SET1
             IENL.6
                               ;Remocon int.
Loop1: NOP
       CMPX #0
        BNE
             Loop1
Finish: CLR1
             ROD0
       CLR1
             ROB0
       RET
; * * * * * * *
       ROL
             R_bit
Data:
       BCS
             Set_rob0
            ROB0
        CLR1
       RET
Set_rob0:SET1ROB0
       RET
Remocon int service routine
Remocon_INT:
       CALL Data
       DEC
             Х
       RETI
```

### 21. OSCILLATOR CIRCUIT

The GMS81C5108 has two oscillation circuits internally.  $X_{IN}$  and  $X_{OUT}$  are input and output for main frequency and  $SX_{IN}$  and  $SX_{OUT}$  are input and output for sub frequency,

respectively, inverting amplifier which can be configured for being used as an on-chip oscillator, as shown in Figure 21-1.



Figure 21-1 Oscillation Circuit

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 21-2 for the layout of the crystal.

**Note:** Minimize the wiring length. Do not allow the wiring to intersect with other signal conductors. Do not allow the wiring to come near changing high current. Set the potential of the grounding position of the oscillator capacitor to that of Vss. Do not ground it to any ground pattern where high current is present. Do not fetch signals from the oscillator.



Figure 21-2 Layout of Oscillator PCB circuit

**Ы**µµ**i**х GMS81C5108

#### **22. RESET**

The GMS81C5108 have two types of reset generation procedures; one is an external reset input, the other is a watch-

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

dog timer reset. Table 22-1 shows on-chip hardware initialization by reset action.

| On-chip Hardware  | Initial Value                 |
|-------------------|-------------------------------|
| Peripheral clock  | On                            |
| SVD               | Enable                        |
| Control registers | Refer to Table 8-1 on page 25 |
| Voltage Booster   | Disable                       |

Table 22-1 Initializing Internal Status by Reset Action

### 22.1 External Reset Input

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

Internal RAM is not affected by reset. When  $V_{DD}$  is turned on, the RAM content is indeterminate. Therefore, this RAM should be initialized before read or tested it.

When the RESET pin input goes to high, the reset operation is released and the program execution starts at the vector address stored at  $FFFE_H$  -  $FFFF_H$ .

A connection for simple power-on-reset is shown in Figure 22-1.



Figure 22-1 Simple Power-on-Reset Circuit



Figure 22-2 Timing Diagram after RESET

#### 22.2 Watchdog Timer Reset

Refer to "13.2 Watch Dog Timer" on page 57.

#### 23. SUPPLY VOLTAGE DETECTION

The GMS81C5108 has an on-chip low voltage detection circuitry to detect the  $V_{DD}$  voltage. A configuration register, SCMR, can enable or disable the low voltage detect circuitry. This GMS81C5108 has two level detector(SVD0, SVD1). The SVD0 flag is set when the  $V_{DD}$  falls below 2.2V and if the  $V_{DD}$  is rise above 2.2V the SVD0 is cleared automatically. The SVD1 flag is set when the  $V_{DD}$  falls below 1.7V and if this flag is set once, it is

not cleared automatically although the  $V_{DD}$  rises above 1.7V. It can be cleared by writing.

If the SVD1 is set, the MCU can be RESET or frozen by the flag SVRT. In the in-circuit emulator, supply voltage detection is not implemented and user can not experiment with it. Therefore, after final development of user program, this function may be experimented or evaluated.



Figure 23-1 Low Voltage Detector Register



Figure 23-2 Power Fail Processor Situations

**Ы**µиіх GMS81C5108

### 24. DEVEMOPMENT TOOLS

#### 24.1 OTP Programming

The GMS87C5108 is an OTP (One Time Programmable) micro-controllers. Its internal user memory is constructed with EPROM (Electrically Programmable Read Only Memory).

The OTP microcontroller is generally used for chip evaluation, first production, small amount production, fast mass production, etc.

Blank OTP's internal EPROM is filled by 00<sub>H</sub>, not FF<sub>H</sub>.

**Note:** In any case, you have to use the \*.OTP file for programming, not the \*.HEX file. After assemble, both OTP and HEX file are generated by automatically. The HEX file is used during program emulation on the emulator.

#### **How to Program**

To program the OTP devices, user can use Hynix own programmer.

#### Hynix own programmer list

Manufacturer: Hynix Semiconductor Programmer:

Choice-Sigma Choice-Gang4

The Choice-Sigma is a Hynix Universal Single Programmer for all of Hynix OTP devices, also the Choice-Gang4 can program four OTPs at once for Hynix OTP.

Ask to Hynix sales part for purchasing or more detail

#### **Programming Procedure**

- 1. Select device GMS87C5108 you want.
- Load the \*.OTP file from the PC. The file is composed of Motorola-S1 format.
- 3. Set the programming address range as below table.

| Address              | Set Value         |
|----------------------|-------------------|
| Buffer start address | E000 <sub>H</sub> |
| Buffer end address   | FFFF <sub>H</sub> |
| Device start address | E000 <sub>H</sub> |

- 4. Mount the socket adapter on the programmer.
- 5. Start program/verify.

#### **Pin Function**

#### V<sub>PP</sub> (Program Voltage)

 $\ensuremath{V_{\mathrm{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.

#### A0~A15 (Address Bus)

A0~A15 are address input pins for internal EPROM.

#### O0~O7 (EPROM Data Bus)

These are data bus for internal EPROM.

24.2 Emulator S/W Setting





### **DIP Switch and VR Setting**

Before execute the user program, keep in your mind the below configuration

| DIP S/W         | , VR        | Description                                                                                                                                                                                                                                                                 | ON/OFF Setting                                                                                                                                                                 |
|-----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SW1             | -           | Emulator Reset Switch. Reset the Emulator.                                                                                                                                                                                                                                  | Reset the Emulator.                                                                                                                                                            |
| OFF ON          | 1           | SW2-1 EVA. Chip  RESET pin                                                                                                                                                                                                                                                  | Normally OFF. EVA. chip can be reset by external user target system board. ON: Reset is available by user target system board. OFF: MCU is reset by REST switch on EVA. board. |
| 3002            | 2           | SW2-2 EVA. Chip Oscillator                                                                                                                                                                                                                                                  | Normally OFF. MCU XOUT pin are disconnected by Emulator internally. Some cir- cumstance user may connect this circuit. ON: Output XOUT signal OFF: Disconnect circuit          |
| AAAAAAAA OFF ON | 1<br>2<br>3 | External Resistor and Capacitor  VDD Adjust Contrast  VR1 50kΩ  VCL1 SW4-2 10kΩ × 3  VCL0 1 WOLD 10kΩ × 3                                                                                                                                                                   | Normally <b>ON</b> . It serves the external bias resistors. If user want to use external circuit instead of internal R, turn on these switches.                                |
| SW4             | 4<br>5<br>6 | LCD Voltage booster circuit.                                                                                                                                                                                                                                                | Must be <b>ON</b> position. It is used for the GMS81C5108.                                                                                                                     |
|                 | 7           | Select the Stack Page.                                                                                                                                                                                                                                                      | Must be <b>OFF</b> position. This switch decide the Stack page 0 (off) or page 1 (on). <b>ON</b> : For the GMS81C7XXX <b>OFF</b> : For the GMS81C5108                          |
|                 | 8           | GMS81C5108 detect the V <sub>DD</sub> voltage but Emulator can not do because Emulator can not operate if V <sub>DD</sub> is below normal opr. voltage (5V), This switch serves LVD environment through the applying 0V to LVD pin of EVA. chip during 5V normal operation. | Position <b>ON</b> during normal operation. <b>ON</b> : Normal operation <b>OFF</b> : Force to detect the LVD, refer to "23. SUPPLY VOLTAGE DETECTION" on page 82.             |

| DIP S/W | , VR | Description                                                                            | ON/OFF Setting                                          |
|---------|------|----------------------------------------------------------------------------------------|---------------------------------------------------------|
| SW5     | 1    | Internal power supply to sub-oscillation circuit.                                      | Must be <b>ON</b> position.                             |
| OFF ON  | 2    | Reserved for other purpose.                                                            | Must be <b>OFF</b> position.                            |
| VR1     | -    | Adjust the LCD contrast. It control the VCL2 voltage. Refer to above SW4-1,2,3 figure. | Adjust the proper position as well as LCD display good. |
| VR2     | -    | Reserved for other purpose.                                                            | Don't care.                                             |

**Інциіх** GMS81C5108

### **Book History**

This Book Ver 1.0 (JUNE 2001)

First edition.

# **APPENDIX**

### A. CONTROL REGISTER LIST

| Address | Dogistor Name                          | Symbol | R/W   | Initial Value                                                                                                  | Dono |
|---------|----------------------------------------|--------|-------|----------------------------------------------------------------------------------------------------------------|------|
| Address | Register Name                          | Symbol | IX/VV | 7 6 5 4 3 2 1 0                                                                                                | Page |
| 00C0    | R0 port data register                  | R0     | R/W   | 000000000                                                                                                      | 32   |
| 00C1    | R1 port data register                  | R1     | R/W   | 000000000                                                                                                      | 32   |
| 00C2    | R2 port data register                  | R2     | R/W   | 0 0 0 0                                                                                                        | 33   |
| 00C3    | R3 port data register                  | R3     | R/W   | 0 0 0 0                                                                                                        | 33   |
| 00C8    | R0 port I/O direction register         | R0DR   | W     | 0 0 0 0 0 0 0 0                                                                                                | 32   |
| 00C9    | R1 port I/O direction register         | R1DR   | W     | 000000000                                                                                                      | 32   |
| 00CA    | R2 port I/O direction register         | R2DR   | W     | 0 0 0 0                                                                                                        | 33   |
| 00CB    | R3 port I/O direction register         | R3DR   | W     | 0 0 0 0                                                                                                        | 33   |
| 00D0    | R0 port pull-up register               | R0PU   | W     | 00000000                                                                                                       | 32   |
| 00D1    | R1 port pull-up register               | R1PU   | W     | 00000000                                                                                                       | 32   |
| 00D2    | R2 port pull-up register               | R2PU   | W     | 0 0 0 0                                                                                                        | 33   |
| 00D3    | R3 port pull-up register               | R3PU   | W     | 0 0 0 0                                                                                                        | 33   |
| 00D4    | R0 port open drain control register    | R0CR   | W     | 00000000                                                                                                       | 32   |
| 00D5    | R1 port open drain control register    | R1CR   | W     | 000000000                                                                                                      | 32   |
| 00D6    | R2 port open drain control register    | R2CR   | W     | 0 0 0 0                                                                                                        | 33   |
| 00D7    | R3 port open drain control register    | R3CR   | W     | 0 0 0 0                                                                                                        | 33   |
| 00D8    | Ext. interrupt edge selection register | IESR   | R/W   | 0 0 0 0 0 0                                                                                                    | 69   |
| 00D9    | Port selection register                | PMR    | R/W   | - 0 - 0 0 0 0 0                                                                                                | 32   |
| 00DA    | Interrupt enable low register          | IENL   | R/W   | - 0 0 0 0                                                                                                      | 65   |
| 00DB    | Interrupt enable high register         | IENH   | R/W   | - 0 0 0 0 0 0 0                                                                                                | 65   |
| 00DC    | Interrupt request flag low register    | IRQL   | R/W   | - 0 0 0 0                                                                                                      | 65   |
| 00DD    | Interrupt request flag high register   | IRQH   | R/W   | - 0 0 0 0 0 0 0                                                                                                | 65   |
| 00DE    | Sleep mode register                    | SMR    | R/W   | 0                                                                                                              | 39   |
| 00E0    | Timer 0 mode register                  | TM0    | R/W   | 0 0 0 0 0 0                                                                                                    | 45   |
|         | Timer 0 counter register               | T0     | R     | 0 0 0 0 0 0 0 0                                                                                                | 45   |
| 00E1    | Timer 0 data register                  | TDR0   | W     | 1 1 1 1 1 1 1 1                                                                                                | 45   |
|         | Timer 0 input capture register         | CDR0   | R     | 0 0 0 0 0 0 0 0                                                                                                | 45   |
| 00E2    | Timer 1 mode register                  | TM1    | R/W   | 0 0 0 0 0 0 0 0                                                                                                | 45   |
| 00E3    | Timer 1 data register                  | TDR1   | W     | 1 1 1 1 1 1 1 1                                                                                                | 45   |
| UUES    | PWM0 pulse period register             | T1PPR  | W     | 1 1 1 1 1 1 1 1                                                                                                | 45   |
|         | Timer 1 counter register               | T1     | R     | 0 0 0 0 0 0 0 0                                                                                                | 45   |
| 00E4    | Timer 1 input capture register         | CDR1   | R     | 000000000                                                                                                      | 45   |
|         | PWM0 pulse duty register               | T1PDR  | R/W   | 000000000                                                                                                      | 45   |
| 00E5    | PWM0 high register                     | PWMHR  | W     | 0 0 0 0                                                                                                        | 45   |
| 00EC    | A/D converter mode register            | ADMR   | R/W   | - 0 0 0 0 1                                                                                                    | 58   |
| 00ED    | A/D converter data register            | ADDR   | R     | $ \mathbf{x}  \mathbf{x}  \mathbf{x}  \mathbf{x}  \mathbf{x}  \mathbf{x}  \mathbf{x}  \mathbf{x}  \mathbf{x} $ | 58   |

GMS81C5108 APPENDIX hyuix

| Address | Pagiatar Nama                    | Symbol | R/W  |   | ln  | iti | al | Va | alu | ıе | ) | Dogg |
|---------|----------------------------------|--------|------|---|-----|-----|----|----|-----|----|---|------|
| Address | Register Name                    | Symbol | R/VV | 7 | 6   | 5   | 4  | 3  | 2   | 1  | 0 | Page |
| 00EF    | Watch timer mode register        | WTMR   | R/W  | - | 0   | 0   | 0  | 0  | 0   | 0  | 0 | 56   |
| 00F0    | Key scan mode register           | KSMR   | R/W  | 0 | 0   | 0   | 0  | 0  | 0   | 0  | 0 | 70   |
| 00F1    | LCD control register             | LCR    | R/W  | 0 | 0   | 0   | 0  | 0  | 0   | 0  | 0 | 72   |
| 00F3    | RAM paging register              | RPR    | R/W  | - | •   | -   | -  | -  | -   | 0  | 0 | 73   |
| 00F4    | Basic interval timer register    | BITR   | R    | 0 | 0   | 0   | 0  | 0  | 0   | 0  | 0 | 43   |
| 00F4    | Clock control register           | CKCTLR | W    | - | - 1 | -   | -  | 0  | 1   | 1  | 1 | 43   |
| 00F5    | System clock mode register       | SCMR   | R/W  | 0 | 0   | 0   | 0  | 0  | 0   | 0  | 0 | 34   |
| 00F6    | Remocon mode register            | RMR    | R/W  | - | 0   | 0   | 0  | 0  | 0   | 0  | 0 | 76   |
| 00F7    | Carrier frequency high selection | CFHS   | W    | - | - 1 | 1   | 1  | 1  | 1   | 1  | 1 | 76   |
| 00F8    | Carrier frequency low selection  | CFLS   | W    | - | -   | 1   | 1  | 1  | 1   | 1  | 1 | 76   |
| 00F9    | Remocon data high register       | RDHR   | W    | 1 | 1   | 1   | 1  | 1  | 1   | 1  | 1 | 76   |
| 00FA    | Remocon data low register        | RDLR   | W    | 1 | 1   | 1   | 1  | 1  | 1   | 1  | 1 | 76   |
| UUFA    | Remocon data counter             | RDC    | R    | 0 | 0   | 0   | 0  | 0  | 0   | 0  | 0 | 76   |
| 00FB    | Remocon output data register     | RODR   | R/W  | - | -   | -   | -  | -  | -   | -  | 0 | 76   |
| 00FC    | Remocon output buffer            | ROB    | R/W  | - | -   | -   | -  | -  | -   |    | 0 | 76   |
| 00FD    | Buzzer data register             | BDR    | W    | 0 | 0   | 0   | 0  | 0  | 0   | 0  | 0 | 60   |
| 00FE    | Serial I/O mode register         | SIOM   | R/W  | 0 | 0   | 0   | 0  | 0  | 0   | 0  | 1 | 62   |
| 00FF    | Serial I/O data register         | SIOD   | R/W  | Х | х   | х   | х  | х  | х   | х  | х | 62   |

### **B. INSTRUCTION**

### **B.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                                                             |
| <i>≠</i>          | Not Equal                                                         |

JUNE 2001 Ver 1.0 iii

### **B.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,rel | ADC<br>#imm    | ADC<br>dp   | ADC<br>dp+X | ADC<br>!abs | ASL<br>A    | ASL<br>dp   | TCALL<br>0  | SETA1<br>.bit | BIT<br>dp   | POP<br>A     | PUSH<br>A   | BRK            |
| 001         | CLRC  |                |                  |                   | SBC<br>#imm    | SBC<br>dp   | SBC<br>dp+X | SBC<br>!abs | ROL<br>A    | ROL<br>dp   | TCALL<br>2  | CLRA1         | COM<br>dp   | POP<br>X     | PUSH<br>X   | BRA<br>rel     |
| 010         | CLRG  |                |                  |                   | CMP<br>#imm    | CMP<br>dp   | CMP<br>dp+X | CMP<br>!abs | LSR<br>A    | LSR<br>dp   | TCALL<br>4  | NOT1<br>M.bit | TST<br>dp   | POP<br>Y     | PUSH<br>Y   | PCALL<br>Upage |
| 011         | DI    |                |                  |                   | OR<br>#imm     | OR<br>dp    | OR<br>dp+X  | OR<br>!abs  | ROR<br>A    | ROR<br>dp   | TCALL<br>6  | OR1<br>OR1B   | CMPX<br>dp  | POP<br>PSW   | PUSH<br>PSW | RET            |
| 100         | CLRV  |                |                  |                   | AND<br>#imm    | AND<br>dp   | AND<br>dp+X | AND<br>!abs | INC<br>A    | INC<br>dp   | TCALL<br>8  | AND1<br>AND1B | CMPY<br>dp  | CBNE<br>dp+X | TXSP        | INC<br>X       |
| 101         | SETC  |                |                  |                   | EOR<br>#imm    | EOR<br>dp   | EOR<br>dp+X | EOR<br>!abs | DEC<br>A    | DEC<br>dp   | TCALL<br>10 | EOR1<br>EOR1B | DBNE<br>dp  | XMA<br>dp+X  | TSPX        | DEC<br>X       |
| 110         | SETG  |                |                  |                   | LDA<br>#imm    | LDA<br>dp   | LDA<br>dp+X | LDA<br>!abs | TXA         | LDY<br>dp   | TCALL<br>12 | LDC<br>LDCB   | LDX<br>dp   | LDX<br>dp+Y  | XCN         | DAS            |
| 111         | EI    |                |                  |                   | LDM<br>dp,#imm | STA<br>dp   | STA<br>dp+X | STA<br>!abs | TAX         | STY<br>dp   | TCALL<br>14 | STC<br>M.bit  | STX<br>dp   | STX<br>dp+Y  | XAX         | STOP           |

|             |             | 1              | 1                | 1                 | 1           |               |               |               | 1           | 1           | 1           |              |              |             |              |               |
|-------------|-------------|----------------|------------------|-------------------|-------------|---------------|---------------|---------------|-------------|-------------|-------------|--------------|--------------|-------------|--------------|---------------|
| 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<br>{X}  | STA<br>!abs+Y | STA<br>[dp+X] | STA<br>[dp]+Y | STY<br>!abs | STY<br>dp+X | TCALL<br>15 | STA<br>{X}+  | STX<br>!abs  | CBNE<br>dp  | XYX          | NOP           |

### **B.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           | <u> </u>                                          |                  |
| 20  | ASL !abs     | 18         | 3          | 5           |                                                   |                  |
| 21  | CMP #imm     | 44         | 2          | 2           |                                                   |                  |
| 22  | CMP dp       | 45         | 2          | 3           |                                                   |                  |
| 23  | CMP dp + X   | 46         | 2          | 4           |                                                   |                  |
| 24  | CMP !abs     | 47         | 3          | 4           | Compare accumulator contents with memory contents | NZC              |
| 25  | CMP !abs + Y | 55         | 3          | 5           | (A)-(M)                                           |                  |
| 26  | CMP [dp + X] | 56         | 2          | 6           |                                                   |                  |
| 27  | CMP [dp]+Y   | 57         | 2          | 6           |                                                   |                  |
| 28  | CMP {X}      | 54         | 1          | 3           |                                                   |                  |
| 29  | CMPX #imm    | 5E         | 2          | 2           | Compare X contents with memory contents           |                  |
| 30  | CMPX dp      | 6C         | 2          | 3           | (X)-(M)                                           | NZC              |
| 31  | CMPX !abs    | 7C         | 3          | 4           |                                                   |                  |
| 32  | CMPY #imm    | 7E         | 2          | 2           | Compare Y contents with memory contents           |                  |
| 33  | CMPY dp      | 8C         | 2          | 3           | (Y)-(M)                                           | NZC              |
| 34  | CMPY !abs    | 9C         | 3          | 4           |                                                   |                  |
| 35  | COM dp       | 2C         | 2          | 4           | 1'S Complement : ( dp ) ← ~( dp )                 | NZ-              |
| 36  | DAA          | DF         | 1          | 3           | Decimal adjust for addition                       | NZC              |
| 37  | DAS          | CF         | 1          | 3           | Decimal adjust for subtraction                    | NZC              |
| 38  | DEC A        | A8         | 1          | 2           | Decrement                                         | NZ-              |
| 39  | DEC dp       | A9         | 2          | 4           | M ← (M)-1                                         | NZ-              |
| 40  | DEC dp + X   | В9         | 2          | 5           |                                                   | NZ-              |
| 41  | DEC !abs     | B8         | 3          | 5           |                                                   | NZ-              |
| 42  | DEC X        | AF         | 1          | 2           |                                                   | NZ-              |
| 43  | DEC Y        | BE         | 1          | 2           |                                                   | NZ-              |

| No. | Mnemonic             | Op<br>Code | Byte<br>No | Cycle<br>No | Operation                                                                           | Flag<br>NVGBHIZC |
|-----|----------------------|------------|------------|-------------|-------------------------------------------------------------------------------------|------------------|
| 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]         | В6         | 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           |                                                                                     | 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           |                                                                                     | 14 2             |
| 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           |                                                                                     |                  |
| 73  | ROL dp               | 29         | 2          | 4           | Rotate left through Carry                                                           | NZC              |
| 74  | ROL dp + X           |            |            | 5           | C 7 6 5 4 3 2 1 0 ← ← ← ← ← ← ← ← ← ←                                               | NZC              |
| 75  | ROL labs             | 39         | 3          | 5           |                                                                                     |                  |
| 76  | ROR A                |            | 1          |             |                                                                                     |                  |
| 77  | ROR dp               | 68         |            | 4           | Rotate right through Carry                                                          | N 70             |
|     | ·                    |            | 2          |             | 7 6 5 4 3 2 1 0 C<br>→ → → → → → → → → — —                                          | NZC              |
| 78  | ROR dp + X           | 79         | 2          | 5           |                                                                                     |                  |
| 79  | ROR !abs<br>SBC #imm | 78         | 3          | 5           | Subtract with Corn                                                                  |                  |
| 80  |                      | 24         | 2          | 2           | Subtract with Carry                                                                 |                  |
| 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 <sub>H</sub>                 | NZ-              |
| 89  | XCN                  | CE         | 1          | 5           | Exchange nibbles within the accumulator $A_7 \sim A_4 \leftrightarrow A_3 \sim A_0$ | NZ-              |

### **Register / Memory Operation**

| No.      | Mnemonic      | Op<br>Code | Byte<br>No | Cycle<br>No | Operation                                                                                                                      | Flag<br>NVGBHIZC |
|----------|---------------|------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|------------------|
| 1        | LDA #imm      | C4         | 2          | 2           | Load accumulator                                                                                                               |                  |
| 2        | LDA dp        | C5         | 2          | 3           | A ← ( 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 ← (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 ← ( M )                                                                                                                      | NZ-              |
| 17       | LDY dp + X    | D9         | 2          | 4           | ()                                                                                                                             |                  |
| 18       | LDY labs      | 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 labs      | FC         | 3          | 5           | ( W ) ← X                                                                                                                      |                  |
| 30       | STY dp        | E9         | 2          | 4           | Store Y-register contents in memory                                                                                            |                  |
| 31       | STY dp + X    | F9         | 2          | 5           | (M) ← Y                                                                                                                        |                  |
| 32       | STY labs      | F8         | 3          | 5           | ( W ) ← 1                                                                                                                      |                  |
| 33       | TAX           | E8         | 1          | 2           | Transfer accumulator contents to X-register : X ← A                                                                            | NZ-              |
| 34       | TAY           | 9F         | 1          | 2           | Transfer accumulator contents to X-register : $X \leftarrow A$                                                                 |                  |
|          | TSPX          |            | 1          |             | <del> </del>                                                                                                                   | NZ-              |
| 35       |               | AE         |            | 2           | Transfer X register contents to X-register: X ← sp                                                                             |                  |
| 36       | TXA           | C8         | 1          | 2           | Transfer X register contents to accumulator: A ← X                                                                             | NZ-              |
| 37<br>38 | TXSP<br>TYA   | 8E<br>BF   | 1          | 2           | Transfer X-register contents to stack-pointer: $sp \leftarrow X$ Transfer Y-register contents to accumulator: $A \leftarrow Y$ | NZ-              |
|          |               |            |            | 2           |                                                                                                                                | NZ-              |
| 39       | XAX           | EE         | 1          | 4           | Exchange X-register contents with accumulator :X \iff A                                                                        |                  |
| 40       | XAY           | DE         | 1          | 4           | Exchange Y-register contents with accumulator :Y ↔ A                                                                           |                  |
| 41       | XMA dp        | BC         | 2          | 5           | Exchange memory contents with accumulator                                                                                      |                  |
| 42       | XMA dp+X      | AD         | 2          | 6           | ( M ) ↔ A                                                                                                                      | NZ-              |
| 43       | XMA {X}       | BB         | 1          | 5           |                                                                                                                                |                  |
| 44       | XYX           | FE         | 1          | 4           | Exchange X-register contents with Y-register : $X \leftrightarrow Y$                                                           |                  |

JUNE 2001 Ver 1.0 vii

### 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<br>( dp+1)( dp) ← ( 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 .bit)$                               | C                |
| 14  | NOT1 M.bit  | 4B         | 3          | 5           | Bit complement : $(M.bit) \leftarrow \sim (M.bit)$                                |                  |
| 15  | OR1 M.bit   | 6B         | 3          | 5           | Bit OR C-flag : $C \leftarrow (C) \lor (M .bit)$                                  | C                |
| 16  | OR1B M.bit  | 6B         | 3          | 5           | Bit OR C-flag and NOT : C $\leftarrow$ ( C ) $\vee$ $\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 ) $\wedge$ ~( A ) | NZ-              |
| 23  | TSET1 !abs  | 3C         | 3          | 6           | Test and set bits with A:<br>A-(M), (M) $\leftarrow$ (M) $\vee$ (A)               | NZ-              |

viii JUNE 2001 Ver 1.0

### **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 \leftarrow (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        | F0         | 2          | 2/4         | Branch if equal if (Z) = 1, then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                                   |                  |
| 8   | BMI rel        | 90         | 2          | 2/4         | Branch if minus if (N) = 1, then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                                   |                  |
| 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{array}{c} 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{array} $ |                  |
| 16  | CBNE dp,rel    | FD         | 3          | 5/7         | Compare and branch if not equal :                                                                                                                                                                                                                                                             |                  |
| 17  | CBNE dp+X,rel  | 8D         | 3          | 6/8         | if $(A) \neq (M)$ , then $pc \leftarrow (pc) + rel$ .                                                                                                                                                                                                                                         |                  |
| 18  | DBNE dp,rel    | AC         | 3          | 5/7         | Decrement and branch if not equal :                                                                                                                                                                                                                                                           |                  |
| 19  | DBNE Y,rel     | 7B         | 2          | 4/6         | if $(M) \neq 0$ , then $pc \leftarrow (pc) + rel$ .                                                                                                                                                                                                                                           |                  |
| 20  | JMP !abs       | 1B         | 3          | 3           | Unconditional jump                                                                                                                                                                                                                                                                            |                  |
| 21  | JMP [!abs]     | 1F         | 3          | 5           | pc ← jump address                                                                                                                                                                                                                                                                             |                  |
| 22  | JMP [dp]       | 3F         | 2          | 4           |                                                                                                                                                                                                                                                                                               |                  |
| 23  | PCALL upage    | 4F         | 2          | 6           | $\label{eq:continuous} \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 (\text{pc}_{\text{H}}), \ \text{sp} \leftarrow \text{sp-1}, \\ & \text{M(s)} \leftarrow (\text{pc}_{\text{L}}), \text{sp} \leftarrow \text{sp} - 1, \text{M(sp)} \leftarrow (\text{PSW}), \text{sp} \leftarrow \text{sp} - 1, \\ & \text{pc}_{\text{L}} \leftarrow (\text{ OFFDE}_{\text{H}}), \ \text{pc}_{\text{H}} \leftarrow (\text{ OFFDF}_{\text{H}}). \end{split}$ | 1-0              |
| 2   | DI       | 60         | 1          | 3           | Disable all interrupts : I ← "0"                                                                                                                                                                                                                                                                                                                                                                                                                                | 0                |
| 3   | EI       | 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 ) ← X , sp ← sp - 1                                                                                                                                                                                                                                                                                                                                                                                                                                       |                  |
| 11  | PUSH Y   | 4E         | 1          | 4           | $M(sp) \leftarrow Y, sp \leftarrow sp - 1$                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |
| 12  | PUSH PSW | 6E         | 1          | 4           | M( sp ) ← PSW , sp ← 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)$                                                                                                                                                                                                                                                                                                                                                 |                  |
| 14  | RETI     | 7F         | 1          | 6           | $\begin{aligned} & \text{Return from interrupt} \\ & \text{sp} \leftarrow \text{sp +1, } \text{ PSW} \leftarrow \text{M( sp ), sp} \leftarrow \text{sp + 1,} \\ & \text{pc}_L \leftarrow \text{M( sp ), sp} \leftarrow \text{sp + 1, } \text{pc}_H \leftarrow \text{M( sp )} \end{aligned}$                                                                                                                                                                     | restored         |
| 15  | STOP     | EF         | 1          | 3           | Stop mode ( halt CPU, stop oscillator )                                                                                                                                                                                                                                                                                                                                                                                                                         |                  |

#### C. MASK ORDER SHEET MASK ORDER & VERIFICATION SHEET GMS81C5108- UD Customer should write inside thick line box. 1. Customer Information 2. Device Information 80QFP Package Company Name **ROM Size** 8K Application **OSC Option** Crystal R Reset Pull Up YES NO Order Date Hitel Chollian Internet Tel: Fax: .OTP) File Name : ( Check Sum: ( E-mail address: 0000<sub>H</sub> Mask Data Name & Signature: Set "00" in this area DFFF<sub>⊢</sub> E000<sub>H</sub> .OTP file data **FFFF**<sub>H</sub> **3. Marking Specification** (*Please check mark into* $\square$ ) ициіх Customer's Area GMS81C5108-UD □ GMS81C5108-UD YYWW KOREA YYWW KOREA 0 0 If the customer logo & part number must be used in this area, please submit a clean original logo & part number. 4. Delivery Schedule Date Quantity **HYNIX Confirmation** YYYY DD Customer sample pcs ММ DD Risk order pcs 5. ROM Code Verification Please confirm out verification data. MM חח MM חח Approval date: Verification date: Check sum: I agree with your verification data and confirm you to make mask set. Tel: Fax: Fax: E-mail address: E-mail address: Name & Name & Signature: Signature:

