

Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

#### Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

E·XFI

| Product Status             | Not For New Designs                                                                      |
|----------------------------|------------------------------------------------------------------------------------------|
| Core Processor             | 8052                                                                                     |
| Core Size                  | 8-Bit                                                                                    |
| Speed                      | 40MHz                                                                                    |
| Connectivity               | EBI/EMI, UART/USART                                                                      |
| Peripherals                | POR, PWM, WDT                                                                            |
| Number of I/O              | 36                                                                                       |
| Program Memory Size        | 64KB (64K x 8)                                                                           |
| Program Memory Type        | FLASH                                                                                    |
| EEPROM Size                | -                                                                                        |
| RAM Size                   | 1.25К х 8                                                                                |
| Voltage - Supply (Vcc/Vdd) | 4.5V ~ 5.5V                                                                              |
| Data Converters            | -                                                                                        |
| Oscillator Type            | Internal                                                                                 |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                                          |
| Mounting Type              | Surface Mount                                                                            |
| Package / Case             | 44-BQFP                                                                                  |
| Supplier Device Package    |                                                                                          |
| Purchase URL               | https://www.e-xfl.com/product-detail/nuvoton-technology-corporation-america/w78e365a40fl |
|                            |                                                                                          |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

| 8.  | TIMIN | G WAVEFORMS                                  | . 30 |
|-----|-------|----------------------------------------------|------|
|     | 8.1   | Program Fetch Cycle                          | . 30 |
|     | 8.2   | Data Read Cycle                              | . 31 |
|     | 8.3   | Data Write Cycle                             | . 32 |
|     | 8.4   | Port Access Cycle                            | . 33 |
| 9.  | TYPIC | AL APPLICATION CIRCUIT                       | . 34 |
|     | 9.1   | External Program Memory and Crystal          | . 34 |
|     | 9.2   | Expanded External Data Memory and Oscillator | . 35 |
| 10. | PACK  | AGE DIMENSIONS                               | . 36 |
|     | 10.1  | 40-pin DIP                                   | . 36 |
|     | 10.2  | 44-pin PLCC                                  | . 36 |
|     | 10.3  | 44-pin PQFP                                  | . 37 |
|     | 10.4  | 48-pin LQFP                                  | . 38 |
| 11. | APPLI | CATION NOTE                                  | . 39 |
|     | 11.1  | In-system Programming Software Examples      | . 39 |
| 12. | REVIS | SION HISTORY                                 | . 44 |

### 4. PIN DESCRIPTION

| SYMBOL                                | TYPE  | DESCRIPTIONS                                                                                                                                                                                                                                                           |  |  |
|---------------------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| ĒĀ                                    | I     | EXTERNAL ACCESS ENABLE: This pin forces the processor to execute the external ROM. The ROM address and data will not be presented on the bus if the $\overline{EA}$ pin is high.                                                                                       |  |  |
| PSEN                                  | ОН    | PROGRAM STORE ENABLE: $\overrightarrow{\text{PSEN}}$ enables the external ROM data in the Port 0 address/data bus. When internal ROM access is performed, no $\overrightarrow{\text{PSEN}}$ strobe signal outputs originate from this pin.                             |  |  |
| ALE                                   | ОН    | ADDRESS LATCH ENABLE: ALE is used to enable the address latch that separates the address from the data on Port 0. ALE runs at 1/6th of the oscillator frequency.                                                                                                       |  |  |
| RST                                   | ΙL    | RESET: A high on this pin for two machine cycles while the oscillator is running resets the device.                                                                                                                                                                    |  |  |
| XTAL1                                 | I     | CRYSTAL 1: This is the crystal oscillator input. This pin may be driven by an external clock.                                                                                                                                                                          |  |  |
| XTAL2                                 | 0     | CRYSTAL 2: This is the crystal oscillator output. It is the inversion of XTAL1.                                                                                                                                                                                        |  |  |
| Vss                                   | I     | GROUND: ground potential.                                                                                                                                                                                                                                              |  |  |
| Vdd                                   | Ι     | POWER SUPPLY: Supply voltage for operation.                                                                                                                                                                                                                            |  |  |
|                                       |       | PORT 0: Function is the same as that of standard 8052.                                                                                                                                                                                                                 |  |  |
| P0.0 – P0.7 I/O D                     |       | This port also provides a multiplexed low order address/data bus during accesses to external memory. Port 0 has internal pull-up resisters enabled by software.                                                                                                        |  |  |
| P1.0 – P1.7                           | I/O H | PORT 1: Function is the same as that of standard 8052.                                                                                                                                                                                                                 |  |  |
| P2.0 – P2.7 I/O H provides<br>and P2. |       | PORT 2: Port 2 is a bi-directional I/O port with internal pull-ups. This port also provides the upper address bits for accesses to external memory. The P2.6 and P2.7 also provide the alternate function $\overrightarrow{REBOOT}$ which is H/W reboot from LD flash. |  |  |
| P3.0 – P3.7                           | I/O H | PORT 3: Function is the same as that of the standard 8052.                                                                                                                                                                                                             |  |  |
| P4.0 – P4.7                           | I/O H | $\frac{\text{PORT 4: A bi-directional I/O. The P4.3 also provides the alternate function}{\text{REBOOT}}$ which is H/W reboot from LD flash.                                                                                                                           |  |  |

\* Note: TYPE I: input, O: output, I/O: bi-directional, H: pull-high, L: pull-low, D: open drain

### W78E365/W78E365A

### nuvoTon

### 5. BLOCK DIAGRAM



### 6. FUNCTIONAL DESCRIPTION

The W78E365 architecture consists of a core controller surrounded by various registers, four general purpose I/O ports, one special purpose programmable 4-bits I/O port, 256+1K bytes of RAM, three timer/counters, a serial port. The processor supports 111 different opcodes and references both a 64K program address space and a 64K data storage space.

### 6.1 RAM

The internal data RAM in the W78E365 is 256+1K bytes. It is divided into two banks: 256 bytes of scratchpad RAM and 1K bytes of AUX-RAM. These RAMs are addressed by different ways.

- RAM 0H 7FH can be addressed directly and indirectly as the same as in 8051. Address pointers are R0 and R1 of the selected register bank.
- RAM 80H FFH can only be addressed indirectly as the same as in 8051. Address pointers are R0, R1 of the selected registers bank.
- AUX-RAM 0H 3FFH is addressed indirectly as the same way to access external data memory with the MOVX instruction. Address pointer are R0 and R1 of the selected register bank and DPTR register. An access to external data memory locations higher than 3FFH will be performed with the MOVX instruction in the same way as in the 8051. The AUX-RAM is **enabled** after a reset. Clearing the bit 4 in CHPCON register will disable the access to AUX-RAM. When executing from internal program memory, an access to AUX-RAM will not affect the Ports P0, P2, WR and RD.

Example:

| CHPENF | R REG    | F6H        |                                                  |
|--------|----------|------------|--------------------------------------------------|
| CHPCON | N REG    | BFH        |                                                  |
| XRAMA  | H REG    | A1H        |                                                  |
|        |          |            |                                                  |
| MOV    | CHPENR,  | #87H       |                                                  |
| MOV    | CHPENR,  | #59H       |                                                  |
| ORL    | CHPCON,  | #00010000B | ; enable AUX-RAM                                 |
| MOV    | CHPENR,  | #00H       |                                                  |
| MOV    | XRAMAH,  | #01H       | ; internal high address                          |
| MOV    | R0, #23H |            |                                                  |
| MOV    | A, #55H  |            |                                                  |
| MOVX   | @R0, A   |            | ; Write 55h data to 0123h AUX-RAM address.       |
| MOV    | XRAMAH,  | #02H       |                                                  |
| MOV    | R1, #FFH |            | ; Read data from 02FFh AUX-RAM address.          |
| MOVX   | A, @R1   |            |                                                  |
| MOV    | DPTR, #0 | 134H       |                                                  |
| MOV    | A, #78H  |            |                                                  |
| MOVX   | @DPTR,   | A          | ; Write 78h data to 0134h AUX-RAM address.       |
| MOV    | DPTR, #7 | FFFH       |                                                  |
| MOVX   | A, @DPR  | Т          | ; Read data from the external 7FFFh address SRAM |

### W78E365/W78E365A

### nuvoTon

#### 6.6.1 Port Options Register



P0UP: Enable Port 0 weak up. The pins of Port 0 can be configured with either the open drain or standard port with internal pull-up. By the default, Port 0 is an open drain bi-directional I/O port. When the P0UP bit in the POR register is set, the pins of port 0 will perform a bi-directional I/O port with internal pull-up that is structurally the same Port2.

#### 6.6.2 INT2/INT3

Two additional external interrupts,  $\overline{\text{INT2}}$  and  $\overline{\text{INT3}}$ , whose functions are similar to those of external interrupt 0 and 1 in the standard 80C52. The functions/status of these interrupts are determined/shown by the bits in the XICON (External Interrupt Control) register. The XICON register is bit-addressable but is not a standard register in the standard 80C52. Its address is at 0C0H. To set/clear bits in the XICON register, one can use the "SETB ( $\overline{\text{CLR}}$ ) bit" instruction. For example, "SETB 0C2H" sets the EX2 bit of XICON.

XICON - external interrupt control (C0H)

| PX3 EX3 IE3 IT3 PX2 EX2 IE2 | IT2 |
|-----------------------------|-----|
|-----------------------------|-----|

PX3: External interrupt 3 priority high if set

EX3: External interrupt 3 enable if set

IE3: If IT3 = 1, IE3 is set/cleared automatically by hardware when interrupt is detected/serviced

IT3: External interrupt 3 is falling-edge/low-level triggered when this bit is set/cleared by software

PX2: External interrupt 2 priority high if set

EX2: External interrupt 2 enable if set

IE2: If IT2 = 1, IE2 is set/cleared automatically by hardware when interrupt is detected/serviced

IT2: External interrupt 2 is falling-edge/low-level triggered when this bit is set/cleared by software

#### P4 (D8H)

| BIT | NAME | FUNCTION                                              |  |  |  |  |
|-----|------|-------------------------------------------------------|--|--|--|--|
| 7   | P47  | I/O pin                                               |  |  |  |  |
| 6   | P46  | I/O pin.                                              |  |  |  |  |
| 5   | P45  | I/O pin.                                              |  |  |  |  |
| 4   | P44  | I/O pin.                                              |  |  |  |  |
| 3   | P43  | Port 4 Data bit which outputs to pin P4.3 at mode 0.  |  |  |  |  |
| 2   | P42  | Port 4 Data bit. which outputs to pin P4.2 at mode 0. |  |  |  |  |
| 1   | P41  | Port 4 Data bit. which outputs to pin P4.1at mode 0.  |  |  |  |  |
| 0   | P40  | Port 4 Data bit which outputs to pin P4.0 at mode 0.  |  |  |  |  |

Here is an example to program the P4.0 as a write strobe signal at the I/O port address 1234H - 1237H and positive polarity, and P4.1 - P4.3 are used as general I/O ports.

MOV P40AH, #12H MOV P40AL, #34H MOV P4CONA, #00001010B MOV P4CONB, #00H MOV P2ECON, #10H

; Base I/O address 1234H for P4.0 ; P4.0 a write strobe signal and address line A0 and A1 are masked. ; P4.1 – P4.3 as general I/O port which are the same as PORT1 ; Write the P40SINV = 1 to inverse the P4.0 write strobe polarity ; default is negative.

Then any instruction MOVX @DPTR, A (with DPTR = 1234H - 1237H) will generate the positive polarity write strobe signal at pin P4.0. And the instruction MOV P4, #XX will output the bit3 to bit1 of data #XX to pin P4.3 – P4.1.



### 6.7 Pulse Width Modulated Outputs (PWM)

There are five pulse width modulated output channels to generate pulses of programmable length and interval. The repetition frequency is defined by an 8-bit prescaler PWMP, which supplies the clock for the counter. The prescaler and counter are common to both PWM channels. The 8-bit counter counts modular 255 (0 ~ 254). The value of the 8-bit counter compared to the contents of five registers: PWM0, PWM1, PWM2, PWM3 and PWM4. Provided the contents of either these registers is greater than the counter value, the corresponding PWM0, PWM1, PWM2, PWM3 or PWM4 output is set HIGH. If the contents of these registers are equal to, or less than the counter value, the output will be LOW. The pulse-width-ratio is defined by the contents of the registers PWM0, PWM1, PWM2, PWM3 and PWM4. The pulse-width-ratio is in the range of 0 to 1 and may be programmed in increments of 1/255. ENPWM0, ENPWM1, ENPWM2, ENPWM3 and ENPWM4 bit will enable or disable PWM output.

Buffered PWM outputs may be used to drive DC motors. The rotation speed of the motor would be proportional to the contents of PWM0/1/2/3/4. The repetition frequency  $f_{pwm}$ , at the PWM0/1/2/3/4 output is given by:

$$f_{pwm} = \frac{f_{osc}}{2 \times (1 + PWMP) \times 255}$$

Prescaler division factor = PWM + 1

 $\label{eq:PWMn} \mbox{PWMn high/low ratio of } PWMn = \frac{(PWMn)}{255 \mbox{-} (PWMn)}$ 

This gives a repetition frequency range of 123 Hz to 31.4K Hz ( $f_{osc} = 16$  Hz). By loading the PWM registers with either 00H or FFH, the PWM channels will output a constant HIGH or LOW level, respectively. Since the 8-bit counter counts modulo 255, it can never actually reach the value of the PWM registers when they are loaded with FFH.

When a compare register (PWM0, PWM1, PWM2, PWM3, PWM4) is loaded with a new value, the associated output updated immediately. It does not have to wait until the end of the current counter period. There is weakly pulled high on PWM output.



PWM4OE: Output enable for PWM4

ENPWM: Enable for PWM4

### 6.8 Watchdog Timer

The Watchdog timer is a free-running timer which can be programmed by the user to serve as a system monitor, a time-base generator or an event timer. It is basically a set of dividers that divide the system clock. The divider output is selectable and determines the time-out interval. When the time-out occurs, a system reset can also be caused if it is enabled. The main use of the Watchdog timer is as a system monitor. This is important in real-time control applications. In case of power glitches or electromagnetic interference, the processor may begin to execute errant code. If this is left unchecked the entire system may crash. The watchdog time-out selection will result in different time-out values depending on the clock speed. The Watchdog timer will de disabled on reset. In general, software should restart the Watchdog timer to put it into a known state. The control bits that support the Watchdog timer are discussed below.

#### Watchdog Timer Control Register



ENW : Enable watch-dog if set.

CLRW : Clear watch-dog timer and prescaler if set. This flag will be cleared automatically

WIDL : If this bit is set, watch-dog is enabled under IDLE mode. If cleared, watch-dog is disabled under IDLE mode. Default is cleared.

| MODE               | WFWIN | CTRL<3:0> | OEN | CEN | SFRAH, SFRAL | SFRFD    |
|--------------------|-------|-----------|-----|-----|--------------|----------|
| Erase 64KB APROM   | 0     | 0010      | 1   | 0   | Х            | Х        |
| Program 64KB APROM | 0     | 0001      | 1   | 0   | Address in   | Data in  |
| Read 64KB APROM    | 0     | 0000      | 0   | 0   | Address in   | Data out |
| Erase 4KB LDROM    | 1     | 0010      | 1   | 0   | Х            | Х        |
| Program 4KB LDROM  | 1     | 0001      | 1   | 0   | Address in   | Data in  |
| Read 4KB LDROM     | 1     | 0000      | 0   | 0   | Address in   | Data out |

### 6.9.1 In-System Programming Control Register (CHPCON)

#### CHPCON (BFH)

| BIT | NAME     | FUNCTION                                                                                                                                                   |
|-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | SWRESET  | When this bit is set to 1, and both FBOOTSL and FPROGEN are set to 1. It will enforce microcontroller reset to initial condition just like power on reset. |
| 6   | -        | Reserve.                                                                                                                                                   |
| 5   | LD/AP    | This bit is read only. 1: CPU is running LDROM program. 0: CPU is running APROM program.                                                                   |
| 4   | ENAUXRAM | 1: Enable on-chip AUX-RAM.                                                                                                                                 |
| 4   |          | 0: Disable the on-chip AUX-RAM                                                                                                                             |
| 3   | 1        | Must be 1                                                                                                                                                  |
| 2   | -        | Reserve.                                                                                                                                                   |
| 1   | FBOOTSL  | When this bit is set to 1, and both SWRESET and FPROGEN are set to 1. It will enforce microcontroller reset to initial condition just like power on reset. |
| 0   | FPROGEN  | When this bit is set to 1, and both SWRESET and FBOOTSL are set to 1. It will enforce microcontroller reset to initial condition just like power on reset. |

This register is protected by CHPENR register. Please write as below procedures while you would like to write CHPCON register.

Mov CHPENR, #87h

Mov CHPENR, #59h

Anl CHPCON, #EFh ; Disable AUX-RAM

Mov CHPENR, #0h

### 6.10 Software Reset

Set CHPCON = 0X83, timer and enter IDLE mode. CPU will reset and restart from APFLASH after time out.

### 6.11 H/W Reboot Mode (Boot from LDROM)

By default, the W78E365 boots from APROM program after a power on reset. On some occasions, user can force the W78E365 to boot from the LDROM program via following settings. The possible situation that you need to enter H/W REBOOT mode when the APROM program can not run properly and device can not jump back to LDROM to execute in-system programming function. Then you can use this H/W REBOOT mode to force the W78E365 jumps to LDROM and executes in-system programming procedure. When you design your system, you may reserve the pins P2.6, P2.7 to switches or jumpers. For example in a CD-ROM system, you can connect the P2.6 and P2.7 to PLAY and EJECT buttons on the panel. When the APROM program fails to execute the normal application program. User can press both two buttons at the same time and then turn on the power of the personal computer, you can release both buttons and finish the in-system programming procedure to update the APROM code. In application system design, user must take care of the P2, P3, ALE, EA and PSEN pin value at reset to prevent from accidentally activating the programming mode or H/W REBOOT mode. It is necessary to add 10K resistor on these P2.6, P2.7 and P4.3 pins.

#### H/W Reboot Mode

| P4.3 | P2.7 | P2.6 | MODE   |
|------|------|------|--------|
| Х    | L    | L    | REBOOT |
| L    | Х    | Х    | REBOOT |





### 7. ELECTRICAL CHARACTERISTICS

#### 7.1 Absolute Maximum Ratings

| PARAMETER             | SYMBOL  | MIN.     | MAX.     | UNIT |
|-----------------------|---------|----------|----------|------|
| DC Power Supply       | VDD-VSS | -0.3     | +6.0     | V    |
| Input Voltage         | Vin     | Vss -0.3 | Vdd +0.3 | V    |
| Operating Temperature | ТА      | 0        | 70       | °C   |
| Storage Temperature   | Тѕт     | -55      | +150     | °C   |

Note: Exposure to conditions beyond those listed under Absolute Maximum Ratings may adversely affect the life and reliability of the device.

### 7.2 D.C. Characteristics

(V\_DD\_- V\_SS= 5V  $\pm 10\%,\,T_A$  = 25°C, Fosc = 20 MHz, unless otherwise specified.)

| SYMBOL                          | PARAMETER                                         | SP   | ECIFICAT | ION  | TEST CONDITIONS                                     |
|---------------------------------|---------------------------------------------------|------|----------|------|-----------------------------------------------------|
| STWBOL                          | FARAWETER                                         | MIN. | MAX.     | UNIT | TEST CONDITIONS                                     |
| V <sub>DD</sub>                 | Operating Voltage                                 | 4.5  | 5.5      | V    | $RST = 1, P0 = V_{DD}$                              |
| I <sub>DD</sub>                 | Operating Current                                 | -    | 20       | mA   | No load<br>V <sub>DD</sub> = 5.5V                   |
| I <sub>IDLE</sub>               | Idle Current                                      | -    | 6        | mA   | Idle mode<br>V <sub>DD</sub> = 5.5V                 |
| I <sub>PWDN</sub>               | Power Down Current                                | -    | 10       | μA   | Power-down mode $V_{DD} = 5.5V$                     |
| I <sub>IN1</sub>                | Input Current<br>P1, P2, P3, P4                   | -50  | +10      | μΑ   | $V_{DD} = 5.5V$<br>$V_{IN} = 0V \text{ or } V_{DD}$ |
| I <sub>IN2</sub>                | Input Current<br>RST                              | -10  | +300     | μΑ   | $V_{DD} = 5.5V$<br>$0 < V_{IN} < V_{DD}$            |
| Ι <sub>LK</sub>                 | Input Leakage Current<br>P0, EA                   | -10  | +10      | μA   | $V_{DD} = 5.5V$ $0V < V_{IN} < V_{DD}$              |
| I <sub>TL</sub> <sup>[*4]</sup> | Logic 1 to 0 Transition Current<br>P1, P2, P3, P4 | -500 | -200     | μA   | $V_{DD} = 5.5V$<br>$V_{IN} = 2.0V$                  |
| VIL1                            | Input Low Voltage<br>P0, P1, P2, P3, P4, EA       | 0    | 0.8      | V    | VDD = 4.5V                                          |
| V IL2                           | Input Low Voltage<br>RST                          | 0    | 0.8      | V    | VDD = 4.5V                                          |

D.C. Characteristics, continued

| SYMBOL           | PARAMETER                                            | S    | PECIFICATI           | ON   | TEST CONDITIONS                                     |
|------------------|------------------------------------------------------|------|----------------------|------|-----------------------------------------------------|
| STWIDUL          |                                                      | MIN. | MAX.                 | UNIT | TEST CONDITIONS                                     |
| V <sub>IL3</sub> | Input Low Voltage<br>XTAL1 <sup>['4]</sup>           | 0    | 0.8                  | V    | $V_{DD} = 4.5V$                                     |
| V <sub>IH1</sub> | Input High Voltage<br>P0, P1, P2, P3, P4, EA         | 2.4  | V <sub>DD</sub> +0.2 | V    | V <sub>D D</sub> = 5.5V                             |
| V <sub>IH2</sub> | Input High Voltage<br>RST                            | 3.5  | V <sub>DD</sub> +0.2 | V    | $V_{DD} = 5.5V$                                     |
| V <sub>IH3</sub> | Input High Voltage<br>XTAL1 <sup>[*4]</sup>          | 3.5  | V <sub>DD</sub> +0.2 | V    | V <sub>DD</sub> = 5.5V                              |
| V <sub>OL1</sub> | Output Low Voltage<br>P1, P2, P3, P4                 | -    | 0.45                 | V    | $V_{DD} = 4.5V$<br>$I_{OL} = +2 \text{ mA}$         |
| V <sub>OL2</sub> | Output Low Voltage<br>P0, ALE, PSEN <sup>[*3]</sup>  | -    | 0.45                 | V    | V <sub>DD</sub> = 4.5V<br>I <sub>OL</sub> = +4 mA   |
| lsk1             | Sink current<br>P1, P3, P4                           | 4    | 8                    | mA   | V <sub>DD</sub> = 4.5V<br>VOL = 0.45V               |
| lsk2             | Sink current<br>P0, P2, ALE, PSEN                    | 10   | 14                   | mA   | V <sub>DD</sub> =4.5V<br>VOL = 0.45V                |
| V <sub>OH1</sub> | Output High Voltage<br>P1, P2, P3, P4                | 2.4  | -                    | V    | V <sub>DD</sub> = 4.5V<br>I <sub>OH</sub> = -100 μA |
| V <sub>OH2</sub> | Output High Voltage<br>P0, ALE, PSEN <sup>[*3]</sup> | 2.4  | -                    | V    | V <sub>DD</sub> = 4.5V<br>I <sub>OH</sub> = -400 μA |
| lsr1             | Source current<br>P1, P2, P3, P4                     | -120 | -180                 | μΑ   | V <sub>DD</sub> = 4.5V<br>VOH = 2.4V                |
| lsr2             | Source current<br>P0, P2, ALE, PSEN                  | -10  | -14                  | mA   | V <sub>DD</sub> =4.5V<br>VOH = 2.4V                 |

Notes:

\*1. RST pin is a Schmitt trigger input.

\*2. P0, ALE and  $\overrightarrow{\text{PSEN}}$  are tested in the external access mode.

\*3. XTAL1 is a CMOS input.

\*4. Pins of P1, P2, P3, P4 can source a transition current when they are being externally driven from 1 to 0.

### 7.3 A.C. Characteristics

The AC specifications are a function of the particular process used to manufacture the part, the ratings of the I/O buffers, the capacitive load, and the internal routing capacitance. Most of the specifications can be expressed in terms of multiple input clock periods (TCP), and actual parts will usually experience less than a  $\pm 20$  nS variation.

#### **Clock Input Waveform**



| PARAMETER       | SYMBOL | MIN. | TYP. | MAX. | UNIT | NOTES |
|-----------------|--------|------|------|------|------|-------|
| Operating Speed | Fop    | 0    | -    | 40   | MHz  | 1     |
| Clock Period    | Тср    | 25   | -    | -    | nS   | 2     |
| Clock High      | Тсн    | 20   | -    | -    | nS   | 3     |
| Clock Low       | Tc∟    | 20   | -    | -    | nS   | 3     |

Notes:

1. The clock may be stopped indefinitely in either state.

2. The TCP specification is used as a reference in other specifications.

3. There are no duty cycle requirements on the XTAL1 input.

### W78E365/W78E365A

### nuvoTon

### 8.3 Data Write Cycle



| PARAMETER              | SYMBOL | MIN.            | TYP.  | MAX.            | UNIT |
|------------------------|--------|-----------------|-------|-----------------|------|
| ALE Low to WR Low      | TDAW   | 3 Тср- $\Delta$ | -     | З Тср+ $\Delta$ | nS   |
| Data Valid to WR Low   | Tdad   | 1 Тср-∆         | -     | -               | nS   |
| Data Hold from WR High | Towd   | 1 Тср-∆         | -     | -               | nS   |
| WR Pulse Width         | TDWR   | 6 Тср-∆         | 6 Тср | -               | nS   |

**Note:** " $\Delta$ " (due to buffer driving delay and wire loading) is 20 nS.

### 8.4 Port Access Cycle



| PARAMETER                    | SYMBOL | MIN.  | TYP. | MAX. | UNIT |
|------------------------------|--------|-------|------|------|------|
| Port Input Setup to ALE Low  | TPDS   | 1 TCP | -    | -    | nS   |
| Port Input Hold from ALE Low | TPDH   | 0     | -    | -    | nS   |
| Port Output to ALE           | Tpda   | 1 TCP | -    | -    | nS   |

Note: Ports are read during S5P2, and output data becomes available at the end of S6P2. The timing data are referenced to ALE, since it provides a convenient reference.

### 9. TYPICAL APPLICATION CIRCUIT

### 9.1 External Program Memory and Crystal



Figure A

| CRYSTAL | C1  | C2      | R    |
|---------|-----|---------|------|
| 6 MHz   | 47P | 47P     | -    |
| 16 MHz  | 30P | 30P     | -    |
| 24 MHz  | 15P | 15P     | -    |
| 32 MHz  | 10P | 10P     | 6.8K |
| 40 MHz  | 5P  | 5P 4.71 |      |

Above table shows the reference values for crystal applications.

#### Notes:

1. C1, C2, R components refer to Figure A

2. Crystal layout must get close to XTAL1 and XTAL2 pins on user's application board. Typical Application Circuit, continued

### **11. APPLICATION NOTE**

#### 11.1 In-system Programming Software Examples

This application note illustrates the in-system programmability of the Nuvoton W78E365 ROM microcontroller. In this example, microcontroller will boot from 64KB APROM bank and waiting for a key to enter in-system programming mode for re-programming the contents of 64KB APROM. While entering in-system programming mode, microcontroller executes the loader program in 4KB LDROM bank. The loader program erases the 64KB APROM then reads the new code data from external SRAM buffer (or through other interfaces) to update the 64KB APROM.

#### Example 1:

|                                                                                                      | am: Program will scan the P1.0. if $P1.0 = 0$ , enters in-system<br>of the content of APROM code else executes the current ROM code.                                    |
|------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ,<br>.chip 8052<br>.RAMCHK OFF<br>.symbols                                                           |                                                                                                                                                                         |
| CHPCON EQU BFH<br>CHPENR EQU F6H<br>SFRAL EQU C4H<br>SFRAH EQU C5H<br>SFRFD EQU C6H<br>SFRCN EQU C7H |                                                                                                                                                                         |
| ORG 0H<br>LJMP 100H                                                                                  | ; JUMP TO MAIN PROGRAM                                                                                                                                                  |
| ,<br>;* TIMER0 SERVICE VECTOR O                                                                      | RG = 000BH                                                                                                                                                              |
| ;<br>ORG 00BH<br>CLR TR0<br>MOV TL0, R6<br>MOV TH0, R7<br>RETI                                       | ; TR0 = 0, STOP TIMER0                                                                                                                                                  |
| ;*************************************                                                               | ***************************************                                                                                                                                 |
| ,*************************************                                                               | ***********************                                                                                                                                                 |
|                                                                                                      |                                                                                                                                                                         |
| MAIN_64K:<br>MOV A,P1                                                                                | : SCAN P1.0                                                                                                                                                             |
| ANL A, #01H                                                                                          | K ; IF P1.0 = 0, ENTER IN-SYSTEM PROGRAMMING MODE                                                                                                                       |
| PROGRAM_64K:                                                                                         |                                                                                                                                                                         |
| MOV CHPENR, #87H<br>MOV CHPENR, #59H<br>MOV CHPCON, #03H<br>MOV TCON, #00H                           | ; CHPENR = 87H, CHPCON REGISTER WRTE ENABLE<br>; CHPENR = 59H, CHPCON REGISTER WRITE ENABLE<br>; CHPCON = 03H, ENTER IN-SYSTEM PROGRAMMING MODE<br>; TR = 0 TIMER0 STOP |

| ;*************************************                                                                          |                                                                                                                                                                                                                 |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| ,<br>ORG 100H<br>MAIN_4K:                                                                                       |                                                                                                                                                                                                                 |  |  |  |  |
| MOV SP, #C0H<br>MOV CHPENR, #87H                                                                                | ; CHPENR = 87H, CHPCON WRITE ENABLE.<br>; CHPENR = 59H, CHPCON WRITE ENABLE.<br>; CHPCON = 03H, ENABLE IN-SYSTEM PROGRAMMING.<br>; DISABLE CHPCON WRITE ATTRIBUTE                                               |  |  |  |  |
| MOV TCON, #00H<br>MOV TMOD, #01H<br>MOV IP, #00H<br>MOV IE, #82H<br>MOV R6, #F0H<br>MOV R7, #FFH<br>MOV TL0, R6 | ; TCON = 00H, TR = 0 TIMER0 STOP<br>; TMOD = 01H, SET TIMER0 A 16BIT TIMER<br>; IP = 00H<br>; IE = 82H, TIMER0 INTERRUPT ENABLED                                                                                |  |  |  |  |
| MOV TH0, R7<br>MOV TCON, #10H<br>MOV PCON, #01H                                                                 | ; TCON = 10H, TR0 = 1, GO<br>; ENTER IDLE MODE                                                                                                                                                                  |  |  |  |  |
| UPDATE_64K:<br>MOV TCON, #00H<br>MOV IP, #00H<br>MOV IE, #82H<br>MOV TMOD, #01H<br>MOV R6, #E0H<br>MOV R7, #B1H | ; TCON = 00H, TR = 0 TIM0 STOP<br>; IP = 00H<br>; IE = 82H, TIMER0 INTERRUPT ENABLED<br>; TMOD = 01H, MODE1<br>; SET WAKE-UP TIME FOR ERASE OPERATION, ABOUT 15 mS. DEPENDING<br>; ON USER'S SYSTEM CLOCK RATE. |  |  |  |  |
| MOV R7, #BITT<br>MOV TL0, R6<br>MOV TH0, R7                                                                     |                                                                                                                                                                                                                 |  |  |  |  |
| ERASE_P_4K:                                                                                                     |                                                                                                                                                                                                                 |  |  |  |  |
| MOV TCON, #10H ;                                                                                                | SFRCN(C7H) = 22H ERASE 64K<br>TCON = 10H, TR0 = 1,GO<br>ENTER IDLE MODE (FOR ERASE OPERATION)                                                                                                                   |  |  |  |  |
| .*******                                                                                                        | ***********************                                                                                                                                                                                         |  |  |  |  |
| ,* BLANK CHECK                                                                                                  |                                                                                                                                                                                                                 |  |  |  |  |
| , , ,                                                                                                           | READ 64KB APROM MODE<br>START ADDRESS = 0H                                                                                                                                                                      |  |  |  |  |
|                                                                                                                 | SET TIMER FOR READ OPERATION, ABOUT 1.5 $\mu S.$                                                                                                                                                                |  |  |  |  |
| BLANK_CHECK_LOOP:                                                                                               |                                                                                                                                                                                                                 |  |  |  |  |
| MOV PCON, #01H ;<br>MOV A, SFRFD ;<br>CJNE A, #FFH, BLANK                                                       | ENABLE TIMER 0<br>ENTER IDLE MODE<br>READ ONE BYTE<br>_CHECK_ERROR<br>NEXT ADDRESS                                                                                                                              |  |  |  |  |

| VERSION | DATE             | PAGE         | DESCRIPTION                                                                                             |
|---------|------------------|--------------|---------------------------------------------------------------------------------------------------------|
| A1      | May, 2003        | -            | Initial Issued                                                                                          |
| A2      | August, 2004     | 32           | Revise title of 9.1                                                                                     |
| A3      | Sep. 14, 2004    | 2            | Remove P4.4 ~ P4.7                                                                                      |
| A4      | Dec. 23, 2004    | 2, 15        | Add PWM in feature list and modify PWM block diagram                                                    |
| A5      | April 20, 2005   | 41           | Add Important Notice                                                                                    |
| 46      | luna 22, 2005    | 3            | Add lead free(RoHS) part number                                                                         |
| AO      | A6 June 22, 2005 |              | Add 32M/40Mhz items in the table                                                                        |
| A7      | Aug. 25, 2005    | 3, 5         | Add Port 0 pull-up resisters information                                                                |
| A8      | Dec 4, 2006      | 3            | Remove all Leaded package parts                                                                         |
| A9      | January 10, 2007 | 3<br>4<br>37 | Add 48-pin LQFP part.<br>Add 48-pin LQFP package<br>Add 48-pin LQFP package dimension                   |
| A10     | April 22, 2008   | 10           | Modified P3 reset state                                                                                 |
| A11     | July 15, 2008    | 7            | Revise typo<br>Incorrect: AUX-RAM is enable after a reset<br>Correct: AUX-RAM is disabled after a reset |
| A12     |                  | 7            | Revise typo, on-chip AUX-RAM is enabled after a reset.<br>(Ver A11 is incorrect)                        |
| A12     | January 12, 2009 | 10           | Revise CHPCON initial value from 0xx00000b to 00x11000b.                                                |

### **12. REVISION HISTORY**

#### **Important Notice**

Nuvoton products are not designed, intended, authorized or warranted for use as components in systems or equipment intended for surgical implantation, atomic energy control instruments, airplane or spaceship instruments, transportation instruments, traffic signal instruments, combustion control instruments, or for other applications intended to support or sustain life. Further more, Nuvoton products are not intended for applications wherein failure of Nuvoton products could result or lead to a situation wherein personal injury, death or severe property or environmental damage could occur.

Nuvoton customers using or selling these products for use in such applications do so at their own risk and agree to fully indemnify Nuvoton for any damages resulting from such improper use or sales.

Please note that all data and specifications are subject to change without notice.

All the trademarks of products and companies mentioned in this datasheet belong to their respective owners.