MPC89L (E) 51-515 Application Note A1.5

Download as pdf or txt
Download as pdf or txt
You are on page 1of 44

MPC89L51/52/53/54/58/515

MPC89E51/52/53/54/58/515

Application Note

Contents
0. Features
1. Pin Assignment
2. Special Function Registers
3. Extended General Purpose I/O Port, P4 New Feature
4. On-chip eXpanded RAM (XRAM) New Feature
5. Second DPTR New Feature
6. Up/Down Counting of Timer 2 New Feature
7. Programmable Clock-Out New Feature
8. Enhanced UART New Feature
9. Eight Interrupt Sources and Four-Priority-Level Nested Structure New Feature
10. Wake-up from Power-down by External Interrupt New Feature
11. One-time Enabled Watchdog Timer (WDT) New Feature
12. Reduced EMI Mode New Feature
13. 12T Mode and 6T Mode New Feature
14. In-System-Programming (ISP) New Feature
15. Non-volatile Data Application using In-Application-Programming New Feature
16. Power-ON Flag New Feature
17. Option Registers
18. Flash Memory Configuration
19. XTAL Oscillating Requirement and ALE Output Frequency
20. Power Consumption
21. How to Reduce EMI
22. UART Baudrate Setting
23. Notes on Using External Interrupt

This document contains information on a new product under development by MEGAWIN. MEGAWIN reserves the right to change or discontinue
this product without notice.
 MEGAWIN Technology Co., Ltd. 2003 All rights reserved. 2005/02 version A1.5

MEGAWIN
Revision History

Version Revision

1.0 The first-time released.

(1) Update AUXR reset value in Section 2.


1.1 (2) Add OSCDN=0 condition in Section 16.
(3) Modify OSCDN description in Section 17.
(1) Modify Section 0 to “Features”.
(2) Update part no in Section 1.
(3) Add more description for in Section 12.
(4) Add short introduction to ISP in Section 14.
1.2 (5) Add reference index to Section 15.
(6) Re-arrange the sequence from Section 16 to Section 21.
(7) Change “(Invalid)” to “(for IAP)” in Section 18.
(8) Add a new section, Section 20, “Power Consumption”.
(9) Add a new section, Section 21, “How to reduce EMI”.
(1) Modify the contents in Section 13.
(2) Refine Section 14, and add new Section 14-7.
(3) Update the attached file for “ISP technical support” in Section 14.
1.3 (4) Release “FZWDTCR” bit in OR1, Section 17.
(5) Modify HWBS description in Section 17.
(6) Add new Section 19-2.
(7) Add a new section, Section 22, “UART Baudrate Setting”.

1.4 (1) Correct XICON description in Section 2.

(1) Add “ISP Mode Select Table” and remove attached “ISP Technical Support” in Section 14.
1.5 (2) Revise test Ipwdn to be < 1.0 uA, in Section 20
(3) Add a new section, Section 23.

2 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN


0. Features

• Compatible with Standard 8051 MCU

• Flash Program Memory with In-System-Programming (ISP) Capability

• Including All the 8052 Features, and New Powerful Features Are Added:
- Extended General Purpose I/O Port, P4
- On-chip eXpanded RAM (XRAM)
- Second DPTR
- Up/Down Counting of Timer 2
- Programmable Clock-Out
- Enhanced UART
- Eight Interrupt Sources
- Four-Priority-Level Nested Interrupt Structure
- Wake-up from Power-down by External Interrupt
- One-time Enabled Watchdog Timer (WDT)
- Reduced EMI Mode
- Non-volatile Data Application using In-Application-Programming
- Power-ON Flag

• 12T-mode and 6T-mode Operation

• Operation Speed: up to 48 MHz @12T-mode or 24MHz @6T-mode

• Security Bits (LOCK, SB and MOVCL)

• EMI Reduction Bit (OSCDN)

• Endurance: 10,000 Write/Erase Cycles

• 3.3V (L-series) and 5V (E-series) Available

• Packages: 40-pin DIP, 44-pin PLCC and 44-pin QFP

MEGAWIN MPC89L(E)51/52/53/54/58/515 Technical Summary 3


1. Pin Assignment

T2/P1.0 1 40 VDD
T2EX/P1.1 2 39 P0.0/AD0
P1.2 3 38 P0.1/AD1
P1.3 4 37 P0.2/AD2
40-pin
P1.4 5 36 P0.3/AD3
P1.5 6 DIP 35 P0.4/AD4
P1.6 7 34 P0.5/AD5
P1.7 8 33 P0.6/AD6
RST 9 32 P0.7/AD7
RXD/P3.0 10 31 -EA
TXD/P3.1 11 30 ALE
-INT0/P3.2 12 29 -PSEN
-INT1/P3.3 13 28 P2.7/A15
T0/P3.4 14 27 P2.6/A14
T1/P3.5 15 26 P2.5/A13
-WR/P3.6 16 25 P2.4/A12
-RD/P3.7 17 24 P2.3/A11
XTAL2 18 23 P2.2/A10
XTAL1 19 22 P2.1/A9
VSS 20 21 P2.0/A8

MPC89L51/52/53/54/58/515AE
MPC89E51/52/53/54/58/515AE
P1.1/T2EX

P1.1/T2EX
P4.2/-INT3

P4.2/-INT3
P0.0/AD0
P0.1/AD1
P0.2/AD2
P0.3/AD3

P0.0/AD0
P0.1/AD1
P0.2/AD2
P0.3/AD3
P1.0/T2

P1.0/T2
VDD

VDD
P1.4
P1.3
P1.2

P1.4
P1.3
P1.2

P1.5 7 6 5 4 3 2 1 44 43 42 41 40 39 P0.4/AD4 P1.5 1 44 43 42 41 40 39 38 37 36 35 34 33 P0.4/AD4


P1.6 8 38 P0.5/AD5 P1.6 2 32 P0.5/AD5
P1.7 9 37 P0.6/AD6 P1.7 3 31 P0.6/AD6
RST 10 36 P0.7/AD7 RST 4 30 P0.7/AD7
RXD/P3.0 11 35 - EA RXD/P3.0 5 29 - EA
P4.3/-INT2 12 44-pin PLCC 34 P4.1 P4.3/-INT2 6 44-pin QFP 28 P4.1
TXD/P3.1 13 33 ALE TXD/P3.1 7 27 ALE
- INT0/P3.2 14 32 - PSEN - INT0/P3.2 8 26 - PSEN
- INT1/P3.3 15 31 P2.7/A15 - INT1/P3.3 9 25 P2.7/A15
T0/P3.4 16 30 P2.6/A14 T0/P3.4 10 24 P2.6/A14
T1/P3.5 17 18 19 20 21 22 23 24 25 26 27 28 29 P2.5/A13 T1/P3.5 11 12 13 14 15 16 17 18 19 20 21 22 23 P2.5/A13
P4.0
VSS

VSS
- WR/P3.6

P4.0

- WR/P3.6
- RD/P3.7
XTAL2
- RD/P3.7

A8/P2.0
A9/P2.1
A10/P2.2
A11/P2.3
A12/P2.4

XTAL1

A8/P2.0
A9/P2.1
A10/P2.2
A11/P2.3
A12/P2.4
XTAL2
XTAL1

MPC89L51/52/53/54/58/515AP MPC89L51/52/53/54/58/515AF
MPC89E51/52/53/54/58/515AP MPC89E51/52/53/54/58/515AF

4 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN


2. Special Function Registers
The Traditional 8052 SFRs
BIT ADDRESS, SYMBOL, OR ALTERNATE PORT FUNCTION RESET
SYMBOL DESCRIPTION ADDRESS
MSB LSB VALUE

ACC* Accumulator E0H 00H


B* B Register F0H 00H
D7H D6H D5H D4H D3H D2H D1H D0H
PSW* Program Status Word D0H
CY AC F0 RS1 RS0 OV - P
000000x0B

SP Stack Pointer 81H 07H


DPH Data Pointer High 83H 00H
DPL Data Pointer Low 82H 00H
87H 86H 85H 84H 83H 82H 81H 80H
P0* Port 0 80H
P0.7 P0.6 P0.5 P0.4 P0.3 P0.2 P0.1 P0.0
FFH
91H 90H
97H 96H 95H 94H 93H 92H
P1* Port 1 90H
P1.7 P1.6 P1.5 P1.4 P1.3 P1.2
P1.1 P1.0 FFH
T2EX T2
A7H A6H A5H A4H A3H A2H A1H A0H
P2* Port 2 A0H
P2.7 P2.6 P2.5 P2.4 P2.3 P2.2 P2.1 P2.0
FFH
B7H B6H B5H B4H B3H B2H B1H B0H
P3* Port 3 B0H P3.7 P3.6 P3.5 P3.4 P3.3 P3.2 P3.1 P3.0 FFH
RD WR T1 T0 /INT1 /INT0 TXD RXD
BFH BEH BDH BCH BBH BAH B9H B8H
IP* Interrupt Priority B8H
- - PT2 PS PT1 PX1 PT0 PX0
x0000000B
AFH AEH ADH ACH ABH AAH A9H A8H
IE* Interrupt Enable A8H
EA - ET2 ES ET1 EX1 ET0 EX0
00H

TMOD Timer Mode 89H GATE C/-T M1 M0 GATE C/-T M1 M0 00H


8FH 8EH 8DH 8CH 8BH 8AH 89H 88H
TCON* Timer Control 88H
TF1 TR1 TF0 TR0 IE1 IT1 IE0 IT0
00H
CFH CEH CDH CCH CBH CAH C9H C8H
T2CON* Timer 2 Control C8H
TF2 EXF2 RCLK TCLK EXEN2 TR2 C/-T2 CP/-RL2
00H

TH0 Timer 1 High 8CH 00H


TL0 Timer 0 Low 8AH 00H
TH1 Timer 1 High 8DH 00H
TL1 Timer 0 Low 8BH 00H
TH2 Timer 2 High CDH 00H
TL2 Timer 2 Low CCH 00H
RCAP2H Timer 2 Capture High CBH 00H
RCAP2L Timer 2 Capture Low CAH 00H
+ 9FH 9EH 9DH 9CH 9BH 9AH 99H 98H
SCON* Serial Port Control 98H
SM0/FE SM1 SM2 REN TB8 RB8 TI RI
00H

SBUF Serial Data Buffer 99H xxxxxxxxB


+
PCON Power Control 87H SMOD SMOD0 - POF GF1 GF0 PD IDL 00xx0000B

Notes:
*: bit addressable
+
: modified from the 8052 SFRs
-: reserved bit

MEGAWIN MPC89L(E)51/52/53/54/58/515 Technical Summary 5


The New-added SFRs for MPC89L51/52/53/54/58/515 & MPC89E51/52/53/54/58/515
BIT ADDRESS, SYMBOL, OR ALTERNATE PORT FUNCTION RESET
SYMBOL DESCRIPTION ADDRESS
MSB LSB VALUE
#
AUXR Auxiliary 8EH - - - - - - EXTRAM AO xxxxxx00B
#
AUXR1 Auxiliary 1 A2H - - - - GF2 - - DPS xxxxxxx0B
#
IPH Interrupt Priority High B7H - PADCH PT2H PSH PT1H PX1H PT0H PX0H x0000000B
# EFH EEH EDH ECH EBH EAH E9H E8H
P4* Port 4 E8H
- - - - P4.3 P4.2 P4.1 P4.0
xxxx1111B
#
SADEN Slave Address Mask B9H 00H
#
SADDR Slave Address A9H 00H
#
T2MOD Timer 2 Mode Control C9H - - - - - - T2OE DCEN xxxxxx00B
# External Interrupt C7H C6H C5H C4H C3H C2H C1H C0H
XICON* Control
C0H
PX3 EX3 IE3 IT3 PX2 EX2 IE2 IT2
xxxxxxxxB
#
WDTCR Watch-dog Timer E1H - - ENW CLRW WIDL PS2 PS1 PS0 xx000000B
#
ISPCR ISP Control Register E7H ISPEN SWBS SWRST - - ICK2 ICK1 ICK0 00H
#
IFMT ISP Mode Table E5H xxxx0000B
ISP Flash #
IFADRH Address High E3H 00H
# ISP Flash
IFADRL Address Low E4H 00H
#
IFD ISP Flash Data E2H 00H
# ISP Sequential
SCMD E6H xxxxxxxxB
Command
Notes:
*: bit addressable
#
: new-added
-: reserved bit

6 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN


3. Extended General Purpose I/O Port, P4
There is an extended bit-addressable GPIO port, P4 (P4.0~P4.3), for the 44-pin PLCC & QFP packages. Also,
P4.2 and P4.3 have the alternate interrupt function, /INT3 and /INT2, respectively.

MEGAWIN MPC89L(E)51/52/53/54/58/515 Technical Summary 7


4. On-chip eXpanded RAM (XRAM)
In addition to the traditional 256 bytes of internal RAM, the MPC89L(E)51/52/53 has 256 bytes of expanded
RAM (XRAM), while the MPC89L(E)54/58/515 has 1024 bytes. Clear EXTRAM bit (in AUXR, bit 1) to enable
XRAM accessing. User can use the instructions “MOVX @Ri” or “MOVX @DPTR” to access XRAM. While
executing these instructions, the I/O status of P0, P2, P3.6 (/WR) and P3.7 (/RD) are not changed, and they still
function as GPIO (General Purpose IO).

Set EXTRAM bit will disable XRAM accessing (but leave XRAM unchanged), and both “MOVX @Ri” and
“MOVX @DPTR” will access the external data memory as the traditional 8051 does.

AUXR (Auxiliary register)


7 6 5 4 3 2 1 0
- - - - - - EXTRAM AO

DEXTRAM: Set to enable external data memory accessing.


AO: Set to turn off ALE output.

For KEIL-C51 compiler, to assign the variables to be located at XRAM, the “pdata” or “xdata” definition should
be used. After being compiled, the variables declared by “pdata” and “xdata” will become the memories
accessed by “MOVX @Ri” and “MOVX @DPTR”, respectively. Thus the MPC89L(E)51/../515 H/W can access
them correctly. See the following descriptions, which is obtained from “Keil Software — Cx51 Compiler User’s
Guide”.

8 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN


5. Second DPTR
The dual DPTR structure (see the following Figure) is a way by which the chip can specify the address of an
external data memory location. There are two 16-bit DPTR registers that address the external memory, and a
single bit called DPS (in AUXR1, bit 0) that allows the program code to switch between them.

(83h) (82h)

DPS=0
DPTR0 DPH DPL

DPTR1 DPH DPL


DPS=1

Selected by DPS External Data Memory


(AUXR1, bit0)

DPTR Instructions

The six instructions that refer to DPTR currently selected using the DPS bit are as follows:

INC DPTR ;Increments the data pointer by 1


MOV DPTR,#data16 ;Loads the DPTR with a 16-bit constant
MOV A,@A+DPTR ;Move code byte relative to DPTR to ACC
MOVX A,@DPTR ;Move external RAM (16-bit address) to ACC
MOVX @DPTR,A ;Move ACC to external RAM (16-bit address)
JMP @A+DPTR ;Jump indirect relative to DPTR

AUXR1 (Auxiliary 1 register)


7 6 5 4 3 2 1 0
- - - - GF2 - - DPS

GF2: General purpose flag.


DPS: DPTR selector, Clear/Set to select DPTR0/DPTR1, respectively.

MEGAWIN MPC89L(E)51/52/53/54/58/515 Technical Summary 9


6. Up/Down Counting of Timer 2
In the 16-bit auto-reload mode, Timer 2 can be configured as either a timer or a counter by C/T2 (T2CON.1),
then be programmed to count up or down. The counting direction, up or down, is determined by bit DCEN (in
T2MOD, bit 0) and pin T2EX (P1.1).

The reset value of DCEN bit is 0, which makes Timer 2 function as the standard 8052 (always count up). If
DCEN=1, Timer 2 can count up or count down according to the logic level of the T2EX pin.

When a logic-1 is applied at T2EX pin, Timer 2 will count up.


It overflows at the transition of [TH2,TL2] from #FFFFH to #0000H. At this time, TF2 flag (T2CON.7) is set by
hardware and CPU will enter the interrupt service routine if the interrupt is previously enabled. Simultaneously,
this overflow causes the 16-bit value of [RCAP2H,RCAP2H] to be reloaded into [TH2,TL2].

When a logic-0 is applied at T2EX pin, Timer 2 will count down.


It underflows when [TH2,TL2] becomes equal to [RCAP2H,RCAP2L]. At this time, TF2 flag is set by hardware
and CPU will enter the interrupt service routine if the interrupt is previously enabled. Simultaneously, this
underflow causes the value 0xFFFF to be reloaded into the [TH2,TL2].

The external flag EXF2 (T2CON.6) toggles when Timer 2 overflows or underflows. It can be used as the 17th bit
of resolution if needed. The EXF2 flag does not cause an interrupt while DCEN=1.

Timer 2 in Auto-Reload Mode (with DCEN=1)

10 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN


T2MOD (Timer 2 Mode Control register)
7 6 5 4 3 2 1 0
- - - - - - T2OE DCEN

T2OE: Timer 2 Output Enable bit.


DCEN: Down Count Enable bit.

T2CON (Timer 2 Control Register)


7 6 5 4 3 2 1 0
TF2 EXF2 RCLK TCLK EXEN2 TR2 C/T2 CP/RL2

TF2: Timer 2 overflow flag set by a Timer 2 overflow and must be cleared by software. TF2 will not be set when
either RCLK=1 or TCLK=1.

EXF2: Timer 2 external flag set when either a capture or reload is caused by a negative transition on T2EX pin
and EXEN2=1. When Timer 2 interrupt is enabled, EXF2=1 will cause the CPU to vector to the Timer 2 interrupt
routine. EXF2 must be cleared by software. EXF2 does not cause an interrupt in up/down mode (DCEN = 1).

RCLK: Receive clock flag. When set, causes the serial port to use Timer 2 overflow pulses for its receive clock
in modes 1 and 3. RCLK=0 causes Timer 1 overflow to be used for the receive clock.

TCLK: Transmit clock flag. When set, causes the serial port to use Timer 2 overflow pulses for its transmit clock
in modes 1 and 3. TCLK=0 causes Timer 1 overflows to be used for the transmit clock.

EXEN2: Timer 2 external enable flag. When set, allows a capture or reload to occur as a result of a negative
transition on T2EX pin if Timer 2 is not being used to clock the serial port. EXEN2=0 causes Timer 2 to ignore
events at T2EX pin.

TR2: Start/stop control for Timer 2. A logic 1 starts the timer.

C/T2: Timer or counter select. When cleared, select internal timer, when set, select external event counter
(falling edge triggered).

CP/RL2: Capture/Reload flag. When set, captures will occur on negative transitions at T2EX pin if EXEN2=1.
When cleared, auto-reloads will occur either with Timer 2 overflows or negative transitions at T2EX pin when
EXEN2=1. When either RCLK=1 or TCLK=1, this bit is ignored and the timer is forced to auto-reload on Timer 2
overflow.

MEGAWIN MPC89L(E)51/52/53/54/58/515 Technical Summary 11


7. Programmable Clock-Out
A 50% duty cycle clock can be programmed to come out on P1.0. Besides being a regular I/O pin, P1.0 has two
alternate functions as shown below.

P1.0 Alternate Functions


Function C/T2 (T2CON.1) T2OE (in T2MOD, bit 1)
Timer 2 external clock input (T2) 1 0
50% duty cycle clock output 0 1

To configure the Timer/Counter2 as a clock generator, bit C/T2 (T2CON.1) must be cleared and bit T2OE (in
T2MOD, bit 1) must be set. Of course, bit TR2 (T2CON.2) also must be set to start the timer.

The Clock-Out frequency depends on the oscillator frequency and the reload value of Timer 2 capture registers
(RCAP2H, RCAP2L) as shown in this equation:

Operating Frequency
n x (65536-[RCAP2H,RCAP2L])

where,
n=4 for 12T mode
n=2 for 6T mode

In the Clock-Out mode, Timer 2 roll-overs will not generate an interrupt. This is similar to when it is used as a
baud-rate generator. It is possible to use Timer 2 as a baud-rate generator and a clock generator
simultaneously. Note that the baud-rate, however, and the clock-out frequency will be the same.

T2MOD (Timer 2 Mode Control Register)


7 6 5 4 3 2 1 0
- - - - - - T2OE DCEN

T2OE: Timer 2 Output Enable bit.


DCEN: Down Count Enable bit.

12 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN


8. Enhanced UART
8.1 Frame Error Detection

While the SMOD0 bit (in PCON, bit 6) is set, the hardware will set the FE bit (SCON.7) when an invalid stop bit
is detected. The FE bit is not cleared by valid frames but should be cleared by software.

SCON (Serial Port Control Register)


7 6 5 4 3 2 1 0
SM0/FE SM1 SM2 REN TB8 RB8 TI RI

SM0/FE:
SM0: Serial Port Mode bit0 (while SMOD0=0).
FE: Frame Error bit (while SMOD0=1).

PCON (Power Control Register)


7 6 5 4 3 2 1 0
SMOD SMOD0 - POF GF1 GF0 PD IDL

SMOD0: 0 to let SCON.7=SM0, and 1 to let SCON.7=FE.


POF: Power-ON Flag.

8.2 Automatic Address Recognition

Automatic Address Recognition is a feature which allows the UART to recognize certain addresses in the serial
bit stream by using hardware to make the comparisons. This feature saves a great deal of software overhead
by eliminating the need for the software to examine every serial address which passes by the serial port. This
feature is enabled by setting the SM2 bit in SCON. In the 9 bit UART modes, mode 2 and mode 3, the Receive
Interrupt flag (RI) will be automatically set when the received byte contains either the “Given” address or the
“Broadcast” address. The 9-bit mode requires that the 9th information bit is a 1 to indicate that the received
information is an address and not data. Automatic address recognition is shown in the following figure.

The 8 bit mode is called Mode 1. In this mode the RI flag will be set if SM2 is enabled and the information
received has a valid stop bit following the 8 address bits and the information is either a Given or Broadcast
address.

Mode 0 is the Shift Register mode and SM2 is ignored.

MEGAWIN MPC89L(E)51/52/53/54/58/515 Technical Summary 13


Using the Automatic Address Recognition feature allows a master to selectively communicate with one or more
slaves by invoking the Given slave address or addresses. All of the slaves may be contacted by using the
Broadcast address. Two special Function Registers are used to define the slave’s address, SADDR, and the
address mask, SADEN.

SADEN is used to define which bits in the SADDR are to be used and which bits are “don’t care”. The SADEN
mask can be logically ANDed with the SADDR to create the “Given” address which the master will use for
addressing each of the slaves. Use of the Given address allows multiple slaves to be recognized while
excluding others.

The following examples will help to show the versatility of this scheme:

Slave 0
SADDR = 1100 0000
SADEN = 1111 1101
Given = 1100 00X0

Slave 1
SADDR = 1100 0000
SADEN = 1111 1110
Given = 1100 000X

In the above example SADDR is the same and the SADEN data is used to differentiate between the two slaves.
Slave 0 requires a 0 in bit 0 and it ignores bit 1. Slave 1 requires a 0 in bit 1 and bit 0 is ignored. A unique
address for Slave 0 would be 1100 0010 since slave 1 requires a 0 in bit 1. A unique address for slave 1 would
be 1100 0001 since a 1 in bit 0 will exclude slave 0. Both slaves can be selected at the same time by an
address which has bit 0 = 0 (for slave 0) and bit 1 = 0 (for slave 1). Thus, both could be addressed with 1100
0000.

In a more complex system the following could be used to select slaves 1 and 2 while excluding slave 0:

Slave 0
SADDR = 1100 0000
SADEN = 1111 1001
Given = 1100 0XX0
Slave 1
SADDR = 1110 0000
SADEN = 1111 1010
Given = 1110 0X0X
Slave 2
SADDR = 1110 0000
SADEN = 1111 1100
Given = 1110 00XX

In the above example the differentiation among the 3 slaves is in the lower 3 address bits. Slave 0 requires that
bit 0 = 0 and it can be uniquely addressed by 1110 0110. Slave 1 requires that bit 1 = 0 and it can be uniquely
addressed by 1110 0101. Slave 2 requires that bit 2 = 0 and its unique address is 1110 0011. To select Slaves
0 and 1 and exclude Slave 2 use address 1110 0100, since it is necessary to make bit 2 = 1 to exclude slave 2.

The Broadcast Address for each slave is created by taking the logical OR of SADDR and SADEN. Zeros in this
result are trended as don’t-cares. In most cases, interpreting the don’t-cares as ones, the broadcast address will
be FF hexadecimal.

Upon reset SADDR (SFR address 0A9H) and SADEN (SFR address 0B9H) are leaded with 0s. This produces a
given address of all “don’t cares” as well as a Broadcast address of all “don’t cares”. This effectively disables the
Automatic Addressing mode and allows the micro-controller to use standard 80C51 type UART drivers which do
not make use of this feature.

14 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN


MEGAWIN MPC89L(E)51/52/53/54/58/515 Technical Summary 15
9. Eight Interrupt Sources and Four-Priority-Level Nested Structure
The MPC89L(E)51/52/53/54/58/515 have eight interrupt sources as shown in the following table.

Interrupt Source Polling Priority Interrupt Vector Address


IE0 (highest priority) 0003H
TF0 . 000BH
IE1 . 0013H
TF1 . 001BH
RI+TI . 0023H
TF2+EXF2 . 002BH
IE2 . 0033H
IE3 (lowest priority) 003BH

IE (Interrupt Enable Register)


7 6 5 4 3 2 1 0
EA - ET2 ES ET1 EX1 ET0 EX0

XICON (External Interrupt Control Register)


7 6 5 4 3 2 1 0
PX3 EX3 IE3 IT3 PX2 EX2 IE2 IT2

PX3: defines the priority level of /INT3 interrupt. If PX3=1, the /INT3 interrupt has the higher priority level.
EX3: enables or disables the /INT3 interrupt. If EX3=1, the /INT3 interrupt is enabled.
IE3: /INT3 interrupt edge flag. Set by hardware when external interrupt edge detected. Cleared when
interrupt processed.
IT3: /INT3 type control bit. Set/cleared by software to specified falling-edge/low-level triggered.
PX2: defines the priority level of /INT2 interrupt. If PX2=1, the /INT2 interrupt has the higher priority level.
EX2: enables or disables the /INT2 interrupt. If EX2=1, the /INT2 interrupt is enabled.
IE2: /INT2 interrupt edge flag. Set by hardware when external interrupt edge detected. Cleared when
interrupt processed.
IT2: /INT2 type control bit. Set/cleared by software to specified falling-edge/low-level triggered.

IP (Interrupt Priority Register)


7 6 5 4 3 2 1 0
- - PT2 PS PT1 PX1 PT0 PX0

IPH (Interrupt Priority High Register)


7 6 5 4 3 2 1 0
PX3H PX2H PT2H PSH PT1H PX1H PT0H PX0H

16 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN


The IPH register combined with IP register makes the four-level interrupt structure possible. The priority level of
each interrupt is determined according to the following table.

IPH IP Priority Level


1 1 Level 3 (highest)
1 0 Level 2
0 1 Level 1
0 0 Level 0 (lowest)

For example, if (PT1H,PT1)=(1,0), then priority level of Timer 1 interrupt is 2, which is higher than level 1 with
(PT1H,PT1)=(0,1) and level 0 with (PT1H,PT1)=(0,0).

MEGAWIN MPC89L(E)51/52/53/54/58/515 Technical Summary 17


10. Wake-up from Power-down by External Interrupt
Entering power-down mode, which is invoked by software, can save even more power. In power-down mode,
the oscillator is stopped and the instruction that invokes power-down is the last instruction executed. And, the
SFRs and on-chip RAM/XRAM retain their values.

Either hardware reset or external interrupt (/INT0, /INT1, /INT2 or /INT3) can be used to exit from power-down
mode. Hardware reset initializes all the SFRs but does not change the on-chip RAM/XRAM, while external
interrupt allows both the SFRs and the on-chip RAM/XRAM to retain their values. To properly exit from power-
down mode, the external interrupt which is selected for waking up CPU must be enabled before power-down.
After power-down, trigger the selected external interrupt to wake up the CPU. Once the interrupt is serviced, the
next instruction (after RETI) to be executed will be the one following the instruction that invoked the power-down
mode. Note, this instruction must be a “NOP”.

Sample code for Wake-up-from-power-down (/INT0 is used in this code)


;******************************************************************************************
; Wake-up-from-power-down by /INT0 interrupt
;******************************************************************************************

INT0 BIT 0B2H ;P3.2


EA BIT 0AFH ;IE.7
EX0 BIT 0A8H ;IE.0

CSEG AT 0000h
JMP start
;
CSEG AT 0003h ;INT0 interrupt vector, address=0003h
JMP IE0_isr
IE0_isr:
CLR EX0
;... do something
;...
RETI
;
start:
;...
;...

SETB INT0 ;pull high P3.2

CLR IE0 ;clear INT0 interrupt flag


SETB IT0 ;may select falling-edge/low-level triggered
SETB EA
SETB EX0 ;enable INT0 interrupt

ORL PCON,#02h ;invoke power-down

;... Now, CPU is in power-down mode


;... Wait for an external falling-edge on INT0-pin
;...

NOP ;! Note: here must be a NOP

wake_up:
;If INT0(P3.2) is triggered by a falling-edge,
; the MCU will wake up, and enter "IE0_isr",
;then return here to run continuously !
;...
;...
;

18 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN


11. One-time Enabled Watchdog Timer (WDT)
The WDT is intended as a recovery method in situations where the CPU may be subjected to software upset.
The WDT consists of a 15-bit free-running counter, a 8-bit prescaler and the WDT control register (WDTCR).
The WDT is disabled at reset. To enable the WDT, user must set ENW bit in the WDTCR. When the WDT is
enabled, it will increment every machine cycle (12 clocks in 12T mode, and 6 clocks in 6T mode), and there is
no way to disable the WDT except through reset (either hardware reset, software reset or WDT reset).

When WDT is enabled, the user needs to service it by writing 1 to the CLRW bit to avoid WDT overflow. When
the 15-bit counter overflows, the chip reset signal will reset the MCU.

WDTCR (Watch-Dog-Timer Control Register)


7 6 5 4 3 2 1 0
- - ENW CLRW WIDL PS2 PS1 PS0
Note: This is a Write-only register.

ENW: Set to enable WDT. This bit can only be cleared by any kind of reset. Software can not clear it.
CLRW: Write 1 to this bit to clear WDT. After WDT cleared, it is automatically cleared by H/W.
WIDL: Set this bit (!! Clear this bit for MPC89L516(556)X2) to let WDT keep counting while the MCU is in the Idle mode.
PS2~PS1: Used to determine the prescaler value.

WDT Block Diagram

Clock source:
Fosc/12, or Fosc/6 PS2,PS1,PS0

Prescaler
Chip reset
ENW 15-bit counter when overflow
2

4 clear

1: in Idle mode 8
0: otherwise
WIDL 16
CLRW
32

64

128

256

MEGAWIN MPC89L(E)51/52/53/54/58/515 Technical Summary 19


WDT overflow period

The WDT overflow period is determined by the following equation:


15
(N x Prescaler x 2 ) / Fosc, where: N=12 for 12T mode, N=6 for 6T mode.

The following table shows the WDT overflow period for MCU running at 12MHz. The period is the maximum
interval for user to clear the WDT to prevent from chip reset.

Example of WDT Overflow Period, @Fosc=12MHz


PS2 PS1 PS0 Prescaler value 12T mode 6T mode
0 0 0 2 65.536 ms 32.768 ms
0 0 1 4 131.072 ms 65.536 ms
0 1 0 8 262.144 ms 131.072 ms
0 1 1 16 524.288 ms 262.144 ms
1 0 0 32 1.048 s 524.288 ms
1 0 1 64 2.097 s 1.048 s
1 1 0 128 4.194 s 2.097 s
1 1 1 256 8.389 s 4.194 s

Sample code for Watchdog Timer

Condition: MCU runs at 12MHz and at 6T mode


Target: WDT Overflow Period = 524.288ms

WDTCR_buf DATA 30h ;declare a buffer for WDTCR


;(because WDTCR is a Write-only register)
start:
;...
;...

MOV WDTCR_buf,#00h ;clear buffer for WDTCR

ANL WDTCR_buf,#0F8h ;(PS2,PS1,PS0)=(1,0,0), prescaler=32


ORL WDTCR_buf,#04h ;@12MHz/6T, WDT_Overflow_Period=524.288ms
MOV WDTCR,WDTCR_buf ;

ORL WDTCR_buf,#20h ;enable WDT


MOV WDTCR,WDTCR_buf ;

main_loop:
ORL WDTCR_buf,#10h ;clear WDT
MOV WDTCR,WDTCR_buf ;
;...
;...
JMP main_loop

ANL WDTCR_buf,#0DFh ;disable WDT


MOV WDTCR,WDTCR_buf ;

20 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN


12. Reduced EMI Mode
Set the AO bit (in AUXR, bit 0) will turn off the ALE output unless the CPU needs to access external data
memory or run out of external program memory. This may reduce EMI (Electro Magnetic Interference) in some
degree.

AUXR (Auxiliary Register)


7 6 5 4 3 2 1 0
- - - - - - EXTRAM AO

EXTRAM: Set to enable external data memory accessing.


AO: Set to turn off ALE output.

MEGAWIN MPC89L(E)51/52/53/54/58/515 Technical Summary 21


13. 12T Mode and 6T Mode
The standard 8051 MCU can only run at 12T mode ( each machine-cycle has only 12 clocks ). While the
MPC89L(E)51/52/53/54/58/515 can also run at 6T mode ( each machine-cycle has only 6 clocks ). Its
performance is twice that of 12T mode at the same Fosc.

To enable 6T mode, program 0 to EN6T bit in OR1 by the WRITER.


Note: After whole-chip erasing (including Option Registers), this bit becomes 1, so the CPU will run at 12T mode.

Timing Calculation

While the MCU runs at 6T-mode and at Fosc, the user may regard it as 12T-mode and at Fosc x 2. So, all
MCU’s timing (including internal and external) calculation can be based on Fosc x 2.

For example,
Suppose that the MCU runs at 6T-mode and Fosc=18MHz, we can regard it as a standard 8051 running at
36MHz. So, we will get
(1) One machine cycle has 1 / 36MHz x 12 = 0.33us
(2) ALE output frequency = 36MHz / 6 = 6MHz
(3) External program/data accessing timing, I/O timing and internal Timer/counter timing are calculated on the
base of 36MHz.

22 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN


14. In-System-Programming (ISP)

This MCU’s program memory is made of Flash memory, which has In-System-Programming (ISP) capability. In-
System-Programming allows the MCU to alter its program memory, in the actual end product, under software
control. This feature opens up a range of applications that need the ability to field update the application
firmware.

Several special function registers are related to ISP:

ISPCR: ISP control register


IFMT: ISP mode select register
IFADRH: ISP Flash address high register
IFADRL: ISP Flash address low register
IFD: ISP Flash data register
SCMD: ISP sequential command register (filled sequentially with 0x46h then 0xB9h to trigger ISP operation)

ISPCR (ISP Control Register)


7 6 5 4 3 2 1 0
ISPEN SWBS SWRST - - ICK2 ICK1 ICK0

ISPEN: Set to 1 to enable ISP function.


SWBS: Software boot select. Set/Cleared to select ISP-memory/AP-memory to boot from after reset. See
Section 14-7.
SWRST: Write 1 to trigger S/W reset.
ICK2-0: Set programming time of ISP. See Section 14-6.

ISP Mode Select Table

IFMT value ISP Mode


0 Standby
1 Read
2 Byte Program
3 Page Erase
5 OR1 Read (with IFADRL=1)
6 OR1 Program (with IFADRL=1)
7 OR1 Erase (with IFADRL=1)

MEGAWIN MPC89L(E)51/52/53/54/58/515 Technical Summary 23


14-1 Boot from ISP-memory to run “ISP code”

As shown in Figure 14a, the ISP-memory is allocated. To run the “ISP code”, the CPU should boot from the ISP-
memory. Two methods are used to boot from the ISP-memory. Figure 14b and Figure 14c demonstrate them.

Figure 14a. ISP-memory Allocation (“ISP code” is placed in ISP-memory)

0000h

AP-memory
Only 4KB for 51
Only 8KB for 52
15KB-ISPsize for 53
Application
code Only 16KB for 54
Only 32KB for 58
63KB-ISPsize for 515

Total Flash Memory


15KB for 51/52/53
63KB for 54/58/515

ISP_start_address
ISP code
ISP-memory
3BFFh for 51/52/53 0KB, 1KB, 2KB or 4KB
FBFFh for 54/58/515

Notes:
(a) “ISP_start_address” is determined by OR0 (Option Register 0).
(b) Use the WRITER to program the “ISP code” into the ISP-memory beginning with “ISP_start_address”.

24 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN


Figure 14b. Boot from ISP-memory through AP-memory

Start

Power on or H/W reset (RST-pin)


(while HWBS=1, SWBS=0, and ISP-memory exists)

Now,
CPU will boot from AP-memory,
and run "Application code".

Check the user-defined NO


ISP condition, do ISP?

YES

SWBS=1 (select boot from ISP-memory) Run "Application code"


SWRST=1 (trigger S/W reset) normally
...
...

Now,
CPU will re-boot from ISP-memory,
and run "ISP code".

ISPEN=1 (enable ISP function),


and initialize ISPCR[2:0]
Do ISP programming
to update the "Application code"

End

MEGAWIN MPC89L(E)51/52/53/54/58/515 Technical Summary 25


Figure 14c. Boot from ISP-memory Directly

Start

Power on or H/W reset (RST-pin)


(while HWBS=0 and ISP-memory exists)

Now,
CPU will boot from ISP-memory,
and run "ISP code".

Check the user-defined NO


ISP condition, do ISP?

YES

ISPEN=1 (enable ISP function), SWBS=0 (select boot from AP-memory)


and initialize ISPCR[2:0] SWRST=1 (trigger S/W reset)
Do ISP programming
to update the "Application code"

Now,
CPU will re-boot from AP-memory,
End and run "Application code" normally.

26 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN


14-2 Normal Operation (not do ISP) while HWBS=0

As mentioned in Section 14-1, to run “ISP code” via booting from ISP-memory by hardware method, the HWBS
bit in OR1 should be programmed to 0 by the Writer. Once HWBS becomes 0 (and ISP-memory exists), the
CPU will always boot from ISP-memory each time it starts from power-on, H/W reset or WDT reset. So, user
must distinguish normal operation from ISP programming. The new red dash line in the following chart (from
Figure 14c) shows the flow for normal operation (not do ISP).

Start

Power on or H/W reset (RST-pin)


(while HWBS=0 and ISP-memory exists)

Now,
CPU will boot from ISP-memory,
and run "ISP code".

Normal operation flow


Check the user-defined
ISP condition, do ISP? NO

YES

ISPEN=1 (enable ISP function), SWBS=0 (select boot from AP-memory)


and initialize ISPCR[2:0] SWRST=1 (trigger S/W reset)
Do ISP programming
to update the "Application code"

Now,
CPU will re-boot from AP-memory,
End and run "Application code" normally.

MEGAWIN MPC89L(E)51/52/53/54/58/515 Technical Summary 27


14-3 An Example for the User-defined ISP Condition

The user-defined ISP condition, for example, may be:


When just power on, P1.0 and P1.1 are simultaneously shorted to ground for more than 100ms.

If user intends to do ISP, he must execute the following steps:

Step1) Short P1.0 and P1.1 to ground, then power on.


Step2) Last for more than 100ms, then release P1.0 and P1.1 for their normal function.
Step3) Do ISP operation.

Once the ISP condition is satisfied, the ISP operation is executed from label “do_ISP”, otherwise go to label
“not_do_ISP”. The following code shows this example.

Start:
.
.

MOV R0,#100 ;check if really do ISP ?


chk_do_ISP: ;
JB P1.0,not_do_ISP ;
JB P1.1,not_do_ISP ;
CALL delay_1ms ;
DJNZ R0,chk_do_ISP ;
JMP do_ISP ;

do_ISP:
.
.
.

not_do_ISP:
.
.
.

delay_1ms:
.
.
RET

28 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN


14-4 Operation Flow of ISP

Figure 14f~14h show the flow chart for the various ISP modes used in the “ISP code”.

Figure 14f. Flow Chart for “Erase”

Start

ISPEN=1 (enable ISP function),


and initialize ISPCR[2:0]

IFMT=0x03 (select Page Erase Mode)

Page_address=0

IFADRH= High-byte of Page_address Page_address=Page_address+0x0200


IFADRL= Low-byte of Page_address (Increment Page_address,
512 bytes per page)
SCMD=0x46, then SCMD=0xB9
(trigger ISP processing by sequential
writing)

NO
Check
end of Page?

YES

End

MEGAWIN MPC89L(E)51/52/53/54/58/515 Technical Summary 29


Figure 14g. Flow Chart for “Program”

Start

ISPEN=1 (enable ISP function),


and initialize ISPCR[2:0]

IFMT=0x02 (select Byte Program Mode)

Byte_address=0

IFADRH= High-byte of Byte_address


IFADRL= Low-byte of Byte_address
IFD=data (to be programmed) Increment Byte_address
SCMD=0x46, then SCMD=0xB9
(trigger ISP processing by sequential
writing)

NO
Check
end of address?

YES

End

30 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN


Figure 14h. Flow Chart for “Read/Verify”

Start

ISPEN=1 (enable ISP function),


and initialize ISPCR[2:0]

IFMT=0x01 (select Read Mode)

Byte_address=0

IFADRH= High-byte of Byte_address


IFADRL= Low-byte of Byte_address
Increment Byte_address
SCMD=0x46, then SCMD=0xB9
(trigger ISP processing by sequential
writing)

NO Compare got data


(in IFD) with wanted data,
the same?

YES

NO
Check end of
address?

YES

ISP fail ISP pass

MEGAWIN MPC89L(E)51/52/53/54/58/515 Technical Summary 31


14-5 Demo Code for the “ISP code”
;******************************************************************************************
; ISP modes
;******************************************************************************************

IFD DATA 0E2h


IFADRH DATA 0E3h
IFADRL DATA 0E4h
IFMT DATA 0E5h
SCMD DATA 0E6h
ISPCR DATA 0E7h
;
MOV ISPCR,#10000001b ;ISPCR.7=1, enable ISP
;ISPCR[2:0]=001, for Fosc=20MHz

;=============================================================================
; 1. Page Erase Mode (512 bytes per page)
;=============================================================================

MOV IFMT,#03h ;select Page Erase Mode

MOV IFADRH,?? ;fill page address in IFADRH & IFADRL


MOV IFADRL,?? ;

MOV SCMD,#46h ;trigger ISP processing


MOV SCMD,#0B9h ;

;Now in processing...(CPU will halt here until complete)


;...

;=============================================================================
; 2. Byte Program Mode
;=============================================================================

MOV IFMT,#02h ;select Byte Program Mode

MOV IFADRH,?? ;fill byte address in IFADRH & IFADRL


MOV IFADRL,?? ;
MOV IFD,?? ;fill the data to be programmed in IFD

MOV SCMD,#46h ;trigger ISP processing


MOV SCMD,#0B9h ;

;Now in processing...(CPU will halt here until complete)


;...

;=============================================================================
; 3. Read Mode
;=============================================================================

MOV IFMT,#01h ;select Read Mode

MOV IFADRH,?? ;fill byte address in IFADRH & IFADRL


MOV IFADRL,?? ;

MOV SCMD,#46h ;trigger ISP processing


MOV SCMD,#0B9h ;

;Now in processing...(CPU will halt here until complete)


;...

MOV A,IFD ;data will be in IFD


;

32 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN


14-6 Programming Time Setting

ISPCR (ISP Control Register)


7 6 5 4 3 2 1 0
ISPEN SWBS SWRST - - ICK2 ICK1 ICK0

ICK2-0: Set programming time of ISP. See the following table for their setting in several Fosc ranges.

Fosc ICK2 ICK1 ICK0


20~45 MHz 0 0 0
10~20 MHz 0 0 1
5~10 MHz 0 1 0
0~5 MHz 0 1 1

14-7 Which Program Memory to Boot from

ISPCR (ISP Control Register)


7 6 5 4 3 2 1 0
ISPEN SWBS SWRST - - ICK2 ICK1 ICK0

SWBS: Software boot select. Set/Cleared to select ISP-memory/AP-memory to boot from after reset.
SWRST: Write 1 to trigger S/W reset.

H/W reset (RST-pin pulled high)


HWBS 1 SWBS
ISP-memory* Power-on reset S/W reset (write 1 to SWRST bit)
(OR1, bit-1) (ISPCR, bit-6)
WDT reset (Watch-dog Timer overflows)
1 1 0 AP-memory AP-memory
1 1 1 AP-memory ISP-memory
1 0 0 AP-memory AP-memory
1 0 1 AP-memory AP-memory
0 1 0 ISP-memory AP-memory
0 1 1 ISP-memory ISP-memory
0 0 0 AP-memory AP-memory
0 0 1 AP-memory AP-memory

Note:
1. The value 1 in the column ISP-memory means ISP-memory exists (not zero byte), while 0 means not exists
(zero byte).
2. For the ISPCR register, the bits ISPEN and SWBS will be initialized to its reset value only by power-on
reset. The other resets won’t initialize these two bits. So, for example, if ISP-memory exists (not zero byte)
and SWBS is set to 1 by firmware before H/W reset, S/W reset or WDT reset come, then the MCU will re-
boot from ISP-memory after these resets.

MEGAWIN MPC89L(E)51/52/53/54/58/515 Technical Summary 33


15. Non-volatile Data Application using In-Application-Programming
Refer to Section 18. Flash Memory Configuratiion, for MPC89L(E)51/52/54/58 (not including 53 and 515),
under the condition of ISP-memory being allocated, there exists an In-Application-Programming memory
(IAP-memory). The range and size of the IAP-memory depend on the ISP-memory size, as listed below.

IAP-memory range and size


Part No.
ISP_size=4KB ISP_size =2KB ISP_size =1KB
0x1000~0x2BFF 0x1000~0x33FF 0x1000~0x37FF
MPC89L(E)51
(7KB) (9KB) (10KB)

0x2000~0x2BFF 0x2000~0x33FF 0x2000~0x37FF


MPC89L(E)52
(3KB) (5KB) (6KB)

0x4000~0xEBFF 0x4000~0xF3FF 0x4000~0xF7FF


MPC89L(E)54
(43KB) (45KB) (46KB)

0x8000~0xEBFF 0x8000~0xF3FF 0x8000~0xF7FF


MPC89L(E)58
(27KB) (29KB) (30KB)

Any Flash page (with 512 bytes) in the IAP-memory can be erased, programmed and read by using the
ISP, as described in Section 14-4. This useful feature can be applied to the application where data must be
kept after power off. Thus, there is no need to use an external EEPROM for saving non-volatile data.

To update the non-volatile data, user should take the following steps:

Step1) Save the whole non-volatile data page (512 bytes) to a buffer (with size of 512 bytes).
Step2) Update some specific bytes in the buffer.
Step3) Erase this non-volatile data page.
Step4) Program the updated data out of the buffer to this page.

Usually, for MPC89L(E)51/52, there is not enough internal RAM for this buffer except using external RAM. So,
we recommend users use the on-chip 256 bytes of XRAM as the buffer. Of course, there should be no user
data saved there. So, one 512-byte Flash page can save only 256 bytes of non-volatile data due to the
limitation of XRAM’s size. If more non-volatile data are needed, use another Flash page to save one more 256
bytes.

For MPC89L(E)54/58, there is enough internal RAM for this buffer while the on-chip 1024 bytes of XRAM are
used (only 512 bytes are needed). Of course, there should be no user data saved there. So, one 512-byte
Flash page can save 512 bytes of non-volatile data. If more non-volatile data are needed, use another Flash
page to save one more 512 bytes.

34 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN


16. Power-ON Flag
The Power-On Flag (POF) is set by hardware when the VDD level rises from 0. The POF bit can be set or
cleared by software and thus allows user to determine if the start of CPU is cool (from power-on) or warm (from
hardware reset or Watchdog Timer reset).

PCON (Power Control Register)


7 6 5 4 3 2 1 0
SMOD SMOD0 - POF GF1 GF0 PD IDL

SMOD0: Cleared for SCON.7=SM0, and set for SCON.7=FE.


POF: Power-ON Flag.

MEGAWIN MPC89L(E)51/52/53/54/58/515 Technical Summary 35


17. Option Registers
Note: The programming value of the Option Registers won’t become effective until next power-on.

OR0 (Option Register 0)


7 6 5 4 3 2 1 0
(reserved) (reserved) ISPAS1 ISPAS0 (reserved) MOVCL SB LOCK
Note: The reserved bit must be kept 1.

(ISPAS1,ISPAS0): used for ISP-memory configuration, see the following table.


ISP-memory Setting Table
MPC89L51/52/53 MPC89L54/58/515
ISP- MPC89E51/52/53 MPC89E54/58/515
(ISPAS1, ISPAS0) memory
size ISP-memory AP-memory ISP-memory AP-memory
start ~ end start ~ end start ~ end start ~ end
51: 0x0000~0x0FFF 54: 0x0000~0x3FFF
(0, 0) 4KB 0x2C00~0x3BFF 52: 0x0000~0x1FFF 0xEC00~0xFBFF 58: 0x0000~0x7FFF
53: 0x0000~0x2BFF 515: 0x0000~0xEBFF
51: 0x0000~0x0FFF 54: 0x0000~0x3FFF
(0, 1) 2KB 0x3400~0x3BFF 52: 0x0000~0x1FFF 0xF400~0xFBFF 58: 0x0000~0x7FFF
53: 0x0000~0x33FF 515: 0x0000~0xF3FF
51: 0x0000~0x0FFF 54: 0x0000~0x3FFF
(1, 0) 1KB 0x3800~0x3BFF 52: 0x0000~0x1FFF 0xF800~0xFBFF 58: 0x0000~0x7FFF
53: 0x0000~0x37FF 515: 0x0000~0xF7FF
51: 0x0000~0x0FFF 54: 0x0000~0x3FFF
(1, 1) 0 None 52: 0x0000~0x1FFF None 58: 0x0000~0x7FFF
53: 0x0000~0x3BFF 515: 0x0000~0xFBFF

MOVCL:
0: MOVC instruction executed from external program memory is disabled for security.
1: MOVC is always available.
SB:
0: Code dumped on a Writer is scrambled for security.
1: Code dumped on a Writer is not scrambled.
LOCK:
0: Code dumped on a Writer is locked to 0xFF for security.
1: Code dumped on a Writer is not locked.

OR1 (Option Register 1)


7 6 5 4 3 2 1 0
FZWDTCR (reserved) (reserved) OSCDN (reserved) (reserved) HWBS EN6T
Note: The reserved bit must be kept 1.

FZWDTCR:
0: The WDTCR register will be initialized to its reset value only by power-on reset.
1: The WDTCR register will be initialized to its reset value by all reset (including power-on, H/W, S/W and WDT reset).
OSCDN:
0: Used under 25MHz for EMI reduction. (The gain of oscillating amplifier is reduced.)
1: The gain of crystal oscillator is enough for higher Fosc oscillating.
HWBS:
0: When power-on, H/W will set SWBS and CPU will boot from ISP-memory if ISP-memory exists.
1: (No action)
EN6T:
0: MCU runs at 6T mode (each machine-cycle has 6 clocks).
1: MCU runs at 12T mode (each machine-cycle has 12 clocks).

36 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN


18. Flash Memory Configuration

MPC89L51/52/53 & MPC89E51/52/53

0x0000 0x0000 0x0000

AP-memory
4KB

0x0FFF AP-memory
8KB

0x1FFF AP-memory
15KB
(for IAP)

ISP-memory ISP-memory (for IAP) ISP-memory


start address start address start address

0x2C00 (ISP=4KB) 0x2C00 (ISP=4KB) 0x2C00 (ISP=4KB)


0x3400 (ISP=2KB) 0x3400 (ISP=2KB) 0x3400 (ISP=2KB)
0x3800 (ISP=1KB) 0x3800 (ISP=1KB) 0x3800 (ISP=1KB)
None (ISP=0KB) None (ISP=0KB) None (ISP=0KB)
ISP-memory ISP-memory ISP-memory
4KB/2KB/1KB/0KB 4KB/2KB/1KB/0KB 4KB/2KB/1KB/0KB
0x3BFF 0x3BFF 0x3BFF

MPC89L51 MPC89L52 MPC89L53


MPC89E51 MPC89E52 MPC89E53

MPC89L54/58/515 & MPC89E54/58/515

0x0000 0x0000 0x0000

AP-memory
16KB

0x3FFF AP-memory
32KB

AP-memory
0x7FFF 63KB
(for IAP)

ISP-memory ISP-memory ISP-memory


start address start address (for IAP) start address

0xEC00 (ISP=4KB) 0xEC00 (ISP=4KB) 0xEC00 (ISP=4KB)


0xF400 (ISP=2KB) 0xF400 (ISP=2KB) 0xF400 (ISP=2KB)
0xF800 (ISP=1KB) 0xF800 (ISP=1KB) 0xF800 (ISP=1KB)
None (ISP=0KB) None (ISP=0KB) None (ISP=0KB)
ISP-memory ISP-memory ISP-memory
4KB/2KB/1KB/0KB 4KB/2KB/1KB/0KB 4KB/2KB/1KB/0KB
0xFBFF 0xFBFF 0xFBFF

MPC89L54 MPC89L58 MPC89L515


MPC89E54 MPC89E58 MPC89E515

MEGAWIN MPC89L(E)51/52/53/54/58/515 Technical Summary 37


19. XTAL Oscillating Requirement and ALE Output Frequency
19-1 XTAL Oscillating Requirement
As shown in the Oscillating Circuit, to achieve successful and exact oscillating, the values for C1, C2 and R1 are
recommended as below.

While OSCDN=1
X1 2~19MHz 20~25MHz 26~30MHz 31~35MHz 36~39MHz 40~43MHz 44~48MHz

C1, C2 47pF 33pF 10pF 10pF 10pF 10pF 5pF

R1 - - 6.8KΩ 5.1KΩ 4.7KΩ 3.3KΩ 3.3KΩ

While OSCDN=0
X1 2~19MHz 20~25MHz 26~30MHz 31~35MHz 36~39MHz 40~43MHz 44~48MHz

C1, C2 47pF 33pF 5pF - - - -

R1 - - 6.8KΩ 5.1KΩ 4.7KΩ 3.3KΩ 3.3KΩ

Note:
(1) ‘-’ means no need.
(2) C1 and C2 include the parasitic capacitance in the PCB.

Oscillating Circuit

MPC89L(E)51~515

XTAL2
X1
XTAL1

R1

C1 C2

19-2 ALE Output Frequency

At 12T-mode, if the XTAL oscillating is successful and correct, the ALE output frequency will be Fosc / 6 (as that
of the standard 8051). While at 6T-mode, it will be Fosc*2 / 6.

For example,
If Fosc=24MHz, the ALE output frequency is 4MHz and 8MHz for 12T-mode and 6T-mode, respectively.

38 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN


20. Power Consumption

L-series @VDD=3.3V, 25°C E-series @VDD=5.0V, 25°C


Fosc 12T mode 6T mode 12T mode 6T mode
Inop Iidle Ipwdn Inop Iidle Ipwdn Inop Iidle Ipwdn Inop Iidle Ipwdn
(mA) (mA) (uA) (mA) (mA) (uA) (mA) (mA) (uA) (mA) (mA) (uA)
4MHz 5.0 1.7 5.4 1.8 8.0 3.7 8.4 3.8
6MHz 5.4 1.8 5.9 2.0 8.9 5.0 9.5 5.0
8MHz 5.8 2.2 6.5 2.4 10.1 6.2 10.8 6.3
10MHz 5.7 2.0 6.6 2.2 9.3 5.2 10.3 5.4
12MHz 6.0 2.0 7.0 2.3 9.5 5.3 10.7 5.6
16MHz 6.6 2.4 7.9 2.7 10.4 5.9 12.0 6.3
20MHz 7.0 2.6 8.7 3.0 11.4 6.6 13.3 7.1
24MHz 7.4 2.7 < 1.0 9.4 3.1 < 1.0 11.6 6.5 < 1.0 13.9 7.1 < 1.0
27MHz 8.0 3.2 10.2 3.6 14.7 9.4 17.0 9.9
30MHz 8.8 3.8 11.3 4.3 16.8 11.2 19.3 11.7
32MHz 9.0 3.9 11.7 4.4 17.1 11.5 19.9 12.1
36MHz 10.4 5.1 13.4 5.7 20.3 14.7 23.9 15.3
40MHz 10.6 5.1 14.0 5.8 19.6 13.8 24.2 14.8
42MHz 10.4 4.7 13.9 5.4 20.9 14.9 25.6 15.9
44MHz 11.0 5.2 14.7 6.0 21.0 14.9 25.7 15.9
48MHz 11.4 5.3 15.1 6.1 20.7 14.3 - -
Notes:
(1) Inop : The IDD current when the MCU executes the following instructions:
Loop:
NOP
JMP Loop
(2) Iidle : The IDD current when the MCU is in its idle mode.
(3) Ipwdn : The IDD current when the MCU is in its power-down mode.

MEGAWIN MPC89L(E)51/52/53/54/58/515 Technical Summary 39


21. How to Reduce EMI
To reduce EMI (Electro Magnetic Interference) generated by the MCU, the following suggestions are useful:

(1) Turn off ALE output as described in Section 12.


(2) Program OSCDN bit (in OR1) to 0 by a Programmer/Writer as described in Section 17.
(3) Use lower Fosc, e.g., lower than 24MHz. (The lower Fosc is, the lower the EMI will be.)
If the performance of 40MHz@12T-mode is necessary, it is strongly recommended to use
20MHz@6T-mode for lower EMI.
(4) Add series resistors R2 and R3 at XTAL1 and XTAL2, respectively, as shown below.

MPC89L(E)51~515

R2
XTAL2
X1 R3
XTAL1

R1

C1 C2

R2 & R3 resistance (for both L-series and E-series)


X1 8MHz 12MHz 16MHz 20MHz 24MHz

C1, C2 47pF 47pF 47pF 47pF 47pF

R1 - - - - -

OSCDN=1 33~680Ω 33~560Ω 33~430Ω 33~360Ω 33~300Ω


R2, R3
OSCDN=0 33~560Ω 33~470Ω 33~300Ω 33~220Ω 33~150Ω

40 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN


22. UART Baudrate Setting
To use Timer 1 as the baudrate generator, follow the steps:

1) T2CON=xx00xxxx, where x means “don’t care” bit.


2) Timer 1 operates at its Mode 2 (8-bit auto-reload), i.e., TMOD=0010xxxx, where x means “don’t care” bit.
3) Find TH1 by:
SMOD
For 12T-mode, baudrate = 2 x Fosc / ( 32 x 12 x (256 - TH1) ).
SMOD
So, TH1 = 256 - 2 x Fosc / (baudrate x 32x 12).
SMOD
For 6T-mode, baudrate = 2 x Fosc x 2 / ( 32 x 12 x (256 - TH1) ).
SMOD
So, TH1 = 256 - 2 x Fosc x 2 / (baudrate x 32 x 12).
Where SMOD is bit-7 of the PCON register.
4) Start Timer 1, set bit TR1 in the TCON register.

To use Timer 2 as the baudrate generator, follow the steps:

1) T2CON=xx11xxxx, where x means “don’t care” bit.


2) Timer 2 operates at its baudrate generator mode, i.e., T2CON=xx11xxxx, where x means “don’t care” bit.
3) Find [RCAP2H,RCAP2L] by:
For 12T-mode, baudrate = Fosc / ( 2 x 16 x (65536 - [RCAP2H, RCAP2L]) ).
So, [RCAP2H, RCAP2L] = 65536 - Fosc / (baudrate x 2 x 16).
For 6T-mode, baudrate = Fosc x 2 / ( 2 x 16 x (65536 - [RCAP2H, RCAP2L]) ).
So, [RCAP2H, RCAP2L] = 65536 - Fosc x 2 / (baudrate x 2 x 16).
4) Start Timer 2, set bit TR2 in the T2CON register

The popular XTAL frequency used for UART application is 11.0592MHz, 18.432MHz, 22.1184MHz and
36.864MHz. The following tables show the TH1 and [RCAP2H, RCAP2L] values for a variety of the standard
baudrate.

MEGAWIN MPC89L(E)51/52/53/54/58/515 Technical Summary 41


Fosc=11.0592MHz
Timer1 ( TH1 ) Timer2 ( [RCAP2H, RCAP2L] )
Baudrate 12T-mode 6T-mode
12T-mode 6T-mode
SMOD=0 SMOD=1 SMOD=0 SMOD=1
300 160 64 64 - 64384 63232
600 208 160 160 64 64960 64384
1200 232 208 208 160 65248 64960
1800 240 224 224 192 65344 65152
2400 244 232 232 208 65392 65248
4800 250 244 244 232 65464 65392
7200 252 248 248 240 65488 65440
9600 253 250 250 244 65500 65464
14400 254 252 252 248 65512 65488
19200 - 253 253 250 65518 65500
38400 - - - 253 65527 65518
57600 - 255 255 254 65530 65524
115200 - - - 255 65533 65530

Fosc=18.432MHz
Timer1 ( TH1 ) Timer2 ( [RCAP2H, RCAP2L] )
Baudrate 12T-mode 6T-mode
12T-mode 6T-mode
SMOD=0 SMOD=1 SMOD=0 SMOD=1
300 96 - - - 63616 61696
600 176 96 96 - 64576 63616
1200 216 176 176 96 65056 64576
1800 - - - - 65216 64896
2400 236 216 216 176 65296 65056
4800 246 236 236 216 65416 65296
7200 - - - - 65456 65376
9600 251 246 246 236 65476 65416
14400 - - - - 65496 65456
19200 - 251 251 246 65506 65476
38400 - - - 251 65521 65506
57600 - - - - 65526 65516
115200 - - - - 65531 65526

42 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN


Fosc=22.1184MHz
Timer1 ( TH1 ) Timer2 ( [RCAP2H, RCAP2L] )
Baudrate 12T-mode 6T-mode
12T-mode 6T-mode
SMOD=0 SMOD=1 SMOD=0 SMOD=1
300 64 - - - 63232 60928
600 160 64 64 - 64384 63232
1200 208 160 160 64 64960 64384
1800 224 192 192 128 65152 64768
2400 232 208 208 160 65248 64960
4800 244 232 232 208 65392 65248
7200 248 240 240 224 65440 65344
9600 250 244 244 232 65464 65392
14400 252 248 248 240 65488 65440
19200 253 250 250 244 65500 65464
38400 - 253 253 250 65518 65500
57600 255 254 254 252 65524 65512
115200 - 255 255 254 65530 65524

Fosc=36.864MHz
Timer1 ( TH1 ) Timer2 ( [RCAP2H, RCAP2L] )
Baudrate 12T-mode 6T-mode
12T-mode 6T-mode
SMOD=0 SMOD=1 SMOD=0 SMOD=1
300 - - - - 61696 57856
600 96 - - - 63616 61696
1200 176 96 96 - 64576 63616
1800 - - - - 64896 64256
2400 216 176 176 96 65056 64576
4800 236 216 216 176 65296 65056
7200 - - - - 65376 65216
9600 246 236 236 216 65416 65296
14400 - - - - 65456 65376
19200 251 246 246 236 65476 65416
38400 - 251 251 246 65506 65476
57600 - - - - 65516 65496
115200 - - - - 65526 65516

MEGAWIN MPC89L(E)51/52/53/54/58/515 Technical Summary 43


23. Notes on Using External Interrupt
The way to manage external interrupts may exist a difference between the so-called 8051 compatible MCUs.

To safely use external interrupts, please refer to the following example, which includes some useful suggestion.

An Example:

ORG 0000h
JMP main

ORG 0003h ;/INT0 interrupt vector


JMP INT0_isr

;--------------------------------------------------------------
main:
CLR IT0 ;IT0=0, select /INT0 as low-level-triggered

SETB EA ;enable /INT0 interrupt


SETB EX0 ;
;
loop:
LCALL check_alarm
JMP loop

;
check_alarm:
;(Suppose: while “check_alarm” is being executed, it must not be interrupted by /INT0.)

PUSH IE ;save IE for the following “CLR EX0”

CLR EX0 ;!!! Note: /INT0 interrupt may happen at this time

NOP ;!!! insert 3 NOPs here for the case:


NOP ; if /INT0 really happens and CPU can run its i.s.r here
NOP ;

MOV P2,#81h ;(!!! these instructions must not be interrupted by /INT0)


MOV P0,#00h ;
SET P1.5 ;
CLR P1.5 ;
MOV P0,#FFh ;
CLR P3.7 ;
MOV A,P0 ;
SETB P3.7 ;

POP IE ;restore IE

RET
;
;--------------------------------------------------------------
INT0_isr:
;…
;…
SETB EX0 ;!!! delete this instruction if have,
; to prevent from /INT0 being enabled again while main program’s
; "CLR EX0" is being executed
;…
;…
RETI
;

44 MPC89L(E)51/52/53/54/58/515 Technical Summary MEGAWIN

You might also like