## ABOV SEMICONDUCTOR Co. Ltd. 8-BIT SINGLE-CHIP MICROCONTROLLERS

## MC80F7708

User's Manual (Ver. 1.0)



#### **REVISION HISTORY**

#### VERSION 1.0 (April 1, 2008) This Book

Corrected PSW(NVGBHIZC) for "INC A" instruction from N-----Z- at " Arithmetic / Logic Operation" on page iv.

VERSION 0.7 (OCT 17, 2007)

Modify CTR(Contrast Controller Level Selection ) in Figure 18-3 LCD Bias Control

VERSION 0.6 (MAY 02, 2007)

Modify FLASH memory endurance: 1000 cycles to 100 cycles (page 1).

VERSION 0.5 (APR 09, 2007)

Remove P-MOS protection diode of LCD SEG or COM pin(R50~R57, R60~R67, R70~R77) in page 13.

Add R7, R4, R4IO, R4OD and R4PU registers to "Table 8-1 Control Registers". (page 27, 28)

Fix reset value of R4OD and R4PUfrom 00-0--0-B to -000000-B and 0000000-B. (page 37)

Change R6IO(0CDh) to R7IO(0B4h) and add R74 ~ R75 in R7 port decribing Figure(page 38)

Modify BIRR description in "Figure 24-1 Block Diagram of BIR (Built-In Reset)". (page 97)

The information contained in this book is not confirmed, just preliminary

### VERSION 0.4 (MAR 29, 2007)

Remove description on sub-active mode: deleting sub clock from clock source (page 39, 40, 41, 44, 47, 48, 50, 52, 53, 55, 56, 57, 60, 66, 67, 89, 90)

Add Isub parameter to Update DC electrical characteristics (page 15) and update ADC characteristics. (page 16)

Add internal 8/4/2MHz oscillation to figure 10-1 and modify description in chapter 10. (page 39)

#### VERSION 0.3 (MAR. 2007)

Add T<sub>VDD</sub> parameter specification and change T<sub>POR</sub> in DC Electrical Characteristics.

Note for configuration option is added and fix some errata.

### Version 1.0

Published by

**FAE Team** 

## ©2007 ABOV Semiconductor Co., Ltd. All rights reserved.

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

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

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



| 1. OVERVIEW                        | 1  | BRK Interrupt                                | 72       |
|------------------------------------|----|----------------------------------------------|----------|
| Description                        | 1  | Multi Interrupt                              | 72       |
| Features                           | 1  | External Interrupt                           | 74       |
| Development Tools                  | 3  | 18. LCD DRIVER                               | 75       |
| Ordering Information               | 4  | Control of LCD Driver Circuit                | 76       |
| 2. BLOCK DIAGRAM                   | 5  | LCD BIAS Control                             | 78       |
| 3. PIN ASSIGNMENT                  | 6  | LCD Display Memory                           | 79       |
| 4. PACKAGE DIAGRAM                 |    | Control Method of LCD Driver                 |          |
| 5. PIN FUNCTION                    |    | Duty and Bias Selection of LCD Driver        |          |
| 6. PORT STRUCTURES                 |    | 19. UNIVERSAL ASYNCHRONOUS SERIA TERFACE     |          |
| 7. ELECTRICAL CHARACTERISTICS      | 14 | Asynchronous Serial Interface Configurat     | ion 84   |
| Absolute Maximum Ratings           | 14 | Relationship between main clock and bau      | d rate . |
| Recommended Operating Conditions   | 14 | 87                                           |          |
| DC Electrical Characteristics      | 15 | 20. OPERATION MODE                           | 88       |
| LCD Characteristics                |    | Operation Mode Switching                     | 88       |
| A/D Converter Characteristics      |    | 21. POWER DOWN OPERATION                     | 89       |
| AC Characteristics                 |    | SLEEP Mode                                   | 89       |
| Typical Characteristics            |    | STOP Mode                                    | 90       |
| 8. MEMORY ORGANIZATION             |    | 22. OSCILLATOR CIRCUIT                       | 94       |
| Registers                          |    | 23. RESET                                    |          |
| Program Memory                     |    | External Reset Input                         |          |
| Data Memory                        |    | Power On Reset                               |          |
| Addressing Mode                    | 30 | Built In Reset                               |          |
| 9. I/O PORTS                       | 34 | Watchdog Timer Reset                         |          |
| Registers for Ports                | 34 | 24. Butil In Reset (BIR)                     |          |
| I/O Ports Configuration            | 35 | 25. Osillation Noise Protector               |          |
| 10. CLOCK GENERATOR                | 39 | 26. FLASH PROGRAMMING SPEC                   |          |
| 11. BASIC INTERVAL TIMER           | 41 | FLASH Configuration Byte                     |          |
| 12. TIMER / COUNTER                | 43 | FLASH Programming                            |          |
| 8-Bit Timer/Counter Mode           | 47 |                                              |          |
| 16 Bit Timer/Counter Mode          | 49 | 27. EMULATOR EVA. BOARD SETTING              |          |
| 8-Bit Capture Mode                 | 51 | 28. IN-SYSTEM PROGRAMMING                    |          |
| 16-bit Capture Mode                |    | Getting Started / Installation               |          |
| 8-Bit (16-Bit) Compare Output Mode |    | Basic ISP S/W Information                    |          |
| PWM Mode                           | 56 | Hardware Conditions to Enter the ISP Mo      |          |
| 13. WATCH TIMER                    | 59 | Sequence to enter ISP mode/user mode         |          |
| 14. WATCH DOG TIMER                | 61 | Difference between auto baud rate and A mode |          |
| 15. ANALOG TO DIGITAL CONVERTER    | 63 | Reference ISP Circuit Diagram and ABO\       | •        |
| 16. BUZZER OUTPUT FUNCTION         | 66 | plied ISP Board                              |          |
| 17. INTERRUPTS                     | 68 | Terminology List                             |          |
| Interrupt Sequence                 | 71 | Instruction Map                              | iii      |
|                                    |    | Instruction Set                              | iv       |





## MC80F7708

# CMOS SINGLE-CHIP 8-BIT MICROCONTROLLER WITH LCD CONTROLLER/DRIVER

### 1. OVERVIEW

### 1.1 Description

The MC80F7708 are an advanced CMOS 8-bit microcontroller with 8K bytes of FLASH ROM(MTP). This device is one of the MC800 family and a powerful microcontroller which provides a high flexibility and cost effective solution to many LCD applications. The MC80F7708 provide the following standard features: 8K bytes of FLASH ROM, 256 bytes of RAM, 20 bytes of segment LCD display RAM, 8/16-bit timer/counter, 10-bit A/D converter, 7-bit watch dog timer, 21-bit watch timer with 7-bit auto reload counter, 8-bit UART, on-chip oscillator and clock circuitry. In addition, this device supports power saving modes to reduce power consumption. So the MC80F7708 is the best controller solution in system which uses charatered LCD display and ADC.

| Device name | Men<br>(By | nory<br>tes) | ADC  | DC PWM | UART | I/O | LCD                            | Operating<br>Voltage | Package |
|-------------|------------|--------------|------|--------|------|-----|--------------------------------|----------------------|---------|
|             | ROM        | RAM          |      |        |      |     |                                |                      |         |
| MC80F7708Q  | 8K         | 256          | 6ch. | 1ch.   | 1ch. | 42  | 16SEG x 8COM<br>(20SEG x 4COM) | 2.2 ~ 5.5V           | 44MQFP  |
| MC80F7708K  | 8K         | 256          | 4ch. | 1ch.   | 1ch. | 40  | 16SEG x 8COM<br>(20SEG x 4COM) | 2.2 ~ 5.5V           | 42SDIP  |

#### 1.2 Features

• 8K Bytes On-chip FLASH ROM (MTP)

FLASH Memory

Endurance : 100 cyclesData Retention : 10 years

256 Bytes On-chip Data RAM

- 20 bytes Display RAM
- Instruction Cycle Time:
  - 333ns at 12MHz (2 cycle NOP instruction)
- · LCD display/controller
  - 1/4 Duty Mode (20Seg × 4Com, 1/3 Bias)
  - 1/8 Duty Mode (16Seg × 8Com, 1/4 Bias)
- Four 8-bit Timer/Counter

(They can be used as two 16-bit Timer/Counter)

- One 7-bit Watch Dog Timer
- One 21-bit Watch Timer
  - 1 minute interrupt available

- · One 8-bit Basic Interval Timer
- · One 6-bit Buzzer Driving Port
- Dual Clock Operation

Main Clock: 400kHz ~ 12MHzSub Clock: 32.768kHz

- Main Clock Oscillation
  - Crystal
  - Ceramic Resonator
  - Internal Oscillation: 8MHz/4MHz/2MHz
- Operating Temperature : -40~85 °C
- Built-in Noise Immunity Circuit
  - Noise Filter
  - BIR (Built-in Reset)
- Power Down Mode
  - Main Clock: STOP, SLEEP mode
- 400kHz to 12MHz Wide Operating Frequency
- · On-Chip POR (Power On Reset)



- Internal Resistor for LCD Bias
- 42/40 Programmable I/O Pins

| MC80F7708Q | I/O: 17<br>I : 1<br>I/O with SEG/COM:24 |
|------------|-----------------------------------------|
| MC80F7708K | I/O: 15<br>I : 1<br>I/O with SEG/COM:24 |

## • 6/4-channel 10-bit On-chip A/D Converter

| MC80F7708Q | 6-channel ADC |
|------------|---------------|
| MC80F7708K | 4-channel ADC |

• One 10-bit High Speed PWM Output

### • 14 Interrupt sources

- External Interrupt : 4

- Timer : 4 - UART : 2

- ADC, WDT, WT, BIT

- One Universal Asynchronous Receiver/Transmitter (UART) at FLASH MCU
- 2.2V to 5.5V Wide Operating Voltage Range
- 44MQFP, 42SDIP Package Types
  - Available Pb free package

| MC80F7708Q | 44MQFP |
|------------|--------|
| MC80F7708K | 42SDIP |



## 1.3 Development Tools

The MC80F7708 are supported by a full-featured macro assembler, an in-circuit emulator CHOICE-Dr. TM and OTP programmers. There are two different type of programmers such as single type and gang type. For mode detail, Macro assembler operates under the MS-Windows 95 and upversioned Windows OS. And HMS800C compiler only operates under the MS-Windows 2000 and upversioned Windows OS.

Please contact sales part of ABOV semiconductor.

| Software               | - MS-Windows based assembler<br>- MS-Windows based Debugger<br>- MC800 C compiler                                 |
|------------------------|-------------------------------------------------------------------------------------------------------------------|
| Hardware<br>(Emulator) | - CHOICE-Dr.<br>- CHOICE-Dr. EVA80C77x B/D                                                                        |
| POD Name               | - CHPOD80C77D-42SD<br>- POD80C77D-44MQ-1010                                                                       |
| FLASH Writer           | - CHOICE - SIGMA II(Single writer) - PGM Plus II(+socket)/III(Single writer) - Standalone GANG4 I/II(Gang writer) |



PGMplus III (Single Writer)



Choice-Dr. (Emulator)



Standalone Gang4 II ( Gang Writer )



## 1.4 Ordering Information

| Device name | ROM Size       | RAM size  | Package |
|-------------|----------------|-----------|---------|
| MC80F7708Q  | 8K bytes FLASH | 256 bytes | 44MQFP  |
| MC80F7708K  | 8K bytes FLASH | 256 bytes | 42SDIP  |

<sup>-</sup> Pb free package;

The "P" suffix will be added at original part number.

For example; MC80F7708Q(Normal package), MC80F7708Q P(Pb free package)



## 2. BLOCK DIAGRAM



\*R24/AN3 and R25/AN5 are not supported in MC80F7708K(42pin).

MC80F7708Q : R20/AN0 ~ R25/AN5 MC80F7708K : R20/AN0 ~ R23/AN3



#### 3. PIN ASSIGNMENT





\*R24/AN3 and R25/AN5 are not not supported in MC80F7708K(42pin).



## 4. PACKAGE DIAGRAM





### 5. PIN FUNCTION

**V**<sub>**DD**</sub>: Supply Voltage.

Vss: Circuit ground.

**RESET:** Reset the MCU Reset.

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

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

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

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

**SEG0~SEG19:** Segment signal output pins for the LCD display. See "18. LCD DRIVER" on page 75 for details. Also SEG0~SEG19 are shared with normal I/O ports and SEG16~19 are multiplexed with COM7~COM4.

**COM0~COM7:** Common signal output pins for the LCD display. See "18. LCD DRIVER" on page 75 for details. Also COM0~SEG7 are shared with normal I/O ports and COM4~COM7 are multiplexed with SEG19~SEG16.

COM4~COM7 and SEG19~SEG16 are selected by LCDD0 of the LCR register.

| LCDD0 COM4~COM7 / SEG19~SEG16 |               |
|-------------------------------|---------------|
| 0                             | COM4 ~ COM7   |
| 1                             | SEG19 ~ SEG16 |

**R01, R04, R06, R07:** R0 is a 4-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 open-drain outputs can be assigned by software.

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

| Port pin | Alternate function                        |  |
|----------|-------------------------------------------|--|
| R01      | EC0 (Timer 0 Event Count Input)           |  |
| R04      | BUZO (Buzzer Output)                      |  |
| R06      | INT0 (External Interrupt 0 Request Input) |  |
| R07      | INT1 (External Interrupt 1 Request input) |  |

**R10 :** R1 is an 1-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, pull-up resistors and open-drain outputs can be assigned by software.

In addition, R1 serves the function of the following special feature.

| Port pin | Alternate function                              |
|----------|-------------------------------------------------|
| R10      | PWM1/T2O<br>(Timer3 PWM Output / Timer2 Output) |

**R20~R25:** R2 is a 4/6-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 open-drain 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) |
| R24      | AN4 (Analog Input Port4) |
| R25      | AN5 (Analog Input Port5) |

**Note:** R24/AN3 and R25/AN5 are not not supported in MC80F7708K(42pin).

**R41~R47:** R4 is a 7-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, R4 serves the functions of the various following special features.

| Port pin | Alternate function                        |
|----------|-------------------------------------------|
| R41      | INT2 (External Interrupt 2 Request input) |
| R42      | X <sub>OUT</sub>                          |
| R43      | X <sub>IN</sub>                           |
| R44      | INT3 (External Interrupt 3 Request input) |
| R45      | SXIN                                      |
| R46      | SX <sub>OUT</sub>                         |
| R47      | RESET                                     |

**R50~R57:** R5 is an 8-bit CMOS bidirectional I/O port or LCD segment output. Each pins 1 or 0 written to the Port Direction Register can be used as outputs or inputs. And each pins can also be set in segment output mode in 1-bit



units by R5PSR Register.

| Port pin | Alternate function            |
|----------|-------------------------------|
| R50      | SEG0 (Segment Output 0) / RX0 |
| R51      | SEG1 (Segment Output 1) / TX0 |
| R52      | SEG2 (Segment Output 2) / ACK |
| R53      | SEG3 (Segment Output 3)       |
| R54      | SEG4 (Segment Output 4)       |
| R55      | SEG5 (Segment Output 5)       |
| R56      | SEG6 (Segment Output 6)       |
| R57      | SEG7 (Segment Output 7)       |

**R60~R67:** R6 is an 8-bit CMOS bidirectional I/O port or LCD segment output. Each pins 1 or 0 written to the Port Direction Register can be used as outputs or inputs. And each pins can also be set in segment output mode in 1-bit units by R6PSR Register.

| Port pin | Alternate function        |
|----------|---------------------------|
| R60      | SEG8 (Segment Output 8)   |
| R61      | SEG9 (Segment Output 9)   |
| R62      | SEG10 (Segment Output 10) |
| R63      | SEG11 (Segment Output 11) |
| R64      | SEG12 (Segment Output 12) |
| R65      | SEG13 (Segment Output 13) |
| R66      | SEG14 (Segment Output 14) |
| R67      | SEG15 (Segment Output 15) |

**R70~R77:** R7 is a 4-bit CMOS input port or LCD segment output. Each pins can be set in digital input or segment output mode in 1-bit units by R7PSR Registe

r.

| Port pin | Alternate function         |
|----------|----------------------------|
| R70      | SEG16 (Segment Output 0) / |
|          | COM7 (Common Output 7) /   |
| R71      | SEG17 (Segment Output 1) / |
|          | COM6 (Common Output 6) /   |
| R72      | SEG18 (Segment Output 2) / |
|          | COM5 (Common Output 5) /   |
| R73      | SEG19 (Segment Output 3) / |
|          | COM4 (Common Output 4)     |
| R74      | COM3 (Common Output 3)     |
| R75      | COM2 (Common Output 2)     |
| R76      | COM1 (Common Output 1)     |
| R77      | COM0 (Common Output 0)     |



| PIN NAME                                         | Pin No.    |            | Primary Function |                            |     | Secondary<br>Function                                   | State<br>@ Reset | State<br>@ STOP            |
|--------------------------------------------------|------------|------------|------------------|----------------------------|-----|---------------------------------------------------------|------------------|----------------------------|
|                                                  | MC80F7708Q | MC80F7708K | I/O              | Description                | I/O | Description                                             | @ Reset          | @ 510P                     |
| V <sub>DD</sub>                                  | 3          | 8          | -                | Supply Voltage             | -   | -                                                       | -                | -                          |
| V <sub>SS</sub>                                  | 4          | 9          | -                | Circuit Ground             | -   | -                                                       | -                | -                          |
| RESET / R47                                      | 11         | 16         | I                | Reset (low active)         | -   | -                                                       | 'L' input        | 'H' input                  |
| X <sub>IN</sub> /R43,<br>X <sub>OUT</sub> /R42   | 7,6        | 12,11      | I,O              | Main clock oscilla-<br>tor | -   | -                                                       | Oscillation      | 'L', 'H'                   |
| SX <sub>IN</sub> /R45,<br>SX <sub>OUT</sub> /R46 | 9,10       | 14,15      | I,O              | Sub clock oscillator       | -   | -                                                       | Oscill           | ation                      |
| R53/SEG3 ~<br>R57/SEG7                           | 17~21      | 22~26      | I/O              | General I/O port           | 0   | LCD segment output                                      | Input port       |                            |
| R60/SEG8 ~<br>R67/SEG15                          | 22~29      | 27~34      | I/O              | General I/O port           | 0   | LCD segment output                                      |                  |                            |
| R70/SEG16/<br>COM7 ~<br>R73/SEG19/<br>COM4       | 30~33      | 35~38      | I/O              | General I/O ports          | 0   | LCD segment<br>output<br>LCD common<br>output           |                  |                            |
| R74/COM3 ~<br>R77/COM0                           | 34~37      | 39~42      | I/O              | General I/O ports          | 0   | LCD common output                                       |                  |                            |
| R01/EC0                                          | 44         | 5          | I/O              |                            | I   | Event Counter<br>Input                                  |                  |                            |
| R04/BUZO                                         | 2          | 7          | I/O              |                            | 0   | Buzzer Output                                           |                  |                            |
| R06/INT0                                         | 1          | 6          | I/O              |                            | I   | Interrupt Input                                         |                  |                            |
| R07/INT1                                         | 12         | 17         | I/O              |                            | I   | Interrupt Input                                         |                  |                            |
| R10/PWM1/<br>T2O                                 | 13         | 18         | I/O              | General I/O port           | 0   | Timer3 PWM<br>Output<br>Timer2 Output                   |                  | State of<br>before<br>STOP |
| R20/AN0 ~<br>R23/AN3                             | 43~40      | 4~1        | I/O              |                            | I   | A/D Converter<br>Analog Input                           |                  |                            |
| R24/AN4 ~<br>R25/AN5                             | 39,38      | -          | I/O              |                            | I   | A/D Converter<br>Analog Input                           |                  |                            |
| R50/SEG0/RX0                                     | 14         | 19         | I/O              | General I/O ports          | 0   | LCD Segment<br>Output<br>UART0 Data<br>Input            |                  |                            |
| R51/SEG1/TX0                                     | 15         | 20         | I/O              | General I/O ports          | 0   | LCD Segment<br>Output<br>UART0 Data<br>Output           |                  |                            |
| R52/SEG2/ACK                                     | 16         | 21         | I/O              | General I/O ports          | 0   | LCD Segment<br>Output<br>UART0 external<br>clock intput |                  |                            |

**Table 5-1 Port Function Description** 



## 6. PORT STRUCTURES

## R01/EC0, R06/INT0, R07/INT1, R41/IN2, R44/INT3



## R04/BUZO, R10/PWM1/T2O



## R20/AN0~R23/AN3, R24/AN4~R25/AN5



**Note:** R24/AN4 and R25/AN5 are available to MC80F7708Q.

## RESET(R47)





## XIN, XOUT (Crystal or Ceramic resonator)



## $X_{IN}, X_{OUT} (@RC, R)$



## $SX_{IN}$ , $SX_{OUT}$



## R43 (X<sub>IN</sub>), R42 (X<sub>OUT</sub>)





## R53/SEG3~R57/SEG7, R60/SEG8~R67/SEG15 R70/SEG16/COM7~R70/SEG19/COM4

## R74/COM3~R77/COM0



## **R51/SEG1/TX0**



## R50/SEG0/RX0, R52/SEG2/ACK





## 7. ELECTRICAL CHARACTERISTICS

## 7.1 Absolute Maximum Ratings

| Supply voltage $-0.3$ to $+6.0$ V                                        |
|--------------------------------------------------------------------------|
| Storage Temperature45 to +125 °C                                         |
| Voltage on any pin with respect to Ground (VSS)0.3 to $V_{DD}\!\!+\!0.3$ |
| Maximum current sunk by (I $_{OL}$ per I/O Pin)20 $mA$                   |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$                     |
| Maximum current (ΣΙοτ )                                                  |

| Maximum current ( $\Sigma I_{OH}$ ) |
|-------------------------------------|
|-------------------------------------|

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

| Parameter                | Comple ed         | Condition                                                                        |      | Specifications |      |      |  |  |  |  |
|--------------------------|-------------------|----------------------------------------------------------------------------------|------|----------------|------|------|--|--|--|--|
| raiailletei              | Symbol            | Condition                                                                        | Min. | Тур.           | Max. | Unit |  |  |  |  |
| Supply Voltage           | $V_{DD}$          | f <sub>MAIN</sub> =4MHz                                                          | 2.2  | -              | 5.5  | V    |  |  |  |  |
| Main Operating Frequency | f <sub>MAIN</sub> | V <sub>DD</sub> <sup>1</sup> =1.8~5.5V<br>V <sub>DD</sub> <sup>2</sup> =2.2~5.5V | 0.4  | -              | 4.0  | MHz  |  |  |  |  |
|                          |                   | V <sub>DD</sub> =4.5~5.5V                                                        | 0.4  | -              | 12.0 |      |  |  |  |  |
| Sub Operating Frequency  | f <sub>SUB</sub>  | V <sub>DD</sub> =V <sub>DD</sub>                                                 | -    | 32.768         | -    | kHz  |  |  |  |  |
| Operating Temperature    | T <sub>OPR</sub>  |                                                                                  | -40  | -              | 85   | °C   |  |  |  |  |

<sup>1.</sup> MASK MCU Operating Voltage.

<sup>2.</sup> FLASH MCU Operating Voltage.



## 7.3 DC Electrical Characteristics

 $(T_A = -40 \sim 85^{\circ}C, V_{DD} = 2.2 \sim 5.5V, V_{SS} = 0V)$ 

| Parameter                                       | Symbol                        | Pin / Condition                                                                         | Sp                   | Unit |                      |       |
|-------------------------------------------------|-------------------------------|-----------------------------------------------------------------------------------------|----------------------|------|----------------------|-------|
| i arameter                                      | Cymbol                        | 1 III / Golialion                                                                       | Min.                 | Тур. | Max.                 | Oilit |
| Innut Lliab Valtage                             | V <sub>IH1</sub>              | R0~R7                                                                                   | 0.7V <sub>DD</sub>   | -    | V <sub>DD</sub> +0.3 | V     |
| Input High Voltage                              | V <sub>IH2</sub>              | RESET, X <sub>IN</sub> , SX <sub>IN</sub> , INT0~3, EC0                                 | 0.8V <sub>DD</sub>   | -    | V <sub>DD</sub> +0.3 | \ \   |
| Innut I am Valtaga                              | V <sub>IL1</sub>              | R0~R7                                                                                   | -0.3                 | -    | 0.3V <sub>DD</sub>   | V     |
| Input Low Voltage                               | V <sub>IL2</sub>              | RESET, X <sub>IN</sub> , SX <sub>IN</sub> , INT0~3, EC0                                 | -0.3                 | -    | 0.2V <sub>DD</sub>   | \ \   |
|                                                 | V <sub>OH1</sub>              | R0~R4 (V <sub>DD</sub> =4.5V, I <sub>OH1</sub> =-1.6mA)                                 | V <sub>DD</sub> -0.3 | -    | -                    |       |
| Output High Voltage                             | V <sub>OH2</sub>              | R5~R7 (V <sub>DD</sub> =4.5V, I <sub>OH2</sub> =-1.6mA)                                 | V <sub>DD</sub> -1.0 | -    | -                    | V     |
| Output Flight Voltage                           | V <sub>OH3</sub> <sup>1</sup> | SEG0~19, COM0~3<br>(V <sub>DD</sub> =4.5V, VCL3~0=3V, I <sub>OH3</sub> =-15μA)          | VCL3-0.4             | -    | -                    |       |
|                                                 | V <sub>OL1</sub>              | R0~R4 (V <sub>DD</sub> =4.5V, I <sub>OL1</sub> =1.6mA)                                  | -                    | -    | 0.35                 |       |
| Output Low Voltage                              | V <sub>OL2</sub>              | R5~R7 (V <sub>DD</sub> =4.5V, I <sub>OL2</sub> =1.6mA)                                  |                      |      | 0.4                  | V     |
| Output Low Voltage                              | V <sub>OL3</sub> <sup>2</sup> | SEG0~19, COM0~3<br>(V <sub>DD</sub> =4.5V, VCL3~0=3V, I <sub>OL3</sub> =15μA)           |                      |      | 0.12                 |       |
| Input High<br>Leakage Current                   | l <sub>IH</sub>               | All input pins including R5~R7 (V <sub>IN</sub> =V <sub>DD</sub> )                      | -                    | -    | 1                    |       |
| Input Low<br>Leakage Current                    | I <sub>IL</sub>               | All input pins including R5~R7 (V <sub>IN</sub> =V <sub>ss</sub> )                      | -1                   | -    | -                    | μΑ    |
| Built in Reset                                  | V <sub>BIR</sub>              | V <sub>DD</sub> (TRM<1:0>=00)                                                           | TBD                  | TBD  | TBD                  |       |
| POR(Power on<br>Reset) Level                    | V <sub>POR</sub>              | V <sub>DD</sub> (T <sub>A</sub> =25°C)                                                  | 2.1                  | 2.4  | 2.7                  | V     |
| POR Start Voltage <sup>3</sup>                  | VSTART                        | V <sub>DD</sub> (T <sub>A</sub> =25°C)                                                  |                      |      | 1.8                  | V     |
| POR Rising Time <sup>3</sup>                    | T <sub>POR</sub>              | V <sub>DD</sub> (T <sub>A</sub> =25°C)                                                  |                      |      | 40                   | ms/V  |
| VDD rising Time <sup>3</sup>                    | T <sub>VDD</sub>              | V <sub>DD</sub> (T <sub>A</sub> =25°C)                                                  |                      |      | 40                   | ms/V  |
| Hysteresis                                      | VT+ ~<br>VT-                  | RESET, INT0~3, EC0 (V <sub>DD</sub> =5V)                                                | 0.2V <sub>DD</sub>   | -    | 0.8V <sub>DD</sub>   | V     |
| Pull-up Current                                 | I <sub>PU</sub>               | R0~R4 (V <sub>DD</sub> =3.0V, V <sub>PIN</sub> =0V)                                     | 20                   | -    | 60                   | μА    |
| Current dissipation in active mode <sup>4</sup> | I <sub>DD</sub>               | V <sub>DD</sub> ( f <sub>MAIN</sub> =8MHz, V <sub>DD=</sub> 5.5V, f <sub>SUB</sub> =0 ) | -                    | 6    | 15                   |       |
| Current dissipation in sleep mode <sup>5</sup>  |                               |                                                                                         | -                    | 2    | 4                    | - mA  |
| Current dissipation in                          | ISTOP                         | f <sub>MAIN</sub> =off, V <sub>DD</sub> =5.5V, f <sub>SUB</sub> =0                      | -                    | 3    | 7                    | μА    |
| stop mode                                       | I <sub>SUB</sub>              | f <sub>MAIN</sub> =off, V <sub>DD=</sub> 5.5V, f <sub>SUB</sub> =32.768kHz              |                      | 10   | TBD                  | uA    |
| Internal 8MHz Oscil-<br>lation Frequency        | f <sub>IN8M</sub>             | VDD=5V, T <sub>A</sub> =25°C                                                            | TBD                  | 8    | TBD                  | MHz   |
| Internal 4MHz Oscil-<br>lation Frequency        | f <sub>IN4M</sub>             | VDD=5V, T <sub>A</sub> =25°C                                                            | TBD                  | 4    | TBD                  | MHz   |

<sup>1.</sup>  $V_{OH3}$  is the voltage when VCL3, VCL2, VCL1 and VCL0 are supplied at pads.

<sup>2.</sup>  $V_{OL3}$  is the voltage when  $V_{SS}$  is supplied at pad.

<sup>3.</sup> These parameters are presented for design guidance only and not tested or guaranteed.

<sup>4.</sup> Current dissipation is proportioned according to operation voltage and frequency.

<sup>5.</sup> In sleep mode, oscillation continues and peripherals are operated normally but internal CPU clock stops.



## 7.4 LCD Characteristics

 $(T_A = -40 \sim 85$ °C,  $V_{DD} = 2.2 \sim 5.5$ V,  $V_{SS} = 0$ V)

| Parameter                     | Symbol           | Condition                     | Sp   | l lmi4 |   |      |
|-------------------------------|------------------|-------------------------------|------|--------|---|------|
| Farameter                     |                  | Condition                     | Min. |        |   | Unit |
| 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}=3.072V @ f_{XIN}=4 MHz, V_{DD}=5.12V @ f_{XIN}=8 MHz, V_{SS}=0V)$ 

| Downwoodon                              |                               |                         |                      | pecification | Unit                 |      |
|-----------------------------------------|-------------------------------|-------------------------|----------------------|--------------|----------------------|------|
| Parameter                               | Symbol                        | Pin/Condition           | Min.                 | Тур.         | Max.                 | Unit |
| Conversion Current                      | I <sub>CON</sub>              | -                       | -                    | TBD          | -                    | mA   |
| Analog Power Supply Input Voltage Range | AV <sub>DD</sub> <sup>1</sup> | $V_{DD}$                | 2.7                  | -            | 5.5                  | V    |
| Analog Input Voltage Range              | V <sub>AIN</sub>              | AN0 ~ AN5               | V <sub>SS</sub> -0.3 | -            | V <sub>DD</sub> +0.3 | V    |
| Resolution                              | N <sub>R</sub>                | -                       |                      | 10           | •                    | Bit  |
| Input Impedance                         | IN[7:0]                       | AN0 ~ AN5               | 1                    | -            | -                    | MΩ   |
| Overall Accuracy                        | N <sub>ACC</sub>              | -                       | -                    | _            | ±3.0                 |      |
| Non Linearity Error                     | N <sub>NLE</sub>              | -                       | -                    | _            | ±3.0                 |      |
| Differential Non Linearity Error        | N <sub>DNLE</sub>             | -                       | -                    | _            | ±3.0                 | LSB  |
| Zero Offset Error                       | N <sub>ZOE</sub>              | -                       | -                    | _            | ±3.0                 |      |
| Full Scale Error                        | N <sub>FSE</sub>              | -                       | -                    | _            | ±3.0                 |      |
| Conversion Time                         | т.                            | f <sub>XIN</sub> = 8MHz | 26                   | -            | -                    |      |
| Conversion Time                         | T <sub>CONV</sub>             | f <sub>XIN</sub> = 4MHz | 26                   | -            | -                    | μS   |

<sup>1.</sup> AVDD input current is measured to  $\ensuremath{V_{\text{DD}}}$  pin when all blocks except ADC are disabled.



## 7.6 AC Characteristics

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

|                                               | 0                                   | <b>D.</b>                            | S    |        |      |                  |  |
|-----------------------------------------------|-------------------------------------|--------------------------------------|------|--------|------|------------------|--|
| Parameter                                     | Symbol Pins                         |                                      | Min. | Тур.   | Max. | Unit             |  |
| Main Operating Frequency                      | f <sub>MCP</sub>                    | X <sub>IN</sub>                      | 0.4  | -      | 12   | 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>                    | -                                    | 166  | -      | 5000 | nS               |  |
| Main Oscillation<br>Stabilization Time (4MHz) | t <sub>MST</sub>                    | X <sub>IN</sub> , X <sub>OUT</sub>   | -    | -      | 20   | mS               |  |
| 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>                      | 35   | -      | -    | nS               |  |
| "H" or "L" Pulse Width                        | tscpw                               | SX <sub>IN</sub>                     | 5    | -      | -    | μS               |  |
| External Clock Transition Time                | t <sub>RCP</sub> , t <sub>FCP</sub> | X <sub>IN</sub>                      | -    | -      | 20   | nS               |  |
| Interrupt Pulse Width                         | t <sub>IVV</sub>                    | INTO, INT1, INT2, IN3                | 2    | -      | -    | t <sub>SYS</sub> |  |
| RESET Input Pulse "L" Width                   | t <sub>RST</sub>                    | RESET                                | 8    | -      | -    | tsys             |  |
| Event Counter Input<br>"H" or "L" Pulse Width | t <sub>ECW</sub>                    | EC0                                  | 2    | -      | -    | tsys             |  |
| Event Counter Transition Time                 | tREC, tFEC                          | EC0                                  | -    | -      | 20   | nS               |  |

<sup>1.</sup>SCMR=XXXX000XB that is  $f_{MAIN} \div 2$ 





Figure 7-1 AC Timing Chart



## 7.7 Typical Characteristics

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

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

The data 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

## **TBD**



#### 8. MEMORY ORGANIZATION

The have separate address spaces for Program memory, Data Memory and Display memory. Program memory can only be read, not written to. It can be up to 8K bytes of Pro-

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

gram memory. Data memory can be read and written to up to 1024 bytes including the stack area. Display memory has prepared 27 nibbles 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  $100_{\rm H}$  to  $15F_{\rm 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 " $15F_{\rm 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 #05FH ; SP  $\leftarrow$  05F<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.



## [Zero flag Z]

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



Figure 8-3 PSW (Program Status Word) Register

#### [Interrupt disable flag I]

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

#### [Half carry flag H]

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

#### [Break flag B]

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

#### [Direct page flag G]

This flag assigns RAM page for direct addressing mode. In

the direct addressing mode, addressing area is from zero page  $00_H$  to  $0FF_H$  when this flag is "0". If it is set to "1", addressing area is assigned by RPR register (address  $0F3_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 (7 $F_{\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



## 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<sub>H</sub> and FFFF<sub>H</sub> 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.



**Figure 8-6 Interrupt Vector Area** 





Figure 8-7 PCALL and TCALL Memory Area





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

```
ORG OFFEOH; Device: MC807708
          DW
              WT INT ; Watch Timer / Watch Dog Timer {\rm BIT\_INT}; Basic Interval Timer
          DW
              AD_Con; AD converter
          DW
              NOT_USED; Not Used
TMR3_INT; Timer-2
TMR1_INT; Timer-1
TMR0_INT; Timer-0
          DW
                             ; Timer-3
          DW
          DW
          DW
               NOT \overline{\text{U}}\text{SED}; Not Used
          DW
              UARTO INT; UART TXO, RXO
          DW
              EX3_INT; INT.3
EX2_INT; INT.2
          DW
          DW
              EX1_INT; Int.1
EX0_INT; Int.0
NOT_USED; Not used
          DW
          DW
          DW
          DW
              RESET; Reset
MAIN PROGRAM
          ORG 0E000H
RESET: DI
                 ; Disable All Interrupts
          CLRG
          LDX #0
          LDA #0
RAM CLR1:STA \{X\}+; Page0 RAM Clear(!0000<sub>H</sub>->!009F<sub>H</sub>)
          CMPX #0A0H
          BNE RAM_CLR1
          LDM RPR, #0000 0001B; Pagel RAM Clear(!0100_{H}->!00FF_{H})
          SETG
          LDX #0
          LDA #0
RAM CLR2:STA {X}+
          CMPX #060H
          BNE RAM CLR2
          CLRG
          LDX #05FH; Stack Pointer Initialize
          TXSP
          LDM RPR, #0000 0000B; Page0 selection
          CALL LCD_CLR; Clear LCD display memory
          LDM R0, #0; Normal Port 0
          LDM R0IO, #1000_0010B; Normal Port Direction LDM R0PU, #1000_0010B; Pull Up Selection Set
          LDM R00D, #0000_0001B; R0 port Open Drain control
          LDM SCMR, #1111 0000B; System clock control
```



## 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 MC80F7708 have  $256 \times 8$  bits for the user data memory (RAM). There are three pages 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



Figure 8-10 RAM Page Selection Register

#### **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  $0A0_{\rm H}$  to  $0FF_{\rm 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 pointer (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 22.

## **LCD Display Memory**

LCD display data area is handled in LCD section.

See "18.3 LCD Display Memory" on page 79.

| A -1 -1 | Ponistor Namo                         | 0      | DAM |   | In | iti | al | Va | alu | е   | Addressing             |
|---------|---------------------------------------|--------|-----|---|----|-----|----|----|-----|-----|------------------------|
| Address | Register Name                         | Symbol | R/W | 7 | 6  | 5   | 4  | 3  | 2   | 1 ( | Mode                   |
| 00A0H   | R0 Open Drain Control Register        | R0OD   | W   | 0 | 0  | -   | 0  | -  | -   | 0 - | byte <sup>1</sup>      |
| 00A1H   | R1 Open Drain Control Register        | R10D   | W   | - | -  | 1   | -  | -  | -   | - C | byte                   |
| 00A2H   | R2Open Drain Control Register         | R2OD   | W   | - | -  | 0   | 0  | 0  | 0   | 0 0 | byte                   |
| 00A4H   | R4Open Drain Control Register         | R4OD   | W   | - | 0  | 0   | 0  | 0  | 0   | 0 - | byte                   |
| 00A5H   | R0 Pull-up Register                   | R0PU   | W   | 0 | 0  | -   | 0  | 0  | 0   | 0 - | byte                   |
| 00A6H   | R1 Pull-up Register                   | R1PU   | W   | - | -  | -   | -  | -  | -   | - C | byte                   |
| 00A7H   | R2 Pull-up Register                   | R2PU   | W   | - | -  | 0   | 0  | 0  | 0   | 0 0 | byte                   |
| 00A9H   | R4 Pull-up Register                   | R2PU   | W   | 0 | 0  | 0   | 0  | 0  | 0   | 0 - | byte                   |
| 00AAH   | Port Selection Register 0             | PSR0   | W   | 0 | 0  | 1   | 0  | 0  | 0   | 0 - | byte                   |
| 00ABH   | Port Selection Register 1             | PSR1   | W   | - | -  | -   | -  | -  | -   | - C | byte                   |
| 00ACH   | R5 Port Selection Register            | R5PSR  | R/W | 1 | 1  | 1   | 1  | 1  | 1   | 1 1 | byte, bit <sup>2</sup> |
| 00ADH   | R6 Port Selection Register            | R6PSR  | R/W | 1 | 1  | 1   | 1  | 1  | 1   | 1 1 | byte, bit              |
| 00AEH   | R7 Port Selection Register            | R7PSR  | R/W | 1 | 1  | 1   | 1  | 1  | 1   | 1 1 | byte, bit              |
| 00B0H   | R7 Data Register                      | R7     | R/W | 0 | 0  | 0   | 0  | 0  | 0   | 0 0 | byte                   |
| 00B2H   | LCD Control Register                  | LCR    | R/W | 0 | 0  | 0   | 0  | 0  | 0   | 0 0 | byte, bit              |
| 00B3H   | LCD BIAS Control Register             | LBCR   | R/W | 0 | 1  | 1   | 1  | 1  | 0   | 0 0 | byte, bit              |
| 00B4H   | R7 Direction Register                 | R7IO   | W   | 0 | 0  | 0   | 0  | 0  | 0   | 0 0 | byte                   |
| 00B8H   | Asynchronous Serial Mode Register0    | ASIMR0 | R/W | 0 | 0  | 0   | 0  | -  | 0   | 0 - | byte, bit              |
| 00B9H   | Asynchronous Serial Status Register0  | ASISR0 | R   | - | -  | -   | -  | -  | 0   | 0 0 | byte                   |
| 00BAH   | Baud Rate Generator Control Register0 | BRGCR0 | R/W | - | 0  | 0   | 1  | 0  | 0   | 0 0 | byte, bit              |
| 00BBH   | Receive Buffer Register0              | RXBR0  | R   | 0 | 0  | 0   | 0  | 0  | 0   | 0 0 | byte                   |
| UUDDII  | Transmit Shift Register0              | TXSR0  | W   | 1 | 1  | 1   | 1  | 1  | 1   | 1 1 | byte                   |
| 00C0H   | R0 port data register                 | R0     | R/W | 0 | 0  | -   | 0  | -  | -   | 0 - | byte, bit              |
| 00C1H   | R0 Direction Register                 | R0IO   | W   | 0 | 0  | -   | 0  | -  | -   | 0 - | byte                   |
| 00C2H   | R1 port data register                 | R1     | R/W | - | -  | -   | -  | -  | -   | - C | byte, bit              |
| 00C3H   | R1 Direction Register                 | R1IO   | W   | - | -  | -   | -  | -  | -   | - C | byte                   |
| 00C4H   | R2 port data register                 | R2     | R/W | - | -  | 0   | 0  | 0  | 0   | 0 0 | byte, bit              |
| 00C5H   | R2 Direction Register                 | R2IO   | W   | - | -  | 0   | 0  | 0  | 0   | 0 0 | byte                   |
| 00C8H   | R4 port data register                 | R2     | R/W | - | 0  | 0   | 0  | 0  | 0   | 0 - | byte, bit              |

**Table 8-1 Control Registers** 



| Address | Register Name                             | Symbol            | R/W  | Initial Value   | Addressing<br>Mode |
|---------|-------------------------------------------|-------------------|------|-----------------|--------------------|
|         |                                           |                   |      | 7 6 5 4 3 2 1 0 |                    |
| 00C9H   | R4 Direction Register                     | R4IO              | W    | - 0 0 0 0 0 0 - | byte               |
| 00CAH   | R5 port data register                     | R5                | R/W  | 00000000        | byte, bit          |
| 00CBH   | R5 Direction Register                     | R5IO              | W    | 00000000        | byte               |
| 00CCH   | R6 port data register                     | R6                | R/W  | 00000000        | byte, bit          |
| 00CDH   | R6 Direction Register                     | R6IO              | W    | 00000000        | byte               |
| 00CEH   | Buzzer Driver Register                    | BUZR              | W    | 1 1 1 1 1 1 1 1 | byte               |
| 00CFH   | Ram Page Selection Register               | RPR               | R/W  | 0 0 1           | byte, bit          |
| 00D0H   | Timer 0 Mode Control Register             | TM0               | R/W  | 0 0 0 0 0 0     | byte, bit          |
|         | Timer 0 Register                          | T0                | R    | 00000000        | byte               |
| 00D1H   | Timer 0 Data Register                     | TDR0              | W    | 1 1 1 1 1 1 1 1 | byte               |
|         | Timer 0 Capture Data Register             | CDR0              | R    | 00000000        | byte               |
| 00D2    | Timer 1 Mode Control Register             | TM1               | R/W  | 00-00000        | byte, bit          |
| 00D3H   | Timer 1 Data Register                     | TDR1              | W    | 1 1 1 1 1 1 1 1 | byte               |
|         | Timer 1 Register                          | T1                | R    | 00000000        | byte               |
| 00D4H   | Timer 1 Capture Data Register             | CDR1              | R    | 00000000        | byte               |
| 00D6H   | Timer 2 Mode Control Register             | TM2               | R/W  | 0 0 0 0 0 0     | byte, bit          |
|         | Timer 2 Register                          | T2                | R    | 00000000        | byte               |
| 00D7H   | Timer 2 Data Register                     | TDR2              | W    | 1 1 1 1 1 1 1 1 | byte               |
|         | Timer 2 Capture data Register             | CDR2              | R    | 00000000        | byte               |
| 00D8H   | Timer 3 Mode Control Register             | TM3               | R/W  | 00000000        | byte, bit          |
|         | Timer 3 Data Register                     | TDR3              | W    | 1 1 1 1 1 1 1 1 | byte               |
| 00D9H   | Timer 3 PWM Period Register               | T3PPR             | W    | 1 1 1 1 1 1 1 1 | byte               |
| 00DAH   | Timer 3 Register                          | T3                | R    | 00000000        | byte               |
|         | Timer 3 PWM Duty Register                 | T3PDR             | R/W  | 00000000        | byte, bit          |
|         | Timer 3 Capture Data Register             | CDR3              | R    | 00000000        | byte               |
| 00DBH   | Timer 3 PWM High Register                 | T3PWHR            | W    | 0 0 0 0         | byte               |
| 00E2H   | 10bit A/D Converter Mode Control Register | ADCM <sup>3</sup> | R/W  | 0 0 0 0 0 0 0 1 | byte, bit          |
| 00E3H   | 10bit A/D Converter Result Register Low   | ADCRL             | R    | Undefined       | byte               |
| 00E4H   | 10bit A/D Converter Result Register High  | ADCRH             | W, R | 0 1 0 X X       | byte, bit          |
| 00E5H   | BIR Control Register                      | BIRR              | R/W  | 00000000        | byte, bit          |
| 00E6H   | Basic Interval Timer Register             | BITR              | R    | Undefined       | byte               |
|         | Clock Control Register                    | CKCTLR            | W    | 0 1 0 1 1 1     | byte               |
| 00E7H   | System Clock Mode Register                | SCMR              | R/W  | 0 0 0           | byte               |
|         | Watch Dog Timer Register                  | WDTR              | W    | 0 1 1 1 1 1 1 1 | byte               |
| 00E8H   | Watch Dog Timer Data Register             | WDTDR             | R    | Undefined       | byte               |
|         | Watch Timer Register                      | WTR               | W    | 0 1 1 1 1 1 1 1 | byte               |
| 00E9H   | Stop & Sleep Mode Control Register        | SSCR              | W    | 00000000        | byte               |

**Table 8-1 Control Registers** 



| Address | Register Name                           | Symbol | R/W | Initial Value |   |   |   |   |   |     | Addressing |
|---------|-----------------------------------------|--------|-----|---------------|---|---|---|---|---|-----|------------|
|         |                                         | Symbol |     | 7             | 6 | 5 | 4 | 3 | 2 | 1 0 | Mode       |
| 00EAH   | Watch Timer Mode Register               | WTMR   | R/W | 0             | 0 | - | - | 0 | 0 | 0 0 | byte, bit  |
| 00F4H   | Interrupt Generation Flag Register High | INTFH  | R/W | -             | - | - | - | 0 | 0 |     | byte, bit  |
| 00F5H   | Interrupt Generation Flag Register Low  | INTFL  | R/W | -             | - | - | - | - | - | 0 0 | byte, bit  |
| 00F6H   | Interrupt Enable Register High          | IENH   | R/W | -             | 0 | 0 | 0 | 0 | 0 |     | byte, bit  |
| 00F7H   | Interrupt Enable Register Middle        | IENM   | R/W | 0             | 0 | 0 | 0 | - | - | - 0 | byte, bit  |
| 00F8H   | Interrupt Enable Register Low           | IENL   | R/W | -             | 0 | 0 | 0 | 0 | - |     | byte, bit  |
| 00F9H   | Interrupt Request Register High         | IRQH   | R/W | -             | 0 | 0 | 0 | 0 | 0 |     | byte, bit  |
| 00FAH   | Interrupt Request Register Middle       | IRQM   | R/W | 0             | 0 | 0 | 0 | - | - | - 0 | byte, bit  |
| 00FBH   | Interrupt Request Register Low          | IRQL   | R/W | -             | 0 | 0 | 0 | 0 | - |     | byte, bit  |
| 00FCH   | Interrupt Edge Selection Register       | IEDS   | R/W | 0             | 0 | 0 | 0 | 0 | 0 | 0 0 | byte, bit  |

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

<sup>3.</sup> bit 0 of ADCM is read only.



## 8.4 Addressing Mode

The MC80F7708 use 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_{\rm H}$  ; A  $\leftarrow$  RAM[ $35_{\rm H}$ ]



## (4) Absolute Addressing $\rightarrow$ !abs

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

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

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

Example;

0735F0 ADC  $!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<sub>H</sub> 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) $\rightarrow$ dp+X

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

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

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

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





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

3F35 JMP [35<sub>H</sub>]



## 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 $\rightarrow$ [!abs]

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

JMP

Example; G=0

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





#### 9. I/O PORTS

The MC80F7708 have seven I/O ports, LCD segment ports (R0, R1, R2, R4, R50/SEG0/RX0  $\sim$  R73/SEG19/COM4) and LCD common ports (R77/COM0  $\sim$  R74/COM3, R73/SEG19/COM4  $\sim$  R70/SEG16/COM7).

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

# 9.1 Registers for Ports

#### **Port Data Registers**

The Port Data Registers are represented as a D-Type flipflop, 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 0C1<sub>H</sub> (R0 port direction register) during initial setting as shown in Figure 9-1.

All the port direction registers in the MC80F7708 have 0 written to them by reset function. Therefore, its initial status is input.



Figure 9-1 Example of port I/O assignment

## **Pull-up Control Registers**

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

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 MC80F7708 have 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 R4 ports have open drain port resistors R0OD~R4OD.

Figure 9-3 shows an open drain port configuration by control register. It is selected as either push-pull port or opendrain port by R0OD, R1OD, R2OD and R4OD.



Figure 9-3 Open-drain Port Structure



# 9.2 I/O Ports Configuration

#### **R0 Port**

R0 is a 4-bit CMOS bidirectional I/O port (address 0C0<sub>H</sub>). Each I/O pin can independently used as an input or an output through the R0IO register (address 0C1<sub>H</sub>).

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

In addition, Port R0 is multiplexed with various special features. The control register PSR0 (address 0AA<sub>H</sub>) 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 PSR0.

| DA Dat          | ta Bogistor                                                    | ADDRESS : 0C0 <sub>H</sub>                                      |
|-----------------|----------------------------------------------------------------|-----------------------------------------------------------------|
| KU Dai          | ta Register                                                    | RESET VALUE : 00-00-B                                           |
| R0              | R07 R06 -                                                      | R04 R01 -                                                       |
| R0 Dir          | ection Register                                                | ADDRESS : 0C1 <sub>H</sub><br>RESET VALUE : 00-00- <sub>B</sub> |
| R0IO            | -                                                              |                                                                 |
|                 |                                                                | Port Direction<br>0: Input<br>1: Output                         |
| R0 Pu<br>Select | ll-up<br>tion Register                                         | ADDRESS :0A5 <sub>H</sub><br>RESET VALUE : 00-00- <sub>1</sub>  |
| R0PU            | -                                                              |                                                                 |
|                 |                                                                | Pull-up select<br>0: Without pull-up<br>1: With pull-up         |
| R0 Op           | en Drain                                                       |                                                                 |
| Select          | tion Register                                                  | ADDRESS :0A0 <sub>H</sub><br>RESET VALUE : 00-00- <sub>1</sub>  |
| R0OD            | -                                                              |                                                                 |
|                 |                                                                | Open Drain selec<br>0: No Open Drain<br>1: Open Drain           |
| Port<br>Select  | tion Register 0                                                | ADDRESS :0AA <sub>H</sub><br>RESET VALUE : 00-0000-             |
|                 |                                                                |                                                                 |
| PSR0            | INT1I INT0I -                                                  | BUZO RX0I TX0O EC0I -                                           |
|                 | INT1I INT0I - INT1I (External Interr<br>0: R07 Port<br>1: INT1 |                                                                 |
|                 | INT1I (External Interr<br>0: R07 Port                          | rupt 1) INTOI (External Interrupt 0<br>0: R06 Port<br>1: INTO   |

| Port Pin | Alternate Function          |
|----------|-----------------------------|
| R01      | EC0 (Timer0 Event Input)    |
| -        | TX0 (TX0 Output)            |
| -        | RX0 (RX0 Input)             |
| R04      | BUZO (Buzzer Output)        |
| R06      | INT0 (External Interrupt 0) |
| R07      | INT1 (External Interrupt 1) |

**Note:** R0IO, R0PU, P0OD and PSR0 are write-only registers. They can not be read and can not be accessed by bit manipulation instruction. Do not use read or read-modifywrite instruction. Use byte manipulation instruction.

#### **R1 Ports**

R1 is an 1-bit CMOS bidirectional I/O port (address 0C2<sub>H</sub>). Each I/O pin can independently used as an input or an output through the R1IO register (address 0C3<sub>H</sub>).

R1 has internal pull-up that is independently connected or disconnected by register R1PU. The control registers for R1 are shown below.

Port R1 is multiplexed with two special features. The control register 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 PWM1 or Timer Output Wave will be shown in each peripheral section.

**Note:** R1IO, R1PU, P1OD and PSR1 are write-only registers. They can not be read and can not be accessed by bit manipulation instruction. Do not use read or read-modifywrite instruction. Use byte manipulation instruction.



| ADDRESS : 0C2 <sub>H</sub><br>RESET VALUE :0 <sub>B</sub>                                              |
|--------------------------------------------------------------------------------------------------------|
|                                                                                                        |
| R10                                                                                                    |
| ADDRESS : 0C3 <sub>H</sub><br>RESET VALUE :0 <sub>B</sub>                                              |
|                                                                                                        |
| Port Direction<br>0: Input<br>1: Output                                                                |
| ADDRESS : 0A6 <sub>H</sub><br>RESET VALUE :0 <sub>B</sub>                                              |
|                                                                                                        |
| Pull-up select 0: Without pull-up 1: With pull-up  ADDRESS:0A1 <sub>H</sub> RESET VALUE:0 <sub>B</sub> |
|                                                                                                        |
| Open Drain select<br>0: No Open Drain<br>1: Open Drain                                                 |
| ADDRESS :0AB <sub>H</sub><br>RESET VALUE :000 <sub>B</sub>                                             |
| - INT31 INT21 PWMO                                                                                     |
| PWM1O (PWM1 Output)<br>0: R10 Port<br>1: PWM1/T2O                                                      |
|                                                                                                        |

**R2 Ports** 

R2 is a 6-bit CMOS bidirectional I/O port (address  $0C4_H$ ). Each I/O pin can independently used as an input or an output through the R2IO register (address  $0C5_H$ ).

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

**Note:** R2IO, R2PU and P2OD are write-only registers. They can not be read and can not be accessed by bit ma-

nipulation instruction. Do not use read or read-modify-write instruction. Use byte manipulation instruction.

**Note:** The R24 and R25 are not supported in the MC80F7708K.



### **R4 Port**

R4 is a 7-bit CMOS bidirectional I/O port (address  $0C8_H$ ). Each I/O pin can independently used as an input or an output through the R4IO register (address  $0C9_H$ ).

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



| R4 Data Register     |                |         |          |       | ADDRESS: 0C8 <sub>H</sub><br>RESET VALUE: -000000- <sub>B</sub> |                               |                                                |  |
|----------------------|----------------|---------|----------|-------|-----------------------------------------------------------------|-------------------------------|------------------------------------------------|--|
| R4                   | R47            | R46     | R45      | R44   | R43                                                             | R42                           | R41 -                                          |  |
| R4 Dire              | ction          | Regi    | ister    |       | ADDR<br>RESE                                                    |                               | 0C9 <sub>H</sub><br>JE : -000000- <sub>E</sub> |  |
| R4IO                 | -              |         |          |       |                                                                 |                               | -                                              |  |
|                      |                |         |          |       |                                                                 | Port I<br>0: Inp<br>1: Ou     |                                                |  |
| R4 Pull<br>Selection |                | giste   | er       |       |                                                                 | ESS :(<br>T VAL               | 0A9 <sub>H</sub><br>UE : 0000000-              |  |
| R4PU                 |                |         |          |       |                                                                 | <u> </u>                      |                                                |  |
| D4 0                 | D              |         |          |       |                                                                 | 0: Wi                         | up select<br>ithout pull-up<br>ith pull-up     |  |
| R4 Ope<br>Selection  |                |         | er       |       |                                                                 | ESS :0                        | )A4 <sub>H</sub><br>UE : -000000- <sub>E</sub> |  |
| R0OD                 | -              |         |          |       |                                                                 |                               | -                                              |  |
|                      |                |         |          |       |                                                                 | 0: No                         | n Drain select<br>Open Drain<br>Den Drain      |  |
| Port<br>Selecti      | on R           | egist   | er 1     |       |                                                                 |                               | :0AB <sub>H</sub><br>LUE :000 <sub>E</sub>     |  |
| PSR1                 | -              | -       | -        | -     | -                                                               | INT3I                         | INT2I PWMO                                     |  |
| 0: R<br>1: II        | R41Port<br>NT2 | İ       | nterrupt | ,     | 0: R′                                                           | //10 (Р<br>10 Port<br>///М1/Т |                                                |  |
| 0: F                 | R41Por<br>NT3  |         | попар    | . 0,  |                                                                 |                               |                                                |  |
| LCD Co               | ntrol          | Regi    | ster     |       |                                                                 | RESS :                        | 0B2 <sub>H</sub><br>UE : 00000000              |  |
| LCR                  | SCKD           | 1 1     | LCDEN    | 0     | 1                                                               | LCDD0                         | LCK1 LCK0                                      |  |
| 0: Su                | ıb Cloc        | k Oscil |          | aable | (SXIN/<br>e (R45/F                                              |                               | T)                                             |  |

In addition, Port R4 is multiplexed with oscillation input/output, reset and interrupt input pins. The control register PSR1 (address  $0AB_H$ ) 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 PSR1.

Main oscillation input/output and reset pin can be used as normal I/O ports (R43/R42) and normal input port(R47) by selecting configuration options in flash writing. Sub oscillation input/output pin can be used as normal I/O ports by writing "1" to the SCKD bit of the LCR register

| Port Pin | Alternate Function                               |
|----------|--------------------------------------------------|
| R41      | INT2 (External Interrupt 2)                      |
| R42      | X <sub>OUT</sub> (Oscillation Output)            |
| R43      | X <sub>IN</sub> (Oscillation Input)              |
| R44      | INT3 (External Interrupt 3)                      |
| R45      | SX <sub>IN</sub> (Subsystem Oscillation Input)   |
| R46      | SX <sub>OUT</sub> (Subsystem Oscillation Output) |
| R47      | RESET (System Reset Input)                       |

**Note:** R4IO, R4PU, P4OD and PSR1 are write-only registers. They can not be read and can not be accessed by bit manipulation instruction. Do not use read or read-modifywrite instruction. Use byte manipulation instruction.

#### **R5 Ports**

R5 is an 8-bit CMOS bidirectional I/O port (address 0CA<sub>H</sub>). Each I/O pin can independently used as an input or an output through the R5IO register (address 0CB<sub>H</sub>).

R5 is multiplexed with LCD segment output(SEG0  $\sim$  SEG7), which can be selected by writing appropriate value into the R5PSR(address 0AC<sub>H</sub>).

R50, R1, R52 is also multiplied with RX0, TX0 and ACK, which can be selected by writing appropriate value into the ASIMR0(address  $0B8_H$ ).



**Note:** R5IO is write-only register. It can not be read and can not be accessed by bit manipulation instruction. Do not use read or read-modify-write instruction. Use byte manipulation instruction.



#### **R6 Ports**

R6 is an 8-bit CMOS bidirectional I/O port (address 0CC<sub>H</sub>). Each I/O pin can independently used as an input or an output through the R6IO register (address 0CD<sub>H</sub>).

R6 is multiplexed with LCD segment output(SEG8  $\sim$  SEG15), which can be selected by writing appropriate value into the R6PSR(address 0AD<sub>H</sub>).

| R6 D  | ata Register                                    | ADDRESS: 0CC <sub>H</sub><br>RESET VALUE: 00000000 <sub>B</sub>   |  |  |  |  |
|-------|-------------------------------------------------|-------------------------------------------------------------------|--|--|--|--|
| R6    | R67 R66 R65 R64                                 | R63 R62 R61 R60                                                   |  |  |  |  |
| R6 D  | irection Register                               | ADDRESS: 0CD <sub>H</sub><br>RESET VALUE: 00000000 <sub>B</sub>   |  |  |  |  |
| R6IO  |                                                 |                                                                   |  |  |  |  |
|       |                                                 | Port Direction<br>0: Input<br>1: Output                           |  |  |  |  |
|       | CD Port<br>ction Register                       | ADDRESS : 0AD <sub>H</sub><br>RESET VALUE : 11111111 <sub>B</sub> |  |  |  |  |
| R6PSR | R6PS7 R6PS6 R6PS5 R6PS4 R                       | R6PS3 R6PS2 R6PS1 R6PS0                                           |  |  |  |  |
|       | 0: Seg Selection(seg15~seg<br>1: Port Selection | J8)                                                               |  |  |  |  |

**Note:** R6IO is write-only register. It can not be read and can not be accessed by bit manipulation instruction. Do not use read or read-modify-write instruction. Use byte manipulation instruction.

#### **R7 Ports**

R7 is a 4-bit CMOS bidirectional I/O port (address  $0B0_H$ ). Each I/O pin can independently used as an input or an output through the R7IO register (address  $0B4_H$ ).

R7 is multiplexed with LCD common output (COM7  $\sim$  COM0) and segment output(SEG16  $\sim$  SEG19), which can be selected by writing appropriate value into the R7PSR(address 0AE<sub>H</sub>) and LCR(address 0B2<sub>H</sub>).



**Note:** R7IO is write-only register. It can not be read and can not be accessed by bit manipulation instruction. Do not use read or read-modify-write instruction. Use byte manipulation instruction.

#### SEG0~SEG19

Segment signal output pins for the LCD display. See "18. LCD DRIVER" on page 75 for details.

# COM0~COM7

Common signal output pins for the LCD display. See "18. LCD DRIVER" on page 75 for details.

SEG16~SEG19 and COM7~COM4 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 which are main-frequency clock oscillator and a sub-frequency clock oscillator. The system clock can also be obtained from the external oscillator. By setting configuration option, the internal 8MHz, 4MHz, 2MHz can also be selected for system clock source.

The clock generator produces the system clocks forming clock pulse, which are supplied to the CPU and the peripheral hardware.

The internal system clock should be selected to main oscillation by setting bit1 and bit0 of the system clock mode register (SCMR). The registers are shown in Figure 10-2.

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



Figure 10-1 Block Diagram of Clock Generator



The SCMR should be set to operate by main oscillation. Bit2, bit1 and bit0 of the SCMR should be set to "000" or

"001" to select main oscillation.



Figure 10-2 SCMR: System Clock Mode Register



# 11. BASIC INTERVAL TIMER

The MC80F7708 have 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 division ratio from 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 0E6<sub>H</sub> is read as a BITR, and written to CKCTLR.



Figure 11-1 Block Diagram of Basic Interval Timer

| BCK<2:0> | Source clock                       | Interrupt (overflow) Period |
|----------|------------------------------------|-----------------------------|
| BCK<2:0> | SCMR[1:0] = 00 or 01               | At f <sub>MAIN</sub> = 4MHz |
| 000      | f <sub>MAIN</sub> ÷2 <sup>3</sup>  | 0.512 ms                    |
| 001      | f <sub>MAIN</sub> ÷2 <sup>4</sup>  | 1.024                       |
| 010      | f <sub>MAIN</sub> ÷2 <sup>5</sup>  | 2.048                       |
| 011      | f <sub>MAIN</sub> ÷2 <sup>6</sup>  | 4.096                       |
| 100      | f <sub>MAIN</sub> ÷2 <sup>7</sup>  | 8.192                       |
| 101      | f <sub>MAIN</sub> ÷2 <sup>8</sup>  | 16.384                      |
| 110      | f <sub>MAIN</sub> ÷2 <sup>9</sup>  | 32.768                      |
| 111      | f <sub>MAIN</sub> ÷2 <sup>10</sup> | 65.536                      |

**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-4. 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 internal clock input. Since a least clock consists of 2 and

# 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
LDM
       TDR0, #249
LDM
       TM0, #0001_0011B
T<sub>1</sub>DM
       TDR1.#124
       TM1,#0000 1111B
LDM
SET1
       TOE
SET1
       T1E
ET
```

#### Example 2:

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

```
LDM SCMR,#0 ;Main clock mode
LDM TDR0,#23H
LDM TDR1,#0F4H
LDM TM0,#0FH ;F<sub>MAIN</sub>/32, 8us
LDM TM1,#4CH

SET1 TOE
EI
:
:
```

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

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

In addition the "capture" function, the register is increased in response external or internal clock interrupt same with timer/counter function. When external interrupt edge input, the count register is captured into capture data register TMx

Timer3 is shared with "PWM" function and Timer2 is shared with "Compare output" function.

#### Example 3:

Timer0 = 8-bit event counter

Timer2 = 8-bit capture mode, 2us sampling count.

```
TDR0, #0FFH
                            ;don't care
T.DM
LDM
       TM0, #1FH
                             ; event counter
LDM
       R0IO, #1XXX XX1XB ; R07, R01 input
       IEDS,#XXXX_01XXB ;FALLIN
PSR0,#1XXX_XX1XB;INT1,EC0
LDM
                             : FALLING
LDM
LDM
       TDR2,#0FFH
LDM
       TM2,#0010 1011B
                             ;2us
                              ; ENABLE TIMER 0
SET1
       TOE
                              ; ENABLE TIMER 1
SET1
       T2E
SET1
       INT1E
                              ; ENABLE INT1
ΕI
```

X: don't care.

#### Example 4:

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

```
LDM
      TDR0,#0FFH
LDM
      TDR1,#0FFH
LDM
       TM0,#2FH
LDM
      TM1, #5FH
       IEDS, #XXXX XX01B
T.DM
LDM
      PSRO, #X1XX XXXXB ; AS INTO
SET1
              ; ENABLE TIMER 0
      INTOE ; ENABLE EXT. INTO
SET1
EI
```

X: don't care.



|         | Bit :                    | 7                                                                                                      | 6                                                                                                       | R/W<br>5                                                         | R/W<br>4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R/W<br>3                                                      | R/W<br>2                                                                                                  | R/W<br>1                                                                                                                                                                                                                                                         | R/W<br>0                                                                       | ADDRESS: 0D0 <sub>H</sub> )                                                                                                                                                                          |
|---------|--------------------------|--------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TM0     |                          | -                                                                                                      | -                                                                                                       | CAP0                                                             | T0CK2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | T0CK1                                                         | T0CK0                                                                                                     | T0CN                                                                                                                                                                                                                                                             | T0ST                                                                           | INITIAL VALUE:000000                                                                                                                                                                                 |
|         | Bit :                    | 7                                                                                                      | 6                                                                                                       | R/W<br>5                                                         | R/W<br>4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R/W<br>3                                                      | R/W<br>2                                                                                                  | R/W<br>1                                                                                                                                                                                                                                                         | R/W<br>0                                                                       |                                                                                                                                                                                                      |
| TM2     | 2., .                    | -                                                                                                      | -                                                                                                       | CAP2                                                             | T2CK2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                               | T2CK0                                                                                                     | T2CN                                                                                                                                                                                                                                                             | T2ST                                                                           | ADDRESS: 0D6 <sub>H</sub> INITIAL VALUE:000000                                                                                                                                                       |
|         |                          | 0: Pause<br>1: Continu<br><b>T0ST,T2S</b><br>0: Stop Co                                                | CN (Time<br>Counting<br>le Counti<br>ounting                                                            | r <b>0,2 Conti</b><br>ng<br>• <b>0,2 Start (</b><br>•r and Start | Control)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                               | 001:<br>010:<br>011:<br>100:<br>101:<br>110:<br>111:                                                      | f <sub>MAIN</sub> ÷2<br>f <sub>MAIN</sub> ÷2 <sup>2</sup><br>f <sub>MAIN</sub> ÷2 <sup>3</sup><br>f <sub>MAIN</sub> ÷2 <sup>5</sup><br>f <sub>MAIN</sub> ÷2 <sup>7</sup><br>f <sub>MAIN</sub> ÷2 <sup>9</sup><br>f <sub>MAIN</sub> ÷2 <sup>1</sup><br>External E | Event cloc                                                                     |                                                                                                                                                                                                      |
|         |                          |                                                                                                        |                                                                                                         |                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                               |                                                                                                           |                                                                                                                                                                                                                                                                  | •                                                                              | ,                                                                                                                                                                                                    |
| M1, TN  | 13 (Tiı                  | -                                                                                                      |                                                                                                         | Control I                                                        | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | •                                                             | R/W                                                                                                       |                                                                                                                                                                                                                                                                  | R/W                                                                            |                                                                                                                                                                                                      |
| •       | <b>13 (Ti</b> i<br>Bit : | R/W<br>7                                                                                               | R/W<br>6                                                                                                | R/W<br>5                                                         | R/W<br>4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R/W<br>3                                                      | R/W<br>2                                                                                                  | R/W<br>1                                                                                                                                                                                                                                                         | R/W<br>0                                                                       | ADDRESS: 0D2 <sub>H</sub>                                                                                                                                                                            |
| TM1, TM | •                        | R/W<br>7<br>-                                                                                          | R/W<br>6<br>16BIT                                                                                       | R/W<br>5<br>-                                                    | R/W<br>4<br>-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R/W<br>3<br>T1CK1                                             | 2<br>T1CK0                                                                                                | R/W<br>1<br>T1CN                                                                                                                                                                                                                                                 | 0<br>T1ST                                                                      | ADDRESS: 0D2 <sub>H</sub>                                                                                                                                                                            |
|         | •                        | R/W<br>7                                                                                               | R/W<br>6                                                                                                | R/W<br>5                                                         | R/W<br>4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R/W<br>3                                                      | 2                                                                                                         | R/W<br>1                                                                                                                                                                                                                                                         | 0                                                                              | ADDRESS: 0D2 <sub>H</sub><br>INITIAL VALUE:-00000                                                                                                                                                    |
| •       | Bit :                    | R/W<br>7<br>-<br>R/W                                                                                   | R/W<br>6<br>16BIT<br>R/W                                                                                | R/W<br>5<br>-<br>R/W                                             | R/W<br>4<br>-<br>R/W<br>4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R/W<br>3<br>T1CK1                                             | 2<br>T1CK0<br>R/W                                                                                         | R/W<br>1<br>T1CN                                                                                                                                                                                                                                                 | 0<br>T1ST<br>R/W                                                               | ADDRESS: 0D2 <sub>H</sub> INITIAL VALUE:-00000 <sub>l</sub> ADDRESS: 0D8 <sub>H</sub>                                                                                                                |
| TM1     | Bit:                     | R/W 7 - R/W 7 POL POL (PWI 0: Duty Ac 1: Duty Ac                                                       | R/W<br>6<br>16BIT<br>R/W<br>6<br>16BIT<br>W Output<br>tive Low<br>tive High<br>Bit Mode<br>dode<br>lode | R/W 5  R/W 5  PWM1E  Polarity S  Selection                       | R/W<br>4<br>-<br>R/W<br>4<br>-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R/W 3 T1CK1  R/W 3 T3CK1  T1C 00: 01: 10: 11: T1C             | Z T1CK0 R/W 2 T3CK0  CK[1:0],T3 K[1:0] fmAIN fMAIN÷2 fmAIN÷23 Timer0 Cl CN,T3CN (                         | R/W<br>1<br>T1CN<br>R/W<br>1<br>T3CN<br>3CK[1:0] (                                                                                                                                                                                                               | 0<br>T1ST<br>R/W<br>0<br>T3ST<br>Timer 1,3<br>00<br>01<br>10                   | ADDRESS: 0D2H INITIAL VALUE:-0-0000 ADDRESS: 0D8H INITIAL VALUE:000-0000 Input Clock Selection) CK[1:0] : f <sub>MAIN</sub> : f <sub>MAIN</sub> :2 : f <sub>MAIN</sub> :24 : Timer2 Clock            |
| TM1     | Bit:                     | R/W 7  R/W 7  POL  POL (PWI 0: Duty Ac 1: Duty Ac 1: Duty Ac 1: 16-Bit M 1: 16-Bit M  PWM1E (I 0: PWM1 | R/W 6 16BIT  R/W 6 16BIT  M Output tive Low tive High Bit Mode adde lode PWM Ena                        | R/W 5  R/W 5  PWM1E  Polarity S  Selection                       | R/W 4 - R/W 4 | R/W 3 T1CK1  R/W 3 T3CK1  T10 00: 01: 10: 11: T10 0: \$ 1: \$ | Z T1CK0 R/W 2 T3CK0  CK[1:0],T3 CK[1:0] fMAIN fMAIN+2 fMAIN+23 Timer0 CC CN,T3CN ( Stop Count Start Count | R/W<br>1<br>T1CN<br>R/W<br>1<br>T3CN<br>3CK[1:0] (                                                                                                                                                                                                               | 0<br>T1ST<br>R/W<br>0<br>T3ST<br>Timer 1,3<br>00<br>01<br>10<br>11<br>Continue | ADDRESS: 0D2H INITIAL VALUE:-0-0000 ADDRESS: 0D8H INITIAL VALUE:000-0000 Input Clock Selection) CK[1:0] : f <sub>MAIN</sub> : : f <sub>MAIN</sub> :2 : f <sub>MAIN</sub> :24 : Timer2 Clock e Start) |

| T0CK2 | T0CK1 | T0CK0 | ١                                     | 4MHz  | 8MHz  | 10MHz   |
|-------|-------|-------|---------------------------------------|-------|-------|---------|
| 0     | 0     | 0     | (f <sub>MAIN</sub> ÷2)                | 500nS | 250nS | 200nS   |
| 0     | 0     | 1     | $(f_{MAIN} \div 2^2)$                 | 1uS   | 500nS | 400nS   |
| 0     | 1     | 0     | (f <sub>MAIN</sub> ÷2 <sup>3</sup> )  | 2uS   | 1uS   | 800nS   |
| 0     | 1     | 1     | (f <sub>MAIN</sub> ÷2 <sup>5</sup> )  | 8uS   | 4uS   | 3.2uS   |
| 1     | 0     | 0     | (f <sub>MAIN</sub> ÷2 <sup>7</sup> )  | 32uS  | 16uS  | 12.8uS  |
| 1     | 0     | 1     | (f <sub>MAIN</sub> ÷2 <sup>9</sup> )  | 128uS | 64uS  | 51.2uS  |
| 1     | 1     | 0     | (f <sub>MAIN</sub> ÷2 <sup>11</sup> ) | 512uS | 256uS | 204.8uS |

Figure 12-1 Timer0,1,2,3 Registers





Figure 12-2 Related Registers with Timer/Counter0, 1





Figure 12-3 Related Registers with Timer/Counter2, 3



| 16BIT | CAP0 | - | T0CK[2:0] | T1CK[1:0] | Timer 0              | Timer 1              |  |
|-------|------|---|-----------|-----------|----------------------|----------------------|--|
| 0     | 0    | - | XXX       | XX        | 8 Bit Timer          | 8 Bit Timer          |  |
| 0     | 0    | - | 111       | XX        | 8 Bit Event Counter  | 8 Bit Timer          |  |
| 0     | 1    | - | XXX       | XX        | 8 Bit Capture        | 8 Bit Compare Output |  |
| 1     | 0    | - | XXX       | 11        | 16 Bit Timer         |                      |  |
| 1     | 0    | - | 111       | 11        | 16 Bit Event Counter |                      |  |
| 1     | 1    | - | XXX       | 11        | 16 Bit Capture       |                      |  |
| 1     | 0    | - | XXX       | 11        | 16 Bit Compare Outp  | ut                   |  |

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

# 12.1 8-Bit Timer/Counter Mode

The MC80F7708 have four 8-bit Timer/Counters, Timer0, Timer1, Timer2 and Timer3 as shown in Figure 12-4.

The "timer" or "counter" function is selected by mode registers TMx (x=0,1,2,3) as shown in Figure 12-1 and Table

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



Figure 12-4 Block Diagram of Timer/Event Counter0,1





Figure 12-5 Block Diagram of Timer 2,3

These timers have each 8-bit count register and data register. The count register is increased by every internal or external clock input. The internal clock has a prescaler divide ratio option of 2, 4, 8, 32,128, 512, 2048 (selected by control bits TxCK2, TxCK1 and TxCK0 of register TM0(2)) and 1, 2, 8 (selected by control bits TxCK1 and TxCK0 of register TM1(3)).

In the Timer, timer register Tx increases from  $00_H$  until it matches TxDR and then reset to  $00_H$ . If the value of Tx is equal with TxDR, Timer x interrupt is occurred (latched in TxIF bit). TxDR 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 R01 of the R0 Direction Register (R0IO) should be set to "0" and the bit EC0E of Port Selection Register PSR0 should set to "1". The Timer 0 can be used as a counter by pin EC0 input, but other timers can not used as a event counter.

**Note:** The contents of TDR0, TDR1, TDR2 and TDR3 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-6 Counting Example of Timer Data Registers



**Figure 12-7 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-8 16-bit Timer / Counter Mode 0



Figure 12-9 16-bit Timer / Counter Mode 2



# 12.3 8-Bit Capture Mode

The Timer 0 capture mode is set by bit CAP0 of timer mode register TM0 (bit CAPx of timer mode register TMx for Timer 1,2,3) as shown in Figure 12-10.

As mentioned above, not only Timer 0 but Timer 1,2,3 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,2,3) increases and matches TDR0 (TDR1,TDR2,TDR3).

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-13, 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,T2,T3), to be captured into registers CDRx (x=0,1,2,3), respectively. After captured, Timer x register is cleared and restarts by hardware.

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

Note: The CDR0, TDR0 and T0 are in same address. In the capture mode, reading operation is to 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 to read the CDR1





Figure 12-10 8-bit Capture Mode (Timer0, Timer1)





Figure 12-11 8-bit Capture Mode (Timer2, Timer3)





Figure 12-12 Input Capture Operation



Figure 12-13 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,2 is selected either internal or external clock by bit TxCK2, TxCK1 and TxCK0.

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



Figure 12-14 16-bit Capture Mode (Timer0,1)





Figure 12-15 16-bit Capture Mode (Timer2,3)

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

The MC80F7708 have a function of Timer Compare Output. To pulse out, the timer match can goes to port pin (R10) as shown in Figure 12-4 and Figure 12-8. Thus, pulse out is generated by the timer match. These operation is implemented to pin, R10/PWM1/T2O.

In this mode, the bit PWM1O of Port Mode Register R1FUNC should be set to "1", and the bit PWM1E of Timer3 Mode Register (TM3) should be cleared to "0".

#### 12.6 PWM Mode

The MC80F7708 has one high speed PWM (Pulse Width Modulation) function which shared with Timer3. In PWM mode, the R10/PWM1 pins operate as a 10-bit resolution PWM output port. For this mode, the bit PWM1O of Port Mode Register (R1FUNC) and the bit PWM1E of timer3 mode register (TM3) should be set to "1" respectively.

The period of the PWM output is determined by the T3PPR (T3 PWM Period Register) and T3PWHR[3:2] (bit3, 2 of T3 PWM High Register) and the duty of the PWM output is determined by the T3PDR (T3 PWM Duty

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{f_{XIN}}{2 \times PrescalerValue \times (TDR+1)}$$

Register) and T3PWHR[1:0] (bit1, 0 of T3PWM High Register).

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

The T3PDR is configured as a double buffering for glitchless PWM output. In Figure 12-16, 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 POL1 of TM3 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-18. As it were, the absolute duty time is not changed in varying frequency.

Note: If the user need to change mode from the Timer3 mode to the PWM mode, the Timer3 should be stopped firstly, and then set period and duty register value. If user writes register values and changes mode to PWM mode while Timer3 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 = [T3PWHR[3:2]T3PPR+1] X Source Clock PWM Duty = [T3PWHR[1:0]T3PDR+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 POL1 (1: High, 0: Low). And if the duty value is set to "00<sub>H</sub>", the PWM output is determined by the bit POL1(1: Low, 0: High). The period value must be same or more than the duty value, and 00<sub>H</sub> cannot be used as the period value.

|            | Frequency                |                          |                        |  |  |  |  |
|------------|--------------------------|--------------------------|------------------------|--|--|--|--|
| Resolution | T3CK[1:0]<br>=00 (250nS) | T3CK[1:0]<br>=01 (500nS) | T3CK[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.2kHz                  | 15.6kHz                  | 3.90kHz                |  |  |  |  |

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



Figure 12-16 PWM Mode





Figure 12-17 Example of PWM at 5MHz



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

#### **Example:**

```
Timer1 @4Mhz, 4kHz -20% duty PWM mode

LDM R1IO,#0000_XXX1B ;R00 output
LDM TM3,#0010_000B ;pwm enable
LDM T3PWHR,#0000_1100B ;20% duty
LDM T3PPR,#1110_0111B ;period 250us
LDM T3PDR,#1100_0111B ;duty 50us
LDM PSR1,#XXXX XXX1B ;set pwm port.
LDM TM3,#0010_0011B ;timer1 start
```

X means don't care



# 13. WATCH TIMER

The watch timer generates interrupt for watch operation. 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 0, 1, 2 of WTMR select the clock source of watch timer among sub-clock,  $f_{MAIN} \div 2^8$ ,  $f_{MAIN} \div 2^7$ ,  $f_{MAIN}$  or  $f_{MAIN} \div 2$  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$  or  $f_{MAIN} \div 2^8$  clock is used when the single clock system is organized. If  $f_{MAIN} \div 2^8$  or  $f_{MAIN} \div 2^7$  clock is used as watch timer clock source, when the CPU enters into stop mode, the main clock is stopped and then watch

timer is also stopped. If the sub-clock is used as the watch timer source clock, the watch timer count cannot be stopped. Therefore, the sub-clock does not stop and 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 60 seconds at sub-clock.

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

**Note:** The Clock source of watch timer is also applied to LCD dirver clock source. When selecting LCD dirver clock source, the WTCK[2:0] should be set to appropriate value.



Figure 13-1 Watch Timer Mode Register





Figure 13-2 Watch Timer Block Diagram

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

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

- 1. Set the clock source of watch timer to sub-clock.
- 2. Enters into STOP mode.
- 3. After released by watch timer interrupt, counts up timer and refreshes LCD Display. When performing count up and refresh the LCD, the CPU operates in main frequency mode.
- 4. Enters into 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. WATCH DOG TIMER

The watch dog timer (WDT) function is used for checking program malfunction due to external noise or other causes and return the operation to the normal contion.

The watchdog timer consists of 7-bit binary counter and the watchdog timer register(WDTR). The source clock of WDT is overflow of Basic Interval Timer. When the value of 7-bit binary counter is equal to the lower 7-bits of WDTR, the interrupt request flag is generated. This can be used as WDT interrupt or CPU reset signal in accordance with the bit WDTON. When WDTCL is set, 7-bit counter of WDT is reset. After one cycle, it is cleared by hardware.

When writing WDTR, the LOADEN bit of WTMR regis-

ter should be cleared to "0".

**Note:** WDTR and WTR has same address 0E8h. The LOADEN bit is used to select WDTR or WTR. When LOADEN of watch timer mode register(WTMR) is set to "1", WDTR can not be wrote and WTR is wrote.

The LOADEN bit should be cleared to "0" when writing any value to WDTR.

**Note:** When using watch dog timer, don't write WDT[6:0] to "0000000".



Figure 14-1 Block Diagram of Watch Dog Timer





Figure 14-2 Watch Dog Timer Interrupt Time



#### 15. ANALOG TO DIGITAL CONVERTER

The analog-to-digital(A/D) converter allows conversion of an analog input signal to an corresponding 10-bit digital value. The A/D module has six analog inputs, which are multiplexed into one sample and hold. The output of the sample and hold is the input of 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 three registers which are the control register ADCM and A/D result register ADCRH and ADCRL. The ADCRH[7:6] is also used as ADC clock source selection bits. The ADCM register, shown in Figure 15-2, 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 R2IO direction register as input mode and setting ADS[3:0] to select the corresponding channel.

The self bias check reference provides fixed voltage (typical 1.185V, tolerance to be defined), which can be the input of ADC when setting ADS[3:0] to "1111b". This feature can be used to check the voltage of VDD pin. The BIR\_ENB and AD\_REFB of BIRR register should be set to "0" for using self bias check reference.

The processing of conversion is start when the start bit ADST is set to "1". After one cycle, it is cleared by hardware. The register ADCRH and ADCRL contain the result (10bit) of the A/D conversion. If the ADC is set to 8-bit mode (ADC8 bit of ADCRH is "1b"), ADCRL contains the result of the A/D conversion. When the conversion is completed, the result is loaded into the ADCR, 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 15-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 needs 13 clock period of ADC clock (f<sub>PS</sub>). It is recommended to use ADC clock of at least 1us period.

**Note:** The ADC value of self bias check reference( $V_{bias\_ref}$ ) is can be used to check the VDD voltage. When  $V_{bias\_ref}$  is 1.185V and VDD is 5.12V, the ADC value is "0EDh". If VDD is changed and ADC value is "13Ch", the VDD voltage is 3.84V.

the ADC value is changed to "13Ch". The VDD voltage can be calculated by following formula.

VDD voltage = V<sub>bias ref</sub> x 1024 ÷ ADC Value



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





Figure 15-2 A/D Converter Mode & Result Registers





Figure 15-3 A/D Converter Operation Flow

#### A/D Converter Cautions

# (1) Input range of AN0 to AN5

The input voltages of AN0 to AN7 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 determinated. The conversion values of the other channels may also be affected.

# (2) Noise counter measures

In order to maintain 8-bit resolution, any attention must be paid to noise on pins  $AV_{DD}$  and AN0 to AN7. Since the ef-

fect 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 15-4 Analog Input Pin Connecting Capacitor

#### (3) Pins AN0/R20 to AN5/R25

The analog input pins AN0 to AN5 also function as input/output port (PORT R2) pins. When A/D conversion is performed with any of pins AN0 to AN57 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_{DD}$ pin input impedance

A series resistor string of approximately  $10 K\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.



# 16. BUZZER OUTPUT FUNCTION

The buzzer driver consists of 6-bit binary counter, the buzzer driver register BUZR and the clock selector. It generates square-wave which is very wide range frequency (500 Hz $\sim$ 125 kHz at f<sub>MAIN</sub> = 4MHz) by user programmable counter.

Pin R04/BUZO is assigned for output port of Buzzer driver by setting the bit BUZO of R0 Function Register(R0FUNC) to "1".

The 6-bit buzzer counter is cleared and start the counting by writing signal to the register BUZR. It is increased from 00<sub>H</sub> until it matches with BUR[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 BUZR determines output frequency for

buzzer driving. BUZR[5:0] is initialized to 3F<sub>H</sub> after reset. Note that BUZR is a write-only register. Frequency calculation is following as shown below.

$$f_{BUZ} = \frac{f_{XIN}}{2 \times DivideRatio \times (BUZR[5:0]+1)}$$

The bits BUCK1, BUCK0 of BUZR select the source clock from prescaler output.

f<sub>BUZ</sub>: Buzzer frequency f<sub>XIN</sub>: Oscillator frequency Divide Ratio: Prescaler divide ratio by BUCK[1:0] BUZR[5:0]: Lower 6-bit value of BUZR. Buzzer control data



Figure 16-1 Buzzer Driver

Example: 2.5kHz output at 4MHz.

LDM R0FUNC, #XXX1 XXXXB LDM BUZR, #1001\_1000B X means don't care



# **Buzzer Output Frequency**

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

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

**Table 16-1 Buzzer Output Frequency** 



# 17. INTERRUPTS

The MC80F7708 interrupt circuits consist of Interrupt enable register (IENH, IENM, IENL), Interrupt request flag register(IRQH, IRQM, IRQL), Interrupt flag register(INTFH, INTFL), Interrupt Edge Selection Register (IEDS), priority circuit and Master enable flag ("I" flag of PSW). The interrupts are controlled by the interrupt master enable flag I-flag (bit 2 of PSW), the interrupt enable register and the interrupt request flag register except Power-on reset and software BRK interrupt. The configuration of interrupt circuit is shown in Figure 17-1 and interrupt priority is shown in Table 17-1.

**Table 17-1 Vector Table** 

| Reset/Interrupt      | Symbol | Priority | Vector Addr. |
|----------------------|--------|----------|--------------|
| Hardware Reset       | RESET  | 0        | FFFEH        |
| External Int. 0      | INTR0  | 1        | FFFAH        |
| External Int. 1      | INTR1  | 2        | FFF8H        |
| External Int. 2      | INTR2  | 3        | FFF6H        |
| External Int. 3      | INTR3  | 4        | FFF4H        |
| UART_RX0             | RX0    | 5        | FFF2H        |
| UART_TX0             | TX0    | 6        | FFF2H        |
| Timer 0 Int.         | T0     | 7        | FFEEH        |
| Timer 1 Int.         | T1     | 8        | FFECH        |
| Timer 2 Int.         | T2     | 9        | FFEAH        |
| Timer 3 Int.         | T3     | 10       | FFE8H        |
| A/D Int.             | ADC    | 11       | FFE4H        |
| BIT Int.             | BIT    | 12       | FFE2H        |
| Watch Dog timer int. | WDT    | 13       | FFE0H        |
| Watch timer int.     | WT     | 14       | FFE0H        |

Each bit of interrupt request flag registers(IRQH, IRQM, IRQL) in Figure 17-1 is set when corresponding interrupt condition is met. The interrupt request flags that actually generate external interrupts are bit INT0F, INT1F and INT2F in Register IRQH and INT3F in Register IRQL. The External Interrupts INT0, INT1, INT2 and INT3 can each be transition-activated (1-to-0, 0-to-1 and both transition). The RX0 and TX0 of UART0 Interrupts are generated by RX0IF and TX0IF which are set by finishing the reception and transmission of data.

The Timer 0,1,2 and Timer 3 Interrupts are generated by T0IF,T1IF,T2IF and T3IF, which are set by a match in their respective timer/counter register. The AD converter

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

The Basic Interval Timer Interrupt is generated by BITIF which is set by overflow of the Basic Interval Timer Register (BITR). The Watch dog Interrupt is generated by WDTIF which set by a match in Watch dog timer register (when the bit WDTON is set to "0"). The Watch Timer Interrupt is generated by WTIF which is set periodically according to the established time interval.

When an interrupt is generated, the bit of interrupt request flag register(IRQH, IRQM, IRQL) that generated it may not cleared itself during interrupt acceptance processing. After interrupt acceptance, it should be cleard in interrupt service routine.

Each bit of Interrupt flag register(INTFH, INTFL) is set when corresponding interrupt flag bit as well as interrupt enable bit are set. The bits of interrupt flag register are never cleared by the hardware although the service routine is vectored to. Therefore, the interrupt flag register can be used to distinguish a right interrupt source from two available ones in a vector address. For example, RX0 and TX0 which have the same vector address(FFF2<sub>H</sub>) may be distinguished by INTFH register.

Interrupt enable registers are shown in Figure 17-2. These registers are composed of interrupt enable bits of each interrupt source, these bits determine whether an interrupt will be accepted or not. When enable bit 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.

In an interrupt service routine, any other interrupt may be serviced. The source(s) of these interrupts can be determined by polling the interrupt request flag bits. Then, 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-1 Block Diagram of Interrupt





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.

71



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 proc            | essing      |                                                                |
|        | POP<br>POP<br>POP<br>RETI | Y<br>X<br>A | ;RESTORE Y REG.<br>;RESTORE X REG.<br>;RESTORE ACC.<br>;RETURN |

General-purpose 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 A
PUSH X
PUSH Y
```

```
; Enable INT0 only
LDM
       IENH,#40H
LDM
       IENM,#0
                      ; Disable other
                      ; Disable other
LDM
       IENL,#0
ΕI
                      ; Enable Interrupt
:
LDM
       IENH,#0FFH
                     ; Enable all interrupts
LDM
       IENM, #OFFH
LDM
       IENL, #0F0H
POP
POP
       Χ
POP
       Α
RETI
```





Figure 17-5 Execution of Multi Interrupt



## 17.4 External Interrupt

The external interrupt on INT0, INT1, INT2 and INT3 pins are edge triggered depending on the edge selection register IEDS (address 0FC<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

```
:
;**** Set port as an input port R0
LDM R0IO, #1011_1111B
;
;**** Set port as an interrupt port
LDM PSR0, #0100_0000B
;
;**** Set Falling-edge Detection
LDM IEDS, #0000_0001B
:
:
```

### **Response Time**

The INT0, INT1,INT2 and INT3 edge are latched into INT0F, INT1F, INT2F and INT3F 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. LCD DRIVER

The MC80F7708 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. VCL3  $\sim$  VCL0 voltage are made by the internal bias resistor circuit.

The MC80F7708 has the segement output port 16 pins (SEG0 ~ SEG15) and Common output port 8 pins (COM0 ~ COM7). If the LCDD0 bit of LCR is set to "1", COM4 ~ COM7 is used as SEG19 ~ SEG16.

The Figure 18-1 shows the configuration of the LCD driver.



Figure 18-1 LCD Driver Block Diagram



### 18.1 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 SEG or COM ports are selected by setting corresponding

bits of R5PSR, R6PSR or R7PSR to "0".

The LCD display can continue to operate during SLEEP and STOP modes if sub-frequency clock is used as LCD clock source.



Figure 18-2 LCD Control Register



**Note:** If the SCKD is set to "1", the SXIN and SXOUT pin is used as normal I/O pin R45, R46.

**Note:** When the Sub clock is used as internal bias source clock, stabilization time is needed. Normally, the stabilization time is need more than 500ms.

**Note:** When selecting Sub clock as the LCD clock source, the WTCK[2:0] bit of WTMR(Watch Timer Mode Register) should be set to "000" as well as SCKD bit of LCR be set to "0".

**Note:** Bit 6, Bit 4, Bit 3 of LCR should be set to "1", "0", "1" respectively.

## **Selecting Frame Frequency**

Frame frequency is set to the base frequency as shown in the following Table 18-1. The  $f_S$  is selected to  $f_{SUB}$  (sub clock) which is 32.768kHz.

| I CD[4:0] | LCD clock              | Frame Frequency (Hz) |            |  |  |
|-----------|------------------------|----------------------|------------|--|--|
| LCR[1:0]  | LCD Clock              | Duty = 1/4           | Duty = 1/8 |  |  |
| 00        | f <sub>SUB</sub> ÷ 32  | 128                  | 64         |  |  |
| 01        | f <sub>SUB</sub> ÷ 64  | 64                   | 32         |  |  |
| 10        | f <sub>SUB</sub> ÷ 128 | 32                   | 16         |  |  |
| 11        | $f_{SUB} \div 256$     | 16                   | 8          |  |  |

**Table 18-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 be-

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



### 18.2 LCD BIAS Control

The MC80F7708 has internal Bias Circuit for driving LCD panel. It alse has the contrast controller of 16 step.

The LCD Bias control register and internal Bias circuit is as shown in the Figure 18-3.

The SYS\_BIR[1:0] and BIF of LBCR register is used for controlling BIR. Refer to "24. Butil In Reset (BIR)"

**Note:** The self bias check reference can be applied to contrast adjustment with VDD voltage variation. Because the VDD voltage can be calculated by reading the ADC value of self bias check reference. Writing appropriate value to CTR[3:0] with VDD level, LCD contrast variation with VDD can be reduced.



Figure 18-3 LCD Bias Control



## 18.3 LCD Display Memory

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

The display datas which stored to the display data area (address  $0460_H$ - $0473_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 18-4 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".

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



Figure 18-4 LCD Display Memory



### 18.4 Control Method of LCD Driver

### **Initial Setting**

Flow chart of initial setting is shown in Figure 18-5.

Example: Driving of LCD





Figure 18-5 Initial Setting of LCD Driver

## 

Figure 18-6 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 18-6. 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.





## **LCD Waveform**

The LCD duty(1/4, 1/8) can be selected by LCR register. The example of 1/4 duty, 1/3 bias are shown in shown Figure 18-7.



Figure 18-7 Example of LCD drive output



## 18.5 Duty and Bias Selection of LCD Driver

4 kinds of driving methods can be selected by LCDD[1:0] (bits 3 and 2 of LCD control register) and connection of BIAS pin exter-

nally. Figure 18-8 shows typical driving waveforms for LCD.).



Figure 18-8 LCD Drive Waveform (Voltage COM-SEG Pins)



## 19. UNIVERSAL ASYNCHRONOUS SERIAL INTERFACE

The Asynchronous serial interface(UART) enables full-duplex operation wherein one byte of data after the start bit is transmitted and received. The on-chip baud rate generator dedicated to UART enables communications using a wide range of selectable baud rates.

The UART driver consists of TXSR0, RXBR0, ASIMR0 and BRGCR0 register. Clock asynchronous serial I/O mode (UART) can be selected by ASIMR register. Figure 19-1 shows a block diagram of the serial interface (UART).



Figure 19-1 UART Block Diagram





Figure 19-2 Baud Rate Generator Block Diagram

## 19.1 Asynchronous Serial Interface Configuration

The asychronous serial interface (UART) consists of the following hardware.

| Item                | Configuration                                                                                      |
|---------------------|----------------------------------------------------------------------------------------------------|
| Register            | Transmit shift register (TXSR0)<br>Receive buffer register (RXBR0)                                 |
| Control<br>register | Asynchronous serial interface mode register (ASIMR0)  Baudrate generator control register (BRGCR0) |

**Table 19-1 Serial Interface Configuration** 

## Transmit Shift Register (TXSR0)

This is the register for setting transmit data. Data written to TXSR0 is transmitted as serial data. When the data length is set as 7 bit, bit 0 to 6 of the data written to TXSR0 are transferred as transmit data. Writing data to TXSR0 starts the transmit operation. TXSR0 can be written by an 8 bit memory manipulation instruction. It cannot be read.

**Note:** Do not write to TXSR0 during a transmit operation. The same address is assigned to TXSR0 and the receive buffer register (RXBR0). A read operation reads values

from RXBR0.

## Receive Buffer Register (RXBR0)

This register is used to hold received data. When one byte of data is received, one byte of new received data is transferred from the receive shift register. When the data length is set as 7 bits, received data is sent to bits 0 to 6 of RXBR0. In this case, the MSB of RXBR0 always becomes 0. RXBR0 can be read by an 8 bit memory manipulation instruction. It cannot be written.

**Note:** The same address is assigned to RXBR0 and the tansmit shift register (TXSR0). During a write operation, values are written to TXSR0.

# Asynchronous serial interface mode control register (ASIMR0)

This is an 8 bit register that controls asynchronous serial interface (UART)'s serial transfer operation. ASIMR0 is set by a 1 bit or 8 bit memory manipulation instruction.

### Baud rate generator control register (BRGCR0)

This register sets the serial clock for asynchronous serial interface. BRGCR0 is set by an 8 bit memory manipulation instruction.





Figure 19-1 Asynchronous Serial Interface Mode & Status Register





Figure 19-2 Baud Rate Generator Control Register, Receive Buffer Register, Transmit shift Register



## 19.2 Relationship between main clock and baud rate

The transmit/receive clock that is used to generate the baud rate is obtained by dividing the main system clock. Transmit/Receive clock generation for baud rate is made by using main system clock which is divided.

The baud rate generated from the main system clock is determined according to the following formula

$$BaudRate = \frac{fx}{2^{n+1}(K+16)}$$

- fx : main system clock oscillation frequency - n : value set via TPS0 to TPS1(1  $\leq$  n  $\leq$  7) - k : value set via MDL0 to MDL3 (0  $\leq$  n  $\leq$ 14)

| Baud Rate | f <sub>X</sub> = 11.0 | 592M       | f <sub>X</sub> = 8.0 | ООМ        | f <sub>X</sub> = 7.37 | 728M       | f <sub>X</sub> = 6.0 | ОМ         | f <sub>X</sub> = 5. | 00M        | f <sub>X</sub> = 4.1 | 1943       |
|-----------|-----------------------|------------|----------------------|------------|-----------------------|------------|----------------------|------------|---------------------|------------|----------------------|------------|
| (bps)     | BRGCR                 | Err<br>(%) | BRGCR                | Err<br>(%) | BRGCR                 | Err<br>(%) | BRGCR                | Err<br>(%) | BRGCR               | Err<br>(%) | BRGCR                | Err<br>(%) |
| 600       | -                     | 1          | -                    | İ          | -                     | ı          | -                    | -          | -                   | -          | 7BH                  | 1.14       |
| 1,200     | -                     | 1          | 7AH                  | 0.16       | 78H                   | 0.00       | 73H                  | 2.79       | 70H                 | 1.73       | 6BH                  | 1.14       |
| 2,400     | 72H                   | 0.00       | 6AH                  | 0.16       | 68H                   | 0.00       | 63H                  | 2.79       | 60H                 | 1.73       | 5BH                  | 1.14       |
| 4,800     | 62H                   | 0.00       | 5AH                  | 0.16       | 58H                   | 0.00       | 53H                  | 2.79       | 50H                 | 1.73       | 4BH                  | 1.14       |
| 9,600     | 52H                   | 0.00       | 4AH                  | 0.16       | 48H                   | 0.00       | 43H                  | 2.79       | 40H                 | 1.73       | 3BH                  | 1.14       |
| 19,200    | 42H                   | 0.00       | 3AH                  | 0.16       | 38H                   | 0.00       | 33H                  | 2.79       | 30H                 | 1.73       | 2BH                  | 1.14       |
| 31,250    | 36H                   | 0.52       | 30H                  | 0.00       | 2DH                   | 1.70       | 28H                  | 0.00       | 24H                 | 0.00       | 21H                  | -1.30      |
| 38,400    | 32H                   | 0.00       | 2AH                  | 0.16       | 28H                   | 0.00       | 23H                  | 2.79       | 20H                 | 1.73       | 1BH                  | 1.14       |
| 76,800    | 22H                   | 0.00       | 1AH                  | 0.16       | 18H                   | 0.00       | 13H                  | 2.79       | 10H                 | 1.73       | -                    | -          |
| 115,200   | 18H                   | 0.00       | 11H                  | 2.12       | 10H                   | 0.00       | -                    | -          | -                   | -          | -                    | -          |

Table 19-2 Relationship Between Main Clock and Baud Rate



### 20. OPERATION MODE

The system clock controller starts or stops the main frequency clock oscillator, which is controlled by system clock mode register (SCMR). Figure 20-1 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.

### **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 20-1 Operating Mode

### 20.1 Operation Mode Switching

## Shifting from the Normal operation to the SLEEP mode

By writing "0F<sub>H</sub>" into SSCR which will be explained in "21.1 SLEEP Mode" on page 89, 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 "21.1 SLEEP Mode" on page 89

## Shifting from the Normal operation to the STOP mode

By writing "5A<sub>H</sub>" into SSCR and then executing STOP instruction, the main-frequency clock oscillation stops and the STOP mode is invoked. But sub-frequency 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) and External Interrupt.

For more details, see "21.2 STOP Mode" on page 90.

**Note:** In the STOP and SLEEP 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.



## 21. POWER DOWN OPERATION

MC80F7708 have 2 power down mode. In power down mode, power consumption is reduced considerably in Battery operation that Battery life can be extended a lot.

Sleep mode is entered by writing "0F<sub>H</sub>" into Stop and Sleep Control Register(SSCR), and STOP mode is entered by writing "5A<sub>H</sub>" into SSCR and then executing STOP instruction.

### 21.1 SLEEP Mode

In this mode, the internal oscillation circuits remain active.

Oscillation continues and peripherals are operate normally but CPU stops. The status of all Peripherals in this mode is shown in Table 21-1. Sleep mode is entered by writing " $0F_H$ " into SSCR (address  $0E9_H$ ).

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



Figure 21-1 SLEEP Mode Register



Figure 21-2 Sleep Mode Release Timing by External Interrupt





Figure 21-3 SLEEP Mode Release Timing by RESET pin

### 21.2 STOP Mode

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

## **Start The Stop Operation**

The STOP mode can be entered by STOP instruction during program execution. In Stop mode, the on-chip main-

frequency 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 and 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 | Halted (Only when the Event counter mode is enabled, Timer 0 operates normally)   | Timer/Event counter 0 operates continuously |  |  |
| Watch Timer           | Operates continuously                                                             | Operates continuously                       |  |  |
| 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                                      |  |  |
| Release method        | by RESET, Watch Timer interrupt,<br>Timer interrupt (EC0), and External interrupt | by RESET, All interrupts                    |  |  |

Table 21-1 Peripheral Operation during Power Down Mode

1. Refer to the Table 10-2



| Operating<br>Clock source | Main<br>Operating Mode | Main<br>Sleep Mode | Stop Mode         |  |
|---------------------------|------------------------|--------------------|-------------------|--|
| Main Clock                | Oscillation            | Oscillation        | Stop              |  |
| Sub Clock                 | Oscillation            | Oscillation        | Oscillation       |  |
| System Clock              | Active                 | Stop               | Stop              |  |
| Peri. Clock               | Active                 | Active             | Stop <sup>1</sup> |  |

<sup>1.</sup> Except watch timer(sub clock) and LCD driver(sub clock)

### Table 21-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 ortimer 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 21-4 STOP Mode Release Timing by External Interrupt





Figure 21-5 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<sub>DD</sub>/V<sub>SS</sub>); 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 uniformed voltage level (not  $V_{SS}$  or  $V_{DD}$ ) is applied to input pin, there can be little current (max. 1mA at around 2V) flow.

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





Figure 21-6 Application Example of Unused Input Port





Figure 21-7 Application Example of Unused Output Port



### 22. OSCILLATOR CIRCUIT

The MC80F7708 have three 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 22-1.



Figure 22-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 22-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 22-2 Layout of Oscillator PCB circuit



## **23. RESET**

The MC80F7708 have has four reset generation sources; external reset input, power on reset (POR), built in reset

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

(BIR) and watch-dog timer reset. Table 23-1 shows onchip hardware initialization by reset action.

| On-chip Hardware  | Initial Value                 |  |  |
|-------------------|-------------------------------|--|--|
| Operation mode    | Main-frequency clock          |  |  |
| Peripheral clock  | On                            |  |  |
| Control registers | Refer to Table 8-1 on page 27 |  |  |

Table 23-1 Initializing Internal Status by Reset Action



Figure 23-1 RESET Block Diagram

## 23.1 External Reset Input

The reset input is the  $\overline{RESET}$  pin, which is the input to a Schmitt Trigger. A reset accomplished by holding the  $\overline{RE-SET}$  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) and 7 oscillator periods are required to start execution as shown in Figure 23-3.

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

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

A connection for normal power-on-reset is shown in Figure 23-2.



Figure 23-2 Normal Power-on-Reset Circuit





Figure 23-3 Timing Diagram of RESET

### 23.2 Power On Reset

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

parmeters (voltage, frequency, temperature...etc) must be met.

**Note:** When "POR" option is checked and "R47EN" option is not checked, RESET/R47 pin acts as external Reset input pin. In this case, the external reset circuit should be connected to RESET pin. If external reset is not needed, not only "POR", but also "R47EN" option should be checked.

## 23.3 Built In Reset

Refer to "24. Butil In Reset (BIR)"

## 23.4 Watchdog Timer Reset

Refer to "14. WATCH DOG TIMER"



## 24. Butil In Reset (BIR)

The MC80F7708 has an on-chip BIR(Built In Reset) circuitry to immunize against power noise. The BIR control register BIRR can enable or disable the built in reset cir-

cuitry. The Block diagram of BIR is shown in the Figure 24-1



Figure 24-1 Block Diagram of BIR (Built-In Reset)



The BIR of MC80F7708 has 8 detection level which can be selected by BIS[2:0] and each level can be trimmed by TRM[1:0].

The NC\_SEL bit of BIRR is used for selecting BIR noise canceller. For example, if the NC\_SEL bit of BIRR is set to "1" and VDD voltage falls below the BIR detection level during 20us, BIR does not generates internal reset signal or freeze mode signal because the 32us noise canceller eleminates low level detection signal less than 32us.

BIR result can be selected by SYS\_BIR[1:0] of LBCR register. When SYS\_BIR[1:0] is set to "00", BIR generates reset singnal. If SYS\_BIR[1:0] is set to "10", it generates freeze mode signal and CPU freeze until the VDD voltage returns to regular level.

The self bias check reference, which can be used for calculating VDD voltage, can be activated by setting the AD\_REFB bit to "0" and BIR\_ENB bit to "0". It is used for checking VDD voltage.

BIF is set to "1" when BIR occurs. It can be used to distinguish reset caused by BIR and other.

When the POR is used, the BIR detection level should be set to the level less than POR level. If the POR level is

2.4V, BIR level 2V and 2.4V can not operate.



Figure 24-2 Example Flow of Reset flow by BIR



## 25. Osillation Noise Protector

The Oscillation Noise Protector (ONP) is used to supply stable internal system clock by excluding the noise which could be entered into oscillator and recovery the oscillation fail. This function could be enabled or disabled by the "ONP" bit of the Device configuration area (20FF<sub>H</sub>) for the MC80F7708.

The ONP function is like below.

- Recovery the oscillation wave crushed or loss caused

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



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



The oscillation fail processor (OFP) can change the clock source from external to internal oscillator when the oscillation fail occured. This function could be enabled or disabled by the "OFP" bit of the Device Configuration Area (MASK option for MC80F0708(4)/0808(4)).

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

The "IN8MCLK", "IN4MCLK", "IN2MCLK",

"IN8MCLKXO", "IN4MCLKXO", "IN2MCLKXO" option of the Device Configuration Area enables the function to operate the device by using the internal oscillator clock in ONP block as system clock. There is no need to connect the x-tal, resonator, RC and R externally. After selecting the this option, the period of internal oscillator clock could be checked by  $X_{OUT}$  outputting clock divided the internal oscillator clock by 4.



## 26. FLASH PROGRAMMING SPEC.

## 26.1 FLASH Configuration Byte

Except the user program memory, there is configuration byte(address  $20FF_H$ ) for the selection of program lock, ONP, OPF, oscillation configuration and reset configuration. The configuration byte of FLASH is shown as Figure 26-1. It could be served when user use the FLASH programmer.

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



Figure 26-1 The FLASH Configuration Byte

### 26.2 FLASH Programming

The MC80F7708 is a MTP microcontroller. Its internal user memory is constructed with FLASH ROM..

Blank FLASH's internal memory 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 FLASH or MTP devices, user can use ABOV own programmer.

### **ABOV** own programmer list

Manufacturer: ABOV Semiconductor Programmer:

Choice-Sigma StandAlone-Gang4 PGM-plus

The Choice-Sigma is a ABOV Universal Single Programmer for



all of ABOV FLASH/OTP devices, also the StandAlone-Gang4 can program four FLASH/OTPs at once for ABOV device.

Ask to ABOV sales part for purchasing or more detail.

## **Programming Procedure**

- 1. Select device MC80F7708.
- 2. 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.



## 27. EMULATOR EVA. BOARD SETTING





### 28. IN-SYSTEM PROGRAMMING

## 28.1 Getting Started / Installation

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

### 1. Power off a target system.

- 2. Configure a target system as ISP mode.

  Refer to "28.3 Hardware Conditions to Enter the ISP Mode"
- 3. Attach a ISP B/D into a target system.
- 4. Connect the serial (RS-232C) cable between a ISP board and available serial port of your PC.
- 5. Power on a target system.
- **6. Run the ABOV ISP software.**Download the ISP S/W from www.abov.co.kr.
  Unzip the download file and run ISP 800.exe
- 7. Select a COM port and a device in the ISP S/W.



Figure 28-1 ISP software



#### 28.2 Basic ISP S/W Information

The Figure 28-1 is the ISP software based on Windows<sup>TM</sup>. This software is only supporting devices with UART. Main feature is automatically to search baudrates in range

Table 28-2. In case of not detecting its baudrates an user manually have to select specific baudrates.

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

**Table 28-1 ISP Function Description** 



#### 28.3 Hardware Conditions to Enter the ISP Mode

The boot loader can be executed by holding  $\overline{ALE}$  high,  $\overline{RE}$ - $\overline{SET}/V_{PP}$  as +9V, and ACLK0(optional) with OSC.

1.8432MHz. The ISP function uses following pins: TxD0, RxD0, ALEB, ACLK and  $\overline{RESET}/V_{PP}$ ..





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



Figure 28-2 Timing diagram to enter the ISP mode

Sequence to enter ISP mode from user mode.

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

Sequence to enter user mode from ISP mode.

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

#### 28.5 Difference between auto baud rate and ACK mode

#### Auto Baud Rate Mode(No Use)

The ISP S/W detects user system clock and MCU configure a baud rate automatically. This mode does not need to connect the ACK pin of target MCU to ISP B/D. But the MC80F7708 does not support this mode.

#### **ACK** mode

If the ISP S/W can not detect user system clock, users have to enter a user system clock. This mode is only used when failed to detect user system clock automatically.

Note: Need to connect the ACK pin to ISP B/D.

The mode supported with devices is shown in Table 28-2.

|           | Auto Baud Rate mode | ACK mode |
|-----------|---------------------|----------|
| MC80F0204 | -                   | 0        |
| MC80F0224 | 0                   | 0        |
| MC80F0448 | 0                   | 0        |
| MC80F7708 | -                   | 0        |

Table 28-2 Supported modes according to devices



#### 28.6 Reference ISP Circuit Diagram and ABOV Supplied ISP Board

The ISP software and hardware circuit diagram are provided at *www.abov.co.kr*.

To get a ISP B/D, contact to sales department. The following circuit diagram is for reference use.



Figure 28-3 Reference ISP Circuit Diagram



Figure 28-4 ISP board supplied by ABOV



# **APPENDIX**



# A. INSTRUCTION

## A.1 Terminology List

| Terminology       | Description                                                        |
|-------------------|--------------------------------------------------------------------|
| A                 | 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 (000 <sub>H</sub> ~0FFF <sub>H</sub> ) |
| 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                                                        |
| X                 | Multiplication                                                     |
| /                 | Division                                                           |
| ()                | Contents Expression                                                |
| ^                 | AND                                                                |
| V                 | OR                                                                 |
| <b>⊕</b>          | Exclusive OR                                                       |
| ~                 | NOT                                                                |
| <b>←</b>          | Assignment / Transfer / Shift Left                                 |
| $\rightarrow$     | Shift Right                                                        |
| $\leftrightarrow$ | Exchange                                                           |
| =                 | Equal                                                              |
| ≠                 | Not Equal                                                          |



## A.2 Instruction Map

| LOW<br>HIGH | 00000 | 00001<br>01    | 00010<br>02      | 00011<br>03       | 00100<br>04    | 00101<br>05 | 00110<br>06 | 00111<br>07 | 01000<br>08 | 01001<br>09 | 01010<br>0A | 01011<br>0B   | 01100<br>0C | 01101<br>0D  | 01110<br>0E | 01111<br>0F    |
|-------------|-------|----------------|------------------|-------------------|----------------|-------------|-------------|-------------|-------------|-------------|-------------|---------------|-------------|--------------|-------------|----------------|
| 000         | -     | SET1<br>dp.bit | BBS<br>A.bit,rel | BBS<br>dp.bit,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  | ш              | 66               | cc                | SBC<br>#imm    | SBC<br>dp   | SBC<br>dp+X | SBC<br>!abs | ROL<br>A    | ROL<br>dp   | TCALL<br>2  | CLRA1<br>.bit | COM<br>dp   | POP<br>X     | PUSH<br>X   | BRA<br>rel     |
| 010         | CLRG  | ш              | 66               | cc                | 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    | u              | 66               | cc                | 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  | u              | 66               | cc                | 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  | ££             | 66               | cc                | EOR<br>#imm    | EOR<br>dp   | EOR<br>dp+X | EOR<br>!abs | DEC<br>A    | DEC<br>dp   | TCALL<br>10 | EOR1<br>EOR1B | DBNE<br>dp  | XMA<br>dp+X  | TSPX        | DEC<br>X       |
| 110         | SETG  | "              | 66               | ££                | LDA<br>#imm    | LDA<br>dp   | LDA<br>dp+X | LDA<br>!abs | TXA         | LDY<br>dp   | TCALL<br>12 | LDC<br>LDCB   | LDX<br>dp   | LDX<br>dp+Y  | XCN         | DAS<br>(N/A)   |
| 111         | EI    | "              | 66               | ££                | LDM<br>dp,#imm | STA<br>dp   | STA<br>dp+X | STA<br>!abs | TAX         | STY<br>dp   | TCALL<br>14 | STC<br>M.bit  | STX<br>dp   | STX<br>dp+Y  | XAX         | STOP           |

| LOW<br>HIGH | 10000<br>10 | 10001<br>11    | 10010<br>12      | 10011<br>13       | 10100<br>14 | 10101<br>15   | 10110<br>16   | 10111<br>17   | 11000<br>18 | 11001<br>19 | 11010<br>1A | 11011<br>1B  | 11100<br>1C   | 11101<br>1D | 11110<br>1E  | 11111<br>1F   |
|-------------|-------------|----------------|------------------|-------------------|-------------|---------------|---------------|---------------|-------------|-------------|-------------|--------------|---------------|-------------|--------------|---------------|
| 000         | BPL<br>rel  | CLR1<br>dp.bit | BBC<br>A.bit,rel | BBC<br>dp.bit,rel | ADC<br>{X}  | ADC<br>!abs+Y | ADC<br>[dp+X] | ADC<br>[dp]+Y | ASL<br>!abs | ASL<br>dp+X | TCALL<br>1  | JMP<br>!abs  | BIT<br>!abs   | ADDW<br>dp  | LDX<br>#imm  | JMP<br>[!abs] |
| 001         | BVC<br>rel  | 66             | ee               | 66                | 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  | u              | 66               | **                | CMP<br>{X}  | CMP<br>!abs+Y | CMP<br>[dp+X] | CMP<br>[dp]+Y | LSR<br>!abs | LSR<br>dp+X | TCALL<br>5  | MUL          | TCLR1<br>!abs | CMPW<br>dp  | CMPX<br>#imm | CALL<br>[dp]  |
| 011         | BNE<br>rel  | ш              | ec               | "                 | 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  | ш              | ec               | "                 | 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  | 66             | ee               | 66                | 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  | 66             | ee               | 66                | LDA<br>{X}  | LDA<br>!abs+Y | LDA<br>[dp+X] | LDA<br>[dp]+Y | LDY<br>!abs | LDY<br>dp+X | TCALL<br>13 | LDA<br>{X}+  | LDX<br>!abs   | STYA<br>dp  | XAY          | DAA<br>(N/A)  |
| 111         | BEQ<br>rel  | ш              | и                | и                 | STA<br>{X}  | STA<br>!abs+Y | STA<br>[dp+X] | STA<br>[dp]+Y | STY<br>!abs | STY<br>dp+X | TCALL<br>15 | STA<br>{X}+  | STX<br>!abs   | CBNE<br>dp  | XYX          | NOP           |



## **A.3 Instruction Set**

# **Arithmetic / Logic Operation**

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



| NO  | MAJEMONIO    | OP   | BYTE | CYCLE | ODERATION                                                                           | FLAG     |
|-----|--------------|------|------|-------|-------------------------------------------------------------------------------------|----------|
| NO. | MNEMONIC     | CODE | NO   | NO    | OPERATION                                                                           | NVGBHIZC |
| 45  | EOR #imm     | A4   | 2    | 2     |                                                                                     |          |
| 46  | EOR dp       | A5   | 2    | 3     |                                                                                     |          |
| 47  | EOR dp + X   | A6   | 2    | 4     |                                                                                     |          |
| 48  | EOR !abs     | A7   | 3    | 4     | Exclusive OR                                                                        | NZ-      |
| 49  | EOR !abs + Y | B5   | 3    | 5     | $A \leftarrow (A) \oplus (M)$                                                       |          |
| 50  | EOR [dp + X] | B6   | 2    | 6     |                                                                                     |          |
| 51  | EOR [dp]+Y   | B7   | 2    | 6     |                                                                                     |          |
| 52  | EOR {X}      | B4   | 1    | 3     |                                                                                     |          |
| 53  | INC A        | 88   | 1    | 2     |                                                                                     |          |
| 54  | INC dp       | 89   | 2    | 4     |                                                                                     |          |
| 55  | INC dp + X   | 99   | 2    | 5     | Increment                                                                           | NZ-      |
| 56  | INC !abs     | 98   | 3    | 5     | M ← (M) + 1                                                                         | 10 2     |
| 57  | INC X        | 8F   | 1    | 2     |                                                                                     |          |
| 58  | INC Y        | 9E   | 1    | 2     |                                                                                     |          |
| 59  | LSR A        | 48   | 1    | 2     | Logical shift right                                                                 |          |
| 60  | LSR dp       | 49   | 2    | 4     | 7 6 5 4 3 2 1 0 C                                                                   | N 50     |
| 61  | LSR dp + X   | 59   | 2    | 5     | "0" -> -> -> -> ->                                                                  | NZC      |
| 62  | LSR !abs     | 58   | 3    | 5     |                                                                                     |          |
| 63  | MUL          | 5B   | 1    | 9     | Multiply: $YA \leftarrow Y \times A$                                                | NZ-      |
| 64  | OR #imm      | 64   | 2    | 2     |                                                                                     |          |
| 65  | OR dp        | 65   | 2    | 3     |                                                                                     |          |
| 66  | OR dp + X    | 66   | 2    | 4     | <b>,</b>                                                                            |          |
| 67  | OR !abs      | 67   | 3    | 4     | Logical OR                                                                          |          |
| 68  | OR !abs + Y  | 75   | 3    | 5     | $A \leftarrow (A) \lor (M)$                                                         | NZ-      |
| 69  | OR [dp + X]  | 76   | 2    | 6     |                                                                                     |          |
| 70  | OR [dp]+Y    | 77   | 2    | 6     |                                                                                     |          |
| 71  | OR {X}       | 74   | 1    | 3     |                                                                                     |          |
| 72  | ROL A        | 28   | 1    | 2     | Rotate left through carry                                                           |          |
| 73  | ROL dp       | 29   | 2    | 4     | C 7 6 5 4 3 2 1 0                                                                   |          |
| 74  | ROL dp + X   | 39   | 2    | 5     |                                                                                     | NZC      |
| 75  | ROL !abs     | 38   | 3    | 5     |                                                                                     |          |
| 76  | ROR A        | 68   | 1    | 2     | Rotate right through carry                                                          |          |
| 77  | ROR dp       | 69   | 2    | 4     |                                                                                     |          |
| 78  | ROR dp + X   | 79   | 2    | 5     | 7 6 5 4 3 2 1 0 C                                                                   | NZC      |
| 79  | ROR !abs     | 78   | 3    | 5     |                                                                                     |          |
|     |              |      |      |       |                                                                                     |          |
| 80  | SBC #imm     | 24   | 2    | 2     |                                                                                     |          |
| 81  | SBC dp       | 25   | 2    | 3     |                                                                                     |          |
| 82  | SBC dp + X   | 26   | 2    | 4     |                                                                                     |          |
| 83  | SBC !abs     | 27   | 3    | 4     | Subtract with carry                                                                 | NVHZC    |
| 84  | SBC !abs + Y | 35   | 3    | 5     | A ← (A)-(M)-~(C)                                                                    |          |
| 85  | SBC [dp + X] | 36   | 2    | 6     |                                                                                     |          |
| 86  | SBC [dp]+Y   | 37   | 2    | 6     |                                                                                     |          |
| 87  | SBC {X}      | 34   | 1    | 3     |                                                                                     |          |
| 88  | TST dp       | 4C   | 2    | 3     | Test memory contents for negative or zero ( 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         | BYTE    | CYCLE   | OPERATION                                                                | FLAG     |
|----------|-------------------------|------------|---------|---------|--------------------------------------------------------------------------|----------|
| 1        | LDA #imm                | CODE<br>C4 | NO<br>2 | NO<br>2 | OI EIVATION                                                              | NVGBHIZC |
| 2        | LDA #IIIIII             | C5         | 2       | 3       |                                                                          |          |
| 3        | LDA dp + X              | C6         | 2       | 4       |                                                                          |          |
| 4        | LDA dp + X              | C7         | 3       | 4       | l and annual date                                                        |          |
| 5        | LDA !abs + Y            | D5         | 3       | 5       | Load accumulator                                                         | N F      |
| 6        | LDA [dp + X]            | D6         | 2       | 6       | $A \leftarrow (M)$                                                       | NZ-      |
| 7        | LDA [dp]+Y              | D7         | 2       | 6       |                                                                          |          |
| 8        | LDA {X}                 | D4         | 1       | 3       |                                                                          |          |
| 9        | LDA { X }+              | DB         | 1       | 4       |                                                                          |          |
| 10       | ` ,                     | E4         | 3       |         | X- register auto-increment : A $\leftarrow$ ( M ) , X $\leftarrow$ X + 1 |          |
| 11       | LDM dp,#imm<br>LDX #imm | 1E         | 2       | 5       | Load memory with immediate data : ( M ) ← imm                            |          |
|          |                         |            |         |         |                                                                          |          |
| 12<br>13 | LDX dp<br>LDX dp + Y    | CC         | 2       | 3       | Load X-register                                                          | NZ-      |
|          | ,                       | CD         |         | 4       | $X \leftarrow (M)$                                                       |          |
| 14       | LDX !abs                | DC         | 3       | 4       |                                                                          |          |
| 15       | LDY #imm                | 3E         | 2       | 2       |                                                                          |          |
| 16       | LDY dp                  | C9         | 2       | 3       | Load Y-register                                                          | NZ-      |
| 17       | LDY dp + X              | D9         | 2       | 4       | $Y \leftarrow (M)$                                                       |          |
| 18       | LDY !abs                | D8         | 3       | 4       |                                                                          |          |
| 19       | STA dp                  | E5         | 2       | 4       |                                                                          |          |
| 20       | STA dp + X              | E6         | 2       | 5       |                                                                          |          |
| 21       | STA !abs                | E7         | 3       | 5       | Store accumulator contents in memory                                     |          |
| 22       | STA !abs + Y            | F5         | 3       | 6       | ( M ) ← A                                                                |          |
| 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) \leftarrow X$                                                       |          |
| 29       | STX !abs                | FC         | 3       | 5       | $(\mathbf{w}) \leftarrow \mathbf{x}$                                     |          |
| 30       | STY dp                  | E9         | 2       | 4       | Store Y-register contents in memory                                      |          |
| 31       | STY dp + X              | F9         | 2       | 5       | (M) ← Y                                                                  |          |
| 32       | STY !abs                | F8         | 3       | 5       | (W) / ~ 1                                                                |          |
| 33       | TAX                     | E8         | 1       | 2       | Transfer accumulator contents to X-register : $X \leftarrow A$           | NZ-      |
| 34       | TAY                     | 9F         | 1       | 2       | Transfer accumulator contents to Y-register : $Y \leftarrow A$           | NZ-      |
| 35       | TSPX                    | AE         | 1       | 2       | Transfer stack-pointer contents to X-register : $X \leftarrow sp$        | NZ-      |
| 36       | TXA                     | C8         | 1       | 2       | Transfer X-register contents to accumulator: $A \leftarrow X$            | NZ-      |
| 37       | TXSP                    | 8E         | 1       | 2       | Transfer X-register contents to stack-pointer: $sp \leftarrow X$         | NZ-      |
| 38       | TYA                     | BF         | 1       | 2       | Transfer Y-register contents to accumulator: $A \leftarrow Y$            | NZ-      |
| 39       | XAX                     | EE         | 1       | 4       | Exchange X-register contents with accumulator :X ↔ A                     |          |
| 40       | XAY                     | DE         | 1       | 4       | Exchange Y-register contents with accumulator :Y ↔ A                     |          |
| 41       | XMA dp                  | ВС         | 2       | 5       | Exchange memory contents with accumulator                                |          |
| 42       | XMA dp+X                | AD         | 2       | 6       | $(M) \leftrightarrow A$                                                  | NZ-      |
| 43       | XMA {X}                 | BB         | 1       | 5       |                                                                          |          |
| 44       | XYX                     | FE         | 1       | 4       | Exchange X-register contents with Y-register : X ↔ Y                     |          |
|          | +                       | -          | ·       |         | · · · · · · · · · · · · · · · · · · ·                                    | +        |



## **16-BIT Operation**

| NO. | MNEMONIC | OP<br>CODE | BYTE<br>NO | CYCLE<br>NO | OPERATION                                                         | FLAG<br>NVGBHIZC |
|-----|----------|------------|------------|-------------|-------------------------------------------------------------------|------------------|
| 1   | ADDW dp  | 1D         | 2          | 5           | 16-Bits add without carry YA ← (YA) + (dp +1) (dp)                | NVH-ZC           |
| 2   | CMPW dp  | 5D         | 2          | 4           | Compare YA contents with memory pair contents : (YA) – (dp+1)(dp) | NZC              |
| 3   | DECW dp  | BD         | 2          | 6           | Decrement memory pair $(dp+1)(dp) \leftarrow (dp+1)(dp) - 1$      | NZ-              |
| 4   | INCW dp  | 9D         | 2          | 6           | Increment memory pair $(dp+1)(dp) \leftarrow (dp+1)(dp) + 1$      | NZ-              |
| 5   | LDYA dp  | 7D         | 2          | 5           | Load YA<br>YA ← (dp +1)(dp)                                       | NZ-              |
| 6   | STYA dp  | DD         | 2          | 5           | Store YA<br>( dp +1 ) ( dp ) ← YA                                 |                  |
| 7   | SUBW dp  | 3D         | 2          | 5           | 16-Bits substact without carry YA ← ( 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)$            | MM7-             |
| 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$ $\sim$ (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$ ~( M .bit )                               | C                |
| 14  | NOT1 M.bit  | 4B         | 3          | 5           | Bit complement : $(M.bit) \leftarrow \sim (M.bit)$                              |                  |
| 15  | OR1 M.bit   | 6B         | 3          | 5           | Bit OR C-flag : $C \leftarrow (C) \lor (M.bit)$                                 | C                |
| 16  | OR1B M.bit  | 6B         | 3          | 5           | Bit OR C-flag and NOT : $C \leftarrow (C) \lor \sim (M .bit)$                   | C                |
| 17  | SET1 dp.bit | x1         | 2          | 4           | Set bit : ( M.bit ) ← "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 : $A - (M)$ , $(M) \leftarrow (M) \lor (A)$            | NZ-              |

April 1, 2008 Ver 1.0 vii



# **Branch / Jump Operation**

| NO. | MNEMONIC       | OP<br>CODE | BYTE<br>NO | CYCLE<br>NO | OPERATION                                                                                                                                                                                                                                                                                                                              | FLAG<br>NVGBHIZC |
|-----|----------------|------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 1   | BBC A.bit,rel  | y2         | 2          | 4/6         | Branch if bit clear :                                                                                                                                                                                                                                                                                                                  |                  |
| 2   | BBC dp.bit,rel | у3         | 3          | 5/7         | if (bit) = 0, then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                                                                                          |                  |
| 3   | BBS A.bit,rel  | x2         | 2          | 4/6         | Branch if bit set :                                                                                                                                                                                                                                                                                                                    |                  |
| 4   | BBS dp.bit,rel | x3         | 3          | 5/7         | if ( bit ) = 1 , then pc ← ( 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<br>if $(N) = 0$ , then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                                                                      |                  |
| 11  | BRA rel        | 2F         | 2          | 4           | Branch always pc ← ( pc ) + rel                                                                                                                                                                                                                                                                                                        |                  |
| 12  | BVC rel        | 30         | 2          | 2/4         | Branch if overflow bit clear<br>if $(V) = 0$ , then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                                                         |                  |
| 13  | BVS rel        | В0         | 2          | 2/4         | Branch if overflow bit set<br>if $(V) = 1$ , then $pc \leftarrow (pc) + rel$                                                                                                                                                                                                                                                           |                  |
| 14  | CALL !abs      | 3B         | 3          | 8           | Subroutine call                                                                                                                                                                                                                                                                                                                        |                  |
| 15  | CALL [dp]      | 5F         | 2          | 8           | $M(sp)\leftarrow (pc_H)$ , $sp\leftarrow sp-1$ , $M(sp)\leftarrow (pc_L)$ , $sp\leftarrow sp-1$ , if !abs, $pc\leftarrow abs$ ; if [dp], $pc_L\leftarrow (dp)$ , $pc_H\leftarrow (dp+1)$ .                                                                                                                                             |                  |
| 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 labs       | 1B         | 3          | 3           |                                                                                                                                                                                                                                                                                                                                        |                  |
| 21  | JMP [!abs]     | 1F         | 3          | 5           | Unconditional jump                                                                                                                                                                                                                                                                                                                     |                  |
| 22  | JMP [dp]       | 3F         | 2          | 4           | pc ← jump address                                                                                                                                                                                                                                                                                                                      |                  |
| 23  | PCALL upage    | 4F         | 2          | 6           | U-page call $ \begin{aligned} & \text{M(sp)} \leftarrow \text{( pc}_{\text{H}} \text{ ), sp} \leftarrow \text{sp - 1, M(sp)} \leftarrow \text{( pc}_{\text{L}} \text{),} \\ & \text{sp} \leftarrow \text{sp - 1, pc}_{\text{L}} \leftarrow \text{( upage ), pc}_{\text{H}} \leftarrow \text{"0FF}_{\text{H}} \text{"}. \end{aligned} $ |                  |
| 24  | TCALL n        | nA         | 1          | 8           | Table call : (sp) $\leftarrow$ ( pc <sub>H</sub> ), sp $\leftarrow$ sp - 1,<br>M(sp) $\leftarrow$ ( pc <sub>L</sub> ),sp $\leftarrow$ sp - 1,<br>pc <sub>L</sub> $\leftarrow$ (Table vector L), pc <sub>H</sub> $\leftarrow$ (Table vector H)                                                                                          |                  |



## **Control Operation & Etc.**

| NO. | MNEMONIC | OP<br>CODE | BYTE<br>NO | CYCLE<br>NO | OPERATION                                                                                                                                                                                                                                                   | FLAG<br>NVGBHIZC |
|-----|----------|------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 1   | BRK      | 0F         | 1          | 8           | Software interrupt : $B \leftarrow$ "1", $M(sp) \leftarrow (pc_H)$ , $sp \leftarrow sp-1$ , $M(s) \leftarrow (pc_L)$ , $sp \leftarrow sp-1$ , $M(sp) \leftarrow (PSW)$ , $sp \leftarrow sp-1$ , $pc_L \leftarrow (0FFDE_H)$ , $pc_H \leftarrow (0FFDF_H)$ . | 1-0              |
| 2   | DI       | 60         | 1          | 3           | Disable interrupts : I ← "0"                                                                                                                                                                                                                                | 0                |
| 3   | El       | E0         | 1          | 3           | Enable interrupts : I ← "1"                                                                                                                                                                                                                                 | 1                |
| 4   | NOP      | FF         | 1          | 2           | No operation                                                                                                                                                                                                                                                |                  |
| 5   | POP A    | 0D         | 1          | 4           | $sp \leftarrow sp + 1, A \leftarrow M(sp)$                                                                                                                                                                                                                  |                  |
| 6   | POP X    | 2D         | 1          | 4           | $sp \leftarrow sp + 1, X \leftarrow M(sp)$                                                                                                                                                                                                                  |                  |
| 7   | POP Y    | 4D         | 1          | 4           | $sp \leftarrow sp + 1, Y \leftarrow M(sp)$                                                                                                                                                                                                                  |                  |
| 8   | POP PSW  | 6D         | 1          | 4           | $sp \leftarrow sp + 1$ , $PSW \leftarrow M(sp)$                                                                                                                                                                                                             | restored         |
| 9   | PUSH A   | 0E         | 1          | 4           | $M(sp) \leftarrow A, sp \leftarrow sp - 1$                                                                                                                                                                                                                  |                  |
| 10  | PUSH X   | 2E         | 1          | 4           | $M(sp) \leftarrow X, sp \leftarrow sp - 1$                                                                                                                                                                                                                  |                  |
| 11  | PUSH Y   | 4E         | 1          | 4           | $M(sp) \leftarrow Y, sp \leftarrow sp - 1$                                                                                                                                                                                                                  |                  |
| 12  | PUSH PSW | 6E         | 1          | 4           | M( sp ) ← 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           | Return from interrupt $sp \leftarrow sp +1$ , $PSW \leftarrow M(sp)$ , $sp \leftarrow sp +1$ , $pc_L \leftarrow M(sp)$ , $sp \leftarrow sp +1$ , $pc_H \leftarrow M(sp)$                                                                                    | restored         |
| 15  | STOP     | EF         | 1          | 3           | Stop mode ( halt CPU, stop oscillator )                                                                                                                                                                                                                     |                  |