EMC EM78612

EM78612
Universal Serial Bus
Microcontroller
Product
Specification
DOC. VERSION 1.1
ELAN MICROELECTRONICS CORP.
April 2004
Trademark Acknowledgments:
IBM is a registered trademark and PS/2 is a trademark of IBM.
Windows is a trademark of Microsoft Corporation.
ELAN and ELAN logo
are trademarks of ELAN Microelectronics Corporation.
Copyright © 2005 by ELAN Microelectronics Corporation
All Rights Reserved
Printed in Taiwan
The contents of this specification are subject to change without further notice. ELAN Microelectronics assumes
no responsibility concerning the accuracy, adequacy, or completeness of this specification. ELAN
Microelectronics makes no commitment to update, or to keep current the information and material contained in
this specification. Such information and material may change to conform to each confirmed order.
In no event shall ELAN Microelectronics be made responsible for any claims attributed to errors, omissions, or
other inaccuracies in the information or material contained in this specification. ELAN Microelectronics shall
not be liable for direct, indirect, special incidental, or consequential damages arising from the use of such
information or material.
The software (if any) described in this specification is furnished under a license or nondisclosure agreement, and
may be used or copied only in accordance with the terms of such agreement.
ELAN Microelectronics products are not intended for use in life support appliances, devices, or systems. Use of
ELAN Microelectronics product in such applications is not supported and is prohibited.
NO PART OF THIS SPECIFICATION MAY BE REPRODUCED OR TRANSMITTED IN ANY FORM OR
BY ANY MEANS WITHOUT THE EXPRESSED WRITTEN PERMISSION OF ELAN
MICROELECTRONICS.
ELAN MICROELECTRONICS CORPORATION
Headquarters:
Hong Kong:
USA:
No. 12, Innovation Road 1
Hsinchu Science Park
Hsinchu, Taiwan 30077
Tel: +886 3 563-9977
Fax: +886 3 563-9966
http://www.emc.com.tw
Elan (HK) Microelectronics
Corporation, Ltd.
Elan Information
Technology Group
Rm. 1005B, 10/F Empire Centre
68 Mody Road, Tsimshatsui
Kowloon , HONG KONG
Tel: +852 2723-3376
Fax: +852 2723-7780
[email protected]
1821 Saratoga Ave., Suite 250
Saratoga, CA 95070
USA
Tel: +1 408 366-8223
Fax: +1 408 366-8220
Europe:
Shenzhen:
Shanghai:
Elan Microelectronics Corp.
(Europe)
Elan Microelectronics
Shenzhen, Ltd.
Elan Microelectronics
Shanghai Corporation, Ltd.
Siewerdtstrasse 105
8050 Zurich, SWITZERLAND
Tel: +41 43 299-4060
Fax: +41 43 299-4079
http://www.elan-europe.com
SSMEC Bldg., 3F, Gaoxin S. Ave.
Shenzhen Hi-Tech Industrial Park
Shenzhen, Guandong, CHINA
Tel: +86 755 2601-0565
Fax: +86 755 2601-0500
23/Bldg. #115 Lane 572, Bibo Road
Zhangjiang Hi-Tech Park
Shanghai, CHINA
Tel: +86 021 5080-3866
Fax: +86 021 5080-4600
Contents
Contents
1
2
3
4
5
6
7
General Description .................................................................................................. 1
Features ..................................................................................................................... 1
Applications............................................................................................................... 2
Pin Configuration ...................................................................................................... 3
Pin Description.......................................................................................................... 4
Function Block Diagram ........................................................................................... 4
Function Description ................................................................................................ 5
7.1
Program Memory................................................................................................ 5
7.2
Data Memory ...................................................................................................... 6
7.2.1
7.2.2
7.3
I/O Ports ........................................................................................................... 17
7.3.1
7.3.2
7.4
Power-On Reset................................................................................................19
WatchDog Reset ...............................................................................................19
USB Reset.........................................................................................................19
Power Saving Mode ......................................................................................... 19
7.6.1
7.6.2
8
9
Auto-Detect PS/2 or USB Mode........................................................................17
USB Device Controller ......................................................................................18
Device Address and Endpoints .........................................................................19
Reset ................................................................................................................ 19
7.5.1
7.5.2
7.5.3
7.6
Programmable Large Current ...........................................................................17
Wakeup by Port Change Function ....................................................................17
USB Application................................................................................................ 17
7.4.1
7.4.2
7.4.3
7.5
Special Purpose Registers ..................................................................................6
USB Application FIFOs .....................................................................................17
Power Down Mode ............................................................................................19
Dual Clock Mode ...............................................................................................20
7.7 Interrupt ............................................................................................................ 20
Absolute Maximum Ratings ................................................................................... 21
DC Electrical Characteristic ................................................................................... 22
Product Specification (V1.1) 04.28.2004
• iii
Contents
Specification Revision History
Doc. Version
1.0
1.1
iv •
Revision Description
Date
Initial Version
2003/03/05
1.
Correction for some text in General Description-P3
2.
Correction for Pin Description of EM78612-P6
3.
Correction for Special Purpose Register-P8
4.
Correction for R4 Example of Selecting Bank-P11
2004/04/28
Product Specification (V1.1) 04.28.2004
EM78612
Universal Serial Bus Microcontroller
1
General Description
The EM78612 is a series of Universal Serial Bus 8-bit RISC Mask Rom
microcontrollers. It is specifically designed for USB low speed device application and
to support legacy device such as PS/2 mouse. The EM78612 also support one
device address and two endpoints. With no firmware involved, these series of
microcontrollers can automatically identify and decode Standard USB Command to
EndPoint Zero.
The EM78612 is implemented on a RISC architecture. It has five-level stack and six
interrupt sources. The amount of General Input/Output pins is up to12. Each device
has 80 bytes SRAM. The ROM size of the EM78612 is 2K.
These series of chips have Dual Clock mode which allows the device to run on very
low power saving frequency.
2
Features
Low-cost solution for low-speed USB devices, such as mouse, joystick, and
gamepad.
USB Specification Compliance
• Universal Serial Bus Specification Version 1.1
• USB Device Class Definition for Human Interface Device (HID), Firmware
Specification Version 1.1
• Support 1 device address and 2 endpoints (EP0 and EP1)
USB Application
• USB protocol handling
• USB device state handling
• Identifies and decodes Standard USB commands to EndPoint Zero
PS/2 Application Support
• Auto-detects PS/2 or USB port
• Built-in PS/2 port interface
Built-in 8-bit RISC MCU
•
•
•
•
•
5 level stacks for subroutine and interrupt
6 available interrupts
8-bit real time clock/counter (TCC) with overflow interrupt
Built-in RC oscillator free running for WatchDog Timer and Dual clock mode
Two independent programmable prescalers for WDT and TCC
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
•1
EM78612
Universal Serial Bus Microcontroller
• Two methods of power saving:
1. Power-down mode (SLEEP mode)
2. Low frequency mode.
• Two clocks per instruction cycle
I/O Ports
• Up to 12 general purposes I/O pins grouped into two ports (Port 6 and 7).
• Up to 2 LED sink pins
• Each GPIO pin of Ports 6 & Port 7 has an internal programmable pull-high
resistor (200K Ohms)
• Each GPIO pin wakes up the MCU from sleep mode by input state change
Internal Memory
• Built-in 2048*13 bits MASK ROM
• Built-in 80 bytes general purpose registers (SRAM)
• Built-in USB Application FIFOs.
Operation Frequency
• Normal Mode: MCU runs on the external oscillator frequency
• Dual Clock Mode: MCU runs at the frequency of 256KHz (or 32KHz, 4KHz,
500Hz), emitted by the internal oscillator with the external ceramic resonator
(or crystal) turned off to save power.
Built-in 3.3V Voltage Regulator
• For MCU power supply
• Pull-up source for the external USB resistor on D-pin.
Package Type
•
•
•
•
3
16 pin PDIP(300MIL) / SOP(150MIL) (EM78612 AP / AM)
18 pin PDIP(300MIL) / SOP(300MIL) (EM78612 BP / BM)
20 pin PDIP(300MIL) / SOP(300MIL) (EM78612 CP / CM)
20 pin SSOP(209MIL) (EM78612 EM)
Applications
This microcontroller is designed for USB low speed device application or non-USB
embedded device. It is also suitable for PS/2 mouse application.
2•
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
EM78612
Universal Serial Bus Microcontroller
4
Pin Configuration
EM78612A*
P61
1●
16
P60
P62
2
15
P64
P63
3
14
P65
P70
4
13
P71
P72
5
12
D+/P50
VSS
6
11
D-/P51
V3.3V
7
10
VDD
OSCI
8
9
OSCO
EM78612B*
P60
1●
18
P64
P61
2
17
P65
P62
3
16
P66
P63
4
15
P67
P70
5
14
P71
P72
6
13
D+/P50
VSS
7
12
D-/P51
V3.3V
8
11
VDD
OSCI
9
10
OSCO
EM78612C*
P60
1●
20
P64
P61
2
19
P65
P62
3
18
P66
P63
4
17
P67
P70
5
16
P71
P72
6
15
P73
NC
7
14
D+/P50
VSS
8
13
D-/P51
V3.3V
9
12
VDD
OSCI
10
11
OSCO
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
3
EM78612
Universal Serial Bus Microcontroller
5
Pin Description
Symbol
I/O
OSCI
I
OSCO
I/O
V3.3V
O
P60 ~ P67
I/O
P70 ~ P73
I/O
D+ / P50
I/O
D- / P51
I/O
VDD
-
VSS
-
Function
6MHz / 12MHz ceramic resonator or crystal input.
Return path for 6-MHz / 12MHz ceramic resonator or crystal.
3.3V DC voltage output from internal regulator. This pin has to be tied to a 4.7
μF capacitor.
Port6 offers up to 8 GIOP pins.
The pull high resistors (200K Ohms) and pull low resistors (15K Ohm) are
selected through pin programming.
Port7 offers up to 4 GIOP pins. The sink current of P70 & P71 are
programmable for driving LED.
Each pin has pull high resistors (200K Ohm) that can be selected through pin
programming.
USB Plus data line interface or PS/2 line interface are user-defined through
firmware setting.
When this pin is used as a PS/2 line interface, it will generate an interrupt
when its state changes (Port5 state change interrupt enable).
USB Minus data line interface or PS/2 line interface are user-defined through
firmware setting.
This pin should be pulled-high with a 1.5K Ohm resistor to V3.3V pin for USB
mode application.
When this pin is used as a PS/2 line interface, it will generate an interrupt
when its state changes (Port5 state change interrupt enable).
Connects to the USB power source or to a nominal 5V-power supply. Actual
VDD range can vary between 4.4V and 5.2V.
Connects to ground.
Table 5-1 Pin Descriptions
6
Function Block Diagram
OSCI
Built-in
RC
OSCO
WDT
Timer
V3.3
D+
3.3V
Regulator
Oscillator
Timing
Control
Prescaler
WDT
Reset &
Sleep &
Wake up
Control
VDD
Prescaler
TCC
R1
(TCC)
D-
R2
(PC)
Transceiver
ROM
USB
Device
Controller
Instruction
register
RAM
Stack1
Stack2
Stack3
Stack4
Stack5
R3
(Status)
ALU
Interrupt
Control
Instruction
Decoder
R4
(RSR)
ACC
DATA & CONTROL BUS
P50/D+/Clk
P51/D-/Data
I/O
Port 5
I/O
Port 6
P60
P61
P62
P63
P64
P65
P66
P67
I/O
Port 7
P70
P71
P72
P73
Figure 6-1 EM78612 Series Function Block Diagram
4•
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
EM78612
Universal Serial Bus Microcontroller
7
Function Description
The EM78612memory is organized into four spaces, namely; User Program Memory
in 2048*13 bits MASK ROM space, Data Memory in 80 bytes SRAM space, and USB
Application FIFOs (for EndPoint0 and EndPoint1). Furthermore, several registers are
used for special purposes.
7.1 Program Memory
The program space of the EM78612 is 2K bytes, and is divided into two pages. Each
page is 1K bytes long. After Reset, the 12-bit Program Counter (PC) points to
location zero of the program space.
It has two interrupt vectors, i.e., Interrupt Vectors at 0x0001 and USB Application
Interrupt Vectors at 0x000A. The Interrupt Vector applies to TCC Interrupt, and Port
5 State Changed Interrupt. The USB Application Interrupt Vector is for USB EndPoint
Zero Interrupt, USB Suspend Interrupt, USB Reset interrupt, and USB Host Resume
Interrupt.
After an interrupt, the MCU will fetch the next instruction from the corresponding
address as illustrated in the following diagram.
After reset
PC
Address
0x0000
Reset Vector
0x0001
Interrupt Vector
0x000A
USB Application Interrupt Vector
Page 0
0x03FF
0x0400
Page 1
0x07FF
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
5
EM78612
Universal Serial Bus Microcontroller
7.2 Data Memory
The Data Memory has 80 bytes SRAM space. It is also equipped with USB
Application FIFO space for USB Application. The Figure 7-1 (next page) shows the
organization of the Data Memory Space.
7.2.1 Special Purpose Registers
When the microcontroller executes instruction, specific registers are invoked for
assistance, such as; Status Register which records the calculation status, Port I/O
Control Registers which control the I/O pins’ direction, etc. The EM78612 series
provides a lot more of other special purpose registers with different functions.
There are 14 Special Operation Registers which are located from Address 0x00 to
0x0F. On other hand, 10 more Special Control Registers are available to control
functions or I/O direction. These are arranged from Address 0x05 to 0x0F.
NOTE
that Special Control Registers can only be read or written by two instructions; IOR
and IOW.
00
01
02
03
04
R0
R1
R2
R3
R4
(Indirection Addressing Register)
(Time Clock / Counter Register)
(Program Counter) & Stack
(Status Register)
(RAM Select Register)
05
06
07
08
09
R5
R6
R7
R8
R9
(Data line I/O Register)
(Port 6 I/O Register)
(Port 7 I/O Register)
(Port6 wakeup pin selection Register)
(Port7 wakeup pin selection Register)
0C
0D
0E
0F
10
IOC5
IOC6
IOC7
IOC8
IOCA (Operation mode Control Register)
IOCB (Port 6 pull low Control Register)
IOCC (Port 6 pull high Control Register)
IOCD (Port 7 pull high Control Register)
IOCE (Special Function Control Register)
IOCF (Interrupt Mask Register)
RC (USB Application Status Register)
RD (USB Application FIFO address register)
RE (USB Application FIFO data register)
RF (Interrupt Status Register)
00
01
10
11
General Purpose Register
1F
(Port 5 I/O Control Register)
(Port 6 I/O Control Register)
(Port 7 I/O Control Register)
(Sink Curent Control Register)
EP0's FIFO
EP1's FIFO
Data Byte Pointer of EP0
Data Byte Pointer of EP1
20
General Purpose
Registers
(Bank0)
Byte0
Byte1
Byte2
Byte3
Byte4
Byte5
Byte6
Byte7
General Purpose
Registers
(Bank1)
3F
Fig 7-1 The Organization of EM78612 Data RAM
6•
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
EM78612
Universal Serial Bus Microcontroller
7.2.1.1 Operation Registers in Bank 0
The following introduces each of the Operation Registers under the Special Purpose
Registers in Bank 0. These Operation Registers are arranged according to the order
of registers’ address. Note that some registers are read only, while others are both
readable and writable.
R0 (Indirect Address Register) Default Value: (0B_0000_0000)
R0 is not a physically implemented register. Its major function is to be an indirect
address pointer. Any instruction using R0 as a pointer actually accesses the data
pointed by the RAM Select Register (R4).
R1 (Time / Clock Counter) Default Value: (0B_0000_0000)
This register TCC, is an 8-bit timer or counter. It is readable and writable as any
other register.
After Power-on reset and WatchDog reset, the initial value of this register is 0x00.
R2 (Program Counter & Stack) Default Value: (0B_0000_0000)
The EM78612 Program Counter is an 11-bit long register that allows access to 2K
bytes of Program Memory. The Program Counter is cleared after Power-on reset or
WatchDog reset. The first instruction that is executed after a reset is located at
Address 00h.
CALL
R3[5]
R2[9] ~ R2[0]
0x0000 Reset Vector
0x0001 Interrupt Vector
0x000A USB Interrupt Vector
Stack 1
RET
RETL
RETI
Stack 2
Stack 3
Stack 4
Stack 5
Page 0
0x03FF
0x0400
Page 1
0x07FF
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
7
EM78612
Universal Serial Bus Microcontroller
R3 (Status Register) Default Value:(0B_0001_1000)
7
6
5
4
3
2
1
0
-
-
PS0
T
P
Z
DC
C
R3 [0] Carry flag.
R3 [1] Auxiliary carry flag.
R3 [2] Zero flag. It will be set to 1 when the result of an arithmetic or logic operation
is zero.
R3 [3] Power down flag. It will be set to 1 during Power-on phase or by “WDTC”
command and cleared when the MCU enters into Power down mode. It
remains in its previous state after WatchDog Reset.
1: Power-on.
0: Power down
R3 [4] Time-out flag. It will be set to 1 during Power-on phase or by “WDTC”
command. It is reset to 0 by WDT time-out.
1: WatchDog timer without overflow.
0: WatchDog timer with overflow.
The various states of Power down flag and Time-out flag at different
conditions are shown below:
Condition
1
1
Power-on reset
1
1
WDTC instruction
0
*P
WDT time-out
1
0
Power down mode
1
0
Wakeup caused by port change during Power down mode
* P: Previous status before WDT reset
R3 [5] Page selection bit. This bit is used to select a page of program memory
(refer to R2, Program Counter).
PS0
Program Memory Page [Address]
0
Page 0 [0000-03FF]
1
Page 1 [0400-07FF]
R3 [6] General purpose registers.
8•
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
EM78612
Universal Serial Bus Microcontroller
R4 (RAM Select Register) Default Value: (0B_0000_0000)
7
6
5
4
3
2
1
0
-
BK0
Ad5
Ad4
Ad3
Ad2
Ad1
Ad0
R4 (RAM select register) contains the address of the registers.
R4 [0~5] are used to select registers in 0x00h~0x3Fh. The address 0x00~0x1F is
common space. After 0x1Fh, SRAM is grouped into four banks.
R4 [6]
are used to select register banks. To select a registers bank, refer to the
following examples and the table below:
R4=01111100 points to the register 0x3C in Bank 1.
R4[6]Bk0
RAM Bank #
0
Bank 0
1
Bank 1
R5 (Data Line I/O Register) Default Value: (0B_0000_0000)
7
6
5
4
3
2
-
-
-
-
-
-
R5 [0]
USB D+ line register or PS/2 clock interface register.
R5 [1]
USB D- line register or PS/2 data interface register.
1
0
D- or PS/2 D+ or PS/2
These two bits are BOTH writable and readable when the MCU is operating under
PS/2 mode. But under USB Mode, these two bits cannot be accessed.
R5 [2~7] General purpose registers.
R6 (Port 6 I/O Register) Default Value: (0B_0000_0000)
7
6
5
4
3
2
1
0
P67
P66
P65
P64
P63
P62
P61
P60
R7 (Port 7 I/O Register) Default Value: (0B_0000_0000)
7
6
5
4
3
2
1
0
-
-
-
-
P73
P72
P71
P70
R8 (Port 6 Wake-up Pin Selection Register) Default Value: (0B_1111_1111)
7
6
5
4
3
2
1
0
/Wu67
/wu66
/Wu65
/Wu64
/Wu63
/Wu62
/Wu61
/Wu60
R8 [0 ~ 7] Select which of the Port 6 pins are to be defined to wake-up the MCU from
sleep mode. When the state of the selected pins changes during sleep
mode, the MCU will wake-up and execute the next instruction
automatically.
1: Disable the wake-up function
0: Enable the wake-up function
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
9
EM78612
Universal Serial Bus Microcontroller
R9 (Port 7 Wake-up Pin Selection Register) Default Value: (0B_1111_1111)
7
6
5
4
3
2
1
0
-
-
-
-
/Wu73
/Wu72
Wu71
/Wu70
R9 [0,2,3] Select which of the Port 7 pins are to be defined to wake-up the MCU from
sleep mode. When the state of the selected pins changes during sleep
mode, the MCU will wake-up and execute the next instruction
automatically.
1: Disable the wake-up function
0: Enable the wake-up function
R9[1]
Port 71
1: Enable the wake-up function
0: Disable the wake-up function
RC (USB Application Status Register) Default Value: (0B_0000_0000)
10 •
7
6
5
4
3
2
1
0
EP0_W
EP0_R
EP1_R
0
Device_Resume
Host_Suspend
EP0_Busy
Stall
RC [0]
Stall flag. When MCU receives an unsupported command or invalid
parameters from host, this bit will be set to 1 by the firmware to notify the
UDC to return a STALL handshake. When a successful SETUP
transaction is received, this bit is cleared automatically. This bit is both
readable and writable.
RC [1]
EP0 Busy flag. When this bit is equal to “1,” it indicates that the UDC is
writing data into the EP0’FIFO or reading data from it. During this time, the
firmware will avoid accessing the FIFO until UDC finishes writing or
reading. This bit is only readable.
RC [2]
Host Suspend flag. If this bit is equal to 1, it indicates that USB bus has no
traffic for the specified period of 3.0 ms. This bit will also be cleared
automatically when a bus activity takes place. This bit is only readable.
RC [3]
Device Resume flag. This bit is set by firmware to general a signal to
wake-up the USB host and is cleared as soon as the USB Suspend signal
becomes low. This bit can only be set by firmware and cleared by the
hardware.
RC [4]
Undefined Register. The default value is 0.
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
EM78612
Universal Serial Bus Microcontroller
RC [5,6]
EP0_R / EP1_R flag. These two bits inform the UDC to read the data
written by firmware from the FIFO. Then the UDC sends the data to the
host automatically. After UDC finishes reading the data from the FIFO,
this bit is cleared automatically.
Therefore, before writing data into the FIFO, the firmware will first check
this bit to prevent overwriting the existing data. These two bits can only
be set by the firmware and cleared by the hardware.
RC [7]
EP0_W flag. After the UDC completes writing data to the FIFO, this bit
will be set automatically. The firmware will clear it as soon as it gets the
data from EP0’s FIFO. Only when this bit is cleared that the UDC will be
able to write a new data into the FIFO.
Therefore, before the firmware can write a data into the FIFO, this bit must
first be set by the firmware to prevent UDC from writing data at the same
time. This bit is both readable and writable.
RD (USB Application FIFO Address Register) Default Value: (0B_0000_0000)
7
6
5
4
3
2
1
0
0
0
0
UAD4
UAD3
UAD2
UAD1
UAD0
RD [0~4]
USB Application FIFO address registers. These five bits are the address
pointer of USB Application FIFO.
RD [5~7]
Undefined registers. The default value is zero.
RE (USB Application FIFO Data Register) Default Value: (0B_0000_0000)
7
6
5
4
3
2
1
0
UD7
UD6
UD5
UD4
UD3
UD2
UD1
UD0
RE (USB Application FIFO data register) contains the data in the register of which
address is pointed by RD.
RF (Interrupt Status Register ) Default Value: (0B_0000_0000)
7
6
-
-
5
4
Port 5 State
USB Host
Change_IF Resume_IF
3
2
USB
USB
Reset_IF Suspend_IF
1
0
EP0_IF
TCC_IF
RF [0]
TCC Overflow interrupt flag. It will be set while TCC overflows, and is
cleared by the firmware.
RF [1]
EndPoint Zero interrupt flag. It will be set when the EM78612 receives
Vender /Customer Command to EndPoint Zero. This bit is cleared by the
firmware.
RF [2]
USB Suspend interrupt flag. It will be set when the EM78612 finds the
USB Suspend Signal on USB bus. This bit is cleared by the firmware.
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
11
EM78612
Universal Serial Bus Microcontroller
RF [3]
USB Reset interrupt flag. It will be set when the host issues the USB
Reset signal.
RF [4]
USB Host Resume interrupt flag. It is set only under Dual Clock mode
when the USB suspend signal becomes low.
RF [5]
Port 5 State Change interrupt flag. It is set when the Port 5 state
changes . (Port 5 state change interrupt only work in PS/2 mode.)
R10~R1F are General purpose registers. These registers can be used no matter
what Bank Selector is. There are 2 banks(BK0 & BK1) R20~R3F General purpose
registers, Select by R4 [6].
7.2.1.2 Control Registers in Bank 0
Special purpose registers for special control purposes are also available. Except for
the Accumulator (A), these registers must be read and written by special instructions.
One of these registers, CONT, can only be read by the instruction "CONTR" and
written by "CONTW" instruction. The remaining special control registers can be read
by the instruction "IOR" and written by the instruction "IOW."
A (Accumulator Register)
The accumulator is an 8-bit register that holds operands and results of arithmetic
calculations. It is not addressable.
CONT (Control Register) Default Value: (0B_0011_1111)
7
6
5
4
3
2
1
0
-
/INT
TSR2
TSR1
TSR0
PSR2
PSR1
PSR0
NOTE
The CONT register can be read by the instruction "CONTR" and written by the
instruction “CONTW."
CONT [0~2] WatchDog Timer prescaler bits. These three bits are used as the
prescaler of WatchDog Timer.
CONT [3~5] TCC Timer prescaler bits.
The relationship between the prescaler value and these bits are as shown below:
12 •
PSR2/TSR2
PSR1/TSR1
PSR0/TSR0
TCC Rate
WDT Rate
0
0
0
1: 2
1: 1
0
0
1
1: 4
1: 2
0
1
0
1: 8
1: 4
0
1
1
1: 16
1: 8
1
0
0
1: 32
1: 16
1
0
1
1: 64
1: 32
1
1
0
1: 128
1: 64
1
1
1
1: 256
1: 128
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
EM78612
Universal Serial Bus Microcontroller
NOTE
The period of WatchDog Timer is based on Power On Time (POT).
Ex:
The POT is 2ms and the prescaler is 1:128 (111),then the WDT reset time is
2ms*128 = 256ms.
CONT [6] Interrupt enable control bit. This bit toggles Interrupt function between
enable and disable. It is set to 1 by the interrupt disable instruction "DISI"
and reset by the interrupt enable instructions "ENI" or "RETI."
0: Enable the Interrupt function.
1: Disable the Interrupt function.
CONT [7] Undefined register. The default value is one.
IOC5 ~IOC7 (I/O Port [Port 5 ~ Port 7] Direction Control Registers
Each bit controls the I/O direction of three I/O ports respectively. When these bits are
set to 1, the relative I/O pins become input pins. Similarly, the I/O pins becomes
outputs when the relative control bits are cleared.
1: Input direction.
0: Output direction.
IOC5 (Data Line I/O Control Register) Default Value: (0B_0000_0011)
7
6
5
4
3
2
1
0
0
0
0
0
0
0
P51
P50
IOC5 [2~7] Undefined registers. The default value is 0.
IOC6 (Port 6 I/O Control Register) Default Value: (0B_1111_1111)
7
6
5
4
3
2
1
0
P67
P66
P65
P64
P63
P62
P61
P60
IOC7 (Port 7 I/O Control Register) Default Value: (0B_1111_1111)
7
6
5
4
3
2
1
0
-
-
-
-
P73
P72
P71
P70
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
13
EM78612
Universal Serial Bus Microcontroller
IOC8 (Sink Current Control Register) Default Value: (0B_0000_0000)
7
6
5
4
3
2
1
0
0
0
Sink1.1
Sink1.0
0
0
Sink01
Sink0.0
IOC8 [0,1][4,5] are P70/P71 sink current control registers. Four levels are offered for
selection:
Sink0.1/1.1
Sink0.0/1.0
Sink Current
0
0
3mA±10%
0
1
6mA±10%
1
0
12mA±10%
1
1
30mA±10%
The default current after Power-on reset is 3mA.
IOCA (Operation Mode Control Register) Default Value: (0B_1100_0011)
7
6
5
4
3
2
1
0
Dual_Frq.1
Dual_Frq.0
0
0
0
0
PS/2
USB
IOCA [0,1]
14 •
These two bits are used to select the operation mode. EM78612 can
auto-detect the type of port device being attached. After identifying
the port, the firmware will set these two bits to enter into a proper
operation mode. The definition of these two control registers is
described in the table below.
IOCA[1]
IOCA[0]
Operation Mode
0
0
Detect Mode
0
1
USB Mode
1
0
PS/2 Mode
1
1
USB Test Mode
IOCA [2~5]
Undefined registers. The default value is 0.
IOCA [6,7]
Select the operation frequency in Dual Clock mode. Four
frequencies are available and can be chosen as Dual Clock mode for
running the MCU program.
Dual_Frq.1
Dual_Frq.0
Frequency
0
0
500Hz
0
1
4kHz
1
0
32kHz
1
1
256kHz
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
EM78612
Universal Serial Bus Microcontroller
IOCB (Port 6 Pull-Low Control Register) Default Value: (0B_0000_0000)
7
6
5
4
3
2
1
0
PL67
PL66
PL65
PL64
PL63
PL62
PL61
PL60
IOCB [0~7] Select whether the 15K Ohm pull-low resistor of Port 6 individual pin is
connected or not.
1: Enable the pull-low function.
0: Disable the pull-low function.
IOCC (Port 6 Pull-High Control Register) Default Value: (0B_0000_0000)
7
6
5
4
3
2
1
0
PH67
PH66
PH65
PH64
PH63
PH62
PH61
PH60
IOCC [0~7] Select whether the 200K Ohm pull-high resistor of Port 6 individual pin is
connected or not.
1: Enable the pull-high function.
0: Disable the pull-high function.
IOCD (Port 7 Pull-High Control Register) Default Value: (0B_0000_0000)
7
6
5
4
3
2
1
0
-
-
-
-
PH73
PH72
PH71
PH70
IOCD [0~3] Select whether the 200K Ohm pull-high resistor of Port 7 individual pin is
connected or not.
1: Enable the pull-high function.
0: Disable the pull-high function.
IOCE (Special Function Control Register) Default Value: (0B_1111_0000)
7
6
5
4
3
2
1
0
/Dual clock
/WUE
WTE
RUN
0
0
0
0
IOCE [0~3] Undefined register. The default value is zero.
IOCE [4]
Run bit. This bit can be cleared by the firmware and set during power-on,
or by the hardware at the falling edge of wake-up signal. When this bit is
cleared, the clock system is disabled and the MCU enters into power
down mode. At the transition of wake-up signal from high to low, this bit
is set to enable the clock system.
1: Run mode. The EM78612 is working normally.
0: Sleep mode. The EM78612 is in power down mode.
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
15
EM78612
Universal Serial Bus Microcontroller
IOCE [5]
WatchDog Timer enable bit. The bit disable/enables the WatchDog
Timer.
1: Enable WDT.
0: Disable WDT.
NOTE
If the Code Option WTC bit is "0,” WDT is always disabled.
IOCE [6]
Enable the wake-up function as triggered by port-change. This bit is set
by UDC.
1: Disable the wake-up function.
0: Enable the wake-up function.
IOCE [7]
Dual clock Control bit. This bit is used to select the frequency of system
clock. When this bit is cleared, the MCU will run on very low frequency
save power and the UDC will stop working.
1: Selects EM78612 to run on normal frequency.
0: Selects to run on slow frequency.
IOCF (Interrupt Mask Register) Default Value: (0B_0000_0000)
7
6
-
-
5
4
3
Port 5 State
USB Host
Change_IE Resume_1E
USB
Reset_IE
2
1
0
USB
EP0_IE TCC_IE
Suspend_IE
IOCF [0~5] TCC / EP0 / USB Suspend / USB Reset / USB Host Resume / Port 5
State Change enable bits. These eight bits respectively control the
function of TCC interrupt, EP0 interrupt, USB Suspend interrupt, USB
Reset interrupt, USB Host Resume interrupt, Port5 State Change
interrupt, Individual interrupt is enabled by setting its associated control bit
in the IOCF to "1".
1: Enable Interrupt.
0: Disable Interrupt.
Only when the global interrupt is enabled by the ENI instruction that the individual
interrupt will work. After DISI instruction, any interrupt will not work even if the
respective control bits of IOCF are set to 1.
The USB Host Resume Interrupt works only under Dual clock mode. This is because
when the MCU is under sleep mode, it will be waked up by the UDC Resume signal
automatically.
16 •
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
EM78612
Universal Serial Bus Microcontroller
7.2.2 USB Application FIFOs
For USB Application, EM78612 provides an 8-byte First-In-First-Out (FIFO) buffer for
each endpoint. The buffer cannot be accessed directly. However, a corresponding
Data Byte Pointer register for each endpoint is made available to address the
individual byte of the FIFO buffer. The content of the individual byte will map to a
special register.
7.3 I/O Ports
The EM78612 has up to twelve General Purposes I/O pins, which are classifies into
two port groups; Port 6 and Port 7. Each pin has an internal resistor that can be
individually selected by user.
The following describes the important features o EM78612 I/O pins.
7.3.1 Programmable Large Current
Port 7 has two pins; P70 and P71 that can drive large current of up to 30mA. The
range of driving current is from 3mA to 30mA, which is programmable. Use IOC8
[0,1] and IOC8 [4,5] to control the sink current of P70/P71. The default current is
3mA.
7.3.2 Wakeup by Port Change Function
Each of the GPIO pins in Port 6 and Port 7 can wakeup the MCU through signal
change from input pin. This function is used to wake-up the MCU automatically from
sleep mode. It also supports the remote wake-up function for USB application.
Any of the Individual pins of Port 6 and Port 7 can be defined to wakeup the MCU by
setting their respective bits, R8 and R9.
7.4 USB Application
EM78612 is specially designed for USB device application and has many powerful
functions that help the firmware to free itself from complex situation in various aspects
of USB application.
7.4.1 Auto-Detect PS/2 or USB Mode
When the EM78612 is connected to the bus, it will auto-detect and identify which type
of bus (USB or PS/2) it is connected to. The conditions that influence auto-detect
function are described below:
1. After a Power-on reset, the initial value of IOCA [0,1] is 0b00. Thus the operation
mode is “Detect mode” and the D+ and D- I/O pins are internal pulled high by
200K Ohm to VDD.
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
17
EM78612
Universal Serial Bus Microcontroller
2. The firmware checks the state of R5 [0,1]. If the state with which these two bits is
0b00, set the IOCA [0] to “1” to define the “USB mode.” Otherwise, set the IOCA
[1] to “1,” to define “PS/2 mode.”
3. When the operation mode is defined as “USB mode,” the D- I/O pin is internal
pulled high by a 1.5K Ohm resistor to 3.3V, which is output from a built-in
regulator.
4. If the operation mode is in “PS/2 mode,” both of the PS/2 interface I/O pins are
internal pulled high by a 2.2K Ohm resistor to VDD.
NOTE
If the auto-detect function is not used, the firmware should set the operation mode,
either in USB mode or PS/2 mode, at the beginning of program.
An additional mode, “USB Test Mode” is also available. This mode has no load on
D+ and D- I/O pins, and can only be used in USB Application case. Therefore, an
external 1.5K Ohm resistor is needed to pull up D- IO pin to 3.3V.
Under “PS/2 mode,” both PS/2 pins are programmed to generate an interrupt. After
setting the Port 5 State change to Interrupt Enable bit, the MCU will interrupt while the
state of these two pins changes.
7.4.2 USB Device Controller
The USB Device Controller (UDC) built-in in the EM78612 can interpret the USB
Standard Command and response automatically without involving firmware. The
embedded Series Interface Engine (SIE) handles the serialization and deserialization
of actual USB transmission. Thus, a developer can concentrate his efforts more in
perfecting the device actual functions and spend less energy in dealing with USB
transaction.
The UDC handles and decodes most Standard USB commands defined in the USB
Specification Rev1.1. If UDC receives an unsupported command, it will set a flag to
notify MCU the receipt of such command. The Standard Commands that EM78612
supports includes; Clear Feature, Get Configuration, Get Interface, Get Status,
Set Address, Set Configuration, Set Feature, and Set Interface.
Each time UDC receives a USB command, it writes the command into EP0’s FIFO.
Only when it receives unsupported command that the UDC will notify the MCU
through interrupt.
Therefore, EM78612 is very flexible under USB application because the developer
can freely choose the method of decoding the USB command as dictated by different
situation.
18 •
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
EM78612
Universal Serial Bus Microcontroller
7.4.3 Device Address and Endpoints
EM78612 supports one device address, two endpoints, EP0 for control endpoint, and
EP1 for interrupt endpoint. Sending data to USB host in EM78612 is very easy. Just
write data into EP’s FIFO, then set flag, and the UDC will handle the rest. It will then
confirm that the USB host has received the correct data from EM78612.
7.5 Reset
The EM78612 provides three types of reset: (1) Power-on Reset, (2) WatchDog
Reset, and (3) USB Reset.
7.5.1 Power-On Reset
Power-on Reset occurs when the device is attached to power and a reset signal is
initiated. The signal will last until the MCU becomes stable. After a Power-on Reset,
the MCU enters into following predetermined states (see below), and then, it is ready
to execute the program.
1. The program counter is cleared.
2. The TCC timer and WatchDog timer are cleared.
3. Special registers and Special Control registers are all set to initial value.
The MCU also has a low voltage detector that detects low output power condition.
Whenever the output voltage of the 3.3V regulator decreases to below 2.2V, a reset
signal is set off.
7.5.2 WatchDog Reset
When the WatchDog timer overflows, it causes the WatchDog to reset. After it
resets, the program is executed from the beginning and some registers will be reset.
The UDC however, remains unaffected.
7.5.3 USB Reset
When UDC detects a USB Reset signal on USB Bus, it interrupts the MCU, then
proceed to perform the specified process that follows.
7.6 Power Saving Mode
The EM78612 provides two options of power saving modes for energy conservation,
i.e., Power Down mode, and Dual Clock mode.
7.6.1 Power Down Mode
The EM78612 enters into Power Down mode by clearing the RUN register (IOCE[4]).
During this mode, the oscillator is turned off and the MCU goes to sleep. It will wake
up when signal from USB host is resumed, or when the WatchDog resets, or the input
port state changes.
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
19
EM78612
Universal Serial Bus Microcontroller
If the MCU wakes up when I/O port status changes, I/O port direction should be set at
input, then the port state is read. For example:
:
// Set the Port 6 to input port
MOV
A,@0XFF
IOW
PORT6
// Read the state of Port 6
MOV
PORT6,PORT6
// Clear the RUN bit
IOR
0X0E
AND
A,@0B11101111
IOW
0X0E
:
:
If the MCU is awaken by a USB Resume signal, the next instruction will be executed,
and one flag, RC[3] will be set to 1.
7.6.2 Dual Clock Mode
The EM78612 has one internal oscillator for power saving application. Clearing the
Bit IOCE [7] will enable the low frequency oscillator. At the same time, the external
oscillator will be turned off. Then the MCU will run under very low frequency to
conserve power. Four types of frequency are available for selection in setting Bits
IOCA [6, 7].
The USB Host Resume Interrupt can only be used in this mode. If this interrupt is
enabled, the MCU will be interrupted when the USB Suspend signal is detected on
USB Bus.
7.7 Interrupt
The EM78612 has two interrupt vectors, one is in 0x0001, and the other is in 0x000A.
When an interrupt occurs while the MCU is running, it will jump to the interrupt vector
(0x0001 or 0x000A) and execute the instructions sequentially from interrupt vector.
RF is the interrupt status register that records the interrupt status in the relative
flags/bits.
The interrupt condition could be one of the following:
20 •
1. TCC Overflow
When the Timer Clock / Counter Register (R1) overflows,
the status flag RF[0] will be set to 1. Its interrupt vector
is 0X0001.
2. EP0 Interrupt
When the UDC successfully received a setup transaction
from host to EndPoint0, the status flag RF[1] will be set
to 1. Its interrupt vector is 0X000A.
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
EM78612
Universal Serial Bus Microcontroller
3. USB Suspend
When UDC detects a USB Suspend signal on USB bus,
the status flag RF[2] will be set to 1. Its interrupt vector
is 0X000A.
4. USB Reset
When the UDC detects a USB Reset signal on USB bus,
the status flag R[3] will be set to 1. Its interrupt vector is
0X000A.
5. USB Host Resume
When UDC detects that the USB bus has left the
Suspend condition, the status flag R[4] will be set to 1.
Its interrupt vector is 0X000A.
6. Port 5 State Change
When the input signals in Port 5 changes, the status flag
RF[4] will be set to 1. Its interrupt vector is 0X0001.
IOCF is an interrupt mask register which can be set individually bit by bit. While their
respective bit is written to 0, the hardware interrupt will inhibit, that is, the EM78612
will not jump to the interrupt vector to execute instructions. But the interrupt status
flags still records the conditions no matter whether the interrupt is masked or not.
The interrupt status flags must be cleared by firmware before leaving the interrupt
service routine and enabling interrupt.
The global interrupt is enabled by the ENI (RETI) instruction and is disabled by the
DISI instruction.
8
Absolute Maximum Ratings
Symbol
Min
Max
Unit
0
70
℃
Storage temperature
-65
150
℃
Input voltage
-0.5
6.0
V
Output voltage
-0.5
6.0
V
Temperature under bias
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
21
EM78612
Universal Serial Bus Microcontroller
9
DC Electrical Characteristic
(T = 25℃, VDD = 5V, VSS = 0V)
Symble
Parameter
Condition
Min
VDD = 4.4V ~ 5.2V
3.0
Type Max
Unit
3.3V Regulator
VRag
Output voltage of 3.3v Regulator
3.3
3.6
V
VResetL
Low Power Reset detecting low Voltage
-
V
VResetH
Low Power Reset detecting high
Voltage
-
V
MCU Operation
IIL
Input Leakage Current for input pins
VIN= VDD,VSS
VIHX
Clock Input High Voltage
VILX
Clock Input Low Voltage
ICC1
VDD operating supply current –
Normal frequency operation mode
-
-
±1
μA
OSCI
2.5
-
-
V
OSCI
-
-
1.0
V
-
-
10
mA
-
-
20
mA
-
-
80
μA
200
μA
Crystal type
Freq. = 6MHz
Output pins floating
ICC2
VDD operating supply current –
Normal frequency operation mode
Crystal type
Freq. = 12MHz
Output pins floating
ISB1
Operating supply current 1 –
Power down mode
All input and I/O pins at VDD
Output pins floating
WDT disabled
ISB2
Operating supply current 2 –
Low frequency mode
RC oscillation type
Freq. = 20kHz~50kHz
Output pins floating
-
-
GPIO Pins
VIH
Input High Voltage
Port 5
1.4
V
VIL
Input Low Voltage
Port 5
1.4
V
VIH
Input High Voltage
Port 6 & 7
1.4
V
VIL
Input Low Voltage
Port 6 & 7
1.4
V
VOH
Output High Voltage
(Port5)
IDrive = 5.0mA
2.4
-
-
V
VOL
Output Low Voltage
(Port5)
ISink = 5.0mA
-
-
0.4
V
VOH
Output High Voltage
(Port5 & Port 6 & P72~P77), OSCO)
IDrive = 10.0mA
2.4
-
-
V
VOL
Output Low Voltage
(Port5 & Port 6 & P72~P77, OSCO)
ISink = 10.0mA
-
-
0.4
V
Input current with pull-high resister
The input pin with internal
pull-high resistor of Port6 or Port7 is connected to VSS.
25
-
μA
IPH
22 •
-
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
EM78612
Universal Serial Bus Microcontroller
Symble
IPL
Parameter
Input current with pull-low resister
Condition
The input pin with internal
pull-low resistor of Port6 is
connected to VDD.
Min
-
Type Max
330
Unit
μA
-
USB Interface
VOH
Static Output High
2.8
-
3.6
V
VOL
Static Output Low
-
-
0.3
V
VDI
Differential Input Sensitivity
0.2
-
-
V
VCM
Differential Input Command Mode Range
0.8
-
2.5
V
VSE
Single Ended Receiver Threshold
0.8
-
2.0
V
CIN
Transceiver Capacitance
-
-
20
pF
VRG
Output Voltage of Internal Regulator
3.0
-
3.6
V
IPH
Input current with pull-high resister
(D-)
USB operation Mode
USB operation Mode
mA
Programmable Large Current
ISink1
P70, P71 Output Sink Current
VOUT = 0.4V,
-10%
IOC8[0,1] or IOC8[4,5] = 00
3
+10%
mA
ISink2
P70, P71 Output Sink Current
VOUT = 0.4V,
-10%
IOC8[0,1] or IOC8[4,5] = 01
6
+10%
mA
ISink3
P70, P71 Output Sink Current
VOUT = 0.4V,
-10%
IOC8[0,1] or IOC8[4,5] = 10
12
+10%
mA
ISink4
P70, P71 Output Sink Current
VOUT = 0.4V,
-10%
IOC8[0,1] or IOC8[4,5] = 11
30
+10%
mA
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)
23
EM78612
Universal Serial Bus Microcontroller
24 •
Product Specification (V1.1) 04.28.2004
(This specification is subject to change without further notice)