# EM78P451S

# 8-Bit Microcontroller with OTP ROM

# Product Specification

Doc. Version 1.4

**ELAN MICROELECTRONICS CORP.** 

March 2010



#### **Trademark Acknowledgments:**

IBM is a registered trademark and PS/2 is a trademark of IBM. Windows is a trademark of Microsoft Corporation.

ELAN and ELAN logo are trademarks of ELAN Microelectronics Corporation.

#### Copyright © 2004~2010 by ELAN Microelectronics Corporation **All Rights Reserved** Printed in Taiwan

The contents of this specification are subject to change without further notice. ELAN Microelectronics assumes no responsibility concerning the accuracy, adequacy, or completeness of this specification. ELAN Microelectronics makes no commitment to update, or to keep current the information and material contained in this specification. Such information and material may change to conform to each confirmed order.

In no event shall ELAN Microelectronics be made responsible for any claims attributed to errors, omissions, or other inaccuracies in the information or material contained in this specification. ELAN Microelectronics shall not be liable for direct, indirect, special incidental, or consequential damages arising from the use of such information or material.

The software (if any) described in this specification is furnished under a license or nondisclosure agreement, and may be used or copied only in accordance with the terms of such agreement.

ELAN Microelectronics products are not intended for use in life support appliances, devices, or systems. Use of ELAN Microelectronics product in such applications is not supported and is prohibited.

NO PART OF THIS SPECIFICATION MAY BE REPRODUCED OR TRANSMITTED IN ANY FORM OR BY ANY MEANS WITHOUT THE EXPRESSED WRITTEN PERMISSION OF ELAN MICROELECTRONICS.



#### **ELAN MICROELECTRONICS CORPORATION**

#### **Headquarters:**

No. 12, Innovation Road 1 Hsinchu Science Park Hsinchu, TAIWAN 308 Tel: +886 3 563-9977 Fax: +886 3 563-9966 webmaster@emc.com.tw http://www.emc.com.tw

#### Hong Kong:

#### Elan (HK) Microelectronics Corporation, Ltd.

Flat A, 19F., World Tech Centre 95 How Ming Street, Kwun Tong Kowloon, HONG KONG Tel: +852 2723-3376

Fax: +852 2723-7780

#### Shenzhen:

#### **Elan Microelectronics** Shenzhen, Ltd.

3F, SSMEC Bldg., Gaoxin S. Ave. I #34, First Fl., 2<sup>nd</sup> Bldg., Shenzhen Hi-tech Industrial Park (South Area), Shenzhen CHINA 518057 Tel: +86 755 2601-0565 Fax: +86 755 2601-0500 elan-sz@elanic.com.cn

#### USA:

#### **Elan Information Technology Group (U.S.A.)**

PO Box 601 Cupertino, CA 95015 U.S.A. Tel: +1 408 366-8225

Fax: +1 408 366-8225

Shanghai:

#### **Elan Microelectronics** Shanghai, Ltd.

Lane 122, Chunxiao Rd. Zhangjiang Hi-Tech Park Shanghai, CHINA 201203 Tel: +86 21 5080-3866 Fax: +86 21 5080-4600 elan-sh@elanic.com.cn



| 1 | Gen   | eral De        | scription                               | 1    |  |  |  |  |  |  |
|---|-------|----------------|-----------------------------------------|------|--|--|--|--|--|--|
| 2 | Feat  | ures           |                                         | 1    |  |  |  |  |  |  |
| 3 | Pin / | Pin Assignment |                                         |      |  |  |  |  |  |  |
| 4 | Pin I | Descrip        | tion                                    | 3    |  |  |  |  |  |  |
|   | 4.1   | EM78F          | P451SP and EM78P451SAQ                  | 3    |  |  |  |  |  |  |
|   | 4.2   |                | P451SDM                                 |      |  |  |  |  |  |  |
| 5 | Fund  | ctional        | Description                             | 5    |  |  |  |  |  |  |
|   | 5.1   |                | tional Registers                        |      |  |  |  |  |  |  |
|   | 0.1   | 5.1.1          | R0 (Indirect Address Register)          |      |  |  |  |  |  |  |
|   |       | 5.1.2          | R1 (TCC)                                |      |  |  |  |  |  |  |
|   |       | 5.1.3          | R2 (Program Counter) and Stack          |      |  |  |  |  |  |  |
|   |       | 5.1.4          | R3 (Status Register)                    |      |  |  |  |  |  |  |
|   |       | 5.1.5          | R4 (RAM Select Register)                |      |  |  |  |  |  |  |
|   |       | 5.1.6          | R5~R8 (Port 5 ~ Port 8)                 |      |  |  |  |  |  |  |
|   |       | 5.1.7          | R9 (Port 9)                             |      |  |  |  |  |  |  |
|   |       | 5.1.8          | RA (SPIRB: SPI Read Buffer)             | 9    |  |  |  |  |  |  |
|   |       | 5.1.9          | RB (SPIWB: SPI Write Buffer)            | 9    |  |  |  |  |  |  |
|   |       | 5.1.10         | RC (SPIS: SPI Status Register)          | 9    |  |  |  |  |  |  |
|   |       | 5.1.11         | RD (SPIC: SPI Control Register)         | .10  |  |  |  |  |  |  |
|   |       | 5.1.12         | RE (TMR1: Timer 1 Register)             | . 11 |  |  |  |  |  |  |
|   |       | 5.1.13         | RF (PWP: Pulse Width Preset Register)   | . 11 |  |  |  |  |  |  |
|   |       | 5.1.14         | R20~R3E (General-Purpose Register)      | . 11 |  |  |  |  |  |  |
|   |       | 5.1.15         | R3F (Interrupt Status Register)         | . 11 |  |  |  |  |  |  |
|   | 5.2   | Specia         | l Purpose Registers                     | 12   |  |  |  |  |  |  |
|   |       | 5.2.1          | A (Accumulator)                         | .12  |  |  |  |  |  |  |
|   |       | 5.2.2          | CONT (Control Register)                 |      |  |  |  |  |  |  |
|   |       | 5.2.3          | IOC5 ~ IOC9 (I/O Port Control Register) |      |  |  |  |  |  |  |
|   |       | 5.2.4          | IOCC (T1CON: Timer 1 Control Register)  |      |  |  |  |  |  |  |
|   |       | 5.2.5          | IOCD (Pull-high Control Register)       |      |  |  |  |  |  |  |
|   |       | 5.2.6          | IOCE (WDT Control Register)             |      |  |  |  |  |  |  |
|   |       | 5.2.7          | IOCF (Interrupt Mask Register)          |      |  |  |  |  |  |  |
|   | 5.3   | TCC/W          | /DT Presacler                           | 16   |  |  |  |  |  |  |
|   | 5.4   | I/O Po         | rts                                     | 16   |  |  |  |  |  |  |
|   | 5.5   | Serial         | Peripheral Interface Mode               | 18   |  |  |  |  |  |  |
|   |       | 5.5.1          | Overview and Features                   | .18  |  |  |  |  |  |  |
|   |       | 5.5.2          | SPI Function Description                | .20  |  |  |  |  |  |  |
|   |       | 5.5.3          | SPI Signal and Pin Description          | .22  |  |  |  |  |  |  |
|   |       | 5.5.4          | Programming the Related Registers       | .23  |  |  |  |  |  |  |
|   |       | 5.5.5          | SPI Mode Timing                         |      |  |  |  |  |  |  |
|   |       | 5.5.6          | SPI Software Application                | .27  |  |  |  |  |  |  |



|   | 5.6  | Timer    | 1                                                  | 30 |
|---|------|----------|----------------------------------------------------|----|
|   |      | 5.6.1    | Overview                                           | 30 |
|   |      | 5.6.2    | Function Description                               | 30 |
|   |      | 5.6.3    | Programming the Related Registers                  | 31 |
|   | 5.7  | Reset    | and Wake-up                                        | 32 |
|   |      | 5.7.1    | The Status of RST, T, and P of the Status Register | 37 |
|   | 5.8  | Interru  | t                                                  | 38 |
|   | 5.9  | Oscilla  | ator                                               | 39 |
|   |      | 5.9.1    | Oscillator Modes                                   | 39 |
|   |      | 5.9.2    | Crystal Oscillator/Ceramic Resonators (Crystal)    | 39 |
|   |      | 5.9.3    | RC Oscillator Mode                                 | 41 |
|   | 5.10 | Code     | Option Register                                    | 42 |
|   |      | 5.10.1   | Word 0                                             | 42 |
|   |      | 5.10.2   | Word 1 (User's ID Code)                            | 43 |
|   | 5.11 | Instruc  | ction Set                                          | 44 |
| 6 | Abs  | olute M  | laximum Ratings                                    | 46 |
| 7 | Elec | trical C | Characteristics                                    | 46 |
|   | 7.1  | DC Cr    | naracteristics                                     | 46 |
|   | 7.2  | AC Ch    | naracteristics                                     | 47 |
| 8 | Timi | ng Dia   | grams                                              | 48 |
| 9 | App  | lication | n Circuit                                          | 49 |
|   |      |          |                                                    |    |
|   |      |          | APPENDIX                                           |    |
| Α | Pacl | kage Ty  | ype                                                | 50 |
| В | Pacl | kage In  | formation                                          | 50 |
| С | Proc | aram Te  | emperature Restriction                             | 56 |

# **Specification Revision History**

| Doc. Version | Revision Description                                  | Date       |
|--------------|-------------------------------------------------------|------------|
| 1.0          | Initial version                                       | 2004/06/01 |
| 1.1          | Added program temperature restriction                 | 2007/10/26 |
| 1.2          | Added a package with new pin assignment (EM78P451SDM) | 2008/12/31 |
| 1.3          | Removed the package type "EM784P51SWM"                | 2009/7/20  |
| 1.4          | Added dice information (EM78P451SH)                   | 2010/03/09 |



# 1 General Description

The EM78451S is an 8-bit microprocessor designed and developed with low-power, high-speed CMOS technology. It has 4K×13-bit on-chip ROM and 140×8-bit on-chip general purpose registers. Its operational kernel is implemented with RISC-like architecture and it is available in mask ROM version. The one time programmable (OTP) version is flexible, in both mass production and engineering test stages. OTP provides users with unlimited volume along with favorable price opportunities. This device is equipped with Serial Peripheral Interface (SPI) function, and it is suitable for wired communication. There are 58 easy-to-learn instructions and the user's program can be emulated with the EMC In-Circuit Emulator (ICE)

## 2 Features

- CPU configuration
  - 4K×13 bits on-chip ROM
  - 140×8 bits on chip general purpose registers
  - 11 special function registers
  - 5-level stacks for subroutine nesting
- Low power consumption:
  - Less than 3 mA at 5V / 4 MHz
  - Typically 10 μA during sleep mode
- I/O port configuration
  - 5 bidirectional I/O ports (35 I/O pins)
  - 12 Wake-up pins
  - 32 programmable pull-high input pins
  - 2 open-drain I/O pins
  - 2 R-option pins
- Operating voltage range: 2.3V ~ 5.5V
- Operating temperature range: 0 ~ 70℃
- Operating frequency range (base on two clocks):
  - Crystal mode:

DC ~ 20 MHz @ 5V

DC ~ 8 MHz @ 3V

DC ~ 4 MHz @ 2.3V

RC mode:

DC ~ 4 MHz @ 2.3V

- Serial Peripheral Interface (SPI)
- Four available interrupts:
  - External interrupt (/INT)
  - SPI transmission completed interrupt
  - TCC overflow interrupt
  - Timer 1 comparator match interrupt
- Peripheral configuration
  - 8-bit real time clock/counter (TCC) with overflow interrupt
  - Power down mode
  - I/O ports have Programmable wake-up function from sleep mode
- Built-in RC oscillator with external serial resistor. ± 10% variation
- 2 ~ 4 machine clocks for each instruction cycle
- 3 LED Direct sinking pins with internal serial resistors
- Built-in power-on reset
- Programmable free running on-chip watchdog timer
- Package Type:

40-pad DICE : EM78P451SH
 40-pin DIP 600mil : EM78P451SP
 44-pin QFP : EM78P451SAQ
 24-pin SSOP 209mil : EM78P451SDM



# 3 Pin Assignment



Figure 3-1a 40-pin DIP EM78P451SP

Figure 3-1b 44-pin QFP EM784P51SAQ



Figure 3-1c 24-pin SSOP EM784P51SDM



# **Pin Description**

# 4.1 EM78P451SP and EM78P451SAQ

| Symbol        | Pin No. | Туре | Function Description                                                                                                                                                                              |
|---------------|---------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P50~P57       | 11~18   | I/O  | 8-bit bidirectional general-purpose I/O port. All of its pins can be pulled-high individually by software.                                                                                        |
| P60~P67       | 27~34   | I/O  | 8-bit bidirectional general-purpose I/O port. All of its pins can be pulled-high by software, and pin-change wake-up pins.                                                                        |
| P70~P72       | 37~35   | I/O  | LED direct-driving pins with internal serial resistor used as output and is software defined.                                                                                                     |
| P80~P87       | 19~26   | I/O  | 8-bit bidirectional general-purpose I/O port. All of its pins can be pulled-high by software. P80 and P81 are also used as R-option pins.                                                         |
| P90~P95       | 5~10    | I/O  | 6-bit bidirectional general-purpose I/O port. All of its pins can be pulled-high by software. P90 and P91 are pin-change wake-up pins.                                                            |
| P70/<br>RESET | 19      | I/O  | LED direct-driving pin with internal serial resistor used as output and is software defined.  Code option Bit 3 (REN): reset enable  REN=0 → for reset pin  REN=1 → for general purpose I/O (P70) |
|               |         |      | Internal pull high resistor 220KΩ                                                                                                                                                                 |
| R-OSCI        | 21      | I    | In Crystal mode: Crystal input In internal C, external R mode: $56K\Omega\pm5\%$ pull-high for 1.8432 MHz                                                                                         |
| osco          | 22      | 0    | In Crystal mode: Crystal output In RC mode: Instruction clock output                                                                                                                              |
| CLK           | 4       | I/O  | By connecting P74 and P76 together, P74 can be pulled-high by software and it is also a pin-change wake-up pin. P76 can be defined as an open-drain output.                                       |
| DATA          | 3       | I/O  | By connecting P75 and P77 together, P75 can be pulled-high by software and it is also a pin-change wake-up pin. P77 can be defined as an open-drain output.                                       |
| VDD           | 38      | _    | Power supply pin                                                                                                                                                                                  |
| VSS           | 1       | _    | Ground pin                                                                                                                                                                                        |
| /INT          | 2       | I    | Interrupt Schmitt trigger pin.  The interrupt function is triggerred at a falling edge.  Users can enable it by software.                                                                         |
| SDI           | 7       | I/O  | Serial data in for SPI                                                                                                                                                                            |
| SDO           | 8       | I/O  | Serial data out for SPI                                                                                                                                                                           |
| SCK           | 9       | I/O  | Serial clock for SPI                                                                                                                                                                              |
| /SS           | 10      | I/O  | /Slave select for SPI                                                                                                                                                                             |



# 4.2 EM78P451SDM

| Symbol        | Pin No. | Туре | Function Description                                                                                                                                                                                                                                                      |
|---------------|---------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P50~P54       | 4~8     | I/O  | 5-bit bidirectional general-purpose I/O port. All of its pins can be pulled-high individually by software.                                                                                                                                                                |
| P60~P67       | 9~16    | I/O  | 8-bit bidirectional general-purpose I/O port. All of its pins can be pulled-high by software, and pin-change wake-up pins.                                                                                                                                                |
| P70~P72       | 19~17   | I/O  | LED direct-driving pins with internal serial resistor used as output and is software defined.                                                                                                                                                                             |
| P92~P94       | 1~3     | I/O  | 3-bit bidirectional general-purpose I/O port. All of its pins can be pulled-high by software.                                                                                                                                                                             |
| P70/<br>RESET | 37      | I/O  | LED direct-driving pin with internal serial resistor used as output and is software defined.   Code option Bit 3 (REN): reset enable   REN=0 $\rightarrow$ for reset pin   REN=1 $\rightarrow$ for general purpose I/O (P70)   Internal pull high resistor 220 K $\Omega$ |
| R-OSCI        | 39      | I    | In Crystal mode: Crystal input In internal C, external R mode: 56 K $\Omega$ $\pm$ 5% pull high for 1.8432 MHz                                                                                                                                                            |
| osco          | 40      | 0    | In Crystal mode: Crystal output In RC mode: Instruction clock output                                                                                                                                                                                                      |
| VDD           | 20      | -    | Power supply pin                                                                                                                                                                                                                                                          |
| VSS           | 23      | 1    | Ground pin                                                                                                                                                                                                                                                                |
| /INT          | 24      | I    | Interrupt Schmitt trigger pin.  The interrupt function is triggerred at a falling edge.  Users can enable it by software.                                                                                                                                                 |
| SDI           | 7       | I/O  | Serial data in for SPI                                                                                                                                                                                                                                                    |
| SDO           | 8       | I/O  | Serial data out for SPI                                                                                                                                                                                                                                                   |
| SCK           | 9       | I/O  | Serial clock for SPI                                                                                                                                                                                                                                                      |

**Note:** The control registers of unused I/O pins which are shown in EM78P451SP/SAQ but not in EM78P451SDM, should be set to output low.



# **5 Functional Description**



Figure 5-1 Functional Block Diagram

# 5.1 Operational Registers

#### 5.1.1 R0 (Indirect Address Register)

R0 is not a physically implemented register. It is used as an indirect addressing pointer. Any instruction using R0 as register actually accesses data pointed by the RAM Select Register (R4).

#### 5.1.2 R1 (TCC)

- Increased by the instruction cycle clock.
- Written and read by program as any other register.

#### 5.1.3 R2 (Program Counter) and Stack

- R2 and the hardware stacks are 12 bits wide.
- The structure is depicted in Figure 5-2.
- Generates 4K×13 on-chip ROM addresses to the relative programming instruction codes. One program page is 1024 words long.
- All the R2 bits are set to "1"s as reset condition occurs.



- "JMP" instruction allows direct loading of the lower 10 program counter bits. Thus,
   "JMP" allows jump to any location on one page.
- "CALL" instruction loads the lower 10 bits of the PC, and then PC+1 is pushed into the stack. Thus, the subroutine entry address can be located anywhere within a page.
- "RET" ("RETL k", "RETI") instruction loads the program counter with the contents at the top of the stack.
- "MOV R2, A" allows the loading of an address from the "A" register to the lower 8 bits of PC, and the ninth and tenth bits (A8~A9) of PC are cleared.
- "ADD R2, A" allows a relative address be added to the current PC, and the ninth and tenth bits of PC are cleared.
- Any instruction that is written to R2 (e.g. "ADD R2, A", "MOV R2, A", "BC R2, 6", etc., except for "TBL") will cause the ninth and tenth bits (A8~A9) of the PC to be cleared. Thus, the computed jump is limited to the first 256 locations of any program page.
- "TBL" allows a relative address to be added to the current PC (R2+A→R2), and the contents of the ninth and tenth bits (A8~A9) of the PC are not changed. Thus, the computed jump can be on the 2nd (or 3rd, or 4th) 256 locations on one program page.
- In the case of EM78P451S, the most significant bits (A10~A11) will be loaded with the contents of bits PS0~PS1 in the status register (R3) upon the execution of a "JMP", "CALL", or any other instructions which writes to R2.
- All instructions are single instruction cycle (fclk/2 or fclk/4) except for the instruction that would change the contents R2. Such instruction will need one more instruction cycle.



Figure 5-2 Program Counter Organization



#### 5.1.4 R3 (Status Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| GP    | PS1   | PS0   | Т     | Р     | Z     | DC    | С     |

Bit 7 (GP) General read/write bit.

Bits 6 ~ 5 (PS1 ~ PS0): Page select bits. PS0~PS1 are used to pre-select a program memory page. When executing a "JMP", "CALL", or other instructions which causes the program counter to be changed (e.g. MOV R2, A), PS0~PS1 are loaded into the 11th and 12th bits of the program counter where it selects selecting one of the available program memory pages. Note that RET (RETL, RETI) instruction does not change the PS0~PS1 bits. That is, the return will always be to the page from where the subroutine was called, regardless of the current setting of PS0~PS1 bits. PS1 bit is not used (read as "0") and cannot be modified in EM78P451S.

| PS1 | PS0 | Program Memory Page [Address] |
|-----|-----|-------------------------------|
| 0   | 0   | Page 0 [000-3FF]              |
| 0   | 1   | Page 1 [400-7FF]              |
| 1   | 0   | Page 2 [800-BFF]              |
| 1   | 1   | Page 3 [C00-FFF]              |

- **Bit 4 (T)** Time-out bit. Set to 1 with the "SLEP" and the "WDTC" commands, or during power up and reset to 0 with WDT timeout.
- **Bit 3 (P)** Power down bit. Set to 1 during power on or by a "WDTC" command and reset to 0 by a "SLEP" command.
- Bit 2 (Z) Zero flag. Set to "1" if the result of an arithmetic or logic operation is zero.
- Bit 1 (DC) Auxiliary carry flag
- Bit 0 (C) Carry flag

#### 5.1.5 R4 (RAM Select Register)

- Bits 7 ~ 6 determine which bank is activated among the 4 banks.
- **Bits 5 ~ 0** are used to select the registers (Address: 00~3F) in indirect addressing mode.

If no indirect addressing is used, the RSR is used as an 8-bit general-purpose read/writer register.

See the data memory configuration in Figure 5-3.



# 5.1.6 R5~R8 (Port 5 ~ Port 8)

- Four general 8 bits I/O registers
- Both P74 and P76 read or write data from the DATA pin, while both P75 and P77 read or write data from the CLK pin.

# 5.1.7 R9 (Port 9)

A general 6-bit I/O register. The values of the two most significant bits are read as "0".

|   | Aaddress                        |                                | R PAGE                   | registers   |           |                         | IOC PAGE registers           |  |  |
|---|---------------------------------|--------------------------------|--------------------------|-------------|-----------|-------------------------|------------------------------|--|--|
|   | 00                              | R0                             | (Indirect A              | ddressing   | Register) | Reserve                 |                              |  |  |
|   | 01                              | R1                             | (Time Cloc               | k Counter)  |           | CONT (Control Register) |                              |  |  |
|   | 02                              | R2                             | (Program C               | Counter)    |           | Reserve                 |                              |  |  |
|   | 03                              | 03 <b>R3</b> (Status Register) |                          |             |           |                         | Reserve                      |  |  |
| П | 04                              | R4                             | (RAM Sele                | ct Registe  | r)        |                         | Reserve                      |  |  |
|   | 05                              | R5                             | (Port 5)                 |             |           | IOC5                    | (I/O Port Control Register)  |  |  |
|   | 06                              | R6                             | (Port 6)                 |             |           | IOC6                    | (I/O Port Control Register)  |  |  |
|   | 07                              | R7                             | R7 (Port 7)  R8 (Port 8) |             |           |                         | (I/O Port Control Register)  |  |  |
|   | 08                              | R8                             |                          |             |           |                         | (I/O Port Control Register)  |  |  |
|   | 09                              | R9                             | <b>9</b> (Port 9)        |             |           | IOC9                    | (I/O Port Control Register)  |  |  |
|   | 0A                              | RA                             | (SPI read b              | ouffer)     |           |                         | Reserve                      |  |  |
|   | 0B                              | RB                             | (SPI write I             | buffer)     |           | Reserve                 |                              |  |  |
|   | 0C                              | RC                             | (SPI status              | buffer)     |           | юсс                     | (Timer1 Control Register)    |  |  |
|   | 0D                              | RD                             | (SPI contro              | ol buffer)  |           | IOCD                    | (Pull_high Control Register) |  |  |
|   | 0E                              | RE                             | (Timer 1 reg             | gister)     |           | IOCE                    | (WDT Control Register)       |  |  |
|   | 0F                              | RF                             | (Pulse width             | n preset re | gister)   | IOCF                    | (Interrupt Mask Register)    |  |  |
|   | 10<br>: General Registers<br>1F |                                |                          |             |           |                         |                              |  |  |
| • | 20<br>:<br>3E                   | Bank 0                         | Bank 1                   | Bank 2      | Bank 3    |                         |                              |  |  |
|   | 3F                              | R3F                            | (Interrupt S             | Status Reg  | jister)   |                         |                              |  |  |

Figure 5-3 Data Memory Configuration



#### 5.1.8 RA (SPIRB: SPI Read Buffer)

| Address | Name     | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 |
|---------|----------|-------|-------|-------|-------|-------|-------|-------|
| 0×0A    | SPIRB/RA | SRB7  | SRB6  | SRB5  | SRB4  | SRB3  | SRB2  | SRB1  |

SRB7~SRB0 are the 8-bit data when there's complete transmission by SPI.

#### 5.1.9 RB (SPIWB: SPI Write Buffer)

| Address | Name     | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|----------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0x0B    | SPIWB/RB | SWB7  | SWB6  | SWB5  | SWB4  | SWB3  | SWB2  | SWB1  | SWB0  |

SWB7~SWB0 are the 8-bit data that are waiting for transmission by SPI.

#### 5.1.10 RC (SPIS: SPI Status Register)

| Address | Name    | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0×0C    | SPIS/RC | _     | _     | _     | TM1IF | OD3   | OD4   | RBFIF | RBF   |

Bits 7 ~ 5 Not used.

Bit 4 (TM1IF): Timer 1 Interrupt Flag

**0** : In Timer 1 mode, receiving is not completed yet, and there's no interrupt

1 : In Timer 1 mode, receiving is completed, and an interrupt occurs if enabled.

Bit 3 (OD3): Open-Drain Control bit

0: Open-drain disable for SDO

1 : Open-drain enable for SDO

Bit 2 (OD4): Open-Drain Control bit

0: Open-drain disable for SCK

1 : Open-drain enable for SCK

Bit 1 (RBFIF): Read Buffer Full Interrupt Flag

0: Receiving is not complete yet; and SPIRB has not fully exchanged.

1 : Receiving is complete, SPIRB is fully exchanged, and an interrupt occurs if enabled.

Bit 0 (RBF): Read Buffer Full flag

0: Receiving is not complete yet, and SPIRB has not fully exchanged.

1: Receiving is complete, SPIRB is fully exchanged.



#### 5.1.11 RD (SPIC: SPI Control Register)

| Address | Name    | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Ox0D    | SPIC/RD | CES   | SPIE  | SRO   | SSE   | _     | SBRS2 | SBRS1 | SBRS0 |

Bit 7 (CES): Clock Edge Select bit

**0**: Data shifts out on a rising edge, and shifts in on a falling edge. Data is on hold during low level.

1 : Data shifts out on a falling edge, and shifts in on a rising edge. Data is on hold during high level.

Bit 6 (SPIE): SPI Enable bit

0: Disable SPI mode

1: Enable SPI mode

Bit 5 (SRO): SPI Read Overflow bit

0: No overflow

1 : A new data is received while the previous data is still being held in the SPIB register. In this situation, the data in the SPIS register will be destroyed. To avoid setting this bit, it is better for users to read the SPIRB register even if only the transmission is implemented.

Note that this can only occur in slave mode.

Bit 4 (SSE): SPI Shift Enable bit

- **0** : Reset as soon as shifting is complete, and the next byte is ready to shift.
- 1 : Start to shift, and keep at 1 while the current byte is still being transmitted

Note that this bit will be reset to 0 at every 1-byte transmission by the hardware.

Bit 2 ~ Bit 0 (SBRS2~SBRS0): SPI Baud Rate Select bits

Refer to the SPI baud rate table illustration under the section "SPI" on the subsequent pages.



#### 5.1.12 RE (TMR1: Timer 1 Register)

| Address | Name    | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0×0E    | TMR1/RE | TMR17 | TMR16 | TMR15 | TMR14 | TMR13 | TMR12 | TMR11 | TMR10 |

**TMR17 ~ TMR10:** Set of bits of Timer 1 register, of which values increase until they match PWP and then reset to 0.

#### 5.1.13 RF (PWP: Pulse Width Preset Register)

| Address | Name   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|--------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0×0F    | PWP/RF | PWP7  | PWP6  | PWP5  | PWP4  | PWP3  | PWP2  | PWP1  | PWP0  |

**PWP7** ~ **PWP0**: Set of bits of the Pulse Width preset in advance for the desired width of the baud clock.

#### 5.1.14 R20~R3E (General-Purpose Register)

RA~R1F, and R20 ~ R3E (including Banks 0~3) are general-purpose registers.

#### 5.1.15 R3F (Interrupt Status Register)

| Address | Name    | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0x3F    | ISR/R3F | -     | -     | -     | -     | TM1IF | SPIIF | EXIF  | TCIF  |

Bits 7 ~ 4: not used, read as "0".

**Bit 3 (TM1IF):** Timer 1 Interrupt Flag. Set by the comparator at Timer 1 application, flag is cleared by software.

**Bit 2 (SPIIF):** SPI Interrupt Flag. Set during completion of data transmission, flag is cleared by software.

**Bit 1 (EXIF):** External Interrupt Flag. Set by a falling edge on the /INT pin, flag is cleared by software.

**Bit 0 (TCIF):** TCC Overflow Interrupt Flag. Set as TCC overflows, flag is cleared by software.

0 : means no interrupt occurs

1 : means with interrupt request

R3F can be cleared by instruction, but cannot be set by instruction.

IOCF is the interrupt mask register.

Note that reading R3F will result to "logic AND" of R3F and IOCF.



# 5.2 Special Purpose Registers

#### 5.2.1 A (Accumulator)

Internal data transfer operation, or instruction operand holding usually involves the temporary storage function of the Accumulator, which is not an addressable register.

#### 5.2.2 CONT (Control Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| /PHEN | /INT  | -     | -     | PAB   | PSR2  | PSR1  | PSR0  |

Bit 7 (/PHEN): I/O pin pull-high enable flag.

0: For P60~P67, P74~P75 and P90~P95, the pull-high function is enabled.

1: The pull-high function is disabled.

Bit 6 (INT): An interrupt enable flag cannot be written to by the CONTW instruction.

0: Interrupt is masked by the DISI instruction.

1: Interrupt is enabled by the ENI or RETI instruction.

Bit 5 and Bit 4: Not used, read as "0".

Bit 3 (PAB): Prescaler assigned bit.

0: TCC

1: WDT

Bit 2 ~ Bit 0 (PSR2 ~ PSR0): TCC/WDT prescaler bits.

| PSR2 | PSR1 | PSR0 | TCC Rate | WDT Rate |
|------|------|------|----------|----------|
| 0    | 0    | 0    | 1:2      | 1:1      |
| 0    | 0    | 1    | 1:4      | 1:2      |
| 0    | 1    | 0    | 1:8      | 1:4      |
| 0    | 1    | 1    | 1:16     | 1:8      |
| 1    | 0    | 0    | 1:32     | 1:16     |
| 1    | 0    | 1    | 1:64     | 1:32     |
| 1    | 1    | 0    | 1:128    | 1:64     |
| 1    | 1    | 1    | 1:256    | 1:128    |

Bits 0 ~ 3, and 7 of the CONT register are readable and writable.



#### 5.2.3 IOC5 ~ IOC9 (I/O Port Control Register)

0 : sets the relative I/O pin as output

1 : puts the relative I/O pin into high impedance

- Both P74 and P76 should not be defined as output pins at the same time. This also applies to both P75 and P77.
- Only the lower 6 bits of the IOC9 register are used.

#### 5.2.4 IOCC (T1CON: Timer 1 Control Register)

| Address | Name       | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|------------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0x0C    | T1CON/IOCC | 0     | 0     | 0     | 0     | 0     | TM1E  | TM1P1 | TM1P0 |

Bit 2 (TM1E): Timer 1 Function Enable bit

0: Disable Timer 1 function as default

1: Enable Timer 1 function

Bit 1 ~ Bit 0 (TM1P): Timer 1 Prescaler bit

Refer to the Timer 1 prescaler table for FOSC illustration under the section on "Timer 1" on the subsequent pages.

#### 5.2.5 IOCD (Pull-high Control Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| S7    | -     | -     | -     | /PU9  | /PU8  | /PU6  | /PU5  |

- The default values of /PU5, /PU6, /PU8, and /PU9 are "1", which means that the pull-high function is disabled.
- /PU6 and /PU9 are "AND" gating with /PHEN, that is, when each one is written with a "0", pull-high is enabled.
- S7 defines the driving ability of P70-P72.

**0**: Normal output

1: Enhances the driving ability of the LED

#### 5.2.6 IOCE (WDT Control Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| -     | ODE   | WDTE  | SLPC  | ROC   | -     | -     | WUE   |

Bits 7, and 1 ~ 2 are not used.

Bit 6 (ODE): Open-drain control bit.

0: Both P76 and P77 are normal I/O pins.

1: Both P76 and P77 pins have internal open-drain function.

The ODE bit can be read and written to.



Bit 5 (WDTE): Control bit used to enable the Watchdog timer.

The WDTE bit can be used only if ENWDT, the Code Option bit, is "1". If the ENWDT bit is "1," then WDT can be disabled / enabled by the WDTE bit.

0: Disable WDT

1: Enable WDT

The WDTE bit is not used if ENWDT, the Code Option bit ENWD is "0". That is, if the ENWDT bit is "0", WDT is always disabled no matter what the WDTE bit is.

The WDTE bit can be read and written to.

- Bit 4 (SLPC): This bit is set by hardware at a falling edge of the wake-up signal and is cleared by software. The SLPC is used to control the oscillator operation. The oscillator is disabled (the oscillator stops, and the controller enters the Sleep 2 mode) on the high-to-low transition and is enabled (the controller is awakened from Sleep 2 mode) on a low-to-high transition. In order to ensure a stable output of the oscillator, once the oscillator is enabled again, there is a delay of approximately 18 ms (oscillator start-up timer (OST)) before the next program instruction is executed. The OST is always activated by a wake-up from sleep mode whether the Code Option bit ENWDT is "0" or not. After waking up, the WDT is enabled if the Code Option ENWDT is "1". The block diagram of Sleep 2 mode and wake-up caused by the input trigger is depicted in Figure 5-4. The SLPC bit can be read and written to.
- Bit 3 (ROC): The ROC bit is used for the R-option. Setting the ROC bit to "1" will enable the status of the R-option pins (P80, P81) to be read by the controller. Clearing the ROC bit will disable the R-option function. Otherwise, the R-option function is implemented. Users must connect the P81 pin and/or P80 pin to VSS with a 560 K $\Omega$  external resistor (Rex). If Rex is connected/disconnected to VDD, the status of P80 (P81) will be read as "0" / "1", refer to Figure 5-6(b). The ROC bit can be read and written to.
- **Bit 0 (/WUE):** Control bit used to enable the wake-up function of P60~P67, P74~P75, and P90~P91.

0: Enable the wake-up function

1: Disable the wake-up function

The /WUE bit can be read and written to.



#### 5.2.7 IOCF (Interrupt Mask Register)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| -     | -     | -     | -     | TM1IE | SPIIE | EXIE  | TCIE  |

Bits 4~7: Not used.

Individual interrupt is enabled by setting its associated control bit in IOCF to "1".

The IOCF Register can be read and written to.

Bit 3 (TM1IE): TM1IE interrupt enable bit.

0 : disable TM1IE interrupt1 : enable TM1IE interrupt

Bit 2 (SPIIE): SPI interrupt enable bit.

0 : disable SPI interrupt1 : enable SPI interrupt

Bit 1 (EXIE): EXIF interrupt enable bit.

0 : disable EXIF interrupt1 : enable EXIF interrupt

Bit 0 (TCIE): TCIF interrupt enable bit.

0 : disable TCIF interrupt1 : enable TCIF interrupt



Figure 5-4 Block Diagram of Sleep Mode and Wake-up Circuits on I/O Ports



#### 5.3 TCC/WDT Presacler

An 8-bit counter is available as prescaler for the TCC or WDT. The prescaler is available for either the TCC or WDT at any given time, and the PAB bit of the CONT register is used to determine the prescaler assigned bit. The PSR0~PSR2 bits determine the prescaler ratio. The prescaler is cleared each time the instruction is written to TCC in TCC mode. The WDT and prescaler, when assigned to WDT mode, are cleared by the WDTC or SLEP instructions. Figure 5-5 depicts the circuit diagram of TCC/WDT.

- R1 (TCC) is an 8-bit timer/counter. The TCC is incremented by 1 at every instruction cycle (without prescaler).
- The Watchdog Timer is a free running on-chip RC oscillator. The WDT will keep running even when the oscillator driver has been turned off (i.e. in Sleep mode). During normal or sleep mode operation, a WDT time-out (if enabled) will cause the device to reset. The WDT can be enabled or disabled any time during normal mode by software programming (if the Code Option bit ENWDT is "1"). Refer to the WDTE bit of the IOCE register. Without presacler, the WDT time-out period is approximately 18 ms<sup>1</sup>.

#### **5.4 I/O Ports**

The I/O registers, from Port 5 to Port 9, are bidirectional tri-state I/O ports. P60~P67, P74~P75, and P90~P91 provides internal pull-high. P60~P67, P74~P75, and P90~P95 provides programmable wake-up function through software. P76~P77 can have an open-drain output by software control. P80~P81 are the R-option pins which are enabled by software. When the R-option function is implemented, it is recommended that P80 and P81 be used as output pins. During R-option enabled state, P80 and P81 must be programmed as input pins. If an external resistor is connected to P80 (P81) for the R-option function, the current consumption should be taken as an important factor in the product applications with low power consideration.

The I/O ports can be defined as "input" or "output" pins by the I/O control registers (IOC5~IOC9) under program control. The I/O registers and I/O control registers are both readable and writable. The I/O interface circuit is shown in Figure 5-6. Note that the reading path source of the input and output pins is different than when reading the I/O port.

-

<sup>&</sup>lt;sup>1</sup> Vdd = 5V, set up time period = 16.2ms  $\pm 30\%$ Vdd = 3V, set up time period = 18.0ms  $\pm 30\%$ 





Figure 5-5 Block Diagram of TCC WDT



Figure 5-6 (a) I/O Port and I/O Control Register Circuit





Figure 5-6 (b) The Circuit of I/O Port with R-option (P80, P81)

# 5.5 Serial Peripheral Interface Mode

#### 5.5.1 Overview and Features

#### Overview:

Figures 5-7, 5-8, and 5-9 show how the EM78P451S communicates with other devices through SPI module. If EM78P451S is a master controller, it sends clock through the SCK pin. A couple of 8-bit data are transmitted and received at the same time. However, if EM78P451S is defined as a slave, its SCK pin could be programmed as an input pin. Data will continue to be shifted based on both the clock rate and the selected edge.

#### Features:

- Operation in either Master mode or Slave mode
- Three-wire or four-wire synchronous communication; that is, full duplex
- Programmable baud rates of communication
- Programming clock polarity, (RD Bit 7)
- Interrupt flag available for the read buffer full
- SPI transmission order
- Up to 8 MHz ( maximum ) bit frequency





Figure 5-7 SPI Master/Slave Communication



Figure 5-8 SPI Configuration of Single-Master and Multi-Slave





Figure 5-9 The SPI Configuration of Single-Master and Multi-Slave

#### 5.5.2 SPI Function Description



Figure 5-10 SPI Block Diagram





Figure 5-11 The Function Block Diagram of SPI Transmission

The following describes the function of each block and explains how to carry out the SPI communication with the signals depicted in Figure 5-10 and Figure 5-11:

P92/SDI: Serial Data In

■ P93/SDO: Serial Data Out

■ P94/SCK: Serial Clock

- P95//SS: /Slave Select (Option). This pin (/SS) may be required during slave mode.
- RBF: Set by Buffer Full Detector, and reset by software.
- RBIF: Set by Buffer Full Detector, and reset by software.
- Buffer Full Detector: Set to 1 when an 8-bit shifting is completed.
- SSE: Loads the data in SPIS register, and begin to shift
- SPIS reg.: Shifting byte in and out. The MSB is shifted first. Both the SPIS and the SPIW registers are loaded at the same time. Once data are written, SPIS starts transmission / reception. The data received will be moved to the SPIR register as the shifting of the 8-bit data is completed. The RBF (Read Buffer Full) flag and the RBFI (Read Buffer Full Interrupt) flag are then set.
- SPIR reg.: Read buffer. The buffer will be updated as the 8-bit shifting is completed. The data must be read before the next reception is completed. The RBF flag is cleared as the SPIR register reads.
- SPIW reg.: Write buffer. The buffer will ignore any attempt to write until the 8-bit shifting is completed.



The SSE bit will be kept in 1 if the communication is still undergoing. This flag must be cleared as the shifting is completed. Users can determine if the next write attempt is available.

- SBRS2 ~ SBRS0: Programming the clock frequency/rates and sources.
- Clock Select: Selects either the internal or external clock as the shifting clock.
- Edge Select: Selects the appropriate clock edges by programming the CES bit.

#### 5.5.3 SPI Signal and Pin Description

The detailed functions of the four pins, SDI, SDO, SCK, and /SS, which are shown in Figure 5-8, are as follows:

#### SDI/P92 (Pin 7):

- Serial Data In
- Receive serially, the Most Significant Bit (MSB) first, Least Significant Bit (LSB) last.
- Defined as high-impedance, if not selected.
- Program the same clock rate and clock edge to latch on both the master and slave devices.
- The received byte will update the transmitted byte.
- Both the RBF and RBFIF bits (located in Register 0x0C) will be set as the SPI operation is completed.
- Timing is shown in Figure 5-12 and 5-13.

#### SDO/P93 (Pin 8):

- Serial Data Out
- Transmit serially; the Most Significant Bit (MSB) first, Least Significant Bit (LSB) last.
- Program the same clock rate and clock edge to latch on both the master and slave devices.
- The received byte will update the transmitted byte.
- The CES (located in Register 0x0D) bit will be reset, as the SPI operation is completed.
- Timing is shown in Figure 5-12 and 5-13.



#### SCK/P94 (Pin 9):

- Serial Clock
- Generated by a master device
- Synchronize the data communication on both the SDI and SDO pins.
- The CES (located in Register 0x0D) is used to select the edge to communicate.
- The SBR0~SBR2 (located in Register 0x0D) is used to determine the baud rate of communication
- The CES, SBR0, SBR1, and SBR2 bits have no effect in slave mode
- Timing is shown in Figure 5-12 and 5-13

#### /SS/P95 (Pin 10):

- Slave Select: negative logic
- Generated by a master device to signify the slave(s) to receive data.
- Goes low before the first cycle of SCK appears, and remains low until the last 8th cycle is completed.
- Ignores the data on the SDI and SDO pins while /SS is high, since the SDO is no longer driven.
- Timing is shown in Figure 5-12 and Figure 5-13.

#### 5.5.4 Programming the Related Registers

As the SPI mode is defined, the related registers of this operation are shown in Table 2 and Table 3.

Table 1 Related Control Registers of the SPI Mode

| Address | Name      | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-----------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0x0D    | *SPIC/RD  | CES   | SPIE  | SRO   | SSE   | _     | SBR2  | SBR1  | SBR0  |
| 0x0F    | INTC/IOCF | -     | -     | -     | -     | TM1IE | SPIIE | EXIE  | TCIE  |

SPIC: SPI Control Register

Bit 7 (CES): Clock Edge Select bit

- **0**: Data shifts out on a rising edge, and shifts in on a falling edge. Data is on hold during a low level.
- 1 : Data shifts out on a falling edge, and shifts in on a rising edge. Data is on hold during a high level.



Bit 6 (SPIE): SPI Enable bit

0: Disable SPI mode

1: Enable SPI mode

Bit 5 (SRO): SPI Read Overflow bit

0: No overflow

1 : A new data is received while the previous data is still being on hold in the SPIB register. Under this condition, the data in the SPIS register will be destroyed. To avoid setting this bit, users should read the SPIRB register even if the transmission is implemented only.

#### Note that this can only occur in Slave mode.

Bit 4 (SSE): SPI Shift Enable bit

**0**: Reset as soon as shifting is complete and the next byte is ready to shift.

1 : Start to shift, and remains on 1 while the current byte continues to transmit.

#### Note that this bit can be reset by hardware only.

Bit 3: Not used, read as 0

Bits 2 ~ 0 (SBR2~SBR0): SPI Baud Rate Select Bits

| SBRS2 (Bit 2) | SBRS1 (Bit 1) | SBRS0 (Bit 0) | Mode   | Baud Rate   |
|---------------|---------------|---------------|--------|-------------|
| 0             | 0             | 0             | Master | Fosc/2      |
| 0             | 0             | 1             | Master | Fosc/4      |
| 0             | 1             | 0             | Master | Fosc/8      |
| 0             | 1             | 1             | Master | Fosc/16     |
| 1             | 0             | 0             | Master | Fosc/32     |
| 1             | 0             | 1             | Slave  | /SS enable  |
| 1             | 1             | 0             | Slave  | /SS disable |
| 1             | 1             | 1             | Master | TMR1/2      |

Note: In Master mode, the /SS pin is disabled.

**INTC:** Interrupt control register

Bit 3 (TM1IE): TM1IE interrupt enable bit.

0 : disable TM1IE interrupt1 : enable TM1IE interrupt

Bit 2 (SPIIE): SPI interrupt enable bit.

0 : disable SPI interrupt1 : enable SPI interrupt



Bit 1 (EXIE): EXIF interrupt enable bit.

0: disable EXIF interrupt

1 : enable EXIF interrupt

Bit 0 (TCIE): TCIF interrupt enable bit.

0 : disable TCIF interrupt

1 : enable TCIF interrupt

Table 2 Related Status/Data Registers of the SPI Mode

| Address | Name     | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|----------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0×0A    | SPIRB/RA | SRB7  | SRB6  | SRB5  | SRB4  | SRB3  | SRB2  | SRB1  | SRB0  |
| 0×0B    | SPIWB/RB | SWB7  | SWB6  | SWB5  | SWB4  | SWB3  | SWB2  | SWB1  | SWB0  |
| 0×0C    | SPIS/RC  | 0     | 0     | 0     | TM1IF | OD3   | OD4   | RBFIF | RBF   |

**SPIRB:** SPI Read Buffer. Once the serial data is received completely, it will be

loaded to SPIRB from SPISR. The RBF bit and the RBFIF bit in the SPIS

register will also be set.

SPIWB: SPI Write Buffer. As a transmitted data is loaded, the SPIS register stands

by and start to shift the data when sensing SCK edge with SSE set to "1".

SPIS: SPI Status register

Bit 4 (TM1IF): Timer 1 interrupt flag

Bit 3 (OD3): Open-Drain Control bit (P93)

0: Open-drain disable for SDO

1 : Open-drain enable for SDO

Bit 2 (OD4): Open Drain-Control bit (P94)

0: Open-drain disable for SCK

1 : Open-drain enable for SCK

Bit 1 (RBFIF): Read Buffer Full Interrupt flag

**0**: Receive is ongoing, SPIB is empty.

1 : Receive is completed, SPIB is full, and an interrupt occurs if enabled.

Bit 0 (RBF): Read Buffer Full flag

0 : Receive is ongoing, SPIB is empty.

1 : Receive is completed, SPIB is full.



#### 5.5.5 SPI Mode Timing

The edge of SCK is selected by programming bit CES. The waveform shown in Figure 5-12 is applicable regardless whether the EM78P451S is in master or slave mode with /SS disabled. However, the waveform in Figure 5-13 can only be implemented in slave mode with /SS enabled.



Figure 5-12 SPI Mode with /SS Disabled



Figure 5-13 SPI Mode with /SS Enabled



#### 5.5.6 SPI Software Application

Example for SPI:

For Master

ORG 0X0

#### Setting:

```
CLRA
IOW 0X05
                      ; Set Port 5 output
IOW 0X06
                       ; Set Port 6 output
MOV 0X05,A
MOV A,@0B11001111
                    ; Set prescaler for WDT
CONTW
MOV A,@0B00010001
                       ; Disable wake-up function
IOW 0X0E
MOV A,@0B0000000
                      ; Disable interrupt
IOW 0X0F
MOV A,@0x07
                       ; SDI input and SDO, SCK output
IOW 0x09
MOV A,@0B1000000
                       ; Clear RBF and RBFIF flag
MOV 0x0C,A
MOV A,@OB11100000 ; Select clock edge and enable SPI
MOV 0X0D,A
```

#### Start:

```
WDTC
BC 0X0C,1
                         ; Clear RBFIF flag
MOV A,@0XFF
MOV 0X05,A
                         ; Show a signal at Port 5
MOV 0X0A,A
                          ; Move FF at read buffer
MOV A,@0XAA
                          ; Move AA at write buffer
MOV 0X0B,A
BS 0X0D,4
                          ; Start to shift SPI data
NOP
JBC 0X0D,4
                         ; Polling loop for checking SPI
JMP $-2
                          ; transmission completed
BC 0X03,2
CALL DELAY
                         ; To catch the data from slaver
MOV A, 0X0A
XOR A,@0X5A
                         ; Compare the data from slaver
JBS 0X03,2
JMP START
```



```
FLAG:
  MOV A,@0X55
                            ; Show the signal when receiving
  MOV 0X05,A
                            ; correct data from slaver
  CALL DELAY
  JMP START
DELAY:
; (User's program)
  EOP
  ORG OXFFF
  JMP SETTING
For Slaver
ORG 0X0
INITI:
  JMP INIT
  ORG 0X2
INTERRUPT:
                      ; Interrupt address
  MOV A,@0X55
  MOV 0X06,A
                      ; Show a signal at Port 6 when entering
                      ; interrupt
  MOV A,@0B11100110
                    ; Enable SPI, /SS disabled
  MOV 0X0D,A
  BS 0X0D,4
                      ; Keep SSE at 1 to wait for SCK signal in
                      ; order to shift data
  MOV A,@0X00
                      ; Move 00 to write buffer in order to keep
                      ; master's read buffer as 00
  MOV 0X0B,A
  BS 0X0D,4
                      ; Keep SSE at 1 to wait for SCK signal in
                      ; order to shift data
  NOP
  JBC 0X0D,4
                      ; Polling loop for checking SPI
                      ; transmission completed
  JMP $-2
  BS 0X0D,4
                      ; Keep SSE at 1 to wait for SCK signal in
                      ; order to shift data
  BC 0X03,2
  MOV A, 0X0A
  MOV 0X06,A
                      ; Read master's data from read buffer
  XOR A,@0XAA
                      ; Check pass signal from read buffer
  JBS 0X03,2
  JMP $-6
  JMP SPI
```



#### **ORG 0X30**

#### INIT:

```
CLRA
 IOW 0X05
 IOW 0X06
 MOV 0x05,A
 MOV 0X06,A
 MOV A,@0XFF
 IOW 0X08
 MOV A,@OB11001111 ; Set prescaler for WDT
 CONTW
 MOV A,@0B00010001
                    ; Disable wake-up function
 IOW 0X0E
 MOV A,@0B00000010 ; Enable external interrupt
 IOW OXF
 ENI
 MOV A,@0B00110111
 IOW 0x09
 BC 0X3F,1
                ; Clear RBFIF flag
 NOP
 JBS 0X3F,1
                     ; Polling loop for checking interrupt
                     ; occurrences
 JMP $-2
 JMP INTERRUPT
SPI:
 BS 0X0D,4
                     ; Keep SSE enabled as long as possible
 WDTC
 MOV A,@0X0F
                     ; Show a signal when entering SPI loop
 MOV 0X06,A
 JBC 0X08,1
                     ; Choose P81 as a signal button
 JMP SPI
 MOV A,@0X5A
                     ; Move 5A into write buffer when P81 button
                     ; is pushed
 MOV 0X0B,A
 NOP
 JBC 0X0D,4
                     ; Polling loop for checking SPI
                     ; transmission complete
 JMP $-2
 BS 0XD,4
 NOP
 NOP
```



```
MOV A,@0XF0
                      ; Display at Port6 when P81 button is pushed
 MOV 0X06,A
 MOV A,@0X00
                      ; Send a signal to master to prevent
                      ; infinite loop
 MOV 0X0B,A
 NOP
 JBC 0X0D,4
 JMP $-2
 BS 0X0D,4
 BC 0x0C,7
 BC 0x0C,1
 NOP
 JMP SPI
DELAY:
                      ; (User's program)
 EOP
 ORG OXFFF
 JMP INITI
```

#### 5.6 Timer 1

#### 5.6.1 Overview

Timer 1 (TMR1) is an 8-bit clock counter with programmable prescaler. It is designed for the SPI module as a baud rate clock generator. TMR1 can be read, written to and cleared on any reset conditions. If TMR1 is employed, it can be turned down for power conservation, by setting the TMR1EN bit [T1CON<2>] to 0.

#### 5.6.2 Function Description

Figure 5-14 shows Timer 1 block diagram. Each signal and block is described as follows:

- OSC/4: Input clock.
- Prescaler: Option of 1:1, 1:4, 1:8, and 1:16 defined by T1P1 and T1P02 (T1CON<1, 0>). It is cleared when a value is written to TMR1 or T1CON, and also during any kind of reset.
- PWP: Pulse width preset register. The desired width of baud clock is written in advance.
- TMR1: Timer 1 register. TMR1 is incremented until its value matches with PWP, and then resets to 0. If it is chosen optionally in the SPI mode, its output is fed as a shifting clock.
- Comparator: To change the output status while a match occurs, the TMR1IF flag will be set at the same time.



#### 5.6.3 Programming the Related Registers

The related registers of the defining TMR1 operation are shown in Table 4 and Table 5

Table 3 Related Control Registers of TMR1

| 2 | Address | Name      | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---|---------|-----------|-------|-------|-------|-------|-------|-------|-------|-------|
|   | 0×0C    | SPIS/RC   | 0     | 0     | 0     | TM1IF | OD3   | OD4   | RBFIF | RBF   |
|   | 0×0F    | INTC/IOCF | 0     | 0     | 0     | 0     | TM1IE | SPIIE | EXIE  | TCIE  |

Table 4 Related Status/Data Registers of TMR1

| Address | Name       | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|------------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0×0E    | TMR1/RE    | TMR17 | TMR16 | TMR15 | TMR14 | TMR13 | TMR12 | TMR11 | TMR10 |
| 0×0F    | PWP/RF     | PWP7  | PWP6  | PWP5  | PWP4  | PWP3  | PWP2  | PWP1  | PWP0  |
| 0×0C    | T1CON/IOCC | 0     | 0     | 0     | 0     | 0     | TM1E  | TM1P1 | TM1P0 |

- TMR1: Timer 1 Register
- TMR17 ~ TMR10 are set of bits of Timer 1 register, which increases until the value matches PWP and then resets to 0.
- PWP: Pulse Width Preset Register
- PWP7 ~ PWP0 is bit set of pulse width preset for the desired width of baud clock in advance.
- T1CON: Timer 1 Control Register

Bit 2 (TM1E): Timer 1 enable bit

Bits 1 ~ 0 (TM1P1~TM1P0): Timer 1 prescaler for Fosc

| TM1P1 | TM1P0 | Prescaler Rate |  |  |  |
|-------|-------|----------------|--|--|--|
| 0     | 0     | 1:1            |  |  |  |
| 0     | 1     | 1:4            |  |  |  |
| 1     | 0     | 1:8            |  |  |  |
| 1     | 1     | 1:16           |  |  |  |



### 5.7 Reset and Wake-up

A reset is initiated by

- (1) Power-on reset
- (2) /RESET pin input "low"
- (3) WDT timeout (if enabled)



Figure 5-14 Block Diagram of Reset

The POR voltage range of the EM78P451S is 1.2V~2.0V. Under customer application, when power is OFF, Vdd must drop below 1.2V and remains OFF for 10μs before power can be switched ON again. This way, the EM78P451S will reset and work normally. The extra external reset circuit will work well if Vdd can rise at very fast speed (50 ms or less). However, in most cases where critical applications are involved, extra devices are required to assist in solving the power-up problem.

The device is kept in a reset condition for a period of approx. 18ms<sup>2</sup> (one oscillator start-up timer period) after the reset is detected and Figure 5-15 is the block diagram of reset. Once a reset occurs, the following functions are performed.

- The oscillator is running, or will be started.
- The Program Counter (R2) is set to all "1".
- When power is switched on, Bits 5~6 of R3 and the upper 2 bits of R4 are cleared.
- All I/O port pins are configured as input mode (high-impedance state).
- The Watchdog timer and prescaler are cleared.

\_

Vdd = 5V, set-up time period =  $16.20 \text{ ms} \pm 30\%$ Vdd = 3V, set-up time period =  $18.0 \text{ ms} \pm 30\%$ 



- The Watchdog timer is enabled if Code Option bit ENWDT is "1".
- The CONT register is set to all "1" except Bit 6 (INT flag).
- Bits 3 and 6 of the IOCE register are cleared, Bits 0, 4 ~ 5 of the IOCE register are set to "1".
- Bits 0 of R3F and Bit 0 of IOCF registers are cleared.

The sleep mode (power down) is achieved by executing the SLEP instruction (named as Sleep 1 Mode). While entering sleep mode, the WDT (if enabled) is cleared but keeps on running. The controller is awakened by WDT timeout (if enabled), and it will cause the controller to reset. The T and P flags of R3 are used to determine the source of the reset (wake-up).

In addition to the basic Sleep 1 Mode, the EM78P451S has another sleep mode (caused by clearing "SLPC" bit of IOCE register, designated as Sleep 2 Mode). In the Sleep 2 Mode, the controller can be awakened by:

- (a) Any of the wake-up pin(s) is set to "0." (Refer to Figure 5-15). Upon waking, the controller will continue to execute the program in-line. In this case, before entering Sleep 2 Mode, the wake-up function of the trigger sources (P60~P67, P74~P75, and P90~P91) should be selected (e.g. input pin) and enabled (e.g. pull-high, wake-up control). One caution should be noted is that after waking up, the WDT is enabled if the Code Option bit ENWDT is "0". The WDT operation (to be enabled or disabled) should be appropriately controlled by software after waking up.
- **(b)** WDT time-out (if enabled) or external reset input on /RESET pin will trigger a controller reset.

Table 5 Usage of Sleep and Sleep 2 Mode

| Usage of Sleep and Sleep 2 Mode                                                                               |                          |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------|--------------------------|--|--|--|--|--|--|--|
| Sleep 2                                                                                                       | Sleep                    |  |  |  |  |  |  |  |
| (a) Before Sleep                                                                                              | (a) Before Sleep         |  |  |  |  |  |  |  |
| <ol> <li>Set Port 6 or P74 or P75 Input</li> </ol>                                                            | Execute SLEP instruction |  |  |  |  |  |  |  |
| <ol> <li>Enable Pull-high and set WDT prescaler over</li> <li>1:1 (Set CONT.7 and CONT.3 ~ CONT.0)</li> </ol> |                          |  |  |  |  |  |  |  |
| <ol><li>Enable Wake-up (Set IOCB or IOCE.0)</li></ol>                                                         |                          |  |  |  |  |  |  |  |
| 4. Execute Seep 2 (Set IOCE.4)                                                                                |                          |  |  |  |  |  |  |  |
| (b) After Wake-up                                                                                             | (b) After Wake-up        |  |  |  |  |  |  |  |
| Next instruction                                                                                              | 1. Reset                 |  |  |  |  |  |  |  |
| 2. Disable Wake-up                                                                                            |                          |  |  |  |  |  |  |  |
| 3. Disable WDT (Set IOCE.5)                                                                                   |                          |  |  |  |  |  |  |  |



If Port 6 Input Status Changed Wake-up is used to wake-up the EM78P451S (Case [a] above), the following instructions must be executed before entering Sleep 2 mode:

```
Α,
         @11111111b ; Set Port6 input
MOV
         IOC6
MOI
                      ; Set Port 6 pull-high, WDT prescaler
MOV
         @0xxx1010b ; must be set over 1:1
CONTW
                       ; Enable Port 6 wake-up function,
         Α,
MOV
         @xx00xxx0b ; Enable Sleep 2
         IOCE
IOW
After
Wake-up
NOP
         A, @ ; Disable Port 6 wake-up function; xx01xxx1b ; Disable WDT
MOV
IOW
          IOCE
```

After waking up from Sleep 2 mode, WDT is automatically enabled. The WDT enabled/disabled operation after waking up from Sleep 2 mode should be properly defined in the software.

To avoid a reset from occurring when the Port 6 "Input Status Changed Interrupt" enters into an interrupt vector or is used to wake-up the MCU, the WDT prescaler must be set above the ratio of 1:1.



Table 6 Summary of the Initialized Values for Registers

| Address | Name        | Reset Type              | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------------|-------------------------|-------|-------|-------|-------|-------|-------|-------|-------|
|         |             | Bit Name                | C57   | C56   | C55   | C54   | C53   | C52   | C51   | C50   |
|         |             | Power-on                | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| N/A     | IOC5        | /RESET and WDT          | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
|         |             | Wake-up from Pin Change | P     | P     | P     | P     | P     | P     | P     | P     |
|         |             | Bit Name                | C67   | C66   | C65   | C64   | C63   | C62   | C61   | C60   |
|         |             | Power-on                | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| N/A     | IOC6        | /RESET and WDT          | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
|         |             | Wake-up from Pin Change | P     | P     | P     | P     | P     | P     | P     | P     |
|         |             | Bit Name                | C77   | C76   | C75   | C74   | C73   | C72   | C71   | C70   |
|         |             | Power-on                | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| N/A     | IOC7        | /RESET and WDT          | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
|         |             | Wake-up from Pin Change | Р     | Р     | Р     | Р     | Р     | Р     | Р     | Р     |
|         |             | Bit Name                | C87   | C86   | C85   | C84   | C83   | C82   | C81   | C80   |
|         | 1000        | Power-on                | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| N/A     | IOC8        | /RESET and WDT          | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
|         |             | Wake-up from Pin Change | Р     | Р     | Р     | Р     | Р     | Р     | Р     | Р     |
|         |             | Bit Name                | C97   | C96   | C95   | C94   | C93   | C92   | C91   | C90   |
| N1/A    | 1000        | Power-on                | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| N/A     | IOC9        | /RESET and WDT          | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
|         |             | Wake-up from Pin Change | Р     | Р     | Р     | Р     | Р     | Р     | Р     | Р     |
|         |             | Bit Name                | /PHEN | /INT  | -     | -     | PAB   | PSR2  | PSR1  | PSR0  |
| N1/A    | CONT        | Power-on                | 1     | 0     | 1     | 1     | 1     | 1     | 1     | 1     |
| N/A     | CONT        | /RESET and WDT          | 1     | Р     | 1     | 1     | 1     | 1     | 1     | 1     |
|         |             | Wake-up from Pin Change | Р     | Р     | Р     | Р     | Р     | Р     | Р     | Р     |
|         |             | Bit Name                | -     | -     | -     | -     | -     | -     | -     | -     |
| 0,400   | DO (IAD)    | Power-on                | U     | U     | U     | U     | U     | U     | U     | U     |
| 0×00    | R0 (IAR)    | /RESET and WDT          | Р     | Р     | Р     | Р     | Р     | Р     | Р     | Р     |
|         |             | Wake-up from Pin Change | Р     | Р     | Р     | Р     | Р     | Р     | Р     | Р     |
|         |             | Bit Name                | -     | -     | -     | -     | -     | -     | -     | -     |
| 0×01    | R1 (TCC)    | Power-on                | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0.01    | K1 (100)    | /RESET and WDT          | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
|         |             | Wake-up from Pin Change | Р     | Р     | Р     | Р     | Р     | Р     | Р     | Р     |
|         |             | Bit Name                | -     | -     | -     | -     | -     | -     | -     | -     |
| 0×02    | R2 (PC)     | Power-on                | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| 0.02    | 112 (1 0)   | /RESET and WDT          | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
|         |             | Wake-up from Pin Change | **P   |
|         |             | Bit Name                | GP    | PS1   | PS0   | Т     | Р     | Z     | DC    | С     |
| 0×03    | R3(SR)      | Power-on                | 0     | 0     | 0     | t     | t     | U     | U     | U     |
| 0.00    | 13(013)     | /RESET and WDT          | 0     | 0     | 0     | t     | t     | Р     | Р     | Р     |
|         |             | Wake-up from Pin Change | Р     | P     | Р     | t     | t     | P     | Р     | Р     |
|         |             | Bit Name                | RSR.1 | RSR.0 | -     | -     | -     | -     | -     | -     |
| 0×04    | R4 (RSR)    | Power-on                | 0     | 0     | U     | U     | U     | U     | U     | U     |
| 0//04   | 114 (11011) | /RESET and WDT          | 0     | 0     | Р     | Р     | Р     | Р     | Р     | Р     |
|         |             | Wake-up from Pin Change | Р     | Р     | Р     | Р     | Р     | Р     | Р     | Р     |
|         |             | Bit Name                | P57   | P56   | P55   | P54   | P53   | P52   | P51   | P50   |
| 0×05    | R5 (P5)     | Power-on                | U     | U     | U     | U     | U     | U     | U     | U     |
| 0,00    | ''(0 (1 0)  | /RESET and WDT          | Р     | Р     | Р     | Р     | Р     | Р     | Р     | Р     |
|         |             | Wake-up from Pin Change | Р     | Р     | Р     | Р     | Р     | Р     | Р     | Р     |



| Address | Name      | Reset Type                       | Bit 7    | Bit 6    | Bit 5  | Bit 4    | Bit 3  | Bit 2      | Bit 1    | Bit 0  |
|---------|-----------|----------------------------------|----------|----------|--------|----------|--------|------------|----------|--------|
| Addiess | Name      | Bit Name                         |          |          |        |          |        | P62        |          | P60    |
|         |           |                                  | P67      | P66<br>U | P65    | P64      | P63    | _          | P61      |        |
| 0×06    | R6 (P6)   | Power-on                         | U<br>P   | P        | U      | U<br>P   | U      | U<br>P     | U        | U<br>P |
|         |           | /RESET and WDT                   | P        | P        | P<br>P | P        | P<br>P | P          | P<br>P   | P      |
|         |           | Wake-up from Pin Change          |          |          | -      | -        | -      | •          |          |        |
|         |           | Bit Name                         | P77      | P76      | P75    | P74      | P73    | P72        | P71      | P70    |
| 0×07    | R7 (P7)   | Power-on /RESET and WDT          | U        | U        | U      | U<br>P   | U      | U<br>P     | U<br>P   | U<br>P |
|         |           |                                  | P<br>P   | P<br>P   | P<br>P | P        | P<br>P | P          | P        | P      |
|         |           | Wake-up from Pin Change Bit Name | P87      | P86      | P85    | P84      | P83    | P82        | P81      | P80    |
|         |           |                                  | U        | U        | U      | U P04    | U      | _ P6∠<br>U | U        | U      |
| 80×0    | R8 (P8)   | Power-on                         | P        | P        | _      | P        | P      | P          | P        | P      |
|         |           | /RESET and WDT                   | P        | P        | P<br>P | P        | P      | P          | -        | P      |
|         |           | Wake-up from Pin Change Bit Name |          | P96      | P95    | P94      | P93    | P92        | P<br>P91 |        |
|         |           |                                  | P97<br>U | U P96    | U P95  | P94<br>U | U      | P92        | U        | P90    |
| 0×09    | R9 (P9)   | Power-on /RESET and WDT          | P        | P        | P      | P        | P      | P          | P        | U<br>P |
|         |           | Wake-up from Pin Change          | P        | P        | P      | P        | P      | P          | P        | P      |
|         |           | Bit Name                         | SRB7     | SRB6     | SRB5   | SRB4     | SRB3   | SRB2       | SRB1     | SRB0   |
|         | RA        | Power-on                         | U        | U        | U      | U<br>U   | U      | U          | U        | U      |
| 0×0A    | (SPIRB)   | /RESET and WDT                   | P        | P        | P      | P        | P      | P          | P        | P      |
|         | (SFIRB)   | Wake-up from Pin Change          | P        | Р        | P      | P        | P      | P          | P        | Р      |
|         |           | Bit Name                         | SWB7     | SWB6     | SWB5   | SWB4     | SWB3   | SWB2       | SWB1     | SWB0   |
|         | RB        | Power-on                         | U        | U        | U      | U        | U      | U          | U        | U      |
| 0×0B    | (SPIWB)   | /RESET and WDT                   | P        | P        | P      | P        | P      | P          | P        | P      |
|         | (SI IVVD) | Wake-up from Pin Change          | P        | Р        | P      | P        | P      | P          | P        | Р      |
|         |           | Bit Name                         | ENSDO    |          | IBDC   | TIIF     | OD3    | OD4        | RBFIF    | RBF    |
|         | RC        | Power-on                         | 0        | 0        | 0      | 0        | 0      | 0          | 0        | 0      |
| 0×0C    | (SPIS)    | /RESET and WDT                   | 0        | 0        | 0      | 0        | 0      | 0          | 0        | 0      |
|         | (01 10)   | Wake-up from Pin Change          | P        | P        | P      | P        | P      | P          | P        | P      |
|         |           | Bit Name                         | CES      | SPIE     | SRO    | SPISE    | -      |            | SBRS1    | •      |
|         | RD        | Power-on                         | 0        | 0        | 0      | 0        | 0      | 0          | 0        | 0      |
| 0×0D    | (SPIC)    | /RESET and WDT                   | 0        | 0        | 0      | 0        | 0      | 0          | 0        | 0      |
|         | (01 10)   | Wake-up from Pin Change          | P        | P        | P      | P        | P      | P          | P        | P      |
|         |           | Bit Name                         | <u> </u> |          | TMR15  |          |        |            | TMR11    | TMR10  |
|         | RE        | Power-on                         | 0        | 0        | 0      | 0        | 0      | 0          | 0        | 0      |
| 0×0E    | (TMR1)    | /RESET and WDT                   | 0        | 0        | 0      | 0        | 0      | 0          | 0        | 0      |
|         | ( )       | Wake-up from Pin Change          | P        | P        | P      | P        | P      | P          | P        | P      |
|         |           | Bit Name                         | PWP7     | PWP6     | PWP5   | PWP4     | PWP3   | PWP2       | PWP1     | PWP0   |
|         | RF        | Power-on                         | 1        | 1        | 1      | 1        | 1      | 1          | 1        | 1      |
| 0×0F    | (PWP)     | /RESET and WDT                   | 1        | 1        | 1      | 1        | 1      | 1          | 1        | 1      |
|         | (* *** )  | Wake-up from Pin Change          | P        | P        | P      | P        | P      | P          | P        | P      |
|         |           | Bit Name                         | -        | -        | -      | -        | T1IF   | SPIIF      | EXIF     | TCIF   |
|         | R3F       | Power-on                         | U        | U        | U      | U        | 0      | 0          | 0        | 0      |
| 0×3F    | (ISR)     | /RESET and WDT                   | U        | U        | U      | U        | 0      | 0          | 0        | 0      |
|         | ( )       | Wake-up from Pin Change          | Ü        | Ü        | Ü      | U        | P      | P          | P        | P      |
|         |           | Bit Name                         | -        | -        | -      | -        | -      | T1E        | T1P1     | T1P0   |
|         |           | Power-on                         | 0        | 0        | 0      | 0        | 0      | 0          | 0        | 0      |
| 0×0C    | IOCC      |                                  |          |          |        |          |        |            |          | _      |
|         |           | /RESET and WDT                   | 0        | 0        | 0      | 0        | 0      | 0          | 0        | 0      |
|         |           | Wake-up from Pin Change          | Р        | Р        | Р      | Р        | Р      | Р          | Р        | Р      |



| Address | Name  | Reset Type              | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------------------------|-------|-------|-------|-------|-------|-------|-------|-------|
|         |       | Bit Name                | S7    | -     | -     | -     | /PU9  | /PU8  | /PU6  | /PU5  |
| 0×0D    | IOCD  | Power-on                | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| UXUD    | ЮСБ   | /RESET and WDT          | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
|         |       | Wake-up from Pin Change | Р     | Р     | Р     | Р     | Р     | Р     | Р     | Р     |
|         |       | Bit Name                | -     | ODE   | WTE   | SLPC  | ROC   | -     | -     | WUE   |
| 0×0E    | IOCE  | Power-on                | U     | 0     | 1     | 1     | 0     | U     | U     | 1     |
| UXUE    | IOCE  | /RESET and WDT          | U     | 0     | 1     | 1     | 0     | U     | J     | 1     |
|         |       | Wake-up from Pin Change | U     | Р     | 1     | 1     | Р     | U     | J     | Р     |
|         |       | Bit Name                | -     | -     | -     | -     | T1IE  | SPIIE | EXIE  | TCIE  |
| 0×0F    | IOCF  | Power-on                | U     | U     | U     | C     | 0     | 0     | 0     | 0     |
| UXUF    | ЮСГ   | /RESET and WDT          | U     | U     | U     | C     | 0     | 0     | 0     | 0     |
|         |       | Wake-up from Pin Change | U     | U     | U     | U     | Р     | Р     | Р     | Р     |
|         |       | Bit Name                | -     | -     | -     | -     | -     | -     | -     | -     |
| 0×10~   | I GPR | Power-On                | U     | U     | U     | J     | J     | U     | J     | U     |
| 0×3E    |       | /RESET and WDT          | Р     | Р     | Р     | Р     | Р     | Р     | Р     | Р     |
|         |       | Wake-Up from Pin Change | Р     | Р     | Р     | Р     | Р     | Р     | Р     | Р     |

<sup>\*\*</sup>To execute the next instruction after the "SLPC" bit status of IOCE register being on high-to-low transition.

U: Unknown or don't care X: Not used -: Not defined

P: Previous value before reset t: Check Table 7

## 5.7.1 The Status of RST, T, and P of the Status Register

A reset condition is initiated by the following events:

- 1. Power-on condition
- 2. Watchdog timer time-out

The values of T and P, listed in Table 7 are used to check how the processor wakes up.

Table 8 shows the events that may affect the status of T and P.



Table 7 Values of RST, T and P after reset

| Reset Type                                | Т | P |
|-------------------------------------------|---|---|
| Power on                                  | 1 | 1 |
| WDT during Operating mode                 | 0 | Р |
| WDT wake-up during Sleep 1 mode           | 0 | 0 |
| WDT wake-up during Sleep 2 mode           | 0 | Р |
| Wake-up on pin change during Sleep 2 mode | Р | Р |

<sup>\*</sup> P: Previous value before reset

Table 8 Status of RST, T and P Being Affected by Events

| Event                                     | Т | Р  |
|-------------------------------------------|---|----|
| Power on                                  | 1 | 1  |
| WDTC instruction                          | 1 | 1  |
| WDT time-out                              | 0 | *P |
| SLEP instruction                          | 1 | 0  |
| Wake-Up on pin change during Sleep 2 mode | Р | Р  |

<sup>\*</sup> P: Previous value before reset

### 5.8 Interrupt

The EM78P451S has the following interrupts.

- 1. /TCC overflow interrupt
- 2. External interrupt (/INT)
- 3. Serial Peripheral Interface (SPI) transmission completed interrupt.
- 4. Timer 1 comparator completed interrupt.

R3F is the interrupt status register, which records the interrupt request in flag bit. IOCF is the interrupt mask register. Global interrupt is enabled by ENI instruction and is disabled by DISI instruction. When one of the interrupts (if enabled) is generated, it will cause the next instruction to be fetched from Address 001H. Once in the interrupt service routine the source of the interrupt can be determined by polling the flag bits in the R3F register. The interrupt flag bit must be cleared by software before leaving the interrupt service routine and enabling interrupts to avoid recursive interrupts.

The flag in the Interrupt Status Register (R3F) is set regardless of the status of its mask bit or the execution of ENI instruction. Note that reading R3F will obtain the output of logic AND of R3F and IOCF (refer to Figure 5-15). The RETI instruction exits the interrupt routine and enables the global interrupt (execution of ENI instruction).

When an interrupt is generated by INT instruction (if enabled), it causes the next instruction to be fetched from Address 002H.





Figure 5-15 Interrupt Input Circuit

### 5.9 Oscillator

#### 5.9.1 Oscillator Modes

The EM78P451S can operate in four different oscillator modes. There are high Crystal (HXT) oscillator mode, low Crystal (LXT) oscillator mode, External RC oscillator mode (ERC), and Internal C, External R oscillator modes. User can select one of them by programming MS, RCT, HLF and HLP in the Code Option Register. Table 9 depicts how these three modes are defined.

Table 9 Oscillator Modes by MS, IRC, RCT

| Mode                                 | MS | RCT | HLF | HLP |
|--------------------------------------|----|-----|-----|-----|
| High Crystal Oscillator              | 1  | ×   | 1   | ×   |
| Low Crystal Oscillator               | 1  | ×   | 0   | 0   |
| External RC Oscillator               | 0  | 1   | ×   | ×   |
| External R and Internal C Oscillator | 0  | 0   | ×   | ×   |

Note: "x": Don't care

### 5.9.2 Crystal Oscillator/Ceramic Resonators (Crystal)

The EM78P451S can be driven by an external clock signal through the OSCI pin as shown in Figure 5-16 below. In most applications, pin OSCI and pin OSCO is connected with a crystal or ceramic resonator to generate oscillation. Figure 5-17 depicts such circuit. Table 10 provides the recommended values of C1 and C2. Since each resonator has its own attribute, user should refer to its specification for appropriate values of C1 and C2. RS, a serial resistor may be necessary for AT strip cut crystal or low frequency mode.





Figure 5-16 Circuit for External Clock Input



Figure 5-17 Circuit for Crystal/Resonator

Table 10 Capacitor Selection Guide for Crystal Oscillator Ceramic Resonators

| Oscillator Type    | Frequency Mode | Frequency | C1 (pF) | C2 (pF) |
|--------------------|----------------|-----------|---------|---------|
|                    |                | 455kHz    | 10~150  | 10~150  |
| Ceramic Resonator  | HXT            | 1.0 MHz   | 40~80   | 40~80   |
| Ceramic Resonator  | TIAT           | 2.0 MHz   | 20~40   | 20~40   |
|                    |                | 4.0 MHz   | 10~30   | 10~30   |
|                    |                | 32.768kHz | 25      | 15      |
|                    | LXT            | 100kHz    | 25      | 25      |
|                    |                | 200kHz    | 25      | 25      |
| Crystal Oscillator |                | 455kHz    | 20~40   | 20~150  |
|                    | HXT            | 1.0 MHz   | 15~30   | 15~30   |
|                    | 11/1           | 2.0 MHz   | 15      | 15      |
|                    |                | 4.0 MHz   | 15      | 15      |

#### 5.9.3 RC Oscillator Mode

For some applications that do not need a very precise timing calculation, the RC oscillator (Figure 5-18 and Figure 5-19) offers a lot of cost savings. Nevertheless, it should be noted that the frequency of the RC oscillator is influenced by the supply voltage, the values of the resistor (Rext), the capacitor (Cext), and even by the operation temperature. Moreover, the frequency also changes slightly from one chip to another due to the manufacturing process variation.

In order to maintain a stable system frequency, the values of the Cext should not be less than 20pF, and that the value of Rext should not be greater than 1 M $\Omega$ . If they cannot be kept in this range, the frequency is easily affected by noise, humidity, and leakage.

The smaller the Rext in the RC oscillator, the faster its frequency will be. On the contrary, for very low Rext values, for instance, 1 K $\Omega$ , the oscillator becomes unstable because the NMOS cannot discharge the current of the capacitance correctly.

Based on the above reasons, it must be kept in mind that all of the supply voltage, the operation temperature, the components of the RC oscillator, the package types, the way the PCB is layout, will affect the system frequency.



Figure 5-18 Circuit for External RC Oscillator Mode



Figure 5-19 Circuit for External R, Internal C Oscillator Mode



### Calibrated frequency of External RC oscillator (For reference only)

| C ext | R ext | Fosc @ 5.0V, 25°C |  |  |  |
|-------|-------|-------------------|--|--|--|
|       | 3.3K  | 3.4 MHz           |  |  |  |
| 20pF  | 5.1K  | 2.2 MHz           |  |  |  |
| 20μ   | 10K   | 1.3 MHz           |  |  |  |
|       | 100K  | 144kHz            |  |  |  |
|       | 3.3K  | 1.2 MHz           |  |  |  |
| 100pF | 5.1K  | 935kHz            |  |  |  |
| ТООРТ | 10K   | 420kHz            |  |  |  |
|       | 100K  | 45kHz             |  |  |  |
|       | 3.3K  | 550kHz            |  |  |  |
| 300pF | 5.1K  | 360kHz            |  |  |  |
| Зоорг | 10K   | 190kHz            |  |  |  |
|       | 100K  | 28kHz             |  |  |  |

#### Internal C, external R Table (For reference only)

| External R (Ω) | Fosc @ 5.0V, 25°C (Hz) |
|----------------|------------------------|
| 10K            | 12M                    |
| 15K            | 7.7M                   |
| 20K            | 5.7M                   |
| 30K            | 3.65M                  |
| 51K            | 2.24M                  |
| 100K           | 1.14M                  |
| 150K           | 749K                   |
| 200K           | 559K                   |
| 510K           | 214K                   |
| 2M             | 56K                    |
| 3.3M           | 32.8K                  |

## 5.10 Code Option Register

### 5.10.1 Word 0

|     | Word 0 |        |        |         |       |       |       |       |       |             |       |       |       |
|-----|--------|--------|--------|---------|-------|-------|-------|-------|-------|-------------|-------|-------|-------|
| Bit | 12     | Bit 11 | Bit 10 | Bit 9   | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3       | Bit 2 | Bit 1 | Bit 0 |
| os  | SC     | ENWDT  | CLKS   | Protect | HLF   | RCT   | HLP   | DEL1  | DEL0  | RESE<br>TEN | N/A   | N/A   | N/A   |

Bit 12 (OSC): Oscillator type selection.

0 : RC type

1 : Crystal type

Bit 11 (ENWDT): Watchdog Timer enabled.

0 : Enable

1: Disable



Bit 10 (CLKS): Clocks of each instruction cycle.

0: Two clocks

1: Four clocks

Bit 9 (Protect): Protect bit.

0: Protect enabled

1: Protect disabled

Bit 8 (HLF): Crystal frequency selection.

0: Low frequency (32.768kHz)

1: High frequency

This bit is useful only when Bit 12 (MS) is 1. When MS is 0, HLF must be 0.

Bit 7 (RCT): Resistor Capacitor

0: external R and internal C

1: external RC

Bit 6 (HLP): Power consumption selection

0: Low power

1: High power

Bit 5 ~ Bit 4: DEL1 and DEL0 (SDI) input delay time options

| DEL 1 | DEL 0 | Delay Time |
|-------|-------|------------|
| 1     | 1     | 0 ns       |
| 0     | 1     | 50 ns      |
| 1     | 0     | 100 ns     |

<sup>\*</sup>Do not set DEL1 and DEL0 bits to all "0", otherwise, the microprocessor won't work.

Bit 3 (RESETEN): reset pin enable bit

**0**: enable, P70/reset  $\rightarrow$  reset pin

1: disable, P70/reset  $\rightarrow$  P70

Bits 2 ~ 0: Not used, set to "1" all the time.

### 5.10.2 Word 1 (User's ID Code)

| Word 1 |        |        |       |       |       |       |       |       |       |       |       |       |
|--------|--------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| ID12   | ID11   | ID10   | ID9   | ID8   | ID7   | ID6   | ID5   | ID4   | ID3   | ID2   | ID1   | ID0   |



#### 5.11 Instruction Set

Each instruction in the instruction set is a 13-bit word divided into an OP code and one or more operands. All instructions are executed within one single instruction cycle (consisting of 2 oscillator periods), unless the program counter is changed by-

- (a) Executing the instruction "MOV R2,A", "ADD R2,A", "TBL", or any other instructions that write to R2 (e.g. "SUB R2,A", "BS R2,6", "CLR R2", etc.).
- **(b)** Execute CALL, RET, RETI, RETL, JMP, Conditional skip (JBS, JBC, JZ, JZA, DJZ, DJZA) which were tested to be true.

Under these cases, the execution takes two instruction cycles.

In addition, the instruction set has the following features:

- (1) Every bit of any register can be set, cleared, or tested directly.
- (2) The I/O register can be regarded as general register. That is, the same instruction can operate on I/O register.

#### Convention:

- **R** = Register designator that specifies which one of the registers (including operation and general purpose registers) is to be utilized by the instruction.
- **b** = Bit field designator that selects the value for the bit located in the register R and which affects the operation.

| k _ | g or | 10-hit | constant | ٥r | litoral | value |
|-----|------|--------|----------|----|---------|-------|
| K = | 0 01 | וט-טונ | constant | ΟI | ınterai | value |

| Binary Instruction | HEX  | Mnemonic | Operation                                        | Status Affected   |
|--------------------|------|----------|--------------------------------------------------|-------------------|
| 0 0000 0000 0000   | 0000 | NOP      | No Operation                                     | None              |
| 0 0000 0000 0001   | 0001 | DAA      | Decimal Adjust A                                 | С                 |
| 0 0000 0000 0010   | 0002 | CONTW    | $A \to CONT$                                     | None              |
| 0 0000 0000 0011   | 0003 | SLEP     | $0 \rightarrow WDT$ , Stop oscillator            | T, P              |
| 0 0000 0000 0100   | 0004 | WDTC     | $0\toWDT$                                        | T, P              |
| 0 0000 0000 rrrr   | 000r | IOW R    | $A\toIOCR$                                       | None <sup>1</sup> |
| 0 0000 0001 0000   | 0010 | ENI      | Enable Interrupt                                 | None              |
| 0 0000 0001 0001   | 0011 | DISI     | Disable Interrupt                                | None              |
| 0 0000 0001 0010   | 0012 | RET      | $[Top\;of\;Stack]\toPC$                          | None              |
| 0 0000 0001 0011   | 0013 | RETI     | [Top of Stack] → PC<br>Enable Interrupt          | None              |
| 0 0000 0001 0100   | 0014 | CONTR    | $CONT \to A$                                     | None              |
| 0 0000 0001 rrrr   | 001r | IOR R    | $IOCR \to A$                                     | None <sup>1</sup> |
| 0 0000 0010 0000   | 0020 | TBL      | $R2+A \rightarrow R2$ , Bits 8~9 of R2 unchanged | Z, C, DC          |
| 0 0000 01rr rrrr   | 00rr | MOV R,A  | $A\toR$                                          | None              |
| 0 0000 1000 0000   | 0800 | CLRA     | $0\toA$                                          | Z                 |
| 0 0000 11rr rrrr   | 00rr | CLR R    | $0 \to R$                                        | Z                 |
| 0 0001 00rr rrrr   | 01rr | SUB A,R  | $R\text{-}A \to A$                               | Z, C, DC          |
| 0 0001 01rr rrrr   | 01rr | SUB R,A  | $R\text{-}A \to R$                               | Z, C, DC          |



| Binary Instruction | HEX  | Mnemonic | Operation                                                                                                    | Status Affected   |
|--------------------|------|----------|--------------------------------------------------------------------------------------------------------------|-------------------|
| 0 0001 10rr rrrr   | 01rr | DECA R   | $R-1 \rightarrow A$                                                                                          | Z                 |
| 0 0001 11rr rrrr   | 01rr | DEC R    | $R-1 \rightarrow R$                                                                                          | Z                 |
| 0 0010 00rr rrrr   | 02rr | OR A,R   | $A \vee VR \to A$                                                                                            | Z                 |
| 0 0010 01rr rrrr   | 02rr | OR R,A   | $A \vee VR \to R$                                                                                            | Z                 |
| 0 0010 10rr rrrr   | 02rr | AND A,R  | $A \& R \rightarrow A$                                                                                       | Z                 |
| 0 0010 11rr rrrr   | 02rr | AND R,A  | A & R $\rightarrow$ R                                                                                        | Z                 |
| 0 0011 00rr rrrr   | 03rr | XOR A,R  | $A \oplus R \to A$                                                                                           | Z                 |
| 0 0011 01rr rrrr   | 03rr | XOR R,A  | $A \oplus R \to R$                                                                                           | Z                 |
| 0 0011 10rr rrrr   | 03rr | ADD A,R  | $A + R \rightarrow A$                                                                                        | Z, C, DC          |
| 0 0011 11rr rrrr   | 03rr | ADD R,A  | $A+R\to R$                                                                                                   | Z, C, DC          |
| 0 0100 00rr rrrr   | 04rr | MOV A,R  | $R \rightarrow A$                                                                                            | Z                 |
| 0 0100 01rr rrrr   | 04rr | MOV R,R  | $R \rightarrow R$                                                                                            | Z                 |
| 0 0100 10rr rrrr   | 04rr | COMA R   | $/R \rightarrow A$                                                                                           | Z                 |
| 0 0100 11rr rrrr   | 04rr | COM R    | $/R \rightarrow R$                                                                                           | Z                 |
| 0 0101 00rr rrrr   | 05rr | INCA R   | $R+1 \rightarrow A$                                                                                          | Z                 |
| 0 0101 01rr rrrr   | 05rr | INC R    | $R+1 \rightarrow R$                                                                                          | Z                 |
| 0 0101 10rr rrrr   | 05rr | DJZA R   | $R-1 \rightarrow A$ , skip if zero                                                                           | None              |
| 0 0101 11rr rrrr   | 05rr | DJZ R    | $R-1 \rightarrow R$ , skip if zero                                                                           | None              |
| 0 0110 00rr rrrr   | 06rr | RRCA R   | $\begin{aligned} R(n) &\rightarrow A(n\text{-}1), \\ R(0) &\rightarrow C,  C \rightarrow A(7) \end{aligned}$ | С                 |
| 0 0110 01rr rrrr   | 06rr | RRC R    | $R(n) \rightarrow R(n-1),$<br>$R(0) \rightarrow C, C \rightarrow R(7)$                                       | O                 |
| 0 0110 10rr rrrr   | 06rr | RLCA R   | $R(n) \rightarrow A(n+1),$<br>$R(7) \rightarrow C, C \rightarrow A(0)$                                       | С                 |
| 0 0110 11rr rrrr   | 06rr | RLC R    | $R(n) \rightarrow R(n+1),$<br>$R(7) \rightarrow C, C \rightarrow R(0)$                                       | С                 |
| 0 0111 00rr rrrr   | 07rr | SWAPA R  | $R(0-3) \to A(4-7),$<br>$R(4-7) \to A(0-3)$                                                                  | None              |
| 0 0111 01rr rrrr   | 07rr | SWAP R   | $R(0-3) \leftrightarrow R(4-7)$                                                                              | None              |
| 0 0111 10rr rrrr   | 07rr | JZA R    | R+1 $\rightarrow$ A, skip if zero                                                                            | None              |
| 0 0111 11rr rrrr   | 07rr | JZ R     | $R+1 \rightarrow R$ , skip if zero                                                                           | None              |
| 0 100b bbrr rrrr   | 0xxx | BC R,b   | $0 \rightarrow R(b)$                                                                                         | None <sup>2</sup> |
| 0 101b bbrr rrrr   | 0xxx | BS R,b   | $1 \rightarrow R(b)$                                                                                         | None <sup>3</sup> |
| 0 110b bbrr rrrr   | 0xxx | JBC R,b  | if R(b)=0, skip                                                                                              | None              |
| 0 111b bbrr rrrr   | 0xxx | JBS R,b  | if R(b)=1, skip                                                                                              | None              |
| 1 00kk kkkk kkkk   | 1kkk | CALL k   | $PC+1 \rightarrow [SP],$<br>(Page, k) $\rightarrow PC$                                                       | None              |
| 1 01kk kkkk kkkk   | 1kkk | JMP k    | $(Page, k) \rightarrow PC$                                                                                   | None              |
| 1 1000 kkkk kkkk   | 18kk | MOV A,k  | $k \rightarrow A$                                                                                            | None              |
| 1 1001 kkkk kkkk   | 19kk | OR A,k   | $A \vee k \to A$                                                                                             | Z                 |
| 1 1010 kkkk kkkk   | 1Akk | AND A,k  | $A \& k \rightarrow A$                                                                                       | Z                 |
| 1 1011 kkkk kkkk   | 1Bkk | XOR A,k  | $A \oplus k \to A$                                                                                           | Z                 |
| 1 1100 kkkk kkkk   | 1Ckk | RETL k   | $k \to A, \text{[Top of Stack]} \to PC$                                                                      | None              |
| 1 1101 kkkk kkkk   | 1Dkk | SUB A,k  | $k-A \rightarrow A$                                                                                          | Z, C, DC          |
| 1 1110 0000 0010   | 1E02 | INT      | $PC+1 \rightarrow [SP], 002H \rightarrow PC$                                                                 | None              |
| 1 1111 kkkk kkkk   | 1Fkk | ADD A,k  | $k+A \rightarrow A$                                                                                          | Z, C, DC          |

Note: <sup>1</sup> This instruction is applicable to IOC5~IOC9, IOCD ~ IOCF only.

<sup>&</sup>lt;sup>2</sup> This instruction is not recommended for RF operation.

This instruction cannot operate on R3F.



# 6 Absolute Maximum Ratings

| Items                      |       | Rating |        |
|----------------------------|-------|--------|--------|
| Temperature under bias     | 0°C   | to     | 70°C   |
| Storage temperature        | -65°C | to     | 150°C  |
| Input voltage              | -0.3V | to     | +6.0V  |
| Output voltage             | -0.3V | to     | +6.0V  |
| Operating Frequency (2clk) | DC    | to     | 20 MHz |

## 7 Electrical Characteristics

### 7.1 DC Characteristics

Ta=25°C, VDD=5V  $\pm$  5%, VSS=0V

| Symbol  | Parameter                                                             | Condition                                 | Min | Тур | Max | Unit |
|---------|-----------------------------------------------------------------------|-------------------------------------------|-----|-----|-----|------|
|         | Crystal VDD to 2.3V                                                   |                                           | DC  | _   | 4   |      |
| FXT     | Crystal VDD to 3V                                                     | Two clocks                                | DC  | -   | 8   | MHz  |
|         | Crystal VDD to 5V                                                     |                                           | DC  | _   | 20  |      |
|         | RC VDD to 2.3V                                                        |                                           | DC  | _   | 4   |      |
| FRC     | RC VDD to 3V                                                          | Two clocks                                | DC  | _   | 4   | MHz  |
|         | RC VDD to 5V                                                          |                                           | DC  | _   | 4   |      |
| IIL     | Input Leakage Current                                                 | VIN = VDD, VSS                            | _   | _   | ±1  | μΑ   |
| VIH1    | Input High Voltage VDD=5V)                                            | -                                         | 2.0 | _   | _   | V    |
| VIL1    | Input Low Voltage (VDD=5V)                                            | -                                         | _   | _   | 0.8 | V    |
| VIHX1   | Clock Input High Voltage (VDD=5V)                                     | OSCI                                      | 2.5 | -   | -   | V    |
| VILX1   | Clock Input Low Voltage (VDD=5V)                                      | OSCI                                      | _   | _   | 1.0 | V    |
| VIHT1   | Input high threshold voltage (Schmitt trigger)                        | P70/RESET pin                             | 2.0 | _   | -   | V    |
| VILT1   | Input low threshold voltage (Schmitt trigger)                         | P70/RESET pin                             | _   | _   | 0.8 | V    |
| VIH2    | Input High Voltage (VDD=3V)                                           | -                                         | 1.5 | _   | _   | V    |
| VIL2    | Input Low Voltage (VDD=3V)                                            | -                                         | _   | _   | 0.4 | V    |
| VIHX2   | Clock Input High Voltage (VDD=3V)                                     | OSCI                                      | 1.5 | _   | -   | V    |
| VILX2   | Clock Input Low Voltage (VDD=3V)                                      | OSCI                                      | _   | _   | 0.6 | V    |
| VOH1    | Output High Voltage<br>(Ports 5, 6, 8, P74~P77,<br>P90~P92, P95~P97,) | IOH = -12.0mA                             | 2.4 | -   | _   | V    |
| VOH2    | Output High Voltage                                                   | S7=1 (IOCD Register Bit 7), IOH = -9.0mA  | 2   | 2.4 | _   | V    |
| V 01 12 | (P70~P72)                                                             | S7=0 (IOCD Register Bit 7), IOH = -12.0mA | 2.4 | _   | _ v |      |
| VOH3    | Output High Voltage<br>(P93/SDO, P94/SCK)                             | IOH = -12.0mA                             | 2.4 | _   | _   | V    |



| Symbol         | Parameter                                                           | Condition                                                            | Min | Тур  | Max  | Unit |
|----------------|---------------------------------------------------------------------|----------------------------------------------------------------------|-----|------|------|------|
| VOL1           | Output Low Voltage<br>(Ports 5, 6, 8, P74~P77,<br>P90~P92, P95~P97) | IOL =12.0mA                                                          | -   | _    | 0.4  | V    |
| VOL 2          | Output Low Voltage                                                  | S7=1 (IOCD Register Bit 7),<br>IOH = 9.0mA                           | -   | 0.4  | 0.8  | V    |
| VOL2 (P70~P72) |                                                                     | S7=0 (IOCD Register Bit 7),<br>IOH = 12.0mA                          | ı   | -    | 0.4  | V    |
| VOL3           | Output Low Voltage<br>(P93/SDO, P94/SCK)                            | IOL = 12.0mA                                                         | _   | _    | 0.4  | V    |
| VOL4           | Output Low Voltage (P74~P77)                                        | IOL = 15.0mA                                                         | -   |      | 0.4  | _    |
| IPH            | Pull-high current                                                   | Pull-high active, Input pin at VSS                                   | -50 | -100 | -240 | μΑ   |
| IPH2           | Pull-high current (P74~P75)                                         | Pull-high active, Input pin at VSS                                   | -   | 1    | -    | mA   |
| IPH3           | Pull high current<br>(P70/RESET)                                    | Pull-high active, Input pin at VSS                                   | -16 | -22  | -29  | μΑ   |
| ISB            | Power down current                                                  | All input and I/O pin at VDD,<br>Output pin floating,<br>WDT enabled | -   | -    | 10   | μΑ   |
| ICC            | Operating supply current                                            | /RESET="High",<br>Fosc=1.84324 MHz (CK2="0"),<br>Output pin floating | _   | _    | 3    | mA   |

## 7.2 AC Characteristics

Ta=0°C~70°C, VDD=5V  $\pm$  5%, VSS=0V

| Symbol | Parameter                        | Conditions | Min          | Тур             | Max | Unit |
|--------|----------------------------------|------------|--------------|-----------------|-----|------|
| Dclk   | Input CLK duty cycle             | _          | 45           | 50              | 55  | %    |
| Tins   | Instruction cycle time (CK2="0") | RC Type    | 500          | -               | DC  | ns   |
| Ttcc   | TCC input period                 | _          | (Tins+20)/N* | ı               | -   | ns   |
| Twdt   | Watchdog timer period            | Ta=25°C    | _            | 18              | 1   | ms   |
| Tdrh   | Device reset hold period         | Ta=25°C    | _            | 18 <sup>3</sup> | _   | ms   |

\*N= selected prescaler ratio.

 $<sup>^{3}</sup>$  Vdd = 5V, set-up time period = 16.2ms ± 30% Vdd = 3V, set-up time period = 18.0ms ± 30%



# 8 Timing Diagrams





AC Testing : Input is driven at 2.4V for logic "1",and 0.4V for logic "0".Timing measurements are made at 2.0V for logic "1",and 0.8V for logic "0".

### **RESET Timing (CLK="0")**



### TCC Input Timing (CLKS="0")





## 9 Application Circuit





### **APPENDIX**

## A Package Type

| OTP MCU     | Package Type | Pin Count | Package Size |
|-------------|--------------|-----------|--------------|
| EM78P451SH  | DICE         | 40        | _            |
| EM78P451SP  | DIP          | 40        | 600 mil      |
| EM78P451SAQ | QFP          | 44        | _            |
| EM78P451SDM | SSOP         | 24        | 209 mil      |

# B Package Information

■ 40-Pad DICE

Pad diagram





#### Pad Name and Coordinate Table

| Pad No. | Pad Name | Coordinate-X | Coordinate-Y |
|---------|----------|--------------|--------------|
| 1       | P9_0_    | -691.0       | 1015.0       |
| 2       | P9_1_    | -715.0       | 89.5         |
| 3       | P9_2_    | -715.0       | -15.5        |
| 4       | P9_3_    | -715.0       | -120.5       |
| 5       | P9_4_    | -715.0       | -225.5       |
| 6       | P9_5_    | -715.0       | -330.5       |
| 7       | P5_0_    | -715.0       | -435.5       |
| 8       | P5_1_    | -715.0       | -540.5       |
| 9       | P5_2_    | -715.0       | -645.5       |
| 10      | P5_3_    | -715.0       | -750.5       |
| 11      | P5_4_    | -715.0       | -855.5       |
| 12      | P5_5_    | -715.0       | -960.5       |
| 13      | P5_6_    | -421.8       | -1015.0      |
| 14      | P5_7_    | -316.8       | -1015.0      |
| 15      | P8_0_    | -211.8       | -1015.0      |
| 16      | P8_1_    | -106.8       | -1015.0      |
| 17      | P8_2_    | -1.9         | -1015.0      |
| 18      | P8_3_    | 103.2        | -1015.0      |
| 19      | P8_4_    | 208.2        | -1015.0      |
| 20      | P8_5_    | 313.2        | -1015.0      |
| 21      | P8_6_    | 418.1        | -1015.0      |
| 22      | P8_7_    | 715.0        | -960.5       |
| 23      | P6_0_    | 715.0        | -855.5       |
| 24      | P6_1_    | 715.0        | -750.5       |
| 25      | P6_2_    | 715.0        | -645.5       |
| 26      | P6_3_    | 715.0        | -540.5       |
| 27      | P6_4_    | 715.0        | -435.5       |
| 28      | P6_5_    | 715.0        | -330.5       |
| 29      | P6_6_    | 715.0        | -225.5       |
| 30      | P6_7_    | 715.0        | -120.5       |
| 31      | P7_2_    | 715.0        | -15.5        |
| 32      | P7_1_    | 715.0        | 89.5         |
| 33      | P7_0_    | 407.6        | 1015.0       |



| Pad No. | Pad Name | Coordinate-X | Coordinate-Y |
|---------|----------|--------------|--------------|
| 34      | VDD      | 302.5        | 1015.0       |
| 35      | OSCI     | 197.6        | 1015.0       |
| 36      | osco     | -152.8       | 1015.0       |
| 37      | GND      | -257.8       | 1015.0       |
| 38      | INTN     | -362.8       | 1015.0       |
| 39      | DATAIO   | -471.1       | 1015.0       |
| 40      | CLKIO    | -582.7       | 1015.0       |



■ 40-Lead Plastic Dual in line (PDIP) — 600 mil





### ■ 44--Lead Quad Flat Package (QFP)





■ 24--Lead Shrink Small Outline Package (SSOP) — 209 mil





## C Program Temperature Restriction

- 1. User using DWTR to program the EM78P451S must ensure that the program temperature is kept at 30°C or below.
- 2. If the program temperature is more than 30°C, it will cause the program to fail.
- 3. When the above Item 2 status occurs, lowering down the environment or ambient temperature to 30°C or below is the solution, after which it will program normally.
- 4. After programming the EM78P451S and the DC characteristics do not change, the working temperature should be  $0^{\circ}$ C ~ $70^{\circ}$ C.