Megawin MG87FE/L4051 8-bits microcontroll Datasheet

笙泉科技股份有限公司
Megawin Technology Co., Ltd.
MG87FE/L2051/4051/6051
Data Sheet
Ver 1.03
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
1/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary, v 1.03
MAKE YOU WIN
Content
1.
2.
3.
4.
General Description ..................................................................................... 4
Features ....................................................................................................... 5
Block Diagram.............................................................................................. 6
Pin Configurations........................................................................................ 7
4.1. Package Instruction .............................................................................................................. 7
4.2. Pin Description (PDIP-20 & SOP-20).................................................................................... 8
5.
8051 CPU Function Description................................................................... 9
5.1. CPU Register ........................................................................................................................ 9
5.2. CPU Timing......................................................................................................................... 10
5.3. CPU Addressing Mode ....................................................................................................... 10
6.
Memory Organization................................................................................. 11
6.1. On-Chip Program Flash ...................................................................................................... 11
6.2. On-Chip Data RAM ............................................................................................................. 12
7.
Special Function Register .......................................................................... 13
7.1. SFR Map............................................................................................................................. 13
7.2. SFR Bit Assignment............................................................................................................ 14
8.
Configurable I/O Ports................................................................................ 16
8.1. IO Structure......................................................................................................................... 16
8.1.1. Port1/3/4 GPIO Structure ............................................................................................. 16
8.2. Port1 Register ..................................................................................................................... 16
8.3. Port3 Register ..................................................................................................................... 16
8.4. Port4 Register ..................................................................................................................... 17
9.
Interrupt...................................................................................................... 18
9.1. Interrupt Structure ............................................................................................................... 18
9.2. Interrupt Register ................................................................................................................ 19
10. Timers/Counters......................................................................................... 23
10.1. Timer0 and Timer1.............................................................................................................. 23
10.1.1. Mode 0 Structure.......................................................................................................... 23
10.1.2. Mode 1 Structure.......................................................................................................... 23
10.1.3. Mode 2 Structure.......................................................................................................... 24
10.1.4. Mode 3 Structure.......................................................................................................... 24
10.1.5. Timer0/1 Register......................................................................................................... 25
10.2. PWM-Timer......................................................................................................................... 27
10.2.1. PWM-Timer Structure................................................................................................... 27
10.2.2. PWM-Timer Register .................................................................................................... 28
11. UART ......................................................................................................... 30
11.1. UART Structure................................................................................................................... 30
11.2. UART Register.................................................................................................................... 31
12. Analog Comparator .................................................................................... 33
12.1. Analog Comparator Structure ............................................................................................. 33
12.2. Analog Comparator Register .............................................................................................. 34
13. Watch Dog Timer (WDT)............................................................................ 35
13.1. WDT Structure .................................................................................................................... 35
13.2. WDT Register ..................................................................................................................... 35
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
2/56
MEGAWIN
MAKE YOU WIN
MG87FE/L2051/4051/6051
Preliminary Ver 1.00
14. Reset.......................................................................................................... 37
14.1. Reset Source ...................................................................................................................... 37
15. Power Management ................................................................................... 38
15.1. Power Saving Mode............................................................................................................ 38
15.1.1. Idle Mode...................................................................................................................... 38
15.1.2. Power-down Mode ....................................................................................................... 38
15.1.3. Interrupt Recovery from Power-down........................................................................... 38
15.1.4. Reset Recovery from Power-down............................................................................... 39
15.1.5. GPIO wake-up Recovery from Power-down................................................................. 39
15.2. Power Control Register....................................................................................................... 39
16. System Clock ............................................................................................. 41
16.1. Clock Structure ................................................................................................................... 41
16.2. Clock Register..................................................................................................................... 41
17.
18.
19.
20.
21.
22.
In System Programming (ISP) ................................................................... 43
In Application Programming (IAP).............................................................. 45
Auxiliary SFRs............................................................................................ 46
Option Setting ............................................................................................ 48
Absolute Maximum Rating ......................................................................... 49
Electrical Characteristics............................................................................ 50
22.1. DC Characteristics .............................................................................................................. 50
23. Package Dimension ................................................................................... 51
24. Instruction Set ............................................................................................ 53
25. Revision History ......................................................................................... 56
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
3/56
MEGAWIN
MAKE YOU WIN
MG87FE/L2051/4051/6051
Preliminary, v 1.03
1. General Description
MG87FE/L2051/4051/6051 is single-chip 8-bits microcontroller with the instruction sets fully compatible with
industrial-standard 80C51 series microcontroller. 2K/4K/6K bytes flash memory and 256 bytes RAM has been
embedded to provide widely field application. In-System-Programming and In-Application-Programming allows
the users to download new code or data while the microcontroller sits in the application. This device executes
one machine cycle in 6 clock cycles or 12 clock cycles. MG87FE/L2051/4051/6051 has one 8-bit I/O ports (P1),
one 7-bit I/O port (P30~P35,P37), two 16-bit timer/counters, one PWM-timer for 8-channel PWM output, a seven
-source, four-priority-level interrupt structure, an enhanced UART, a precision analog comparator, on-chip crystal
oscillator(combined P42,P43) and a high-precision internal oscillator.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
4/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary Ver 1.00
MAKE YOU WIN
2. Features
z
80C51 Central Processing Unit
z
MG87FE/L2051 with 2KB flash ROM, 4051/4KB flash ROM; 6051/6KB flash ROM
z
Operating voltage: E type: 4.5V~5.5V and L type: 2.4V~3.6V
z
Operation frequency : 48MHz(max)@12T and 24MHz@6T mode
-
External crystal mode
-
Internal RC-oscillator with +/- 4% frequency drift @ -40 ~ 85℃, there are 6 kinds of frequencies
selectable:
Internal oscillator frequency
1
6MHz
2
11.059MHz
3
12MHz
4
22.118MHz
5
24MHz
6
24.576MHz
z
ISP memory zone could be optioned as 0.5K/1KB/1.5KB~3.5KB
z
IAP capability; 1KB IAP memory size
z
On-chip 256 bytes data RAM for MG87FE/L2051/4051/6051
z
Code protection for flash memory access
z
Two 16-bit timer/counter
z
PWM-Timer for PWM generator or normal 8-bit timer, selectable interrupt on INT3
z
Seven sources, four-level-priority interrupt capability.
z
Enhanced UART, provides frame-error detection and hardware address-recognition
z
15 bits Watch-Dog-Timer with 8-bit pre-scalar, one-time enabled by CPU or power-on
z
Power control: idle mode and power-down mode, Power-down can be woken-up by INT0(P3.2), INT1(P3.3),
INT2(P4.3), INT3(P4.2) and other I/O.
z
z
z
I/O port list, P1[7:0], P3[7,5:0], P4.2/INT3 on XTAL2, P4.3/INT2 on XTAL1
Built-in analog comparator with selectable interrupt on INT2. AIN0(V+) on P1.0 and AIN1(V-) on P1.1,
output on P3.6
Package type: PDIP-20, SOP-20
Items
MG87Fxy051AE20
MG87Fxy051AS20
Package Type
PDIP-20
SOP-20
Description
x = E:5.0V , L:3.3V
y = 2, 4, 6 . 2051/4051/6051
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
5/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary, v 1.03
MAKE YOU WIN
3. Block Diagram
RAM ADDR
Register
RAM256
Flash ROM
Port4 Latch
PWM Timer
Timer0/1
UART
ISP/IAP
XTAL1/P4.3
XTAL2/P4.2
XTAL OSC/
Port4 Driver
Int. OSC
8051 Core
Interrupt
Address
Generator
RESET
RST Logic
Port1 Latch
Port3 Latch
Program
Counter
Port1 Driver
Port3 Driver
DPTR
+
WDT
P1.0 ~ P1.7
P3.0 ~ P3.5
P3.7
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
6/56
MEGAWIN
MAKE YOU WIN
MG87FE/L2051/4051/6051
Preliminary Ver 1.00
4. Pin Configurations
4.1. Package Instruction
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
7/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary, v 1.03
MAKE YOU WIN
4.2. Pin Description (PDIP-20 & SOP-20)
Pin Name
Pin Number
I/O type
Description
P1.0~P1.7
12~19
I/O
Port1: General-purposed I/O with weak pull-up resistance inside.
When 1s are written into Port1, the strong output driving PMOS
only turn-on two periods and then the weak pull-up resistance
keeps the port high.
P1.0 is the comparator positive input.
P1.1 is the comparator negative input.
P1.2 has a swapped function with P4.2/INT3.
P1.3 has a swapped function with P4.3/INT2.
P1.4 has a swapped function with P3.4/T0.
P1.5 has a swapped function with P3.5/T1.
P3.0~P3.7
2~3,6~9,11
I/O
Port3: General-purposed I/O with weak pull-up resistance inside.
When 1s are written into Port1, the strong output driving PMOS
only turn-on two periods and then the weak pull-up resistance to
keep the port high. Port3 also serves the special function of
MG87FE/L2051/4051/6051.
P3.4 has a swapped function with P1.4.
P3.5 has a swapped function with P1.5.
RESET
1
I
RESET: A high on this pin for at least two machine cycles will reset
the device.
XTAL1/P4.3
XTAL2/P4.2
5
4
I/O
Crystal1: Input to the inverting oscillator amplifier.
I/O
XTAL1 has an alternate function for P4.3/INT2.
P4.3/INT2 has a swapped function with P1.3.
Crystal2: Output from the inverting amplifier.
XTAL2 has an alternate function for P42/INT3.
P4.2/INT3 has a swapped function with P1.2.
VDD
20
P
POWER
VSS
10
G
GROUND
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
8/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary Ver 1.00
MAKE YOU WIN
5. 8051 CPU Function Description
5.1. CPU Register
PSW: Program Status Word
Address=D0H, read/write, Power On + RESET=0000-0000
7
6
5
4
3
CY
AC
F0
RS1
RS0
2
OV
1
F1
0
P
CY: Carry bit.
AC: Auxiliary carry bit.
F0: General purpose flag 0.
RS1: Register bank select bit 1.
RS0: Register bank select bit 0.
OV: Overflow flag.
F1: General purpose flag 1.
P: Parity bit.
The program status word(PSW) contains several status bits that reflect the current state of the CPU. The PSW,
shown above, resides in the SFR space. It contains the Carry bit, the Auxiliary Carry(for BCD operation), the two
register bank select bits, the Overflow flag, a Parity bit and two user-definable status flags.
The Carry bit, other than serving the function of a Carry bit in arithmetic operations, also serves as the
“Accumulator” for a number of Boolean operations.
The bits RS0 and RS1 are used to select one of the four register banks shown in the on-chip-data-RAM section.
A number of instructions refer to these RAM locations as R0 through R7.
The Parity bit reflects the number of 1s in the Accumulator. P=1 if the Accumulator contains an odd number of 1s
and otherwise P=0.
SP: Stack Pointer
Address=81H, read/write, Power On + RESET=0000-0111
7
6
5
4
3
SP[7]
SP[6]
SP[5]
SP[4]
SP[3]
2
SP[2]
1
SP[1]
0
SP[0]
DPL: Data Pointer Low
Address=82H, read/write, Power On + RESET=0000-0000
7
6
5
4
3
DPL[7]
DPL[6]
DPL[5]
DPL[4]
DPL[3]
2
DPL[2]
1
DPL[1]
0
DPL[0]
DPH: Data Pointer High
Address=83H, read/write, Power On + RESET=0000-0000
7
6
5
4
3
DPH[7]
DPH[6]
DPH[5]
DPH[4]
DPH[3]
2
DPH[2]
1
DPH[1]
0
DPH[0]
B: B Register
Address=F0H, read/write, Power On + RESET=0000-0000
7
6
5
4
3
B[7]
B[6]
B[5]
B[4]
B[3]
2
B[2]
1
B[1]
0
B[0]
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
9/56
MEGAWIN
MG87FE/L2051/4051/6051
MAKE YOU WIN
Preliminary, v 1.03
5.2. CPU Timing
A machine cycle is the shortest timing period to achieve an instruction. In MG87FE/L2051/4051/6051, some
instructions need 1 machine cycle to achieve, but others need 2 or 4 machine cycles. A machine cycle takes 12
clock periods or 6 clock periods. For 12MHz system clock, it is 1us or 0.5us.
A machine cycle is consisted of six sequential states. The states are from S1 to S6. For each state, it is
partitioned into two phase – phase1 and phase2. Each phase is corresponding to 1 clock period. Execution of a
one-cycle instruction begins during S1 when the op-code is latched into the instruction register. A second fetch
appears during S4 of the same machine cycle. Execution is completed at the end of S6 of the machine cycle.
MOVX instruction is in-active in MG87FE/L2051/4051/6051 because there is no on-chip external RAM and no
external access bus. Write operation will have no effect. And read operation will always cause an un-excepted
operation.
5.3. CPU Addressing Mode
Direct Addressing (DIR)
In direct addressing the operand is specified by an 8-bit address field in the instruction. Only internal data RAM
and SFRs can be direct addressed.
Indirect Addressing (IND)
In indirect addressing the instruction specified a register which contains the address of the operand. Both internal
and external RAM can be indirectly addressed.
The address register for 8-bit addresses can be R0 or R1 of the selected bank, or the Stack Pointer.
The address register for 16-bit addresses can only be the 16-bit data pointer register – DPTR.
Register Instruction (REG)
The register banks, containing registers R0 through R7, can be accessed by certain instructions which carry a
3-bit register specification within the op-code of the instruction. Instructions that access the registers this way are
code efficient because this mode eliminates the need of an extra address byte. When such instruction is
executed, one of the eight registers in the selected bank is accessed.
Register-Specific Instruction
Some instructions are specific to a certain register. For example, some instructions always operate on the
accumulator or data pointer, etc. No address byte is needed for such instructions. The op-code itself does it.
Immediate Constant (IMM)
The value of a constant can follow the op-code in the program memory.
Index Addressing
Only program memory can be accessed with indexed addressing and it can only be read. This addressing mode
is intended for reading look-up tables in program memory. A 16-bit base register(either DPTR or PC) points to
the base of the table, and the accumulator is set up with the table entry number. Another type of indexed
addressing is used in the conditional jump instruction.
In conditional jump, the destination address is computed as the sum of the base pointer and the accumulator.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
10/56
MEGAWIN
MAKE YOU WIN
MG87FE/L2051/4051/6051
Preliminary Ver 1.00
6. Memory Organization
MG87FE/L2051/4051/6051 device has separate address spaces for program and data memory. On-chip data
memory can be accessed by 8-bit addresses, which can be quickly stored and manipulated by the 8-bit CPU.
Program memory in MG87FE/L2051/4051/6051 can only be read, not written into.
6.1. On-Chip Program Flash
In MG87FE/L2051/4051/6051, the first partition named AP-memory is the space for storing user’s application
program code. The second one named as IAP-memory and the space which is accessed by CPU for storing the
user data. The third is named as ISP-memory and it is special for ISP boot code program.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
11/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary, v 1.03
MAKE YOU WIN
6.2. On-Chip Data RAM
7FH
FFH
Upper128
30H
20H
1FH
10H
08H
00H
Bit
addressable
Bank3
Accessed by
indirect
addressing
2FH
1FH
Bank2
Bank1
17H
0FH
Bank0
07H
SFRs
accessed by
direct
addressing
7FH
Lower128
00H
MG87FE/L2051/4051/6051 has internal data RAM that is mapped into three separate segments. They are lower
128 bytes of RAM, upper 128 bytes of RAM and 128 bytes Special Function Register (SFR).
6.2.1 Lower 128 bytes of RAM: (addresses 0x00 to 0x7F) are accessed by either direct or indirect addressing.
6.2.2 Upper 128 bytes of RAM: (addresses 0x80 to 0xFF) are accessed only by indirect addressing (using R0 or
R1).
6.2.3 The Special Function Registers: (addresses 0x80 to 0xFF) are accessed only by direct addressing.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
12/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary Ver 1.00
MAKE YOU WIN
7. Special Function Register
7.1. SFR Map
0/8
1/9
F8H
F0H
E8H
D0H
3/B
4/C
5/D
6/E
7/F
FFH
00000000
B
F7H
00000000
P4
CCAP0L
XXXX11XX
00000000
E0H
D8H
2/A
CCAP0H
EFH
WDTCR
IFD
IFADRH
IFADRL
IFMT
SCMD
ISPCR
0X000000
11111111
00000000
00000000
XXXX0000
XXXXXXXX
0000XXXX
CCON
CMOD
00XXXXXX
00000000
DFH
PSW
P3WKPE
P1WKPE
00000000
0X000000
00000000
C8H
C0H
B8H
B0H
A8H
90H
88H
XICON
CKCON
00000000
XXXXX000
IPL
SADEN
CKCON2
XXX00000
00000000
XX001010
P3
IPH
11111111
00X00000
IE
SADDR
0XX00000
00000000
AUXR1
SCON
SBUF
00000000
XXXXXXXX
B7H
9FH
P1
TSTWD
ACSR
0X000000
0XX00000
TCON
TMOD
TL0
TL1
TH0
TH1
AUXR
CKCON3
00000000
00000000
00000000
00000000
00000000
00000000
00000000
XXXXXX0X
SP
DPL
DPH
PCON
00000111
00000000
00000000
00010000
1/9
2/A
3/B
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
BFH
A7H
11111111
0/8
C7H
AFH
0XXX0XXX
80H
13/56
D7H
CFH
A0H
98H
E7H
4/C
5/D
6/E
7/F
97H
8FH
87H
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary, v 1.03
MAKE YOU WIN
7.2. SFR Bit Assignment
SYMBOL
DESCRIPTION
ADDRESS
BIT ADDRESS AND SYMBOL
LSB
SP
DPL
DPH
PCON
TCON
Stack Pointer
Data Pointer Low
Data Pointer High
Power Control
Timer Control
81H
82H
83H
87H
88H
TMOD
TL0
TL1
TH0
TH1
AUXR
CKCON3
P1
ACSR
SCON
Timer Mode
Timer Low 0
Timer Low 1
Timer High 0
Timer High 1
Auxiliary
Clock Control 3
Port 1
Analog Comp. Reg.
Serial Control
89H
8AH
8BH
8CH
8DH
8EH
8FH
90H
97H
98H
SMOD
SMOD0 PWMEN
9FH
TF1
GATE
9EH
TR1
C/T
9DH
TF0
M1
POF
9CH
TR0
M0
GF1
9BH
IE1
GATE
GF0
9AH
IT1
C/T
PD
89H
IE0
M1
IDL
88H
IT0
M0
SM0
/FE
SM1
SM2
REN
TB8
RB8
TI
RI
P14FD
AFH
EA
AEH
EAC
ADH
ACH
ES
GF2
ABH
ET1
AAH
EX1
A9H
ET0
A8H
EX0
B7H
B6H
B5H
T1
B4H
T0
PSH
B3H
INT1
PT1H
B2H
INT0
PX1H
B1H
TXD
PT0H
BDH
BCH
PS
BBH
PT1
BAH
PX1
B9H
PT0
INITIAL
VALUE
00000111B
00000000B
00000000B
00010000B
00000000B
00000000B
00000000B
00000000B
00000000B
00000000B
INT3H INT2H P15FS P14FS P13FS P12FS P11PU P10PU 00000000B
PWDEX EN6TR xxxxxx0xB
97H
96H
95H
94H
93H
92H
91H
90H 11111111B
ACIDX
ACF ACEN ACM2 ACM1 ACM0 0xx00000B
9FH
9EH
9DH
9CH
9BH
9AH
99H
98H 00000000B
SBUF
AUXR1
IE
Serial Buffer
Auxiliary 1
Interrupt Enable
99H
A2H
A8H
SADDR
P3
Slave Address
Port 3
A9H
B0H
IPH
B7H
IPL
Interrupt Priority
High
Interrupt Priority Low
B8H
SADEN
CKCON2
XICON
Slave Address Mask
Clock Control 2
Ext. Interrupt Control
B9H
BFH
C0H
CKCON
PSW
Clock Control
Program Status
Word
C7H
D0H
OSCDR EN6TR XCKS5 XCKS4 XCKS3 XCKS2 XCKS1 XCKS0 xx001010B
C7H
C6H
C5H
C4H
C3H
C2H
C1H
C0H 00000000B
PX3/
EX3
IE3
IT3
PX2
EX2
IE2
IT2
PTC
SCKS2 SCKS1 SCKS0 xxxxx000B
D7H
D6H
D5H
D4H
D3H
D2H
D1H
D0H 00000000B
P3WKPE
P1WKPE
CCON
P3 Wake-up Enable
P1 Wake-up Enable
Counter Control
Reg.
Counter Mode Reg.
Watch-dog-timer
Control register
ISP Flash data
ISP Flash address
High
ISP Flash Address
Low
ISP Mode Table
IAP Low Boundary
D6H
D7H
D8H
CY
AC
F0
RS1
RS0
OV
P
P37WE
P35WE P34WE P33WE P32WE P31WE P30WE 0x000000B
P17WE P16WE P15WE P14WE P13WE P12WE P11WE P10WE 00000000B
CF
CR
00xxxxxxB
CMOD
WDTCR
IFD
IFADRH
IFADRL
IFMT
IAPLB
D9H
E1H
00000000B
PX3H/ PX2H/
PTCH PACH
BFH
BEH
PAC
B8H
PX0
xxx00000B
CIDL
WRF
POS2
-
POS1
ENW
POS0
CLW
CPS2
WIDL
CPS1
PS2
CPS0
PS1
ECF
PS0
00000000B
0x000000B
E2H
E3H
11111111B
00000000B
E4H
00000000B
E5H
Note 1
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
B0H 1x111111B
RXD
PX0H 00x00000B
00000000B
-
-
This document information is the intellectual property of Megawin Technology.
14/56
xxxxxxxxB
0xxx0xxxB
0xx00000B
-
-
MS3
MS2
MS1
MS0
xxxx0000B
11111111B
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary Ver 1.00
MAKE YOU WIN
SCMD
ISPCR
P4
CCAP0L
B
CCAP0H
ISP Serial Command
ISP Control Register
Port 4
B Register
E6H
E7H
E8H
EAH
F0H
FAH
ISPEN
-
BS
-
SRST
-
CFAIL
-
EBH
EAH
-
-
F7H
F6H
F5H
F4H
F3H
F2H
F1H
F0H
xxxxxxxxB
0000xxxxB
xxxx11xxB
00000000B
00000000B
00000000B
Note1: The registers are addressed by IFMT and SCMD. Please refer the IFMT register description for more
detail information.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
15/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary, v 1.03
MAKE YOU WIN
8. Configurable I/O Ports
8.1. IO Structure
8.1.1. Port1/3/4 GPIO Structure
VDD
VDD
VDD
2 clocks
delay
Weak
Strong
Very weak
Port pin
Port latch data
Input data
By the way, the pull-up resistor is disabled on P10/P11 in default.
8.2. Port1 Register
P1: Port 1 Register
Address=90H, read/write, Power On + RESET=1111-1111
7
6
5
4
3
P17
P16
P15
P14
P13
2
P12
1
P11
0
P10
Bit 7~0: P17~P10 could be set/cleared by CPU. Or it also can be toggled on addressed port channel by
PWM-Timer underflow event in PWM mode.
8.3. Port3 Register
P3: Port 3 Register
Address=B0H, read/write, Power On + RESET=1X11-1111
7
6
5
4
3
P37
P36
P35
P34
P33
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
16/56
2
P32
1
P31
0
P30
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary Ver 1.00
MAKE YOU WIN
Bit 7, 5~0: P37, P35~P30 could only be set/cleared by CPU. P36 is read only for CPU from analog comparator
output.
8.4. Port4 Register
P4: Port 4 Register
Address=E8H, read/write, Power On + RESET=XXXX-11XX
7
6
5
4
3
P43
Bit 3~2: P43~P42 could be only be set/cleared by CPU.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
17/56
2
P42
1
-
0
-
MEGAWIN
MAKE YOU WIN
9. Interrupt
9.1. Interrupt Structure
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
18/56
MG87FE/L2051/4051/6051
Preliminary, v 1.03
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary Ver 1.00
MAKE YOU WIN
9.2. Interrupt Register
IE: Interrupt Enable Register
Address=E8H, read/write, Power On + RESET=00X0-0000
7
6
5
4
3
EA
EAC
-ES
ET1
2
EX1
1
ET0
0
EX0
Bit 7: EA, All interrupts enable register.
0: Global disables all interrupts.
1: Global enables all interrupts.
Bit 6: EAC, Analog Comparator interrupt Enable register.
0: Disable analog comparator interrupt and reserve the interrupt vector (33H) to /INT2.
1: Enable analog comparator interrupt and occupy the /INT2 interrupt vector (33H) for analog comparator event.
In this mode, IE2 still maintains its original function but it will not generate an interrupt whether EX2 is set or
not.
Bit 5: Reserved.
Bit 4: ES, Serial port interrupt enable register.
0: Disable serial port interrupt.
1: Enable serial port interrupt.
Bit 3: ET1, Timer 1 interrupt enable register.
0: Disable Timer 1 interrupt.
1: Enable Timer 1 interrupt.
Bit 2: EX1, External interrupt 1 enable register.
0: Disable external interrupt 1.
1: Enable external interrupt 1.
Bit 1: ET0, Timer 0 interrupt enable register.
0: Disable Timer 0 interrupt.
1: Enable Timer 1 interrupt.
Bit 0: EX0, External interrupt 0 enable register.
0: Disable external interrupt 0.
1: Enable external interrupt 1.
XICON: External Interrupt Control Register
Address=C0H, read/write, Power On + RESET=0000-0000
7
6
5
4
3
PX3/PTC
EX3
IE3
IT3
PX2
2
EX2
1
IE2
0
IT2
Bit 7: PX3, External interrupt 3 priority-L register.
0: Lower priority, setting with PX3H to select priority level.
1: Higher priority, setting with PX3H to select priority level.
Bit 7: PTC, PWM-Timer interrupt priority-L register. PX3 has an alternated function, PTC, that is switched by ECF.
When ECF is set, this bit is PTC function. If cleared, this bit is PX3 function.
0: Lower priority, setting with PTCH to select priority level.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
19/56
MEGAWIN
MG87FE/L2051/4051/6051
Preliminary, v 1.03
MAKE YOU WIN
1: Higher priority, setting with PTCH to select priority level.
Bit 6: EX3, external interrupt 3 enable register.
0: Disable external /INT3.
1: Enable external /INT3. This function will be masked when CMOD.ECF is enabled.
Bit 5: IE3, Interrupt 3 Edge flag.
0: Cleared when interrupt start to be serviced. It also could be cleared by CPU.
1: Set by hardware when external interrupt edge detected. It also could be set by CPU.
Bit 4: IT3, Interrupt 3 type control bit.
0: Cleared by CPU to specify low level triggered on Interrupt 3. If AUXR.INT3H is set, this bit specifies high level
triggered on /INT3.
1: Set by CPU to specify falling edge triggered on Interrupt 3. If AUXR.INT3H is set, this bit specifies rising edge
triggered on /INT3.
Bit 3: PX2, External interrupt 2 priority-L register.
0: Lower priority, setting with PX2H to select priority level.
1: Higher priority, setting with PX2H to select priority level.
Bit 2: EX2, external interrupt 2 enable register.
0: Disable external interrupt 2.
1: Enable external interrupt 2. This function will be masked when IE.EAC is enabled.
Bit 1: IE2, Interrupt 2 Edge flag.
0: Cleared when interrupt start to be serviced. It also could be cleared by CPU.
1: Set by hardware when external interrupt edge detected. It also could be set by CPU.
Bit 0: IT2, Interrupt 2 type control bit.
0: Cleared by CPU to specify low level triggered on /INT2. If AUXR.INT2H is set, this bit specifies high level
triggered on /INT2.
1: Set by CPU to specify falling edge triggered on /INT2. If AUXR.INT2H is set, this bit specifies rising edge
triggered on /INT2.
IPL: Interrupt Priority Low Register
Address=B8H, read/write, Power On + RESET=X0X0-0000
7
6
5
4
3
PAC
-PS
PT1
2
PX1
1
PT0
0
PX0
2
PX1H
1
PT0H
0
PX0H
Bit 7: reserved.
Bit 6: PAC, Analog Comparator interrupt priority-L register.
Bit 5: Reserved.
Bit 4: PS, Serial port interrupt priority-L register.
Bit 3: PT1, Timer 1 interrupt priority-L register.
Bit 2: PX1, external interrupt 1 priority-L register.
Bit 1: PT0, Timer 0 interrupt priority-L register.
Bit 2: PX0, external interrupt 0 priority-L register.
IPH: Interrupt Priority High Register
Address=B7H, read/write, Power On + RESET=00X0-0000
7
6
5
4
3
PX3H/PTCH PX2H/PACH
-PSH
PT1H
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
20/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary Ver 1.00
MAKE YOU WIN
Bit 7: PX3H/PTCH, external interrupt 3 priority-H register. It has an alternate function for PWM-Timer interrupt
priority-H register when CMOD.ECF is enabled.
Bit 6: PX2H/PACH, external interrupt 2 priority-H register. It has an alternate function for Analog Comparator
interrupt priority-H register when IE.EAC is enabled.
Bit 5: Reserved.
Bit 4: PSH, Serial port interrupt priority-H register.
Bit 3: PT1H, Timer 1 interrupt priority-H register.
Bit 2: PX1H, external interrupt 1 priority-H register.
Bit 1: PT0H, Timer 0 interrupt priority-H register.
Bit 2: PX0H, external interrupt 0 priority-H register.
IPL (or XICON) and IPH are combined to form 4-level priority interrupt as the following table.
{IPH.x , IPL.x}
11
10
01
00
Priority Level
1 (highest)
2
3
4
There are seven interrupt sources available in MG87FE/L2051/4051/6051. Each interrupt source can be
individually enabled or disabled by setting or clearing a bit in the SFR named IE. This register also contains a
global disable bit(EA), which can be cleared to disable all interrupts at once.
Each interrupt source has two corresponding bits to represent its priority. One is located in SFR named IPH and
the other in IPL (or XICON) register. Higher-priority interrupt will be not interrupted by lower-priority interrupt
request. If two interrupt requests of different priority levels are received simultaneously, the request of higher
priority is serviced. If interrupt requests of the same priority level are received simultaneously, an internal polling
sequence determine which request is serviced. The following table shows the internal polling sequence in the
same priority level and the interrupt vector address.
Source
External interrupt 0
Timer 0
External interrupt 1
Timer1
Serial Port
External interrupt 2 or Comparator
External interrupt 3 or PWM-Timer
Vector address
03H
0BH
13H
1BH
23H
2BH
33H
3BH
Priority within level
1
(highest)
2
3
4
5
6
7
The external interrupt /INT0, /INT1, /INT2 and /INT3 can each be either level-activated or transition-activated,
depending on bits IT0 and IT1 in register TCON, IT2 and IT3 in register XICON. The flags that actually generate
these interrupts are bits IE0 and IE1 in TCON, IE2 and IE3 in XICON. When an external interrupt is generated,
the flag that generated it is cleared by the hardware when the service routine is vectored to only if the interrupt
was transition –activated, then the external requesting source is what controls the request flag, rather than the
on-chip hardware.
The Timer0 and Timer1 interrupts are generated by TF0 and TF1, which are set by a rollover in their respective
Timer/Counter registers in most cases. When a timer interrupt is generated, the flag that generated it is cleared
by the on-chip hardware when the service routine is vectored to.
The serial port interrupt is generated by the logical OR of RI and TI. Neither of these flags is cleared by hardware
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
21/56
MEGAWIN
MAKE YOU WIN
MG87FE/L2051/4051/6051
Preliminary, v 1.03
when the service routine is vectored to. The service routine should poll RI and TI to determine which one to
request service and it will be cleared by software.
/INT2 and Analog Comparator share the same interrupt vector, 33H. If IE.EAC is enabled, the interrupt vector,
33H will be used for Analog Comparator with the interrupt flag, ACSR.ACF, and IE2 will not be cleared when 33H
interrupt vector is addressed to.
If IE.EAC is disabled, the interrupt vector, 33H, will be used for /INT2 and the interrupt flag, XICON.IE2, that will
be cleared when EX2 is enabled and the interrupt vector is addressed to.
/INT3 and PWM-Timer share the same interrupt vector, 3BH. If CMOD.ECF is enabled, the interrupt vector, 3BH
will be used for PWM-Timer with the interrupt flag, CCON.CF, and IE3 will not be cleared when 3BH interrupt
vector is addressed to.
If CMOD.ECF is disabled, the interrupt vector, 3BH, will be used for /INT3 and the interrupt flag, XICON.IE3, that
will be cleared when EX3 is enabled and the interrupt vector is addressed to.
All of the bits that generate interrupts can be set or cleared by software, with the same result as though it had
been set or cleared by hardware. In other words, interrupts can be generated or pending interrupts can be
canceled in software.
How hardware see the interrupts
Each interrupt flag is sampled at S5P2 of every machine cycle. The samples are polled during the next S5P2. If
one of the flags was in a set condition at S5P2 of the first cycle, the second cycle(polling cycle) will find it and the
interrupt system will generate an hardware LCALL to the appropriate service routine as long as it is not blocked
by any of the following conditions.
Block conditions:
z
z
z
An interrupt of equal or higher priority level is already in progress.
The current cycle (polling cycle) is not the final cycle in the execution of the instruction in progress.
The instruction in progress is RETI or any write to the IE, IP or IPH registers.
Any of these three conditions will block the generation of the hardware LCALL to the interrupt service routine.
Condition 2 ensures that the instruction in progress will be completed before vectoring into any service routine.
Condition 3 ensures that if the instruction in progress is RETI or any access to IE or IP, then at least one or more
instruction will be executed before any interrupt is vectored to.
The polling cycle is repeated with each machine cycle, and the values polled are the values that were present at
S5P2 of the previous machine cycle. Note that if an interrupt flag is active but not being responded to for one of
the above conditions, if the flag is not still active when the blocking condition is removed, the denied interrupt will
not be serviced. In other words, the interrupt flag was once active but not being responded to for one of the
above conditions, if the flag is not still active when the blocking condition is removed, the denied interrupt will not
be serviced. The interrupt flag was once active but not serviced is not kept in memory. Each polling cycle is new.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
22/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary Ver 1.00
MAKE YOU WIN
10.
Timers/Counters
MG87FE/L2051/4051/6051 has two Timers/Counters: Timer 0 and Timer 1. All of them can be configured as
timers or event counters.
In the “timer” function, the register is incremented every machine cycle. In other words, it is to count the machine
cycle. Due to 12(6) oscillator periods in a machine cycle, the count rate is 1/12(1/6) of the oscillator frequency.
In the “counter” function, the register is incremented in response to a 1-to-0 transition at its corresponding
external input pin, T0 or T1. In this function, the external input is sampled during S5P2 of every machine cycle.
When the samples show a high in one cycle and a low in the next cycle, the count is incremented. The new count
value appears in the register during S3P1 of the cycle following the one in which the transition was detected.
10.1. Timer0 and Timer1
10.1.1. Mode 0 Structure
The timer register is configured as a 13-bit register. As the count rolls over from all 1s to all 0s, it sets the timer
interrupt flag TFx. The counted input is enabled to the timer when TRx = 1 and either GATE=0 or INTx = 1. Mode
0 operation is the same for Timer0 and Timer1.
SYSCLK
12
C//T=0
TLx[4:0]
THx[7:0]
Overflow
TFx
Interrupt
C//T=1
Tx Pin
TRx
x = 0 or 1
GATE
/INTx Pin
10.1.2. Mode 1 Structure
Mode1 is the same as Mode0, except that the timer register is being run with all 16 bits.
SYSCLK
12
C//T=0
TLx[7:0]
Tx Pin
THx[7:0]
Overflow
TFx
Interrupt
C//T=1
TRx
GATE
/INTx Pin
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
23/56
x = 0 or 1
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary, v 1.03
MAKE YOU WIN
10.1.3. Mode 2 Structure
Mode 2 configures the timer register as an 8-bit counter(TLx) with automatic reload. Overflow from TLx not only
set TFx, but also reload TLx with the content of THx, which is determined by software. The reload leaves THx
unchanged. Mode 2 operation is the same for Timer0 and Timer1.
SYSCLK
12
C//T=0
TLx[7:0]
Tx Pin
Overflow
TFx
Interrupt
C//T=1
Reload
TRx
GATE
THx[7:0]
x = 0 or 1
/INTx Pin
10.1.4. Mode 3 Structure
Timer1 in Mode3 simply holds its count, the effect is the same as setting TR1 = 1. Timer0 in Mode 3 enables TL0
and TH0 as two separate 8-bit counters. TL0 uses the Timer0 control bits such like C/T, GATE, TR0, INT0 and
TF0. TH0 is locked into a timer function (can not be external event counter) and take over the use of TR1, TF1
from Timer1. TH0 now controls the Timer1 interrupt.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
24/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary Ver 1.00
MAKE YOU WIN
10.1.5. Timer0/1 Register
TMOD: Timer/Counter Mode Control Register
Address=89H, read/write, Power On + RESET=0000-0000
7
6
5
4
3
2
1
0
GATE
C/T
M1
M0
GATE
C/T
M1
M0
|Å----------------------- Timer1 -------------------------Æ|Å--------------------------Timer0 ------------------------Æ|
Bit 7/3: Gate, Gating control for Timer1/0.
0: Disable gating control for Timer1/0.
1: Enable gating control for Timer1/0. When set, Timer1/0 or Counter1/0 is enabled only when /INT1 or /INT0 pin
is high and TR1 or TR0 control bit is set.
Bit 6/2: C/T, Timer for Counter function selector.
0: Clear for Timer operation, input from internal system clock.
1: Set for Counter operation, input form T1 input pin.
Bit 5~4/1~0: Operating mode selection.
M1
M0
Operating Mode
0
0
13-bit timer/counter for Timer0 and Timer1
0
1
16-bit timer/counter for Timer0 and Timer1
1
0
8-bit timer/counter with automatic reload for Timer0 and Timer1
1
1 (Timer0) TL0 is 8-bit timer/counter, TH0 is locked into 8-bit timer
1
1 (Timer1) Timer/Counter1 Stopped
TCON: Timer/Counter Control Register
Address=88H, read/write, Power On + RESET=0000-0000
7
6
5
4
3
TF1
TR1
TF0
TR0
IE1
2
IT1
1
IE0
0
IT0
Bit 7: TF1, Timer 1 overflow flag.
0: Cleared by hardware when the processor vectors to the interrupt routine, or cleared by software.
1: Set by hardware on Timer/Counter 1 overflow, or set by software.
Bit 6: TR1, Timer 1 Run control bit.
0: Cleared by software to turn Timer/Counter 1 off.
1: Set by software to turn Timer/Counter 1 on.
Bit 5: TF0, Timer 0 overflow flag.
0: Cleared by hardware when the processor vectors to the interrupt routine, or cleared by software.
1: Set by hardware on Timer/Counter 0 overflow, or set by software.
Bit 4: TR0, Timer 0 Run control bit.
0: Cleared by software to turn Timer/Counter 0 off.
1: Set by software to turn Timer/Counter 0 on.
Bit 3: IE1, Interrupt 1 Edge flag.
0: Cleared when interrupt processed on if transition-activated.
1: Set by hardware when external interrupt 1 edge is detected (transmitted or level-activated).
Bit 2: IT1: Interrupt 1 Type control bit.
0: Cleared by software to specify low level triggered external interrupt 1.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
25/56
MEGAWIN
MG87FE/L2051/4051/6051
MAKE YOU WIN
Preliminary, v 1.03
1: Set by software to specify falling edge triggered external interrupt 1.
Bit 1: IE0, Interrupt 0 Edge flag.
0: Cleared when interrupt processed on if transition-activated.
1: Set by hardware when external interrupt 0 edge is detected (transmitted or level-activated).
Bit 0: IT0: Interrupt 0 Type control bit.
0: Cleared by software to specify low level triggered external interrupt 0.
1: Set by software to specify falling edge triggered external interrupt 0.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
26/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary Ver 1.00
MAKE YOU WIN
10.2. PWM-Timer
An 8-bits timer that special designed for PWM generator.
10.2.1. PWM-Timer Structure
CCAP0H
CCAP0L
PWMEN
System Clock
Toggle
Pre-Scaler
/1
/2
/4
/8
/16
/32
/64
/128
CL
PWM out
Toggle P1.0~P1.7
8-bit
Down Counter
IDLE
CIDL
POS2
POS1
POS0
CPS2
CPS1
CPS0
ECF
CMOD
CF
CR
CCON
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
27/56
INT3
interrupt
vector
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary, v 1.03
MAKE YOU WIN
10.2.2. PWM-Timer Register
CMOD: PWM-timer Mode Register
Address=D9H, read/write, Power On + RESET=0000-0000
7
6
5
4
3
CIDL
POS2
POS1
POS0
CPS2
2
CPS1
Bit 7: CIDL, Counter Idle Control.
0: Program the PWM-Timer to continue functioning during IDLE mode.
1: Program the PWM-Timer to be gated off during IDLE mode.
Bit 6~4: POS[2:0], PWM output port select.
POS[2:0]
0 0 0
0 0 1
0 1 0
0 1 1
1 0 0
1 0 1
1 1 0
1 1 1
X X X
PWMEN
1
1
1
1
1
1
1
1
0
PWM Output Port
P1.0
P1.1
P1.2
P1.3
P1.4
P1.5
P1.6
P1.7
Disabled
Bit 3~1: CPS[2:0], Counter Pre-scalar Select.
CPS[2:0]
0 0 0
0 0 1
0 1 0
0 1 1
1 0 0
1 0 1
1 1 0
1 1 1
Pre-scalar
1
2
4
8
16
32
64
128
Bit 0: ECF, Enable PWM-Timer underflow interrupt.
0: Disables CF bit in CCON to generate an interrupt.
1: Enables CF bit in CCON to generate an interrupt.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
28/56
1
CPS0
0
ECF
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary Ver 1.00
MAKE YOU WIN
CCON: PWM-timer Control Register
Address=D8H, read/write, Power On + RESET=00XX-XXXX
7
6
5
4
3
CF
CR
-
2
-
1
-
0
-
Bit 7: CF, PWM-timer underflow Flag.
0: This flag can only be cleared by software.
1: Set by hardware when the counter rolls under. CF flags an interrupt if bit ECF in CMOD is set. CF may be set
by either hardware or software.
Bit 6: CR, PWM-timer Run control bit.
0: Must be cleared by software to turn the PWM-Timer counter off.
1: Set by software to turn the PWM-Timer counter on.
Bit 5~0: Reserved.
CACP0L: PWM-Timer L-Duty Register
Address=EAH, read/write, Power On + RESET=0000-0000
7
6
5
4
3
-
2
-
1
-
0
-
CACP0H: PWM-Timer H-Duty Register
Address=FAH, read/write, Power On + RESET=0000-0000
7
6
5
4
3
-
2
-
1
-
0
-
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
29/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary, v 1.03
MAKE YOU WIN
11.
UART
The serial port(UART) of MG87FE/L2051/4051/6051 support full-duplex transmission. It can transmit and receive
simultaneously. The serial port receive and transmit share the same SFR – SBUF, but actually there is two
SBUFs in the chip, one is for transmit and the other is for receive. The serial port can be operated in 4 different
modes.
11.1. UART Structure
Mode 0
Serial data enters and exits through RXD(P3.0) and TXD(P3.1) outputs the shift clock. 8-bits are
transmitted/received with LSB first. The baud rate is fixed at 1/12 the system clock frequency.
FSYSCLK
12
Baud Rate in Mode 0 =
Mode1
10 bits are transmitted through TXD or received through RXD. The frame data includes a start bit(0), 8 data bits
and a stop bit(1). One receive, the stop bit goes into RB8 in SFR – SCON. The baud rate is variable.
Baud Rate in Mode 1 =
2SMOD
32
X (timer1 overflow rate)
Mode2
11 bits are transmitted through TXD or received through RXD. The frame data includes a start bit(0), 8 data bits, a
programmable 9th bit and a stop bit(1). On transmit, the 9th data bit comes from TB8 in SCON. On receive, the
9th data bit goes into RB8 in SCON. The baud rate is programmable to either 1/32 or 1/64 the system clock
frequency.
Mode3
Mode 3 is the same as mode 2 except the baud rate is variable.
Baud Rate in Mode 3 =
2SMOD
32
X (timer1 overflow rate)
In all four modes, transmission is initiated by any instruction that use SBUF as a destination register. Reception is
initiated in mode 0 by the condition RI = 0 and REN = 1. Reception is initiated in the other modes by the incoming
start bit with 1-to-0 transition if REN=1.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
30/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary Ver 1.00
MAKE YOU WIN
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 comparison circuit. This feature improves the overhead of software by eliminating
the need in examine every incoming address. This feature is enabled by setting the SM2 bit in SCON. In mode2
and mode3, the receive interrupt flag(RI) will be automatically set when the received byte contains either the
“Given” address or the “Broadcast” address. These two modes require the 9th received bit is a 1 to indicate that
received information is an address and not the data byte.
In mode1, the RI flag will be set if SM2 is enabled and a valid stop bit is received which the stop bit follows the 8
address bits and the information is either a given or Broadcast address.
In mode 0, SM2 is ignored.
Framing Error Detection
Framing Error Detection allows the serial port to check for valid stop bits in modes 1, 2, or3. A missing stop bit
can be caused, for example, by noise on the serial lines, or transmission by two CPUs simultaneously.
If a stop bit is missing, a Framing Error bit FE is set. The FE bit can be checked in software after each reception
to detect communication errors. Once set, the FE bit must be cleared in software. A valid stop bit will not clear
FE.
The FE bit is located in SCON and shares the same bit address as SM0. Control bit SMOD0 in the PCON
register (location PCON.6) determines whether the SM0 or FE bit is accessed. If SMOD0 = 0, then accesses to
SCON.7 are to SM0. IF SMOD0 = 1, then accesses to SCON.7 are to FE.
11.2. UART Register
SCON: Serial port Control Register
Address=98H, read/write, Power On + RESET=0000-0000
7
6
5
4
3
SM0/FE
SM1
SM2
REN
TB8
2
RB8
1
TI
0
RI
Bit 7: FE, Framing Error bit. The SMOD0 bit must be set to enable access to the FE bit.
0: The FE bit is not cleared by valid frames but should be cleared by software.
1: This bit is set by the receiver when an invalid stop bit is detected.
Bit 7: Serial port mode bit 0, (SMOD0 must = 0 to access bit SM0)
Bit 6: Serial port mode bit 1.
SM0
0
0
1
1
SM1
0
1
0
1
Mode
0
1
2
3
Description
shift register
8-bit UART
9-bit UART
9-bit UART
Baud Rate
FSYSCLK/12
variable
FSYSCLK /64 or FSYSCLK /32
variable
Bit 5: Serial port mode bit 2.
0: Disable SM2 function.
1: Enable the automatic address recognition feature in Modes 2 and 3. If SM2=1, RI will not be set unless the
received 9th data bit is 1, indicating an address, and the received byte is a Given or Broadcast address. In
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
31/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary, v 1.03
MAKE YOU WIN
mode1, if SM2=1 then RI will not be set unless a valid stop Bit was received, and the received byte is a Given
or Broadcast address. In Mode 0, SM2 should be 0.
Bit 4: REN, Enable serial reception.
0: Clear by software to disable reception.
1: Set by software to enable reception.
Bit 3: TB8, The 9th data bit that will be transmitted in Modes 2 and 3. Set or clear by software as desired.
Bit 2: RB8, In Modes 2 and 3, the 9th data bit that was received. In Mode 1, if SM2 = 0, RB8 is the stop bit that
was received. In Mode 0, RB8 is not used.
Bit 1: TI. Transmit interrupt flag.
0: Must be cleared by software.
1: Set by hardware at the end of the 8th bit time in Mode 0, or at the beginning of the stop bit in the other modes,
in any serial transmission.
Bit 0: RI. Receive interrupt flag.
0: Must be cleared by software.
1: Set by hardware at the end of the 8th bit time in Mode 0, or halfway through the stop bit time in the other modes,
in any serial reception (except see SM2).
SBUF: Serial Buffer Register
Address=99H, read/write, Power On + RESET=XXXX-XXXX
7
6
5
4
3
2
1
0
Bit 7~0: It is used as the buffer register in transmission and reception.
SADDR: Slave Address Register
Address=A9H, read/write, Power On + RESET=0000-0000
7
6
5
4
3
2
1
0
SCON: Slave Address Mask Register
Address=B9H, read/write, Power On + RESET=0000-0000
7
6
5
4
3
2
1
0
SADDR register is combined with SADEN register to form Given/Broadcast Address for automatic address
recognition. In fact, SADEN functions as the “mask” register for SADDR register. The following is the example for
it.
SADDR =
SADEN =
Given
=
1100 0000
1111 1101
1100 00x0
The Given slave address will be checked except
bit 1 is treated as “don’t care”
The Broadcast Address for each slave is created by taking the logical OR of SADDR and SADEN. Zero in this
result is considered as “don’t care”. Upon reset, SADDR and SADEN are loaded with all 0s. This produces a
Given Address of all “don’t care” and a Broadcast Address of all “don’t care”. This disables the automatic address
detection feature.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
32/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary Ver 1.00
MAKE YOU WIN
12.
Analog Comparator
A single analog comparator is provided in the MG87FE/L2051/4051/6051. The comparator operation is such that
the output is a logical “HIGH” when the positive input AIN0 (P1.0]) is greater than the negative input AIN1 (P1.1).
Otherwise the output is “LOW”. Setting the ACEN bit in ACSR enables the comparator. When the comparator is
first enabled, the comparator output and interrupt flag are not guaranteed to be stable for 10 microseconds. The
corresponding comparator interrupt should not be enabled during that time, and the comparator interrupt flag
must be cleared before the interrupt is enabled in order to prevent an immediate interrupt service.
The comparator may be configured to cause an interrupt under a variety of output value conditions by setting the
ACM bits in ACSR. The comparator interrupt flag ACF in ACSR is set whenever the comparator output matches
the condition specified by ACM. The flag may be polled by firmware or may be used to generate an interrupt and
must be cleared by firmware. The analog comparator is always disabled during Idle or Power-down modes.
12.1. Analog Comparator Structure
To CPU read P3.6
P1.0 (AIN0)
P1.1 (AIN1)
+
-
Timer 1 Overflow
CF
Start
Compare
Start
Compare
Comparator Interrupt detecting logic,
example of negative edge comparator interrupt with debounce
Comparator Structure
The comparator output is sampled at every State 4 (S4) of every machine cycle. The conditions on the analog
inputs may be such that the comparator output will toggle excessively. This is especially true if applying slow
moving analog inputs. Three de-bouncing modes are provided to filter out this noise. In de-bouncing mode, the
comparator uses Timer-1 to modulate its sampling time. When a relevant transition occurs, the comparator waits
until two Timer-1 overflows have occurred before re-sampling the output. If the new sample agrees with the
expected value, ACF is set. Otherwise, the event is ignored. The filter may be tuned by adjusting the timeout
period of Timer-1. Because Timer-1 is free running, the de-bouncer must wait for two overflows to guarantee that
the sampling delay is at least 1 timeout period. Therefore, after the initial edge event, the interrupt may occur
between 1 and 2 timeout periods later.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
33/56
MEGAWIN
MG87FE/L2051/4051/6051
Preliminary, v 1.03
MAKE YOU WIN
12.2. Analog Comparator Register
ACSR: Analog Comparator Control & Status Register
Address=97H, read/write, Power On + RESET=0xx0-0000
7
6
5
4
3
ACIDX
ACF
ACEN
2
ACM2
1
ACM1
0
ACM0
Bit 7: ACIDX, Analog Comparator IDLE control.
0: Program the Analog Comparator to be gated off during IDLE mode.
1: Program the Analog Comparator to continue functioning during IDLE mode.
Bit 6~5: Reserved.
Bit 4: ACF. Analog Comparator Interrupt Flag.
0: The flag must be cleared by software.
1: Set when the comparator output meets the conditions specified by the ACM [2:0] bits and ACEN is set. The
interrupt may be enabled/disabled by setting/clearing bit 6 of IE.
Bit 3: ACEN. Analog Comparator Enable.
0: Clearing this bit will force the comparator output low and prevent further events from setting ACF.
1: Set this bit to enable the comparator.
Bit 2~0: ACM2 ~ ACM1, Analog Comparator Interrupt Mode.
ACM[2:0]
0 0 0
0 0 1
0 1 0
0 1 1
1 0 0
1 0 1
1 1 0
1 1 1
Interrupt Mode
Negative (Low) level
Positive edge
Toggle with de-bounce
Positive edge with de-bounce
Negative edge
Toggle
Negative edge with de-bounce
Positive (High) level
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
34/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary Ver 1.00
MAKE YOU WIN
13.
Watch Dog Timer (WDT)
13.1. WDT Structure
1/256
1/128
1/64
1/32
1/16
1/8
1/4
1/2
8-bit prescalar
15-bit timer
Fosc
IDLE
WRF
-
ENW
CLRW
WIDL
PS2
PS1
PS0
WDTCR Register
13.2. WDT Register
WDTCR: Watch-Dog-Timer Control Register
Address=E1H, read/write, Power On + Reset =0x00-0000
7
6
5
4
3
WRF
ENW
CLRW
WIDL
Bit 7: WRF, WDT reset flag.
0: This bit should be cleared by software.
1: When WDT overflows, this bit is set by hardware.
Bit 6: Reserved.
Bit 5: ENW. Enable WDT.
0: ENW can not be cleared by software.
1: Enable WDT while it is set.
Bit 4: CLRW. Clear WDT counter.
0: Hardware will automatically clear this bit.
1: Clear WDT to recount while it is set.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
35/56
2
PS2
1
PS1
0
PS0
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary, v 1.03
MAKE YOU WIN
Bit 3: WIDL. WDT idle control.
0: WDT stops counting while the MCU is in idle mode.
1: WDT keeps counting while the MCU is in idle mode.
Bit 2~0: PS2 ~ PS0, select pre-scalar output for WDT time base input.
PS[2:0]
0 0 0
0 0 1
0 1 0
0 1 1
1 0 0
1 0 1
1 1 0
1 1 1
Pre-scalar Value
2
4
8
16
32
64
128
256
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
36/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary Ver 1.00
MAKE YOU WIN
14.
Reset
During reset, all I/O Registers are set to their initial values, the port pins are weakly pulled to VDD, and the
program starts execution from the Reset Vector, 0000H, or ISP start address by OR setting. MG87FE/
L2051/4051/6051 all have four sources of reset: external reset, power-on reset, WDT reset, and software reset.
14.1. Reset Source
External Reset
POR
Internal Reset
WDT Reset
Software Reset
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
37/56
MEGAWIN
MG87FE/L2051/4051/6051
MAKE YOU WIN
15.
Preliminary, v 1.03
Power Management
MG87FE/L2051/4051/6051 supports two power-reducing modes: Idle and Power-down mode. These two modes
are accessed through the PCON register.
15.1. Power Saving Mode
15.1.1. Idle Mode
Setting the IDL bit in PCON enters idle mode. Idle mode halts the internal CPU clock. The CPU state is preserved
in its entirety, including the RAM, stack pointer, program counter, program status word, and accumulator. The
Port pins hold the logical states they had at the time that Idle was activated. Idle mode leaves the peripherals
running in order to allow them to wake up the CPU when an interrupt is generated. Timer 0, Timer 1, PWM-Timer
and the UART will continue to function during Idle-mode. The analog comparator is disabled during Idle. Any
enabled interrupt source or reset may terminate Idle-mode. When exiting Idle-mode with an interrupt, the
interrupt will immediately be serviced, and following RETI, the next instruction to be executed will be the one
following the instruction that put the device into Idle.
P1.0 and P1.1 should be set to “0” if no external pull-ups are used, or set to “1” if external pull-ups are used, or
set to “1” if AUXR.P10PU&P11PU are enabled.
15.1.2. Power-down Mode
Setting the PD bit in PCON enters Power-down mode. Power-down mode stops the oscillator and powers down
the Flash memory in order to minimize power consumption. Only the power-on circuitry will continue to draw
power during Power-down. During Power-down the power supply voltage may be reduced to the RAM keep-alive
voltage. The RAM contents will be retained; however, the SFR contents are not guaranteed once VDD has been
reduced. Power-down may be exited by external reset, power-on reset, enabled external interrupts, or enabled
wake-up GPIOs.
The user should not attempt to enter (or re-enter) the power-down mode for a minimum of 4 μs until after one of
the following conditions has occurred: Start of code execution (after any type of reset), or exit from power-down
mode.
15.1.3. Interrupt Recovery from Power-down
Four external interrupts may be configured to terminate Power-down mode. External interrupts /INT0 (P3.2),
/INT1 (P3.3), /INT2 (P4.3) and /INT2 (P4.2) may be used to exit Power-down. To wake up by external interrupt
/INT0, /INT1, /INT2, or /INT3, the interrupt must be enabled and configured for level-sensitive operation.
If the interrupt vector of /INT2 (P4.3) is occupied by Analog Comparator, low level P4.3 input still have wake-up
capability when /INT2 interrupt enable, XICON.EX2, is set (enabled). If the interrupt vector of /INT3 (P4.2) is
occupied by PWM-Timer underflow, low level P4.2 input still have wake-up capability when /INT3 interrupt enable,
XICON.EX3, is set (enabled).
When terminating Power-down by an interrupt, two different wake-up modes are available. When PWDEX in
CKCON3.2 is zero, the wake up period is internally timed. At the falling edge on the interrupt pin, Power-down is
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
38/56
MEGAWIN
MG87FE/L2051/4051/6051
MAKE YOU WIN
Preliminary Ver 1.00
exited, the oscillator is restarted, and an internal timer begins counting. The internal clock will not be allowed to
propagate and the CPU will not resume execution until after the timer has reached internal counter full. After the
timeout period, the interrupt service routine will begin. To prevent the interrupt from re-triggering, the ISR should
disable the interrupt before returning. The interrupt pin should be held low until the device has timed out and
begun executing.
When PWDEX = 1 the wake-up period is controlled externally by the interrupt. Again, at the falling edge on the
interrupt pin, Power-down is exited and the oscillator is restarted. However, the internal clock will not propagate
and CPU will not resume execution until the rising edge of the interrupt pin. After the rising edge on the pin, the
interrupt service routine will begin. The interrupt should be held low long enough for the oscillator to stabilize.
15.1.4. Reset Recovery from Power-down
Wake-up from Power-down through an external reset is similar to the interrupt with PWDEX = 0. At the rising
edge of RST, Power-down is exited, the oscillator is restarted, and an internal timer begins counting. The internal
clock will not be allowed to propagate to the CPU until after the timer has reached internal counter full. The RST
pin must be held high for longer than the timeout period to ensure that the device is reset properly. The device will
begin executing once RST is brought low.
It should be noted that when idle is terminated by a hardware reset, the device normally resumes program
execution, from where it left off, up to two machine cycles before the internal reset algorithm takes control.
On-chip hardware inhibits access to internal RAM in this event, but access to the port pins is not inhibited. To
eliminate the possibility of an unexpected write to a port pin when Idle is terminated by reset, the instruction
following the one that invokes Idle should not be one that writes to a port pin or to external memory.
15.1.5. GPIO wake-up Recovery from Power-down
The GPIOs of MG87FE/L2051/4051/6051, P1.7 ~ P1.0 and P3.0 ~ P3.5, P3.7 have wake-up CPU capability that
are enabled by individual control bit in P1WKPE and P3WKPE. If the interrupt is disabled on P3.2/INT0 or
P3.3/INT1, P3.2 and P3.3 still have the wake-up function from the P3WKPE control. But P4.2/INT3 and
P4.3/INT2 can wake-up CPU only when the respective interrupt is enabled.
Wake-up from Power-down through an enabled wake-up GPIO is similar to the interrupt with PWDEX = 0. At the
falling edge of enabled wake-up GPIO, Power-down is exited, the oscillator is restarted, and an internal timer
begins counting. The internal clock will not be allowed to propagate to the CPU until after the timer has reached
internal counter full. After the timeout period, there is no any interrupt and CPU will execute the following
command after last power-down instruction. That is, the enabled wake-up GPIOs will only have the capability to
wake-up CPU without any interrupt function.
15.2. Power Control Register
PCON: Power Control Register
Address=87H, read/write, Power On + RESET =0001-0000, RESET=000x-0000
7
6
5
4
3
2
1
SMOD
SMOD0
PWMEN
POF
GF1
GF0
PD
Bit 7: SMOD, double Baud rate control bit.
0: Disable double Baud rate of the UART.
1: Enable double Baud rate of the UART in mode 1, 2, or 3.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
39/56
0
IDL
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary, v 1.03
MAKE YOU WIN
Bit 6: SMOD0, Frame Error select.
0: SCON.7 is SM0 function.
1: SCON.7 is FE function. Note that FE will be set after a frame error regardless of the state of SMOD0.
Bit 5: PWMEN, PWM mode enable for PWM-Timer.
0: Set the PWM-Timer as Timer mode.
1: Set the PWM-Timer as PWM mode and trigger the output on P1.0 ~ P1.7 by POS[2:0] indexed.
Bit 4: POF. Power-On Flag.
0: The flag must be cleared by software.
1: POF is set to “1” during power up (i.e. cold reset). It can be set under software control and is not affected by
RESEST (i.e. warm resets).
Bit 3~2: GF1, GF0, General purpose flags.
Bit 1: PD, Power-Down control bit.
0: This bit could be cleared by CPU or any exited power-down event.
1: Setting this bit activates power down operation.
Bit 0: IDL, Idle mode control bit.
0: This bit could be cleared by CPU or any exited Idle mode event.
1: Setting this bit activates idle mode operation.
P1WKPE: Port 1 Wake-up Enable Control Register
Address=D7H, read/write, RESET=0000-0000
7
6
5
4
3
P17WKP
P16WKP
P15WKP P14WKP P13WKP
2
P12WKP
1
P11WKP
0
P10WKP
Bit 7~0: Wake-up enable bit for each P1 pins.
0: Disable port pin wake-up function.
1: Enable port pin wake-up function when port input at falling edge in power-down mode and idle mode.
P1WKPE: Port 3 Wake-up Enable Control Register
Address=D6H, read/write, RESET=0000-0000
7
6
5
4
3
P37WKP
P35WKP P34WKP P33WKP
2
P32WKP
1
P31WKP
0
P30WKP
Bit 7, 5~0: Wake-up enable bit for each P3 pins except P3.6.
0: Disable port pin wake-up function.
1: Enable port pin wake-up function when port input at falling edge in power-down mode and idle mode.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
40/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary Ver 1.00
MAKE YOU WIN
16.
System Clock
16.1. Clock Structure
16.2. Clock Register
CKCON: Clock Control Register
Address=C7H, read/write, RESET=xxxx-x000
7
6
5
4
-
3
-
2
SCKS2
1
SCKS1
0
SCKS0
1
XCKS1
0
XCKS0
Bit 7~3: Reserved.
Bit 2~0: SCKS2 ~ SCKS0, programmable System Clock Selection.
SCKS[2:0]
0 0 0
0 0 1
0 1 0
0 1 1
1 0 0
1 0 1
1 1 0
1 1 1
System Clock (FSYSCLK)
CLKin
CLKin /2
CLKin /4
CLKin /8
CLKin /16
CLKin /32
CLKin /64
CLKin /128
CKCON2: Clock Control Register 2
Address=BFH, read/write, RESET=xx00-1010
7
6
5
4
OSCDR
EN6TR
XCKS5
XCKS4
3
XCKS3
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
41/56
2
XCKS2
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary, v 1.03
MAKE YOU WIN
Bit 7: OSCDR, OSC Driving control Register. Default value is load from OR1.b4 inverted value. And it could be
read/written by CPU.
0: The driving of crystal oscillator is enough for oscillation up to 48MHz.
1: The driving of crystal oscillator is reduced. It will helpful in EMI reduction. Regarding application not needing
high frequency clock, it is recommended to do so.
Bit 6: EN6TR, Enable 6T mode control register. Default value is load from OR1.b0 inverted value. And it could be
read/written by CPU. The access on this bit will affect CKCON3.EN6TR to corresponding operation and
get same control function.
0: MG87FE/L2051/4051/6051 will run in 12T mode.
1: MG87FE/L2051/4051/6051 will run in 6T mode.
Bit 5~0: This is set the crystal frequency value to define the time base of ISP/IAP programming. Fill with a proper
value according to OSCin, as listed below.
[XCKS5~XCKS0] = OSCin – 1, where OSCin=1~48 (MHz) in 12T mode.
[XCKS5~XCKS0] = OSCinX2 – 1, where OSCin=0.5~24 (MHz) in 6T mode.
For a 12T examples,
(1) If OSCin=12MHz, then fill [XCKS4~XCKS0] with 11, i.e., 001011B.
(2) If OSCin=6MHz, then fill [XCKS4~XCKS0] with 5, i.e., 000101B.
OSCin @ 12T
1MHz
2MHz
3MHz
4MHz
……
45MHz
46MHz
47MHz
48MHz
OSCin @ 6T
0.5MHz
1MHz
1.5MHz
2MHz
……
22.5MHz
23MHz
23.5MHz
24MHz
XCKS Setting
6’b000000
6’b000001
6’b000010
6’b000011
……
6’b101100
6’b101101
6’b101110
6’b101111
The default value of XCKS= 6’b001010 for OSCin= 11MHz at 12T mode.
CKCON3: Clock Control Register 3
Address=8FH, read/write, por+RESET=xxxx-xx0x
7
6
5
4
-
3
-
2
-
1
PWDEX
0
EN6TR
Bit 7~2: Reserved.
Bit 1: PWDEX, Power-down Exit Mode.
0: wake up from Power-down is internally timed.
1: wake up from Power-down is externally controlled.
Bit 0: EN6TR, Enable 6T mode control register. Default value is load from OR1.b0 inverted value. And it could be
read/written by CPU. The access on this bit will affect CKCON2.EN6TR to corresponding operation and
get same control function.
0: MG87FE/L2051/4051/6051 will run in 12T mode.
1: MG87FE/L2051/4051/6051 will run in 6T mode.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
42/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary Ver 1.00
MAKE YOU WIN
17.
In System Programming (ISP)
IFD: ISP/IAP Flash Data Register
Address=E2H, read/write, RESET=1111-1111
7
6
5
4
3
2
1
0
Data
IFD is the data port register for ISP/IAP operation. The data in IFD will be written into the desired address in
operating ISP/IAP write and it is the data window of readout in operating ISP/IAP read.
If IMFT is indexed on IAPLB access, read/write IFD through SCMD flow will access the register content of IAPLB.
IFADRH: ISP/IAP Address for High-byte addressing
Address=E3H, read/write, Power On + RESET=0000-0000
7
6
5
4
3
Address
2
1
0
2
1
0
IFADRH is the high-byte address port for all ISP/IAP modes.
IFADRL: ISP/IAP Address for Low-byte addressing
Address=E4H, read/write, Power On + RESET=0000-0000
7
6
5
4
3
Address
IFADRL is the low byte address port for all ISP/IAP modes. In page erase operation, it is ignored.
IFMT: ISP/IAP Flash Mode Table
Address=E5H, read/write, Power On + RESET=XXXX-0000
7
6
5
4
3
Reserved
2
1
Mode Selection
0
Bit 7~4: Reserved
Bit 3~0: ISP/IAP operating mode selection
Bit[3:0]
0
0
0
0
Standby
0
0
0
1
AP-memory read
0
0
1
0
AP-memory program
0
0
1
1
AP-memory page erase
0
1
0
0
IAPLB write
0
1
0
1
IAPLB read
Mode
IFMT is used to select the flash mode for performing numerous ISP/IAP function.
IAPLB: IAP Low Boundary
Address=indirect, read/write, Power On + RESET=1111-1111
7
6
5
4
3
IAPLB
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
43/56
2
1
0
MEGAWIN
MG87FE/L2051/4051/6051
Preliminary, v 1.03
MAKE YOU WIN
Bit 7~0: The IAPLB determines the IAP-memory lower boundary. Since a Flash page has 512 bytes, the IAPLB
must be an even number.
To read IAPLB, MCU need to define the IMFT for mode selection on IAPLB Read and set ISPCR.ISPEN. And
then write 0x46h & 0xB9h sequentially into SCMD. The IAPLB content is available in IFD. If write IAPLB, MCU
will put new IAPLB setting value in IFD firstly. And then select IMFT, enable ISPCR.ISPEN and then set SCMD.
The IAPLB content has already finished the updated sequence.
The range of the IAP-memory is determined by IAPLB and the ISP start address as listed below.
IAP lower boundary = IAPLBx256, and
IAP higher boundary = ISP start address – 1.
For example, if IAPLB=0x12 and ISP start address is 0x1C00, then the IAP-memory range is located at 0x1200 ~
0x1BFF.
Additional attention point, the IAP low boundary address must not be higher than ISP start address.
SCMD: Sequential Command Data register / RDID (Read DID register)
Address=E6H, read/write, Power On + RESET=xxxx-xxxx
7
6
5
4
3
2
SCMD
1
0
SCMD is the command port for triggering ISP/IAP/IAPLB activity. If SCMD is filled with sequential 0x46h, 0xB9h
and if ISPCR.7 = 1, ISP/IAP activity will be triggered.
ISPCR: ISP Control Register
Address=E5H, read/write, Power On + RESET= 0000-xxxx
7
6
5
4
3
ISPEN
SWBS
SWRST
CFAIL
-
2
1
0
Bit 7: ISPEN, ISP/IAP operation enable.
0: Global disable all ISP/IAP program/erase/read function.
1: Enable ISP/IAP program/erase/read function.
Bit 6: SWBS, software boot selection control.
0: Boot from main-memory after reset.
1: Boot from ISP memory after reset.
Bit 5: SWRST, software reset trigger control.
0: No operation
1: Generate software system reset. It will be cleared by hardware automatically.
Bit 4: CFAIL, Command Fail indication for ISP/IAP operation.
0: The last ISP/IAP command has finished successfully.
1: The last ISP/IAP command fails. It could be caused since the access of flash memory was inhibited.
Bit 3~0 : Reserved.
MG87FE/L2051/4051/6051 does not make use of idle-mode to perform ISP operation. Instead, it creates CPU
wait-state to release flash memory for ISP control circuit use. Once ISP run over, CPU will be waken-up and
advanced to the instruction which follows the previous instruction that invokes ISP activity. During ISP operation,
interrupt service is also blocked until ISP run over.
ISP control circuit has a built-in timer for timing sequence control. It is referred from OSC frequency and defined
by CKCON2.XCKS[5:0] to get the accuracy erase/program timing.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
44/56
MEGAWIN
MG87FE/L2051/4051/6051
MAKE YOU WIN
18.
Preliminary Ver 1.00
In Application Programming (IAP)
MG87FE/L2051/4051/6051 available program memory size (AP-memory) is restricted to 2K(for 2051), 4K(for
4051), 6K(for 6051). The flash memory between IAPLB and ISP start address could be defined as data flash
memory and can be accessed by the ISP operation in field application. The size of IAP flash memory is variable.
It is defined by IAPLB.
When MG87FE/L2051/4051/6051 boots from AP-memory, it is restricted to have the capability of accessing IAP
data flash memory space only. AP-memory and ISP-memory are protected from abnormal disturbance.
When MG87FE/L2051/4051/6051 boots from ISP-memory, AP-memory and data flash memory(IAP) are opened
for ISP access.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
45/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary, v 1.03
MAKE YOU WIN
19.
Auxiliary SFRs
AUXR: Auxiliary Control Register
Address=8EH, read/write, RESET=0000-0000
7
6
5
4
INT3H
INT2H
P15FS
P14FS
3
P13FS
2
P12FS
1
P11PU
0
P10PU
Bit 7: INT3H, INT3 High/Rising trigger enable.
0: Remain INT3 triggered on low level or falling edge on P4.2.
1: Set INT3 triggered on high level or rising edge on P4.2.
Bit 6: INT2H, INT2 High/Rising trigger enable.
0: Remain INT2 triggered on low level or falling edge on P4.3.
1: Set INT2 triggered on high level or rising edge on P4.3.
Bit 5: P15FS, pin P1.5 function swapped enable.
0: Pin P1.5 and P3.5 reserves original default function.
1: Pin P1.5 function is swapped with P3.5/T1. And Pin P3.5 function is swapped by P1.5.
Bit 4: P14FS, pin P1.4 function swapped enable.
0: Pin P1.4 and P3.4 reserve original default function.
1: Pin P1.4 function is swapped with P3.4/T0. And Pin P3.4 function is swapped by P1.4.
Bit 3: P13FS, pin P1.3 function swapped enable.
0: Pin P1.3 and P4.3 reserve original default function.
1: Pin P1.3 function is swapped with P4.3/INT2. And Pin P4.3 function is swapped by P1.3 if internal OSC is
enabled to release XTAL1 for GPIO function.
Bit 2: P12FS, pin P1.2 function swapped enable.
0: Pin P1.2 and P4.2 reserve original default function.
1: Pin P1.2 function is swapped with P4.2/INT3. And Pin P4.2 function is swapped by P1.2 if internal OSC is
enabled to release XTAL2 for GPIO function.
Bit 1: P11PU, Enable P1.1 pull-up resistor.
0: P1.1 without Pull-Up resistor in open-drain mode.
1: P1.1 with Pull-Up resistor in open-drain mode.
Bit 0: P10PU, Enable P1.0 pull-up resistor.
0: P1.0 without Pull-Up resistor in open-drain mode.
1: P1.0 with Pull-Up resistor in open-drain mode.
P1.1 & P1.0 is high-impedance input and N-MOS output without pull-up resistor in default mode. P11PU &
P10PU in AUXR will enable the pull-up resistor on P1.1/P1.0 individually. If P1.1 & P1.0 are used for GPIO
function, CPU could not drive low without external pull-up resistor in power down mode when P11PU &
P10PU are enabled.
AUXR1: Auxiliary Control Register 1
Address=A2H, read/write, Power On + RESET=0xxx-0xxx
7
6
5
4
3
P14FD
GF2
Bit 7: P14FD, Enable P14 output with fast driving.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
46/56
2
-
1
-
0
MEGAWIN
MAKE YOU WIN
0: P14 has normal driving on output state.
1: Enable P14 output with fast driving.
Bit 6~4: Reserved.
Bit 3: GF2, General purpose Flag 2.
Bit 2~0: Reserved.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
47/56
MG87FE/L2051/4051/6051
Preliminary Ver 1.00
MEGAWIN
MAKE YOU WIN
MG87FE/L2051/4051/6051
Preliminary, v 1.03
20.
Option Setting
LOCK
HWBS
HWBS2
When enabled, dump ROM code function was disabled
When enabled, MCU will boot from ISP-memory if ISP-memory is configured after power up.
When enabled, MCU will boot from ISP-memory if ISP-memory is configured after reset by
RESET pin.
When enabled, the gain of crystal oscillator is reduced. It will helpful in EMI reduction.
Regarding application not needing high frequency clock, it is recommended for system clock
under 40MHz..
When enabled, MCU will run at 6T mode.
OSCDN
EN6T
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
48/56
MEGAWIN
MAKE YOU WIN
21.
MG87FE/L2051/4051/6051
Preliminary Ver 1.00
Absolute Maximum Rating
For MG87FE2051/4051/6051
Parameter
Rating
Unit
Ambient temperature under bias
-55 ~ +125
°C
Storage temperature
-65 ~ + 150
°C
Voltage on any Port I/O Pin or RESET with respect
-0.5 ~ VDD + 0.5
V
to Ground
Voltage on VDD with respect to Ground
-0.5 ~ +6.0
V
Maximum total current through VDD and Ground
400
mA
Maximum output current sunk by any Port pin
40
mA
*Note: stresses above those listed under “Absolute Maximum Ratings” may cause permanent damage to the
device. This is a stress rating only and functional operation of the devices at those or any other conditions
above those indicated in the operation listings of this specification is not implied. Exposure to maximum
rating conditions for extended periods may affect device reliability.
For MG87FL2051/4051/6051
Parameter
Rating
Unit
Ambient temperature under bias
-55 ~ +125
°C
Storage temperature
-65 ~ + 150
°C
Voltage on any Port I/O Pin or RESET with respect
-0.3 ~ VDD + 0.3
V
to Ground
Voltage on VDD with respect to Ground
-0.3 ~ +4.2
V
Maximum total current through VDD and Ground
400
mA
Maximum output current sunk by any Port pin
40
mA
*Note: stresses above those listed under “Absolute Maximum Ratings” may cause permanent damage to the
device. This is a stress rating only and functional operation of the devices at those or any other conditions
above those indicated in the operation listings of this specification is not implied. Exposure to maximum
rating conditions for extended periods may affect device reliability.
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
49/56
MEGAWIN
MAKE YOU WIN
22.
MG87FE/L2051/4051/6051
Preliminary, v 1.03
Electrical Characteristics
22.1.
DC Characteristics
VSS = 0V, TA = 25 ℃, VDD = 5.0V and 12 clocks per machine cycle, unless otherwise specified
Limits
Unit
Symbol
Parameter
Test Condition
min
Typ.
max
VIH1
Input High voltage (Ports 1, 3, 4)
2.0
V
VIH2
Input High voltage (RESET)
3.5
V
VIL1
Input Low voltage (Ports 1, 3, 4)
0.8
V
VIL2
Input Low voltage (RESET)
1.6
V
IIH
Input High Leakage current (Ports 1, 3, 4)
VPIN = VDD
0
10
uA
IIL
Logic 0 input current (Ports 1, 3, 4)
VPIN = 0.4V
20
50
uA
IH2L
Logic 1 to 0 input transition current (Ports 1, VPIN =1.8V
250
500
uA
3, 4)
IOH1
Output High current (Ports 1, 3, 4)
VPIN =2.4V
150
220
uA
IOL1
Output Low current (Ports 1, 3, 4)
VPIN =0.4V
12
mA
mA
IOP
Operating current
FOSC = 12MHz
8
16
10
20
FOSC = 24MHz
mA
IIDLE
Idle mode current
FOSC = 12MHz
4
8
5
10
FOSC = 24MHz
IPD
Power down current
0.1
10
uA
RRST Internal reset pull-down resistance
100
Kohm
VSS = 0V, TA = 25 ℃, VDD = 3.3V and 12 clocks per machine cycle, unless otherwise specified
Limits
Unit
Symbol
Parameter
Test Condition
min
Typ.
max
VIH1
Input High voltage (Ports 1, 3, 4)
2.0
V
VIH2
Input High voltage (RESET)
2.8
V
VIL1
Input Low voltage (Ports 1, 3, 4)
0.8
V
VIL2
Input Low voltage (RESET)
1.5
V
IIH
Input High Leakage current (Ports 1, 3, 4)
VPIN = VDD
0
10
uA
IIL
Logic 0 input current (Ports 1, 3, 4)
VPIN = 0.4V
7
30
uA
IH2L
Logic 1 to 0 input transition current (Ports 1, VPIN =1.8V
100
250
uA
3, 4)
IOH1
Output High current (Ports 1, 3, 4)
VPIN =2.4V
40
70
uA
IOL1
Output Low current (Ports 1, 3, 4)
VPIN =0.4V
8
mA
mA
IOP
Operating current
FOSC = 12MHz
6
12
8
16
FOSC = 24MHz
mA
IIDLE
Idle mode current
FOSC = 12MHz
2
4
2.5
5
FOSC = 24MHz
IPD
Power down current
0.1
50
uA
RRST Internal reset pull-down resistance
200
Kohm
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
50/56
MEGAWIN
MAKE YOU WIN
23.
Package Dimension
PDIP-20
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
51/56
MG87FE/L2051/4051/6051
Preliminary Ver 1.00
MEGAWIN
MAKE YOU WIN
SOP-20
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
52/56
MG87FE/L2051/4051/6051
Preliminary, v 1.03
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary Ver 1.00
MAKE YOU WIN
24.
Instruction Set
MNEMONIC
DESCRIPTION
BYTE
EXECUTION
TIME(MC)
1
2
1
2
1
2
2
2
2
3
2
3
1
2
2
3
1
1
1
1
1
1
2
2
1
2
1
1
1
1
1
1
1
2
1
1
2
2
2
2
1
2
1
2
2
2
2
2
2
2
2
2
1
1
1
1
1
2
1
2
1
2
1
2
1
1
1
1
1
1
1
1
1
1
DATA TRASFER
MOV A,Rn
Move register to Acc
MOV A,direct
Move direct byte o Acc
MOV A,@Ri
Move indirect RAM to Acc
MOV A,#data
Move immediate data to Acc
MOV Rn,A
Move Acc to register
MOV Rn,direct
Move direct byte to register
MOV Rn,#data
Move immediate data to register
MOV direct,A
Move Acc to direct byte
MOV direct,Rn
Move register to direct byte
MOV direct,direct
Move direct byte to direct byte
MOV direct,@Ri
Move indirect RAM to direct byte
MOV direct,#data
Move immediate data to direct byte
MOV @Ri,A
Move Acc to indirect RAM
MOV @Ri,direct
Move direct byte to indirect RAM
MOV @Ri,#data
Move immediate data to indirect RAM
MOV DPTR,#data16
Load DPTR with a 16-bit constant
MOVC A,@A+DPTR
Move code byte relative to DPTR to Acc
MOVC A,@A+PC
Move code byte relative to PC to Acc
MOVX A,@Ri
Move external RAM(8-bit address) to Acc
MOVX A,@DPTR
Move external RAM(16-bit address) to Acc
MOVX @Ri,A
Move Acc to external RAM(8-bit address)
MOVX @DPTR,A
Move Acc to external RAM(16-bit address)
PUSH direct
Push direct byte onto Stack
POP direct
Pop direct byte from Stack
XCH A,Rn
Exchange register with Acc
XCH A,direct
Exchange direct byte with Acc
XCH A,@Ri
Exchange indirect RAM with Acc
XCHD A,@Ri
Exchange low-order digit indirect RAM with Acc
ARITHEMATIC OPERATIONS
ADD A,Rn
Add register to Acc
ADD A,direct
Add direct byte to Acc
ADD A,@Ri
Add indirect RAM to Acc
ADD A,#data
Add immediate data to Acc
ADDC A,Rn
Add register to Acc with Carry
ADDC A,direct
Add direct byte to Acc with Carry
ADDC A,@Ri
Add indirect RAM to Acc with Carry
ADDC A,#data
Add immediate data to Acc with Carry
SUBB A,Rn
Subtract register from Acc with borrow
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
53/56
MEGAWIN
MG87FE/L2051/4051/6051
Preliminary, v 1.03
MAKE YOU WIN
SUBB A,direct
Subtract direct byte from Acc with borrow
SUBB A,@Ri
Subtract indirect RAM from Acc with borrow
SUBB A,#data
Subtract immediate data from Acc with borrow
INC A
Increment Acc
INC Rn
Increment register
INC direct
Increment direct byte
INC @Ri
Increment indirect RAM
DEC A
Decrement Acc
DEC Rn
Decrement register
DEC direct
Decrement direct byte
DEC @Ri
Decrement indirect RAM
INC DPTR
Increment DPTR
MUL AB
Multiply A and B
DIV AB
Divide A by B
DA A
Decimal Adjust Acc
2
1
2
1
1
2
1
1
1
2
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
2
4
4
1
1
2
1
2
2
3
1
2
1
2
2
3
1
2
1
2
2
3
1
1
1
1
1
1
1
1
1
1
1
1
2
1
1
1
1
1
2
1
1
1
1
1
2
1
1
1
1
1
1
1
1
2
1
1
1
1
LOGIC OPERATION
ANL A,Rn
AND register to Acc
ANL A,direct
AND direct byte to Acc
ANL A,@Ri
AND indirect RAM to Acc
ANL A,#data
AND immediate data to Acc
ANL direct,A
AND Acc to direct byte
ANL direct,#data
AND immediate data to direct byte
ORL A,Rn
OR register to Acc
ORL A,direct
OR direct byte to Acc
ORL A,@Ri
OR indirect RAM to Acc
ORL A,#data
OR immediate data to Acc
ORL direct,A
OR Acc to direct byte
ORL direct,#data
OR immediate data to direct byte
XRL A,Rn
Exclusive-OR register to Acc
XRL A,direct
Exclusive-OR direct byte to Acc
XRL A,@Ri
Exclusive-OR indirect RAM to Acc
XRL A,#data
Exclusive-OR immediate data to Acc
XRL direct,A
Exclusive-OR Acc to direct byte
XRL direct,#data
Exclusive-OR immediate data to direct byte
CLR A
Clear Acc
CPL A
Complement Acc
RL A
Rotate Acc Left
RLC A
Rotate Acc Left through the Carry
RR A
Rotate Acc Right
RRC A
Rotate Acc Right through the Carry
SWAP A
Swap nibbles within the Acc
BOOLEAN VARIABLE MANIPULATION
CLR C
Clear Carry
CLR bit
Clear direct bit
SETB C
Set Carry
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
54/56
MEGAWIN
MG87FE/L2051/4051/6051
MAKE YOU WIN
SETB bit
Set direct bit
CPL C
Complement Carry
CPL bit
Complement direct bit
ANL C,bit
AND direct bit to Carry
ANL C,/bit
AND complement of direct bit to Carry
ORL C,bit
OR direct bit to Carry
ORL C,/bit
OR complement of direct bit to Carry
MOV C,bit
Move direct bit to Carry
MOV bit,C
Move Carry to direct bit
JC rel
Jump if Carry is set
JNC rel
Jump if Carry not set
Preliminary Ver 1.00
2
1
2
2
2
2
2
2
2
2
2
1
1
1
2
2
2
2
1
2
2
2
3
3
3
2
2
2
2
3
1
1
2
3
2
1
2
2
3
3
3
3
2
3
1
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
1
BOOLEAN VARIABLE MANIPULATION
JB bit,rel
Jump if direct bit is set
JNB bit,rel
Jump if direct bit not set
JBC bit,rel
Jump if direct bit is set and then clear bit
PROAGRAM BRACHING
ACALL addr11
Absolute subroutine call
LCALL addr16
Long subroutine call
RET
Return from subroutine
RETI
Return from interrupt subroutine
AJMP addr11
Absolute jump
LJMP addr16
Long jump
SJMP addr16
Short jump
JMP @A+DPTR
Jump indirect relative to DPTR
JZ rel
Jump if Acc is zero
JNZ rel
Jump if Acc not zero
CJNE A,direct,rel
Compare direct byte to Acc and jump if not equal
CJNE A,#data,rel
Compare immediate data to Acc and jump if not equal
CJNE Rn,#data,rel
Compare immediate data to register and jump if not equal
CJNE @Ri,#data,rel
Compare immediate data to indirect RAM and jump if not equal
DJNZ Rn,rel
Decrement register and jump if not equal
DJNZ direct,rel
Decrement direct byte and jump if not equal
NOP
No Operation
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
55/56
MG87FE/L2051/4051/6051
MEGAWIN
Preliminary, v 1.03
MAKE YOU WIN
25.
Revision History
Rev
V1.00
Descriptions
1. Initial release
Date
2009/FEB/14
V1.01 1. Page-41, change clock structure diagram
2. Page-22, CUS-Timer Æ PWM-Timer
V1.02 1. Page-5, modified order information, MG87Fxy051AE20Æ MG87Fxy051AE
2. Page-5, modified order information, MG87Fxy051AS20Æ MG87Fxy051AS
2009/APR/08
V1.03 1. Page-5, modified order information, MG87Fxy051AEÆ MG87Fxy051AE20
2. Page-5, modified order information, MG87Fxy051ASÆ MG87Fxy051AS20
3. Page-33, comparator structure diagram modify input pin name.
2009/MAY/01
This document information is the intellectual property of Megawin Technology.
© Megawin Technology Co., Ltd. 2009 All rights reserved.
QP-7300-03D
56/56
Similar pages