EMC EM78P915 8-bit micro-controller Datasheet

EM78P915
8-BIT MICRO-CONTROLLER
Product
specification v2.0
ELAN MICROELECTRONICS CORP.
No. 12, Innovation 1st RD., Science-Based Industrial Park
Hsin Chu City, Taiwan
TEL: (03) 5639977
FAX: (03) 5630118
EM78P915
8-bit Micro-controller
Version History
Specification revision history for EM78P915
Version
Description
1.1
Add program pin location table
1.2
Pin assignment change, and POR=2.0V, green mode=2.2~5.5V
Oscillator start to stable time will smaller/equal 0.5 sec, remove LCD driving
Ability control
1.3
Add SDT characteristic table
R4 page bit7 (RBF) is modified to Read-only
“End of FSK to carrier detect high” is 5 ms
Update table 24
Modify R7, IOC7, IOCB, value in table 1
1.4
Add interrupt node, note7 and note8 in page3
1.5
Bug modify in page 21
1.6
Add notice about setting code-option and /POVD on/off in page 3.
1.7
Remove DED function, operation voltage = 3.1V at 10.74MHz
1.8
Modify TDP1/2 description in page 34
1.9
Add chip pad diagram, modify /POVD description
2.0
Add P915/915 family list and development tool list in appendix C, D, E, F
Relative to Rom-less, OTP and Mask
Operation voltage
Work clock (Max)
OP
Comparator
Key tone
External INT
LCD
Data Rom
RAM size
Programmable ROM
SDT
Stack
Bi-directional port
DTMF generator
DTMF receiver
Current D/A
MEI/RTF
Call waiting
Low battery detect
SPI
FSK decode
OTP
OTP/ROMLess
OTP
78P911
78P808/78R808
78P915
2.5~5.5V(normal mode) 2.2~5.5V(normal mode) 2.2V~5.5V(normal mode)
3.58MHz
10.74MHz
10.74MHz
X
Yes
X
CMP1
CMP1, 2, 3
CMP1
X
Yes
X
INT0~3
INT0~2
INT0, INT2
SEG0~59,
SEG0~79
SEG0~27,
COM0~15
COM0~23
SEG48~SEG79,
COM0~15
X
256K*8
X
2.5K*8
8K*8
2.5K*8
16K*13
32K*13
32K*13
X
X
Yes
8
32
8
36
51
44
Yes
TONE generator
Current D/A
X
Yes
Yes
X
Yes
Yes
X
X
X
Yes
Yes
Yes
Yes
Comparator
Comparator
X
Yes
Yes
Yes
Yes
Yes
Note
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
User Guide
(Before using this chip, take a look at the following description note, it includes important messages.)
1. You will see some names for the register bits definitions. Some name will be appeared very frequently in the whole spec.
The following describes the meaning for the register’s definitions such as bit type, bit name, bit number and so on.
RA
PAGE0
7
RAB7
R/W-0
Bit type
6
RAB6
R/W-0
5
BAB5
R-1
read/write
(default value=0)
4
RAB4
R/W-1
read/write
(default value=1)
Bit name
Bit number (7 is MSB, 0 is LSB)
Register name and its page,
RA PAGE0 represents address
0x0A of register page 0
3
X
2
RAB2
R
1
RAB1
R-0
read only
(w/o default value)
0
RAB0
R/W
read/write
(w/o default value)
(undefined) not allowed to use
read only
(default value=1)
read only
(default value=0)
Figure 1, Register overview description
2. There are some undefined bits in the registers. The values in these bits are unpredicted. These bits are not allowed to
use. We use the symbol “X” in the spec to recognize them. A fixed value must be written in some specific unused
bits by software or some unpredicted wrong will occur.
These bits are as below.
Register
R5
R6
R6
R7
R7
R8
R9
RE
RE
IOC5
IOC5
IOC5
IOC6
IOC6
IOC7
IOC7
IOC8
IOCA
IOCB
IOCD
IOCE
IOCE
Register
PAGE
0
0
1
0
1
1
1
0
1
0
1
2
0
2
0
1
1
1
1
1
1
1
Default value
Initial Setting value
Bit
7
0
0
7
0
0
7~0
00000000
00000000
6~4
000
000
7~0
00000000
00000000
7~0
00000000
00000000
7~0
00000000
00000000
6~5
00
00
5~4
00
00
7
0
0
7~5
000
000
7~0
00000000
00000000
7,5~4
0,01
0,01
4~3
00
00
6~4
111
111
7~0
00000000
00000000
7~0
00000000
00000000
6~4
111
111
7,5~4
0,01
0,01
7~0
00000000
00000000
1~0
00
00
7~4
000
000
Table 1, initial setting reference in using ICE915
Effect
Power consumption increase
Power consumption increase
Un-expect error
Un-expect error
Un-expect error
Un-expect error
Un-expect error
Power consumption increase
Un-expect error
Power consumption increase
Power consumption increase
Un-expect error
Un-expect error
Power consumption increase
Un-expect error
Un-expect error
Un-expect error
Power consumption increase
Power consumption increase
Power consumption increase
Power consumption increase
Un-expect error
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
3. In the appendix, it provides all operational/special purpose registers, figures and tables list for user to search quickly.
4. While switching main clock (regardless of high freq to low freq or on the other hand), adding 6 instructions delay (NOP) is
required.
5. Please do not switch MCU operation mode from normal mode to sleep mode directly. Before into idle or sleep mode,
please switch MCU to green mode.
6. For DATA RAM least address (A0~A7), when using “INC” instruction and overflow occur, the middle address will
auto_increase. If using “DEC” instruction and least address from 0x00 0xFF, the middle address can’t auto_decrease.
7. With increasing frequency of using interrupt, it may be occur interrupt flag loss. But it could be solved by our suggestion.
So for avoiding any instruction loss, please obey the following program way for now, of course, we already start to enable
our production procedure for reducing the possibility of loss.
Suggestion way,
Clear interrupt flag (RF): change “BC” to “MOV”.
Example: clear bit0 of RF,
Before
Suggestion now
MOV a,@0xFE
BC 0x0f, 0x00
MOV 0x0f,a
8. In the application, some users need latch interrupt flag during disable interrupt mask register (IOCF), but some users don’t
need. In the application of EM78 series, we revise this status to latch. So, users must clear the latch interrupt flag before
enable interrupt mask register. The method how to use instruction is showed as follows,
Example:
IOR
IOCF
MOV RF,A
MOV A,@0x??
IOW IOCF
9. Code-option setting note: Un-used or empty bit of code-option can’t be changed to 0. So, please keep them in 1 to avoid
some un-prediction occur.
10. /POVD setting note: please confirm whether /POVD will be enable or disable before ordering EM78P915. If users still
couldn’t understand, users can get some information from our FAE or sales.
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
I. General Description
The EM78P915 is an 8-bit CID (Call Identification) RISC type microprocessor with low power, high speed CMOS
technology. Integrated onto a single chip are on chip watchdog (WDT), RAM, ROM, programmable real time clock /counter,
internal interrupt, power down mode, LCD driver, FSK decoder, CALL WAITING decoder, SDT detector, current DA
module and tri-state I/O. The EM78P915 provides a single chip solution to design a CID of calling message display.
II. Feature
CPU
Operating voltage: 2.2V~5.5V for normal mode
Main CLK (Hz)
Under
10.74M
0.895M~3.58M
Operating Voltage (min)
2.2V
3.1V
2.2V~5.5V for green mode
32K 13 on chip program ROM
2.5K 8 on chip RAM
Up to 44 bi-directional tri-state I/O ports
8 level stack for subroutine nesting
8-bit real time clock/counter (TCC)
Two independent 8 bits up-counter interrupt.
Selective signal sources and trigger edges , and with overflow interrupt
Programmable free running on chip watchdog timer
99.9
single instruction cycle commands
4 step Normal mode CLK : 0.895 , 1.79 , 3.58 , 10.74 MHz generated by internal PLL.
Four operation modes.
1. Sleep mode: CPU and PLL turn off, 32.768KHz clock turn off
2. Idle mode: CPU and PLL turn off, 32.768KHz clock turn on
3. Green mode: PLL turn off, CPU and 32.768KHz clock turn on
4. Normal mode: PLL turn on, CPU and 32.768KHz clock turn on
Universal Low battery detector
Input port wake up function
9 interrupt source, 6 external, 3 internal
Port key scan function
Clock frequency 32.768KHz
oscillator start to stable time will smaller/equal 0.5 sec
SPI
Serial Peripheral Interface (SPI) : a kind of serial I/O interface
Interrupt flag available for the read buffer full or transmitter buffer empty.
Programmable baud rates of communication
Three-wire synchronous communication.(shared with IO )
CID
Operation Voltage 2.4V 5.5V for FSK
Operation Voltage 2.4V 5.5V for DTMF receiver
Compatible with Bellcore GR-30-CORE (formerly as TR-NWT-000030)
Compatible with British Telecom (BT) SIN227 & SIN242
FSK demodulator for Bell 202 and ITU-T V.23 (formerly as CCITT V.23)
CALL WAITING
Operation Voltage 2.4V 5.5V
Compatible with Bell-core special report SR-TSV-002476
Call-Waiting (2130Hz plus 2750Hz) Alert Signal Detector
Good talk-down and talk-off performance
Sensitivity compensated by adjusting input OP gain
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
LCD
LCD operation voltage chosen by software
Common driver pins : 16
Segment driver pins : 60
1/4 bias
1/8,1/16 duty
Current D/A
Operation Voltage 2.2V~5.5V
10-bit resolution and 3-bit output level
Current D/A output can drive speaker through a transistor for sound player
Can switch output port between DAOUT1 and DAOUT2 by user
SDT (Stutter Dial Tone)
TIA/EIA-855 compatible Stutter Dial Tone detector.
Detect the dual frequencies (350Hz and 440Hz) of SDT signal.
PACKAGE
None, but only for COB
III. Application
1. adjunct units
2. answering machines
3. feature phones
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
IV. Pin Configuration
SEG21
SEG20
SEG19
SEG18
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
1
2
3
4
5
6
SEG17
SEG16
SEG15
SEG14
SEG13
SEG12
SEG11
SEG10
SEG9
SEG8
SEG7
SEG6
SEG5
SEG4
SEG3
SEG2
SEG1
SEG0
COM15
COM14
COM13
COM12
COM11
COM10
COM9
COM8
COM7
COM6
COM5
COM4
COM3
COM2
COM1
COM0
23
24
25
26
27
28
GND
GND
VDTBL
P56
P55
PC6
PC7
P80
P81
P82
P83
P84
P85
P86
96
95
94
93
92
91
90
89
88
87
86
85
84
83
82
81
80
79
78
77
76
75
74
73
72
71
70
69
68
DAOUT2
P66
P63
P62
31
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
29
30
VDTBH
VDD
XIN
XOUT
VDD
PLLC11
RING1
TIP1
EGIN2
EGIN1
CWGS
CWIN
P61
P60
TEST1
RESET
P77
P73
P72
P71
P70
P97
P96
P95
P94
P93
P92
P91
P90
P87
16
17
18
19
20
21
22
SEG22
SEG23
SEG24
SEG25
SEG26
SEG27
PB0
PB1
PB2
PB3
PB4
PB5
PB6
PB7
PC0
PC1
PC2
PC3
PC4
PC5
Figure 2-1, Pad assignment (for chip)
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
COM6
COM7
COM8
COM9
COM10
COM11
COM12
COM13
COM14
COM15
SEG0
SEG1
SEG2
SEG3
SEG4
SEG5
SEG6
SEG7
SEG8
SEG9
SEG10
SEG11
SEG12
SEG13
SEG14
SEG15
EM78P915
8-bit Micro-controller
64
63
62
61
60
59
58
57
56
55
54
53
52
51
50
49
48
47
46
45
44
43
42
41
40
39
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
COM5
COM4
COM3
COM2
COM1
COM0
NC
NC
NC
NC
NC
NC
NC
NC
NC
VDD
XIN
XOUT
VDD
PLLC
RING
TIP
EGIN2
EGIN1
CWGS
CWIN
GND
GND
P56/EST
P55/STGT
DAOUT2
NC
NC
NC
NC
NC
NC
NC
102
101
100
99
98
97
96
95
94
93
92
91
90
89
88
87
86
85
84
83
82
81
80
79
78
77
76
75
74
73
72
71
70
69
68
67
66
65
SEG16
SEG17
SEG18
SEG19
SEG20
SEG21
SEG22
SEG23
SEG24
SEG25
SEG26
SEG27
PB0/SEG48
PB1/SEG49
PB2/SEG50
PB3/SEG51
PB4/SEG52
PB5/SEG53
PB6/SEG54
PB7/SEG55
PC0/SEG56
PC1/SEG57
PC2/SEG58
PC3/SEG59
PC4/SEG60
PC5/SEG61
PC6/SEG62
PC7/SEG63
P80/SEG64
P81/SEG65
P82/SEG66
P83/SEG67
P84/SEG68
P85/SEG69
P86/SEG70
NC
NC
NC
NC
NC
NC
NC
NC
P87/SEG71
P90/SEG72
P91/SEG73
P92/SEG74
P93/SEG75
P94/SEG76
P95/SEG77
P96/SEG78
P97/SEG79
P70/INT0
P71/INT0
P72/INT0
P73/INT0
P77/INT2
/RESET
TEST
P60/SCK
P61/SDO
P62/SDI
P63/CMP1
P66/DAOUT1
Figure 2-2, Pin assignment (for 128 pin QFP)
Package type: EM78P915AQ BD-GR94261 (/POVD disable), EM78P915BQ BD-GR94262 (/POVD enable)
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
V. Functional Block Diagram
120 byte
LCD RAM
Pull high
control
DAOUT1
DAOUT2
Current
DA1
COM0~COM15
SEG0~SEG7
SEG8~SEG27
SEG48~SEG55/PB0~PB7
SEG56~SEG63/PC0~PC7
SEG64~SEG71/P80~P87
SEG72~SEG79/P90~P97
LCD driver
GPIO control
Vin
32K x 13
Program ROM
Comparator
MCU
2.5K x 8
Data RAM
32.768K Hz
XIN
MCLK
Sub OSC
XOUT
PLL
P70~P73/INT0
PORT7
CW
Interrupt
Control
P77/INT2
SDT
detector
TIP
RING
EST
FSK
decoder
Timer 0
TCC
Timer 1
WDT
SPI
(Serial port)
GAIN
CWTIP
P60/SCK
P62/SDI
P61/SDO
DTMF
receiver
STGT
Figure 3, Block diagram1
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
VI. Pin Descriptions
PIN
POWER
VDD
AVDD
I/O
DESCRIPTION
POWER
GND
AVSS
POWER
Digital power
Analog power
They connect together when package as 128 pin QFP.
Digital ground
Analog ground
They connect together when package as 128 pin QFP.
CLOCK
XIN
XOUT
PLLC
I
O
I
Input pin for 32.768 kHz oscillator
Output pin for 32.768 kHz oscillator
Phase loop lock capacitor, connect a capacitor 0.01u to 0.047u
with GND
LCD
COM0..COM15
O
O
SEG0..SEG7
O
SEG8...SEG27
O (I/O: PORTB)
SEG48..SEG55
O (I/O: PORTC)
SEG56..SEG63
O (I/O: PORT8)
SEG64..SEG71
O (I/O: PORT9)
SEG72..SEG79
FSK, TONE, KTONE
TIP
I
RING
I
CW
CWGS
CWIN
DTMF receiver
EST
Common driver pins of LCD drivers
Segment driver pins of LCD drivers
SEG48 to SEG79 are shared with IO PORT.
Should be connected with TIP side of twisted pair lines for FSK.
Should be connected with RING side of twisted pair lines for
FSK.
O
I
Gain adjustment of single-ended input OP Amp
Single-ended input OP Amp for call waiting decoder
O
Early steering output. Presents a logic high immediately when the
digital algorithm detects a recognizable tone-pair (signal
condition). Any momentary loss of signal condition will cause
EST to return to a logic low. This pin shared with PORT56.
Steering input/guard time output (bi-directional). A voltage
greater than Vtst detected at ST causes the device to register the
detected tone-pair and update the output latch.
A voltage less than Vtst frees the device to accept a new tonepair. The GT output acts to reset the external steering timeconstant; its state is a function of EST and the voltage on ST .
This pin shared with PORT55.
STGT
I/O
SERIAL IO
SCK
IO (PORT60)
SDO
O (PORT61)
SDI
I
(PORT62)
Master: output pin, Slave: input pin. This pin shared with
PORT60.
Output pin for serial data transferring. This pin shared with
PORT61.
Input pin for receiving data. This pin shared with PORT62.
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
Comparator
CMP1
CURRENT DA
DAOUT1
I
(PORT63)
O (PORT66)
DAOUT2
IO
P55 ~P56
P60 ~P63,
P66
P70 ~ P73, P77
O
I/O
P80 ~ P87
I/O
P90 ~ P97
I/O
PB0 ~ PB7
I/O
PC0 ~ PC7
I/O
INT0
PORT70…73
INT2
PORT77
TEST
I
/RESET
I
I/O
I/O
Comparator input pins. Shared with PORT63.
Current DA output pin. It can be a control signal for sound
generating.
Shared with PORT66.
Current DA output pin.
PORT 5 can be INPUT or OUTPUT port each bit.
PORT 6 can be INPUT or OUTPUT port each bit.
Internal pull high.
PORT 7 can be INPUT or OUTPUT port each bit.
Internal Pull high function.
Auto key scan function.
Interrupt function.
PORT 8 can be INPUT or OUTPUT port each bit.
Shared with LCD Segment signal.
PORT 9 can be INPUT or OUTPUT port each bit.
Shared with LCD Segment signal.
PORT B can be INPUT or OUTPUT port each bit.
Shared with LCD Segment signal.
PORT C can be INPUT or OUTPUT port each bit.
Shared with LCD Segment signal.
Interrupt sources, which has the same interrupt flag. Any pin from
PORT70 to PORT73 has a falling edge signal, it will generate a
interruption.
Interrupt source. Once PORT77 has a falling edge or rising edge
signal (controlled by CONT register), it will generate a
interruption.
Test pin into test mode for factory test only. Connect it ground in
application.
Low reset
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
VII. Functional Descriptions
VII. 1 Operational Registers
Address
00
01
02
03
04
05
06
07
08
09
0A
0B
0C
0D
R PAGE 0 register
R0
R1 (TCC buffer)
R2 (progam counter)
R3 (status )
R4 (RSR, bank select)
R5 (port55~56, program ROM page)
R PAGE 1 register
R7 (port70~73, 77)
R8 (port80~87)
R9 (port90~97)
RA (CPU mode, clock, FSK, WDT)
RB (portB0~B7)
RC (port C0~C7)
RD (comparator control)
R4 (SPI status and control)
R5 (SPI data buffer)
R6 (unused)
R7 (unused)
R8 (unused)
R9 (unused)
RA (LCD RAM address)
RB (LCD data buffer)
RC (DATA RAM data buffer)
RD (DATA RAM address0~7)
0E
RE (CAS, key scan, LCD control)
RE (DATA RAM address8~11 )
0F
RF (interrupt flag)
R6 (port60~63, 66, /SDT,SDTPWR)
Figure 4, operational registers overview
Address
Control PAGE 0 register
00
01
02
03
04
IOC5 (IOC55, 56, P8S,P9S,PBS, PCS,CASPWR)
05
06
IOC6 (port60~63, 66 IO setting)
07
IOC7 (port70~73, 77 IO setting)
08
IOC8 (port80~87 IO setting)
09
IOC9 (port90~97 IO setting)
0A
IOCA (counter1, 2 prescale and source)
0B
IOCB (portB0~B7 IO setting)
0C
IOCC (portC0~C7 IO setting)
0D
IOCD (counter 1 preset)
0E
IOCE (counter 2 preset)
0F
IOCF (interrupt mask flag)
Control PAGE 1 register
Control PAGE 2 register
IOC5 (LCD bias control, CDAS)
IOC6 (current DA)
IOC7 (Unused)
IOC8 (Unused)
IOC9 (DTMF receiver control)
IOCA (port7 pull high)
IOCB (port6 pull high)
IOC5 (Unused)
IOC6 (port s/w, CDAL)
IOCC (DAoutput2 volume control,DAoutput1/2
switch ,DA0~DA2)
IOCD (Unused)
IOCE (comparator IO set)
IOCE (VRSEL)
Figure 5, Special purpose registers overview
Note1: operational register page0/1 and special purpose register page0/1/2 are different from program page0~31.
Note2: in figure 4, R”X” represents that address “X” of register in the operational register page 0/1.
Note3: in figure 5, IOC”X” represents that address “X” of register in the special purpose register page 0/1/2.
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
Address
10
11
12
13
14
15
16
17
18
19
1A
1B
1C
1D
1E
1F
general
general
general
general
general
general
general
general
general
general
general
general
general
general
general
general
purpose regigter 10
purpose regigter 11
purpose regigter 12
purpose regigter 13
purpose regigter 14
purpose regigter 15
purpose regigter 16
purpose regigter 17
purpose regigter 18
purpose regigter 19
purpose regigter 1A
purpose regigter 1B
purpose regigter 1C
purpose regigter 1D
purpose regigter 1E
purpose regigter 1F
Figure 6, general purpose registers 10 ~ 1F
Address
20
21
22
Bank 0
Bank 1
Bank 2
Bank 3
general purpose regigter 20
general purpose regigter 20
general purpose regigter 20
general purpose regigter 20
general purpose regigter 21
general purpose regigter 21
general purpose regigter 21
general purpose regigter 21
general purpose regigter 22
general purpose regigter 22
general purpose regigter 22
general purpose regigter 22
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
3E
3F
general purpose regigter 3E
general purpose regigter 3E
general purpose regigter 3E
general purpose regigter 3E
general purpose regigter 3F
general purpose regigter 3F
general purpose regigter 3F
general purpose regigter 3F
Figure 7, general purpose registers 20 ~ 3F in Bank0/1/2/3
In figure 4 and 5, if user want to read/write one or more of these registers to enable some functions, user must take care of
the page number of operational register page and special purpose register page. It must be changed to the proper page number
to avoid read/write error occurring.
In figure 6, general purpose registers 10~1F can be read/write anytime without changing operational register pages and
special purpose register pages.
In figure 7, general purpose registers 20~3F are the similar to general purpose registers 10~1F, but user must take care of
bank0/1/2/3 to avoid read/write error occurring.
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
VII. 2 Operational Registers Detail descriptions
R0 (Indirect Addressing Register)
R0 is not a physically implemented register. It is useful as indirect addressing pointer. Any instruction using R0 as
register actually accesses data pointed by the RAM Select Register (R4).
Example:
MOV a, @ 0x20
;store a address at R4 for indirect addressing
MOV 0x04,A
MOV a, @ 0xAA
;write data 0xAA to R20 at bank0 through R0
MOV 0x00,A
R1 (TCC)
TCC Data buffer. Increased by 16.38KHz or by the instruction cycle clock (controlled by CONT register).
Written and read by the program as any other register.
R2 (Program Counter)
The structure is depicted in Figure. 6.
Generates 32K 13 on-chip PROGRAM ROM addresses to the relative programming instruction codes.
"JMP" instruction allows the direct loading of the low 10 program counter bits.
"CALL", this instruction loads the low 10 bits of the PC, PC+1, and then push into the stack.
"RET'' ("RETL k", "RETI") instruction loads the program counter with the contents at the top of stack.
"MOV R2, A" allows the loading of an address from the A register to the PC, and the ninth and tenth bits are cleared to
"0''.
"ADD R2, A" allows a relative address be added to the current PC, and contents of the ninth and tenth bits are cleared to
"0''.
"TBL" allows a relative address be added to the current PC, and contents of the ninth and tenth bits don't change. The
most significant bit (A10~A14) will be loaded with the content of bit PS0~PS3 in the status register (R5) upon the
execution of a "JMP'', "CALL'', "ADD R2, A'', or "MOV R2, A'' instruction.
If a interrupt trigger, PROGRAM ROM will jump to address8 at page0. The CPU will store ACC, R3 status and R5 PAGE
automatically, it will restore after instruction RETI.
R5 (Program PAGE)
CALL and
interrupt
PC
A14 A13 A12 A11 A10
00000
00001
11111
Mapping
A9 A8
A7 ~ A0
PAGE number
PAGE 0
PAGE 1
Address
0000~03FF
0400~07FF
PAGE 31
7C00~7FFF
stack 1
stack 2
store
.
.
.
stack 7
stack 8
ACC, R3 and
R5(program PAGE)
restore
Figure 8, program counter organization
R3 (Status Register)
PAGE 0
7
6
PAGE
IOCP1S
R/W-0
R/W-0
5
IOCPAGE
R/W-0
4
T
R/W-X
3
P
R/W-X
2
Z
R/W-X
1
DC
R/W-X
0
C
R/W-X
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
Bit 0 (C): Carry flag
Bit 1 (DC): Auxiliary carry flag
Bit 2 (Z): Zero flag
Bit 3 (P): Power down bit.
Set to 1 during power on or by a "WDTC" command and reset to 0 by a "SLEP" command.
Bit 4 (T): Time-out bit.
Set to 1 by the "SLEP" and "WDTC" command, or during power up and reset to 0 by WDT timeout.
EVENT
T
P
REMARK
WDT wake up from sleep mode
0
0
WDT time out (not sleep mode)
0
1
/RESET wake up from sleep
1
0
Power up
1
1
Low pulse on /RESET
x
x
x : don't care
Table 2, Event for power down bit and timer out bit
Bit 5(IOCPAGE): change IOC5 ~ IOCE to another page
Please refer to Fig.4 control register configuration for details.
0/1
page0 / page1
Bit 6(IOCP1S): change IOC PAGE1 and PAGE2 to another option register
Please refer to Fig.4 control register configuration for details.
0/1
page1 /page2
Bit 6(IOCP1S)
Bit 5 (IOCPAGE)
PAGE SELECT
X
0
PAGE 0
0
1
PAGE 1
1
1
PAGE 2
Table 3, relation with IOCP1S bit and IOCPAGE bit
Bit 7(PAGE): change R4 ~ RE to another page
Please refer to Fig.4 control register configuration for details.
R4 (RAM selection for common registers R20 ~ R3F, SPI)
PAGE 0 (RAM selection register)
7
6
5
4
3
2
1
0
RB1
RB0
RSR5
RSR4
RSR3
RSR2
RSR1
RSR0
R/W-0
R/W-0
R/W-X
R/W-X
R/W-X
R/W-X
R/W-X
R/W-X
Bit 0 ~ Bit 5 (RSR0 ~ RSR5): Indirect addressing for common registers R20 ~ R3F
RSR bits are used to select up to 32 registers (R20 to R3F) in the indirect addressing mode.
Bit 6 ~ Bit 7 (RB0 ~ RB1): Bank selection bits for common registers R20 ~ R3F
These selection bits are used to determine which bank is activated among the 4 banks for 32 register (R20 to R3F)..
Please refer to Fig.4 control register configuration for details.
PAGE 1 (SPI control register)
7
6
5
4
3
2
1
0
RBF
SPIE
SRO
SE
SCES
SBR2
SBR1
SBR0
R-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
Fig. 6 shows how SPI to communicate with other device by SPI module. If SPI is a master controller, it sends clock through
the SCK pin. An 8-bit data is transmitted and received at the same time. If SPI, however, is defined as a slave, its SCK pin
could be programmed as an input pin. Data will continue to be shifted on a basis of both the clock rate and the selected edge.
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
SDO
SDI
Master Device
Salve Device
R5 page1
SPI data buffer
SPIR register
SPIW register
SPIS Reg
SDI
SDO
SCK
SCK
SPI module
Bit 0
Bit7
Figure 9, Single SPI Master / Salve Communication
Bit 0 ~ Bit 2 (SBR0 ~ SBR2): SPI baud rate selection bits
SBR2
0
0
0
0
1
1
1
1
SBR1
0
0
1
1
0
0
1
1
SBR0
0
1
0
1
0
1
0
1
Mode
Master
Master
Master
Master
Master
Master
Slave
Baud rate
Fsco
Fsco/2
Fsco/4
Fsco/8
Fsco/16
Fsco/32
X
Table 4, SPI baud rate selection
<Note> Fsco = CPU instruction clock
For example:
If PLL enable and RA PAGE0 (Bit5, Bit4)=(1,1), instruction clock is 3.58MHz/2
Fsco=3.5862MHz/2
If PLL enable and RA PAGE0 (Bit5, Bit4)=(0,0), instruction clock is 0.895MHz/2
Fsco=0.895MHz/2
If PLL disable, instruction clock is 32.768kHz/2
Fsco=32.768kHz/2.
Bit 3 (SCES): SPI clock edge selection bit
1 Data shifts out on falling edge, and shifts in on rising edge. Data is hold during the high level.
0 Data shifts out on rising edge, and shifts in on falling edge. Data is hold during the low level.
Bit 4 (SE): SPI shift enable bit
1
Start to shift, and keep on 1 while the current byte is still being transmitted.
0
Reset as soon as the shifting is complete, and the next byte is ready to shift.
<Note>: This bit has to be reset in software.
Bit 5 (SRO): SPI read overflow bit
1
A new data is received while the previous data is still being hold in the SPIB register. In this situation, the data in SPIS
register will be destroyed. To avoid setting this bit, users had better to read SPIB register even if the transmission is
implemented only.
0
No overflow
<Note>: This can only occur in slave mode.
Bit 6 (SPIE): SPI enable bit
1
Enable SPI mode
0
Disable SPI mode
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
Bit 7 (RBF): SPI read buffer full flag
1
Receive is finished, SPIB is full.
0
Receive is not finish yet, SPIB is empty.
Write
R5
Read
R5
RBF
RBFI
SPIWC
SPIR reg.
SPIW reg.
set to 1
SPIE
SDI/P62
Buffer Full Detector
SDI
MUX
SPIS reg.
shift right
PORT62
bit 0
bit 7
SDO
SDO/P61
MUX
SPIC reg. (R4 page1)
PORT61
Edge
Select
SPIE
0
3
SBR0 ~SBR2
Noise
Filter
SBR2~SBR0
3
2
Clock Select
Tsco
Prescaler
4, 8, 16, 32, 64, 128
Edge
Select
16.38kHz
SCK
PORT60
MUX
SCK/P60
SCK
SPIE
Figure 10, SPI structure
SPIC reg.: SPI control register
SDO/P61: Serial data out
SDI/P62: Serial data in
SCK/P60: Serial clock
RBF: Set by buffer full detector, and reset in software.
RBFI: Interrupt flag. Set by buffer full detector, and reset in software.
Buffer Full Detector: Sets to 1, while an 8-bit shifting is complete.
SE: Loads the data in SPIW register, and begin to shift
SPIE: SPI control register
SPIS reg.: Shifting byte out and in. The MSB will be shifted first. Both the SPIS register and the SPIW register are
loaded at the same time. Once data being written to, SPIS starts transmission / reception. The received data
will be moved to the SPIR register, as the shifting of the 8-bit data is complete. The RBF (Read Buffer Full)
flag and the RBFI (Read Buffer Full Interrupt) flag are set.
SPIR reg.: Read buffer. The buffer will be updated the 8-bit shifting is complete. The data must be read before the next
reception is finished. The RBF flag is cleared as the SPIR register read.
SPIW reg.: Write buffer. The buffer will deny any write until the 8-bit shifting is complete. The SE bit will be kept in 1
if the communication is still under going. This flag must be cleared as the shifting is finished. Users can
determine if the next write attempt is available.
SBR2 ~ SBR0: Programming the clock frequency/rates and sources.
Clock select: Selecting either the internal instruction clock or the external 16.338KHz clock as the shifting clock.
Edge Select: Selecting the appropriate clock edges by programming the SCES bit
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
SCK
(SCES=0)
SCK
(SCES=1)
Bit7
Bit6
B it5
Bit4
Bit3
B it2
Bit1
B it0
SDO
SDI
RBF
Shift data in
Shift data out
Clear by software
Figure 11, SPI timing
R5 (PORT5 I/O data, Program page selection, SPI data)
PAGE 0 (PORT5 I/O data register, Program page register)
7
6
5
4
3
X
R56
R55
PS4
PS3
R/W-0
R/W-0
R/W-0
R/W-0
Bit 0 ~ Bit 4 (PS0 ~ PS4): Program page selection bits
PS4
0
0
0
0
:
:
1
1
PS3
0
0
0
0
:
:
1
1
2
PS2
R/W-0
1
PS1
R/W-0
0
PS0
R/W-0
PS2 PS1 PS0 Program memory page (Address)
0
0
0 Page 0
0
0
1 Page 1
0
1
0 Page 2
0
1
1 Page 3
:
:
: :
:
:
: :
1
1
0 Page 30
1
1
1 Page 31
Table 5, program page selection
User can use PAGE instruction to change page to maintain program page by user. And the program page is maintained
by EMC's complier. It will change user's program by inserting instructions within program.
Bit 5 ~ Bit 6 (P55 ~ P56): 2-bit PORT55~56 I/O data register
User can use IOC5 page0 register to define input or output each bit.
Bit 7(Unused)
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
PAGE 1 (SPI data buffer)
7
6
5
4
3
2
1
0
SPIB7
SPIB6
SPIB5
SPIB4
SPIB3
SPIB2
SPIB1
SPIB0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
Bit 0 ~ Bit 7 (SPIB0 ~ SPIB7): SPI data buffer
If you write data to this register, the data will write to SPIW register. If you read this data, it will read the data from
SPIR register. Please refer to figure7
R6 (PORT6 I/O data)
PAGE 0 (PORT6 I/O data register)
7
6
5
4
3
2
1
0
X
P66
SDTPWR
/SDT
P63
P62
P61
P60
R/W-0
R/W-0
R
R/W-0
R/W-0
R/W-0
R/W-0
Bit 0 ~ Bit 3, Bit 6 (P60 ~ P63, P66): 8-bit PORT60~63, PORT66 I/O data register
User can use IOC6 page0 register to define input or output each bit.
Bit 4 (/SDT): Data of /SDT, “0” is expressed the valid signal and “1” is expressed the invalid.
Bit 5 (SDTPWR): Control SDT on/off by 1/0.
Bit 7 (Unused)
PAGE 1 (Unused)
7
6
X
X
5
X
4
X
3
X
2
X
1
X
0
X
Bit 0 ~ Bit 7 (Unused)
R7 (PORT7 I/O data)
PAGE 0 (PORT7 I/O data register)
7
6
5
4
3
2
1
P77
X
X
X
P73
P72
P71
R/W-0
R/W-0
R/W-0
R/W-0
Bit 0 ~ Bit 4, Bit 7(P70 ~ P73, P77): 8-bit PORT70~74, PORT77 I/O data register
User can use IOC7 page0 register to define input or output each bit.
Bit 4 ~ 6(Unused)
PAGE 1 (Unused)
7
6
X
X
5
X
4
X
3
X
2
X
0
P70
R/W-0
1
X
0
X
1
P81
R/W-0
0
P80
R/W-0
1
X
0
X
Bit 0 ~ Bit 7 (Unused)
R8 (PORT8 I/O data)
PAGE 0 (PORT8 I/O data register)
7
6
5
4
3
2
P87
P86
P85
P84
P83
P82
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
Bit 0 ~ Bit 7 (P80 ~ P87): 8-bit PORT8 ( 0~7 ) I/O data register
User can use IOC8 page0 register to define input or output each bit.
PAGE 1 (Unused)
7
6
X
X
5
X
4
X
3
X
2
X
Bit 0 ~ Bit 7 (Unused)
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
R9 (PORT9 I/O data)
PAGE 0 (PORT9 I/O data register)
7
6
5
4
3
2
P97
P96
P95
P94
P93
P92
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
Bit 0 ~ Bit 7 (P90 ~ P97): 8-bit PORT9 (0~7 ) I/O data register
User can use IOC9 page0 register to define input or output each bit.
PAGE 1 (Unused)
7
6
X
X
5
X
4
X
3
X
2
X
1
P91
R/W-0
0
P90
R/W-0
1
X
0
X
Bit 0 ~ Bit 7 (Unused)
RA (CPU power saving, PLL, Main clock selection, FSK, Watchdog timer, LCD address)
PAGE 0 (CPU power saving bit, PLL, Main clock selection bits, FSK, Watchdog timer enable bit)
7
6
5
4
3
2
1
0
IDLE
PLLEN
CLK1
CLK0
FSKPWR FSKDATA
/CD
WDTEN
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R
R
R/W-0
Bit 0 (WDTEN): Watch dog control register
User can use WDTC instruction to clear watch dog counter. The counter 's clock source is 32768/2 Hz. If the prescaler
assigns to TCC. Watch dog will time out by (1/32768)*2 * 256 = 15.616ms. If the prescaler assigns to WDT, the time of
time out will be more times depending on the ratio of prescaler.
0/1
disable/enable
Bit 1 (/CD): FSK carrier detect indication
0/1
Carrier Valid/Carrier Invalid
It's a read only signal. If FSK decoder detect the energy of mark or space signal. The Carrier signal will go to low level.
Otherwise it will go to high.. Note!! Should be at normal mode.
Bit 2 (FSKDATA): FSK decoding data output
It's a read only signal. If FSK decode the mark or space signal , it will output high level signal or low level signal at this
register. It's a raw data type. That means the decoder just decode the signal and has no process on FSK signal. Note!!
Should be at normal mode.
User can use FSK data falling edge interrupt function to help data decoding.
Ex:
MOV A,@01000000
IOW IOCF
;enable FSK interrupt function
CLR
RF
ENI
;wait for FSK data's falling edge
:
0 = Space data ( 2200Hz )
1 = Mark data (1200Hz)
Bit 3 (FSKPWR): FSK power control
0/1
FSK decoder powered down / FSK decoder powered up
It's the control register of FSK block power.
The relation between bit 1 to bit 3 is shown in Figure.10. You have to power FSK decoder up first, then wait a setup time
(Tsup) and check carrier signal (/CD). If the carrier is low, program can process the FSK data.
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
FIRST RING
2 SECONDS
0.5 SEC
0.5 SEC
SECOND RING
2 SECONDS
FSK signal
TIP/RING
Tcdl
Tcdh
/CD
Tdoc
FSKDATA
DATA
Tsup
/FSKPWR
Figure 12, the relation between bit 1 ~ bit 3 of FSK in RA
The controller is a CMOS device designed to support the Caller Number Deliver feature which is offered by the
Regional Bell Operating Companies. The FSK block comprises one path: the signal path. The signal path consist of an
input differential buffer, a band pass filter, an FSK demodulator and a data valid with carrier detect circuit.
In a typical application, user can use his own external ring detect output as a triggering input to IO port. User can use
this signal to wake up whole chip by external ring detect signal.
By setting “1” to bit 3 (FSKPWR) of register RA to activate the block of FSK decoder. If bit 3 (FSKPWR) of register
RA is set to “0”, the block of FSK decoder will be powered down.
The input buffer accepts a differential AC coupled input signal through the TIP and RING input and feeds this signal to
a band pass filter. Once the signal is filtered, the FSK demodulator decodes the information and sends it to a post filter.
The output data is then made available at bit 2 (FSKDATA) of register RA. This data, as sent by the central office,
includes the header information (alternate "1" and "0") and 150 ms of marking which precedes the date, time and calling
number. If no data is present, the bit 2 (DATA) of register RA is held on “1” state. This is accomplished by an carrier
detect circuit which determines if the in-band energy is high enough. If the incoming signal is valid, bit 1 (/CD) of
register RA will be “0” otherwise it will be held on “1”. And thus the demodulated data is transferred to bit 2 (DATA) of
register RA. If it is not, then the FSK demodulator is blocked.
Bit 4 ~ Bit 5 (CLK0 ~ CLK1): Main clock selection bits
User can choose different frequency of main clock by CLK1 and CLK2. All the clock selection is list below.
PLLEN
CLK1
1
1
1
1
0
0
0
0
0
0
1
1
Don’t care
Don’t care
Don’t care
Don’t care
CLK0
Sub clock
MAIN clock
CPU clock
0
32.768kHz
895.658kHz 895.658kHz (Normal mode)
1
32.768kHz
1.7913MHz 1.7913MHz (Normal mode)
0
32.768kHz
10.7479MHz 10.7479MHz (Normal mode)
1
32.768kHz
3.5826MHz 3.5826MHz (Normal mode)
don’t care
32.768kHz
Don’t care
32.768kHz (Green mode)
don’t care
32.768kHz
Don’t care
32.768kHz (Green mode)
don’t care
32.768kHz
Don’t care
32.768kHz (Green mode)
don’t care
32.768kHz
Don’t care
32.768kHz (Green mode)
Table 6, main clock selection
Bit 6 (PLLEN): PLL enable control bit
It is CPU mode control register. If PLL is enabled, CPU will operate at normal mode (high frequency, main clock);
otherwise, it will run at green mode (low frequency, 32768 Hz).
0/1
disable/enable
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
3.5826MHz to analog circuit
4 =>895.658kHz
2 =>1.7913MHz
1 =>3.5826MHz
3 =>10.7479MHz
PLL
Sub-clock
32.768kHz
ENPLL
1
switch
System clock
0
CLK1 ~ CLK0
Figure 13, the relation between 32.768kHz and PLL
Bit 7 (IDLE): power saving mode control register
When PLL is disable, users can set this bit after using “SLEP” instruction for SLEEP mode or IDLE
mode selection.
0/1 -> SLEEP/IDLE
this bit will decide SLEP instruction which to go.
The status after wake-up and the wake-up sources list as the table below.
Wakeup signal
TCC time out
IOCF bit 0=1
And "ENI"
COUNTER1 time out
IOCF bit 1=1
And "ENI"
COUNTER2 time out
IOCF bit 2=1
And "ENI"
WDT time out
SLEEP mode
RA(7,6)=(0,0)
+ SLEP
No function
IDLE mode
RA(7,6)=(1,0)
+ SLEP
GREEN mode
RA(7,6)=(x,0)
no SLEP
Interrupt
(1) wake-up
(jump to address 8
(2) interrupt
(jump to address 8 at page0)
at page 0)
(3) after RETI
instruction, jump to
SLEP next
instruction
No function
(1) wake-up
(2) interrupt
(jump to address 8
at page 0)
(3) after RETI
instruction, jump to
SLEP next
instruction
No function
(1) wake-up
(2) interrupt
(jump to address 8
at page 0)
(3) after RETI
instruction, jump to
SLEP next
instruction
RESET and
(1) wake-up
Jump to address (2) next instruction
0
NORMAL mode
RA(7,6)=(x,1)
no SLEP
Interrupt
(jump to address
8 at page0)
Interrupt
Interrupt
(jump to address 8 (jump to address
at page0)
8 at page0)
Interrupt
Interrupt
(jump to address 8 (jump to address
at page0)
8 at page0)
RESET and Jump RESET and
to address 0
Jump to address
0
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
PORT7
IOCF bit3 or bit5 = 1
And "ENI"
Interrupt
Interrupt
RESET and
(1) wake-up
(jump to address 8 (jump to address
Jump to address (2) interrupt
8 at page0)
0
(jump to address 8 at page0)
at page 0)
(3) after RETI
instruction, jump to
SLEP next
instruction
Table 7, sleep/green/normal modes with wake up signal
<Note> Stack overflow interrupt function is exist in ROM less and OTP chip only.
<Note> PORT70 ~ PORT73 's wakeup function is controlled by IOCF bit3 and ENI instruction. They are falling edge
trigger.
PORT77 's wakeup function is controlled by IOCF bit5 and ENI instruction. It's falling edge or rising edge trigger (controlled
by CONT register).
PAGE 1 (LCD address)
7
6
5
4
3
2
1
0
LCDA7
LCDA6
LCDA5
LCDA 4
LCDA 3
LCDA 2
LCDA 1
LCDA 0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
Bit 0 ~ Bit 7 (LCDA0 ~ LCDA7): LCD address for LCD RAM reading or writing
The data in the LCD RAM correspond to the COMMON and SEGMENT signals as the table.
COM15 ~COM8
COM7 ~ COM0
(set R9 PAGE1 bit7=0) (set R9 PAGE1 bit7=0)
Address 80H
Address 00H
Address 81H
Address 01H
Address 82H
Address 02H
:
:
Address 9BH
Address 1BH
Address 9CH
Address 1CH
:
:
Address AFH
Address 2FH
Address B0H
Address 30H
:
:
Address CEH
Address 4EH
Address CFH
Address 4FH
Address D0H
Address 50H
:
:
Address FFH
Address 7FH
Table 8, Common/Segment signal
RB (PORTB I/O data, LCD data)
PAGE 0 (PORTB I/O data register)
7
6
5
4
3
2
PB7
PB6
PB5
PB4
PB3
PB2
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
Bit 0 ~ Bit 7 (PB0 ~ PB7): 8-bit PORTB0~B7 I/O data register
User can use IOCB page0 register to define input or output each bit.
SEG0
SEG1
SEG2
:
SEG27
Empty
:
Empty
SEG48
:
SEG78
SEG79
Empty
:
Empty
1
PB1
R/W-0
0
PB0
R/W-0
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
PAGE 1 (LCD data buffer)
7
6
5
4
3
2
1
LCDD7
LCDD6
LCDD5
LCDD4
LCDD3
LCDD2
LCDD1
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
Bit 0 ~ Bit 7 (LCDD0 ~ LCDD7): LCD data buffer for LCD RAM reading or writing
Example.
MOV A, @0
MOV
R9_PAGE1, A
MOV RA_PAGE1, A
;ADDRESS
MOV A, @0XAA
MOV RB_PAGE1, A
;WRITE DATA 0XAA TO LCD RAM
MOV A, RB_PAGE1
;READ DATA FROM LCD RAM
RC (PORTC I/O data, Data RAM data)
PAGE 0 (PORTC I/O data register)
7
6
5
4
3
2
PC7
PC6
PC5
PC4
PC3
PC2
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
Bit 0 ~ Bit 7 (PC0 ~ PC7): 8-bit PORTC0~C7 I/O data register
User can use IOCC page0 register to define input or output each bit.
1
PC1
R/W-0
0
LCDD0
R/W-0
0
PC0
R/W-0
PAGE 1 (Data RAM data buffer)
7
6
5
4
3
2
1
0
RAMD7
RAMD6
RAMD5
RAMD4
RAMD3
RAMD2
RAMD1
RAMD0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
Bit 0 ~ Bit 7 (RAMD0 ~ RAMD7): Data RAM data buffer for RAM reading or writing.
Example.
MOV
A , @1
MOV
RD_PAGE1 , A
MOV
A , @0
MOV
RE_PAGE1 , A
MOV
A , @0x55
MOV
RC_PAGE1 , A
;write data 0x55 to DATA RAM which address is "0001".
MOV
A , RC_PAGE1
;read data
RD (Comparator control, Data RAM address (0 ~ 7))
PAGE 0 (Comparator control bits)
7
6
5
4
3
2
1
0
CMPEN CMPFLAG CMPS1
CMPS0
CMP_B3
CMP_B2
CMP_B1
CMP_B0
R/W-0
R
R-0
R-0
R/W-0
R/W-0
R/W-0
R/W-0
If user define the PORT63 (by CMPIN1 at IOCE page1) to a comparator input. User can use this register to control
comparator's function.
Bit 0~Bit 3(CMP_B0~CMP_B3): Reference voltage selection of internal bias circuit for comparator.
Reference voltage for comparator =
VDD
n 0.5
, for
16
n
0 ~ 15
Bit 4~Bit 5(CMPS0~CMPS1): Channel selection to CMP1
CMPS1
CMPS0
Input
0
0
CMP1
Table 9, channel selection of CMP
Bit 6(CMPFALG): Comparator output flag
0
Input voltage < reference voltage
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
1
Input voltage > reference voltage
Bit 7(CMPEN): Enable control bit of comparator.
0/1
disable/enable, when this bit is set to “0”, 2.0V ref circuit is also powered off.
CM PEN
CM P1
refere n c e
v o lta g e
S e tu p tim e 1 0 u s
C P U c lo c k
CM PFLA G
C o m p a re s ta rt
C om pare end
Figure 14, Comparator timing
CMP1
P63/CMP1
MUX
+
CMPFLAG
PORT63
-
CMPIN1
VDD
V2_0
ref.
2.0V
MUX
CMPEN
VRSEL
VR
1/2R
1111
R
1110
R
CMPEN
MUX
0000
1/2R
4
CMP_B3 to CMP_B0
Figure 15, Comparator circuit
If users want to enable/disable 2.0V to be reference voltage, please refer to bit7 (VRSEL) of IOCE page 2.
PAGE 1 (Data RAM address0 ~ address7)
7
6
5
4
3
2
1
0
RAMA7
RAMA6
RAMA5
RAMA4
RAMA3
RAMA2
RAMA1
RAMA0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
Bit 0~Bit 7(RAMA0~RAMA7): Data RAM address (address0 to address7) for RAM reading or writing
Note: if users read address, which out the range (2.5K), the data maybe a random value or previous data.
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
RE (CAS, Key scan, LCD control, Data RAM address (8 ~ 11))
PAGE 0 (Key scan control, LCD control)
7
6
5
4
3
2
1
0
CAS
X
X
KEYSCAN
LCD1
LCD0
LCDM1
LCDM0
R
R/W-0
R/W-0
R/W-0
R/W-0
R-0
Bit 0~Bit 1(LCDM0~LCDM1): LCD common mode, bias select and COM/SEG switch control bits
LCDM1, LCDM0
0,0
0,1
1,0
1,1
COM output mode LCD bias
16 common
1/4 bias
Unused
8 common
1/4 bias
Unused
Table 10, LCD common mode
COM/SEG switch
SEG0 ~ SEG7 select
SEG0 ~ SEG7 select
<Note> When 8 and 16 LCD common mode is set, SEG0 ~ SEG7 and LCD bias is 1/4 bias.
Bit 2~Bit 3 (LCD0~LCD1): LCD operation function definition.
LCD1, LCD0
LCD operation
0,0
Disable
0,1
Blanking
1,0
Reserved
1,1
LCD enable
Table 11, LCD operation function define
The controller can drive LCD directly. LCD block is made up of LCD driver, display RAM, segment output pins,
common output pins and LCD operating bias pins.
Duty, the number of segment , the number of common and frame frequency are determined by LCD mode register RE
PAGE0 Bit 0~ Bit 1.
The basic structure contains a timing control, which uses the basic frequency 32.768kHz to generate the proper timing
for different duty and display access. RE PAGE1 register is a command register for LCD driver and display. The LCD
display (disable, enable, blanking) is controlled by RE PAGE0 Bit 2 ~ Bit 3 and the driving duty is decided by RE
PAGE Bit 0 ~ Bit 2. LCD display data is stored in data RAM which address and data access controlled by registers RA
PAGE1 and RB PAGE1.
User can regulate the contrast of LCD display by IOC5 PAGE1 (BIAS3..BIAS0). Up to 16 levels contrast is
convenient for better display. And the internal voltage follower can afford large driving source.
COM signal: The number of COM pins varies according to the duty cycle used, as following:
In 1/8 duty mode COM8 ~ COM15 must be open.
In 1/16 duty mode COM0 ~ COM15 pins must be used.
Duty
COM0 ~ COM7
1/8
o
1/16
o
x : open, o : select
COM8 COM9
x
x
o
o
..
..
..
COM15
x
o
Table 12, relation with Duty mode and COM
SEG signal: The segment signal pins are connected to the corresponding display RAM. The high byte to the low byte
Bit 0 ~ Bit 7 are correlated to COM0 ~ COM15 respectively. When a bit of display RAM is 1, a select signal is sent to
the corresponding segment pin, and when the bit is 0, a non-select signal is sent to the corresponding segment pin.
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
Bit 4(KEYSCAN): Key scan function enable control bit
0/1
disable/enable
If you enable key scan function LCD waveform will has a small pulse within a period like Fig.14.
frame
COM0..COM7/COM15
vdd
v1
v2
v3
vlcd
gnd
COM2
vdd
v1
v2
v3
vlcd
gnd
SEG
30us
Figure 16, key scan waveform for 1/8, 1/16 duty
Bit 5(Unused)
Bit 6(Unused)
RELATION BETWEEN SEG , KEYSCAN
KEY SCAN PULSE
KEY SCAN
CONTROL
SEGMENT
Figure 17, KEYSCAN and segments
Bit 7(CAS): CALL WAITING decoding output
0/1
CW data valid / No data
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
Software design flow:
Step1: Port70 ~ port73 set to input mode
Step2: Port70~port73 pull high
Step3: Enable key scan signal
Step4: Once push a key. Set RA bit6 = “1” and switch to normal mode
Step5: Blank LCD. Disable scan key signal
Step6: Set portX as normal i/o. PortX sent probe signal to port70~73 and read port70~73. Get the key.
Note: a probe signal should be delay a instruction at least to another probe signal
Step7: Set portX to SEG port, enable LCD.
Note: one port must be port70~73 (INT0), and another port is the shared port like port9, port8, portC and portB.
PAGE 1 (Data RAM address8 ~ address11)
7
6
5
4
X
X
X
X
3
2
1
0
RAMA11 RAMA10
RAMA9
RAMA8
R/W-0
R/W-0
R/W-0
R/W-0
Bit 0~Bit 4(RAMA8~RAMA11) : Data RAM address (address8 to address11) for RAM reading.
Bit 6 (Unused)
Bit 7 (Unused)
RF (Interrupt flags)
7
6
5
4
3
2
1
0
RBF/SDT FSK/CW
INT2
SDTI
INT0
CNT2
CNT1
TCIF
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
"1" means interrupt request, "0" means non-interrupt
Bit 0(TCIF): TCC timer overflow interrupt flag
Set when TCC timer overflows.
Bit 1(CNT1): Counter1 timer overflow interrupt flag
Set when counter1 timer overflows.
Bit 2(CNT2): Counter2 timer overflow interrupt flag
Set when counter2 timer overflows.
Bit 3(INT0): External INT0 pin interrupt flag
If PORT70, PORT7, PORT72 or PORT73 has a falling edge trigger signal. CPU will set this bit.
Bit 4(SDTI): SDT interrupt flag
Set when receive a SDT valid data.
Bit 5(INT2): External INT2 pin interrupt flag
If PORT77 has a falling edge or rising edge (controlled by CONT register) trigger signal. CPU will set this bit.
Bit 6(FSK/CW): FSK data or Call waiting data interrupt flag.
If FSKDATA or CAS has a falling edge trigger signal, CPU will set this bit.
Bit 7(RBF/STD): SPI data transfer complete or DTMF receiver signal valid interrupt
If serial IO 's RBF signal has a rising edge signal (RBF set to "1" when transfer data completely), CPU will set this bit.
Or DTMF receiver's STD signal has a rising edge signal (DTMF decode a DTMF signal).
IOCF is the interrupt mask register. User can read and clear.
Trigger edge as the table
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
Signal
TCC
COUNTER1
COUNTER2
INT0
SDTI
INT2
FSK
RBF/STD
Trigger
<Note>
Time out
Time out
Time out
Falling edge
SDT valid data
Falling/Falling & rising edge Controlled by CONT register
Falling edge
Rising edge
Table 13, interrupt trigger
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
R10~R3F (General Purpose Register)
R10~R3F (Banks 0 ~ 3): All of them are general purpose registers.
VII. 2 Special Purpose Registers
A (Accumulator)
Internal data transfer, or instruction operand holding
It's not an addressable register.
CONT (Control Register)
7
6
5
4
INT_EDGE
INT
TS
X
R/W-1
R/W-1
R/W-1
R/W-1
Bit 0~Bit 2(PSR0~PSR2): TCC/WDT prescaler bits
PSR2
0
0
0
0
1
1
1
1
3
PAB
R/W-1
2
PSR2
R/W-1
PSR1
PSR0
TCC rate
0
0
1:2
0
1
1:4
1
0
1:8
1
1
1:16
0
0
1:32
0
1
1:64
1
0
1:128
1
1
1:256
Table 14, pre-scale of TCC and WDT
1
PSR1
R/W-1
0
PSR0
R/W-1
WDT rate
1:1
1:2
1:4
1:8
1:16
1:32
1:64
1:128
Bit 3(PAB): Prescaler assignment bit
0/1
TCC/WDT
Bit 4: undefined
Bit 5(TS): TCC signal source
0
Instruction clock
1
16.384kHz
Instruction clock = MCU clock/2, Refer to RA Bit 4 ~ Bit 6 for PLL and Main clock selection. See fg.17.
Bit 6(INT): INT enable flag
0
interrupt masked by DISI or hardware interrupt
1
interrupt enabled by ENI/RETI instructions
Bit 7(INT_EDGE): interrupt edge type of P77
0 77 's interruption source is a rising edge signal and falling edge signal.
1
P77 's interruption source is a falling edge signal.
CONT register is readable (CONTR) and writable (CONTW).
TCC and WDT:
There is an 8-bit counter available as prescaler for the TCC or WDT. The prescaler is available for the TCC only or WDT
only at the same time.
An 8 bits counter is available for TCC or WDT determined by the status of the bit 3 (PAB) of the CONT register.
See the prescaler ratio in CONT register.
Fig.16 depicts the circuit diagram of TCC/WDT.
Both TCC and prescaler will be cleared by instructions which write to TCC each time.
The prescaler will be cleared by the WDTC and SLEP instructions, when assigned to WDT mode.
The prescaler will not be cleared by SLEP instructions, when assigned to TCC mode.
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
Data
Bus
Instruction clock
16.384kHz
M
U
X
M
U
X
TS
W DT
WDTE
SYNC
2 cycles
TCC overflow interrupt
PAB
M
U
X
T CC(R1)
8-bit Counter
PSR0 ~
PSR2
8-to-1 MUX
PAB
M UX
PAB
WDT timeout
Figure 18, TCC/WDT structure
ins
Figure 19, TCC timing
IOC5 (PORT5 I/O control, PORT switch, CDAS, LCD bias, CASPWR)
PAGE 0 (PORT5 I/O control register, PORT switch)
7
6
5
4
3
2
1
0
X
IOC56
IOC55
CASPWR
P9SH
P9SL
P8SH
P8SL
R/W-1
R/W-1
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
Bit 0 (P8SL): Switch low nibble I/O PORT8 or LCD segment output for share pins SEGxx/P8x pins
0
select normal P80 ~ P83 for low nibble PORT8
1
select SEG64 ~ SEG67 output for LCD SEGMENT output.
Bit 1 (P8SH): Switch high nibble I/O PORT8 or LCD segment output for share pins SEGxx/P8x pins
0
select normal P84 ~ P87 for high nibble PORT8
1
select SEG68 ~ SEG71 output for LCD SEGMENT output.
Bit 2 (P9SL): Switch low nibble I/O PORT9 or LCD segment output for share pins SEGxx/P9x pins
select normal P90 ~ P93 for low nibble PORT9
0
1
select SEG72 ~ SEG75 output for LCD SEGMENT output.
Bit 3 (P9SH): Switch high nibble I/O PORT9 or LCD segment output for share pins SEGxx/P9x pins
0
select normal P94 ~ P97 for high nibble PORT9
1
select SEG76 ~ SEG79 output for LCD SEGMENT output.*Bit 4:general register
Bit 4 (CWPWR): Power control of Call Waiting circuit
1/0
enable circuit /disable circuit
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
Bit 5~Bit 6(IOC55~IOC56): PORT5 I/O direction control registers.
0
put the relative I/O pin as output
1
put the relative I/O pin into high impedance
Bit 7(Unused)
PAGE 1 (CDAS, LCD bias control)
7
6
5
X
X
X
4
3
CDAS
BIAS3
R/W-0
R/W-0
Bit 0~Bit 3(BIAS0~BIAS3): LCD operation voltage selection
2
BIAS2
R/W-0
1
BIAS1
R/W-0
0
BIAS0
R/W-0
n
15 , n can be set by BIAS0~BIAS3.
= VDD
5
n
5
15 )
VDD Vdiff , VLCD VDD (1
5
5
Vdiff
VLCD
(BIAS3 to BIAS0)
0000
0001
0010
0011
0100
:
1101
1110
1111
Vdiff voltage
VDD * (5-0/15)/5 5V
VDD * (5-1/15)/5 4.93V
VDD * (5-2/15)/5 4.86V
VDD * (5-3/15)/5 4.79V
VDD * (5-4/15)/5 4.72V
:
:
VDD * (5-13/15)/5 4.14V
VDD * (5-14/15)/5 4.07V
VDD * (5-15/15)/5 4V
Table 15, LCD operation voltage selection
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
F ra m e
C O M 0
V
V
V
V
V
D D
1
2
3
LC D
C O M 1
V D D
V 1
V 2
V 3
V LC D
C O M 2
V
V
V
V
V
D D
1
2
3
LC D
C O M 3
V
V
V
V
V
D D
1
2
3
LC D
SEG
V
V
V
V
V
D D
1
2
3
LC D
V
V
V
V
V
D D
1
2
3
LC D
d a rk
SEG
lig h t
Figure 20, LCD waveform (1/4 bias) for 1/8 duty, 1/16 duty
Bit 4(CDAS): Current DA switch
0
normal PORT66
1
Current DA output
Bit 5 ~ Bit7 (Unused)
PAGE 2 (Unused)
7
6
X
X
5
X
4
X
3
X
2
X
1
X
0
X
Bit 0 ~ Bit 7 (Unused)
IOC6 (PORT6 I/O control, CDA, PORT switch)
PAGE 0 (PORT6 I/O control register)
7
6
5
4
3
2
1
0
X
IOC66
X
X
IOC63
IOC62
IOC61
IOC60
R/W-1
R/W-1
R/W-1
R/W-1
R/W-1
Bit 0~Bit 3, Bit 6 (IOC60~IOC63, IOC66): PORT60~63, PORT66 I/O direction control register
0
put the relative I/O pin as output
1
put the relative I/O pin into high impedance
Bit 4~5, 7(Unused)
PAGE 1 (Current DA control, DA9~DA3)
7
6
5
4
DAEN
DA9
DA8
DA7
3
2
1
0
DA6
DA5
DA4
DA3
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
Bit 0~Bit 6(DA0~DA6): Current DA output buffer
User can use this buffer to control the output current of current DA for the driving transistor of speaker.
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
Bit 7 (DAEN): Current DA enable control
0/1
disable/enable
DA9~DA0
VDD
DA2SW
DAOUTPUT2
current DA
circuit
port66
VDD
PORT66
VOL0~3
DAEN
DAS
Figure 21, Current DA structure
PAGE 2 (PORT switch, CDAL0~CDAL2)
7
6
5
4
3
PCSH
PCSL
PBS
X
X
R/W-0
R/W-0
R/W-0
R-0
R-0
Bit 0~Bit 2(DAL0~DAL2): change output level of current DA
2
CDAL2
R/W-0
1
CDAL1
R/W-0
0
CDAL0
R/W-0
CDAL2 CDAL1 CDAL0
Output current (mA)
5 1/16 = 0.3125
0
0
0
5 3/16 = 0.9375
0
0
1
5 5/16 = 1.5625
0
1
0
5 7/16 = 2.1875
0
1
1
5 9/16 = 2.8125
1
0
0
5 11/16 = 3.4375
1
0
1
5 13/16 = 4.0625
1
1
0
1
1
1
5 15/16 = 4.6875
Table 16, current DAout1 output level
Bit 3~Bit 4(Unused)
Bit 5(PBS): Switch I/O PORTB or LCD segment output for share pins SEGxx/PBx
0
select normal PB0 ~ PB7 for PORTB
1
select SEG48 ~ SEG55 output for LCD SEGMENT output.
Bit 6(PCSL): Switch low nibble I/O PORTC or LCD segment output for share pins SEGxx/PCx
0
select normal PC0 ~ PC3 for low nibble PORTC
1
select SEG56 ~ SEG59 output for LCD SEGMENT output.
Bit 7(PCSH): Switch high nibble I/O PORTC or LCD segment output for share pins SEGxx/PCx
select normal PC4 ~ PC7 for high nibble PORTC
0
1
select SEG60 ~ SEG63 output for LCD SEGMENT output.
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
IOC7 (PORT7 I/O control)
PAGE 0 (PORT7 I/O control register)
7
6
5
4
3
2
1
0
IOC77
X
X
X
IOC73
IOC72
IOC71
IOC70
R/W-1
R/W-1
R/W-1
R/W-1
R/W-1
Bit 0~Bit 3, Bit 7(IOC70~IOC73, IOC77): PORT70~73, PORT77 I/O direction control register
0
put the relative I/O pin as output
1
put the relative I/O pin into high impedance
Bit 4~6(Unused)
PAGE 1 (Unused)
7
6
X
X
5
4
3
2
1
0
X
X
X
X
X
X
1
IOC81
R/W-1
0
IOC80
R/W-1
Bit 0~Bit 7(Unused)
IOC8 (PORT8 I/O control)
PAGE 0 (PORT8 I/O control register)
7
6
5
4
3
2
IOC87
IOC86
IOC85
IOC84
IOC83
IOC82
R/W-1
R/W-1
R/W-1
R/W-1
R/W-1
R/W-1
Bit 0~Bit 7(IOC80~IOC87): PORT80~87 I/O direction control register
0
put the relative I/O pin as output
1
put the relative I/O pin into high impedance
PAGE 1 (Unused)
7
6
X
X
5
4
3
2
1
0
X
X
X
X
X
X
1
IOC91
R/W-1
0
IOC90
R/W-1
Bit 0~Bit 7(Unused)
IOC9 (PORT9 I/O control, DTMF receiver)
PAGE 0 (PORT9 I/O control register)
7
6
5
4
3
2
IOC97
IOC96
IOC95
IOC94
IOC93
IOC92
R/W-1
R/W-1
R/W-1
R/W-1
R/W-1
R/W-1
Bit 0~Bit 7(IOC90~IOC97): PORT90~97 I/O direction control register
0
put the relative I/O pin as output
1
put the relative I/O pin into high impedance
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
PAGE1 (DTMF receiver)
7
6
5
4
3
2
1
0
DREN
STD
TDP2
TDP1
Q4
Q3
Q2
Q1
R/W-0
R/W-0
R/W-0
R/W-0
R
R
R
R
Bit 0~Bit 3(Q1~Q4): DTMF receiver decoding data
To provide the code corresponding to the last valid tone-pair received (see code table). STD signal which steering
output presents a logic high when a received tone-pair has been registered and the Q4 ~ Q1 output latch updated and
generate a interruption (IOCF has enabled); returns to logic low when the voltage on ST/GT falls below Vtst.
TDP2
TDP1
Tdp
0
0
20 ms
0
1
15 ms
1
0
10 ms
1
1
5 ms
Table 17,Tone detection present time setup
F low
697
697
697
770
770
770
852
852
852
941
941
941
697
770
852
941
Any
F high
1209
1336
1477
1209
1336
1477
1209
1336
1477
1209
1336
1477
1633
1633
1633
1633
Any
Key
1
2
3
4
5
6
7
8
9
0
*
#
A
B
C
D
Any
DREN
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
0
Q4~Q1
0001
0010
0011
0100
0101
0110
0111
1000
1001
1010
1011
1100
1101
1110
1111
0000
xxxx
(x:unknown)
Table 18, DTMF receiver
Bit 4~Bit 5(TDP1, TDP2): we recommend that keep them in [0,0] please.
Bit 6(STD): Delayed steering output.
Presents a logic high when a received tone-pair has been registered and the output latch updated; returns to logic low
when the voltage on St/GT falls below V tst.
0/1
Data invalid/data valid
Bit 7(DREN): DTMF receiver power control
0/1
power down/ power up
Be sure open main clock before using DTMF receiver circuit . A logic low applied to DREN will shut down power of
the device to minimize the power consumption in a standby mode. It stops functions of the filters.
In many situations not requiring independent selection of receive and pause, the simple steering circuit of is applicable.
Component values are chosen according to the following formulae:
t REC = t DP + t GTP
t ID = t DA + t GTA
The value of t DP is a parameter of the device and t REC is the minimum signal duration to be recognized by the
receiver. A value for C of 0.1 uF is recommended for most applications, leaving R to be selected by the designer. For
example, a suitable value of R for a t REC of 30mS would be 300k.
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
Different steering arrangements may be used to select independently the guard-times for tone-present (t GTP ) and
tone-absent (t GTA ). This may be necessary to meet system specifications which place both accept and reject limits on
both tone duration and inter digital pause.
Guard-time adjustment also allows the designer to tailor system parameters such as talk off and noise immunity.
Increasing t REC improves talk-off performance, since it reduces the probability that tones simulated by speech will
maintain signal condition for long enough to be registered. On the other hand, a relatively short t REC with a long t DO
would be appropriate for extremely noisy environments where fast acquisition time and immunity to drop-outs would be
required.
VDD
VDD
C
ST/GT
EST
R
Figure 22, DTMF receiver delay time control
TONE
EST
TONE
Tdp
5~20mS
by S/W
Tgta
30mS Typ.
Tgtp
30mS Typ.
Vtst
1/2 VDD
ST/GT
Tpq
8 uS Typ.
Q4..Q1
STD
LINE_ENG
Figure 23, DTMF receiver timing
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
IOCA (CN1’s and CN2’s clock and scaling, PORT7 pull high control)
PAGE 0 (Counter1’s and Counter2's clock and scale setting)
7
6
5
4
3
2
CNT2S
C2P2
C2P1
C2P0
CNT1S
C1P2
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
Bit 0~Bit 2(C1P0~C1P2): Counter1 scaling
C1P2
0
0
0
0
1
1
1
1
1
C1P1
R/W-0
C1P1
C1P0
0
0
0
1
1
0
1
1
0
0
0
1
1
0
1
1
Table 19, counter1 scaling
COUNTER1
1:2
1:4
1:8
1:16
1:32
1:64
1:128
1:256
C2P1
C2P0
0
0
0
1
1
0
1
1
0
0
0
1
1
0
1
1
Table 20, counter2 scaling
COUNTER2
1:2
1:4
1:8
1:16
1:32
1:64
1:128
1:256
0
C1P0
R/W-0
Bit 3(CNT1S): Counter1 clock source
0/1
16.384kHz/instruction clock
Bit 4~Bit 6(C2P0~C2P2): Counter2 scaling
C2P2
0
0
0
0
1
1
1
1
Bit 7(CNT2S): Counter2 clock source
0/1
16.384kHz/instruction clock
PAGE1 (PORT7 pull high control register)
7
6
5
4
3
2
1
PH77
X
X
X
PH73
PH72
PH71
R/W-0
R/W-0
R/W-0
R/W-0
Bit 0~Bit 3, Bit 7(PH70~PH73, PH77): PORT70~73, PORT 77 pull high control register
0
disable pull high function.
1
enable pull high function
Bit 4~6(Unused)
IOCB (PORTB I/O control, PORT6 pull high control)
PAGE 0 (PORTB I/O control register)
7
6
5
4
3
2
IOCB7
IOCB6
IOCB5
IOCB4
IOCB3
IOCB2
R/W-1
R/W-1
R/W-1
R/W-1
R/W-1
R/W-1
Bit 0~Bit 7(IOCB0~IOCB7) : PORTB(0~7) I/O direction control register
0
put the relative I/O pin as output
1
put the relative I/O pin into high impedance
1
IOCB1
R/W-1
0
PH70
R/W-0
0
IOCB0
R/W-1
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
PAGE 1 (PORT6 pull high control register)
7
6
5
4
3
2
1
X
PH66
X
X
PH63
PH62
PH61
R/W-0
R/W-0
R/W-0
R/W-0
Bit 0~Bit 3, Bit 6 (PH60~PH63, PH66): PORT60~63, PORT66 pull high control register
0
disable pull high function.
1
enable pull high function
Bit 4~5, 7(Unused)
IOCC (PORTC I/O control, DA0~DA2, DA2SW, VOL0~3)
PAGE 0 (PORT9 I/O control register)
7
6
5
4
3
2
IOCC7
IOCC6
IOCC5
IOCC4
IOCC3
IOCC2
R/W-1
R/W-1
R/W-1
R/W-1
R/W-1
R/W-1
Bit 0~Bit 7(IOCC0~IOCC7): PORTC (0~7) I/O direction control register
0
put the relative I/O pin as output
1
put the relative I/O pin into high impedance
PAGE 1 (DA0~DA2)
7
6
VOL3
VOL2
1
IOCC1
R/W-1
0
PH60
R/W-0
0
IOCC0
R/W-1
5
4
3
2
1
0
VOL1
VOL0
DA2SW
DA2
DA1
DA0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
Bit0~Bit2 (DA0~DA2): Current DA bit0~bit2
Bit 3 (DA2SW): This bit “1”/”0” control DAOUPUT 2 on/off. If turn on DAOUTPUT 2 than DAOUTPUT 1 will be
disable, DAOUPUT 2 is turn off than DAOUTPUT will be enable (assume port66 as DAOUPUT 1).
Bit 4~7 (VOL0~VOL3): There are four bits to control DAout2 output volume level.
VOL3 ~ VOL0
Max voice output current (mA)
5 1/16 mA = 0.3125 mA
0000
0001
5 x 2/16 mA = 0.625 mA
0010
5 x 3/16 mA = 0.9375 mA
0011
5 x 4/16 mA = 1.25 mA
0100
5 x 5/16 mA = 1.5625 mA
0101
5 x 6/16 mA = 1.875 mA
0110
5 x 7/16 mA = 2.1875 mA
0111
5 x 8/16 mA = 2.5 mA
1000
5 x 9/16 mA = 2.8125 mA
1001
5 x 10/16 mA = 3.125 mA
1010
5 x 11/16 mA = 3.4375 mA
1011
5 x 12/16 mA = 3.75 mA
1100
5 x 13/16 mA = 4.0625 mA
1101
5 x 14/16 mA = 4.375 mA
1110
5 x 15/16 mA = 4.6875 mA
1111
5 mA
Table 21, DAout2 output volume level
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
IOCD (Counter1 data)
PAGE 0 (Counter1 data buffer)
7
6
5
CN17
CN16
CN15
4
3
2
1
0
CN14
CN13
CN12
CN11
CN10
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
Bit 0~Bit 7(CN10~CN17): Counter1's data buffer
User can read and write this buffer. Counter1 is a eight bit up-counter with 8-bit prescaler that user can use IOCD to
preset and read the counter. ( write = preset) After an interruption, it will reload the preset value.
CNT1S
data bus 8-bit
clock
sync with
2 cycles
8-bit counter
16.384KHz
timer 1 buffer
interrupt
occur
8-bit
MUX
C1P2~C1P0
8-1 MUX
3-bit
Figure 24, counter1 structure
Example:
write:
IOW 0x0D ; write the data at accumulator to counter1 (preset)
Example:
read:
IOR 0x0D ;read IOCD data and write to accumulator
PAGE 1 (Unused)
7
6
X
X
5
4
3
2
1
0
X
X
X
X
X
X
Bit 0~Bit 7(Unused)
IOCE (Counter2 data, Comparator)
PAGE 0 (Counter2 data buffer)
7
6
5
CN27
CN26
CN25
4
3
2
1
0
CN24
CN23
CN22
CN21
CN20
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
Bit 0~Bit 7(CN20~CN27): Counter2's data buffer
User can read and write this buffer. Counter2 is a eight bit up-counter with 8-bit prescaler that user can use IOCD to
preset and read the counter. (write = preset) After a interruption, it will reload the preset value.
Example:
write:
IOW 0x0E ; write the data at accumulator to counter2 (preset)
Example:
read:
IOR 0x0E ;read IOCE data and write to accumulator
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
PAGE 1 (Comparator IO set)
7
6
5
X
X
X
4
CMPIN1
R/W -0
3
P5S2
R/W-0
2
P5S1
R/W-0
1
X
0
X
Bit 0 ~ Bit 1(Unused)
Bit 2~Bit 3 (P5S1~P5S2): PORT5 switch
P5S2
0
1
0
1
P5S1
PORT55
PORT56
0
PORT55
PORT56
1
STGT
EST
1
0
Table 22, PORT5 switch
Status
Normal PORT5 IO
DTMF receiver IO
Unused
Unused
Bit 4 (CMPIN1): Switch for controlling PORT63 as IO PORT or a comparator input.
0
IO PORT63
1
comparator input
Bit 5 ~ Bit 7 (Unused)
PAGE 2 (Energy Detector)
7
6
5
4
3
2
1
0
VRSEL
X
X
X
X
X
X
X
R/W-0
Bit 0 ~ 6(Unused)
Bit 7 (VRSEL): Reference voltage VR selection bit for Comparator
0/1 VR = VDD/VR = 2.0V, When this bit is set to “0”, V2_0 ref. circuit will be powered off.
2.0V ref. circuit is only powered on when this bit and RD page0 bit 7(CMPEN) are all set to “1”.
Notice: IOCE page 2 register is a write-only register. To avoid some un-predicted error, please don’t read..
IOCF (Interrupt Mask Register)
7
6
5
4
RBF/STD FSK/CW
INT2
SDTMI
R/W-0
R/W-0
R/W-0
R/W-0
Bit 0 ~ Bit 7: Interrupt enable bits.
0/1
disable interrupt/enable interrupt
3
INT0
R/W-0
2
CNT2
R/W-0
1
CNT1
R/W-0
0
TCIF
R/W-0
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
VII. 3 I/O Port
PCRD
PORT
Q
P
R
Q
C
L
Q
P
R
Q
C
L
D
CLK
PCWR
D
CLK
IOD
PDWR
PDRD
0
1
M
U
X
Figure 25, The circuit of I/O port and I/O control register
The I/O registers are bi-directional tri-state I/O ports. The I/O ports can be defined as "input" or "output" pins by the
I/O control registers under program control. The I/O registers and I/O control registers are both readable and writable.
The I/O interface circuit is shown in Fig.24
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
VII. 4 RESET
The RESET can be caused by
(1) Power on voltage detector reset (POVD) and power on reset
(2) WDT timeout. (if enabled and in GREEN or NORMAL mode)
(3) /RESET pin pull low
<Note> At case (1), POVD is controlled by CODE OPTION. If you enable POVD, CPU will reset at 2V under. And
CPU will consume more current about 3uA. And the power on reset is a circuit always enable. It will reset CPU
at about 1.4V and consume about 0.5uA.
Once the RESET occurs, the following functions are performed.
The oscillator is running, or will be started.
The Program Counter (R2) is set to all "0".
When power on, the upper 3 bits of R3 and the upper 2 bits of R4 are cleared.
The Watchdog timer and prescaler counter are cleared.
The Watchdog timer is disabled.
The CONT register is set to all "1"
The other register (bit7 ~ bit0)
address
R register
page0
4
5
6
7
8
9
A
B
C
D
E
F
00xxxxxx
x0000000
x0010000
0xxx0000
00000000
00000000
00000x10
00000000
00000000
0x000000
1xx00000
00000000
R register
page1
IOC register
page0
00000000
00000000
x1100000
xxxxxxxx
x1xx1111
xxxxxxxx
1xxx1111
xxxxxxxx
11111111
xxxxxxxx
11111111
00000000
00000000
00000000
11111111
00000000
11111111
00000000
00000000
x0xx0000
00000000
00000000
Table 24, registers value after reset
IOC register
page1
IOC register
page2
xxx00000
00000000
xxxxxxxx
xxxxxxxx
00000000
0xxx0000
x0xx0000
00000000
xxxxxxxx
xxx000xx
-
xxxxxxxx
00000000
00000000
Figure 26, Reset timing
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
VII. 5 wake-up
The controller provided sleep mode for power saving.
(1) SLEEP mode, RA (7)=0 + "SLEP" instruction.
The controller will turn off all the CPU and crystal. Other circuit with power control like key tone control or PLL control
(which has enable register), user has to turn it off by software.
Wake-up from SLEEP mode
(1) WDT time out
(2) External interrupt
(3) /RESET pull low
All these cases will reset controller , and run the program at address zero. The status just like the power on reset. Be sure to
enable circuit at case (1) or (2).
VII. 6 Interrupt
RF is the interrupt status register, which records the interrupt request in flag bits. IOCF is the interrupt mask register. TCC
timer, Counter1 and Counter2 are internal interrupt source. P70 ~ P74, P77 (INT0 ~ INT2) are external interrupt input which
interrupt sources are come from the external. If the interrupts are happened by these interrupt sources, then RF register will
generate '1' flag to corresponding register if you enable IOCF register. Global interrupt is enabled by ENI instruction and is
disabled by DISI instruction. When one of the interrupts (when enabled) generated, will cause the next instruction to be
fetched from address 008H. Once in the interrupt service routine the source of the interrupt can be determined by polling the
flag bits in the RF register. The interrupt flag bit must be cleared in software before leaving the interrupt service routine and
enabling interrupts to avoid recursive interrupts.
VII. 7 Instruction Set
Instruction set has the following features:
(1) Every bit of any register can be set, cleared, or tested directly.
(2) The I/O register can be regarded as general register. That is, the same instruction can operates on I/O register.
The symbol "R" represents a register designator which specifies which one of the 64 registers (including operational
registers and general purpose registers) is to be utilized by the instruction. Bits 6 and 7 in R4 determine the selected
register bank. "b'' represents a bit field designator which selects the number of the bit, located in the register "R'',
affected by the operation. "k'' represents an 8 or 10-bit constant or literal value.
INSTRUCTION
BINARY
HEX
MNEMONIC
OPERATION
STATUS
AFFECTED
Instruction
cycle
No Operation
Decimal Adjust A
A
CONT
0 WDT, Stop
oscillator
0 WDT
A
IOCR
Enable Interrupt
Disable Interrupt
PC
[Top of Stack]
[Top of Stack]
PC
Enable Interrupt
CONT
A
IOCR A
R2+A
R2 bits 9,10 do
not clear
A
R
0 A
0 R
None
C
None
T,P
1
1
1
1
T,P
None
None
None
None
None
1
1
1
1
2
2
None
None
Z,C,DC
1
1
2
None
Z
Z
1
1
1
0
0
0
0
0000
0000
0000
0000
0000
0000
0000
0000
0000
0001
0010
0011
0000
0001
0002
0003
NOP
DAA
CONTW
SLEP
0
0
0
0
0
0
0000
0000
0000
0000
0000
0000
0000
0000
0001
0001
0001
0001
0100
rrrr
0000
0001
0010
0011
0004
000r
0010
0011
0012
0013
WDTC
IOW R
ENI
DISI
RET
RETI
0 0000 0001 0100
0 0000 0001
rrrr
0 0000 0010 0000
0014
001r
0020
CONTR
IOR R
TBL
0
0
0
00rr
0080
00rr
MOV R,A
CLRA
CLR R
0000
0000
0000
01rr
1000
11rr
rrrr
0000
rrrr
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0001
0001
0001
0001
0010
0010
0010
0010
0011
0011
0011
0011
0100
0100
0100
0100
0101
0101
0101
0101
0110
00rr
01rr
10rr
11rr
00rr
01rr
10rr
11rr
00rr
01rr
10rr
11rr
00rr
01rr
10rr
11rr
00rr
01rr
10rr
11rr
00rr
rrrr
rrrr
rrrr
rrrr
rrrr
rrrr
rrrr
rrrr
rrrr
rrrr
rrrr
rrrr
rrrr
rrrr
rrrr
rrrr
rrrr
rrrr
rrrr
rrrr
rrrr
01rr
01rr
01rr
01rr
02rr
02rr
02rr
02rr
03rr
03rr
03rr
03rr
04rr
04rr
04rr
04rr
05rr
05rr
05rr
05rr
06rr
0
0110
01rr
rrrr
06rr
0
0110
10rr
rrrr
06rr
0
0110
11rr
rrrr
06rr
0
0111
00rr
rrrr
07rr
0 0111 01rr
0 0111 10rr
0 0111 11rr
0 100b bbrr
0 101b bbrr
0 110b bbrr
0 111b bbrr
1 00kk kkkk
rrrr
rrrr
rrrr
rrrr
rrrr
rrrr
rrrr
kkkk
07rr
07rr
07rr
0xxx
0xxx
0xxx
0xxx
1kkk
1
1
1
1
1
1
01kk
1000
1001
1010
1011
1100
kkkk
kkkk
kkkk
kkkk
kkkk
kkkk
kkkk
kkkk
kkkk
kkkk
kkkk
kkkk
1kkk
18kk
19kk
1Akk
1Bkk
1Ckk
1
1
1101
1110
kkkk
0000
kkkk
0001
1Dkk
1E01
1 1110 100k kkkk
1E8k
1 1111 kkkk
kkkk
1Fkk
1 instruction cycle = 2 main clock.
SUB A,R
SUB R,A
DECA R
DEC R
OR A,R
OR R,A
AND A,R
AND R,A
XOR A,R
XOR R,A
ADD A,R
ADD R,A
MOV A,R
MOV R,R
COMA R
COM R
INCA R
INC R
DJZA R
DJZ R
RRCA R
R-A
A
R
R-A
R-1
A
R-1
R
A R A
A R R
A&R A
A&R
R
A R A
A R R
A+R
A
A+R R
A
R
R R
/R
A
/R
R
R+1 A
R+1 R
R-1
A, skip if zero
R, skip if zero
R-1
R(n)
A(n-1)
R(0)
C, C A(7)
RRC R
R(n-1)
R(n)
R(0)
C, C R(7)
RLCA R
R(n)
A(n+1)
R(7)
C, C A(0)
RLC R
R(n) R(n+1)
R(7)
C, C R(0)
SWAPA R
R(0-3) A(4-7)
R(4-7)
A(0-3)
SWAP R
R(4-7)
R(0-3)
JZA R
R+1
A, skip if zero
JZ R
R+1
R, skip if zero
BC R,b
0
R(b)
BS R,b
1 R(b)
JBC R,b
if R(b)=0, skip
JBS R,b
if R(b)=1, skip
CALL k
PC+1 [SP]
(Page, k) PC
JMP k
(Page, k) PC
MOV A,k
k A
OR A,k
A k A
AND A,k
A&k
A
XOR A,k
A k
A
RETL k
k A, [Top of Stack]
PC
SUB A,k
k-A
A
INT
PC+1 [SP]
001H
PC
PAGE k
K->R5(4:0)
ADD A,k
k+A
A
Table 25, instructions overview
Z,C,DC
Z,C,DC
Z
Z
Z
Z
Z
Z
Z
Z
Z,C,DC
Z,C,DC
Z
Z
Z
Z
Z
Z
None
None
C
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
2 if skip
2 if sk ip
1
C
1
C
1
C
1
None
1
None
None
None
None
None
None
None
None
1
2 if skip
2 if skip
1
1
2 if skip
2 if skip
2
None
None
Z
Z
Z
None
2
1
1
1
1
2
Z,C,DC
None
1
1
None
Z,C,DC
1
1
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
VII. 8 CODE Option Register
The controller has one CODE option register, which is not part of the normal program memory. The option bits
cannot be accessed during normal program execution.
CODE Option Register1 (Program ROM)
7
6
5
4
3
2
1
0
CWMODE
/POT
Bit 0(/POT): program ROM protect option
If set 1 to the bit, program memory can be access; else if clear this bit, program memory can be written only.
Bit 2~4(Unused)
Bit 5(CWMODE): CAS tone (2130 Hz plus 2750 Hz) accepted frequency range deviation select.
0
2% Call waiting accepted frequency range deviation.(Application for China protocol :
1.5% )
1
1.2% Call waiting accepted frequency range deviation.(Application for Europe and USA
protocol :
0.5% )
Bit 6~7(Unused)
VII. 8. 1 PAD Option
PAD Option
Please refer to figure2-1 in page 6. /POVD function will be decided to enable or disable by VDTBL or VDTBH pin.
/POVD
1
0
Pin connect
2.2V reset Power on reset
2.0V
VDTBH connect to VDD and
No
yes
VDTBL floated
VDTBL connect to GND and
Yes
yes
VDTBH floated
Table 26, /POVD
sleep mode current
1uA
10uA
Note: In instruction table, “MOV R, R”, R must be the same register.
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
VII. 9 CALL WAITING Function Descriptions
DATA
FSK
demodulator
TIP
RING
&
/CD
stuttered dail tone
detector
/SDT
GAIN
CWTIP
+
Vdd/2
Filter
Detection
block
CAS
Voltage
reference
Figure 27, Call Waiting Block Diagram
Call Waiting service works by alerting a customer engaged in a telephone call to a new incoming call. This way the
customer can still receive important calls while engaged in a current call. The CALL WAITING DECODER can detect
CAS(Call-Waiting Alerting Signal 2130Hz plus 2750Hz) and generate a valid signal on the data pins.
The call waiting decoder is designed to support the Caller Number Deliver feature, which is offered by regional Bell
Operating Companies.
In a typical application, after enabling CW circuit (by IOC5 page0 bit4 CWPWR) this IC receives Tip and Ring
signals from twisted pairs. The signals as inputs of pre-amplifier, and the amplifier sends input signal to a band pass
filter. Once the signal is filtered, the Detection block decodes the information and sends it to R3 register bit7 . The
output data made available at R3 CAS bit.
The data is CAS signals. The CAS is normal high. When this IC detects 2130Hz and 2750Hz frequency, then CAS pin
goes to low.
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
VII. 11 Stuttered dial tone detect (SDT)
TIP
RING
FSK Data
+
FSK block
/CD
SDT block
/SDT
Figure 29, SDT block
SDT (Stuttered dial tone) circuit and FSK circuit use the same input OP Amp. When SDTPWR bit (bit 5 of register R6) is
set, SDT circuit is powered on and SDT detection is enabled. SDT detection enable means it is power on and detect 350Hz
plus 440Hz dual frequency. And SDT signal detection output is sent to /SDT bit (bit 4 of register R6) with low enable.
If SDT circuit works, it consists of high-band and low-band pass tone filter, level detect, frequency counting and digital
algorithm to qualify timing.
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
VIII. Absolute Operation Maximum Ratings
RATING
DC SUPPLY VOLTAGE
INPUT VOLTAGE
OPERATING TEMPERATURE RANGE
SYMBOL
VDD
Vin
Ta
VALUE
-0.3 To 6
-0.5 to VDD +0.5
0 to 70
UNIT
V
V
IX. DC Electrical Characteristic
(Operation current consumption for Analog circuit)
Parameter
Operation current for FSK
Symbol
I_FSK
Operation current for CW
I_CW
Operation current for DTMF I_DR
receiver
Current DA output current
I_DA
Operation current for
Comparator
I_CMP
SDT
I_SDT
(Ta=25 C, VDD=5V 5%, VSS=0V)
Parameter
Symbol
Input Leakage Current for IIL1
input pins
Input Leakage Current for bi- IIL2
directional pins
Input High Voltage
VIH
Input Low Voltage
VIL
Input
High
Threshold VIHT
Voltage
Input Low Threshold Voltage VILT
Clock Input High Voltage
VIHX
Clock Input Low Voltage
VILX
Output High Voltage
VOH1
(port5,8,9,B,C)
(port6,7)
Output Low Voltage
VOL1
(port5,8,9,B,C)
(port6,7)
Pull-high current
IPH
Power down current
(SLEEP mode)
ISB1
Condition
Min
VDD=5V, CID power on
VDD=3V, CID power on
VDD=5V, CID power on
VDD=5V, CID power on
VDD=3V, DTMFr power on
VDD=3V, DTMFr power on
VDD=5V, CDA power on
VDD=3V, CDA power on
VDD=5V, PT power on
VDD=3V, PT power on
Typ
2.5
2.0
2.5
2.0
2.5
2.0
2.5
2.0
0.15
0.13
Max
4.0
3.5
4.0
3.5
4.0
3.5
4
3.5
0.3
0.2
Unit
mA
VDD=5V, SDT power on
VDD=3V, SDT power on
1.8
1.5
3.3
3.0
mA
Typ
Max
1
Unit
A
1
A
Condition
VIN = VDD, VSS
Min
VIN = VDD, VSS
2.0
0.8
/RESET, TCC, RDET1
/RESET, TCC,RDET1
OSCI
OSCI
IOH = -5mA
IOH = -8mA
IOL = 5mA
IOL = 8mA
Pull-high active input pin at
VSS
All input and I/O pin at
VDD, output pin floating,
WDT disabled
2.0
0.8
1.8
1.2
2.0
2.0
mA
mA
mA
mA
V
V
V
V
V
V
V
0.4
V
V
-10
0.4
-15
V
A
1
4
A
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
Low clock current
(GREEN mode)
ISB2
Operating supply current
(NORMAL mode)
ICC
Tone generator
voltage
CLK=32.768KHz, All analog
circuit disable , All input and
I/O pin at VDD, output pin
floating, WDT disabled, LCD
disable
/RESET=High, PLL enable
CLK=3.579MHz, output pin
floating and LCD enable, all
analog circuit disable
reference Vref2
35
50
A
2.8
3.5
mA
0.7
VDD
0.5
X. AC Electrical Characteristic
CPU instruction timing (Ta=25 C, VDD=5V, VSS=0V)
Parameter
Input CLK duty cycle
Instruction cycle time
Symbol
Dclk
Tins
Device delay hold time
Tdrh
TCC input period
Ttcc
Watchdog timer period
Twdt
Note 1: N= selected prescaler ratio.
Condition
Min
45
Typ
50
60
550
16
32.768kHz
3.579MHz
Note 1
Ta = 25 C
FSK AC Characteristic (Vdd=5V,Ta=+25 C)
CHARACTERISTIC
FSK sensitivity
Low Level Sensitivity Tip & Ring @SNR 20dB
High Level Sensitivity Tip & Ring @SNR 20dB
Signal Reject
FSK twist
Positive Twist (High Level)
Positive Twist (Low Level)
Negative Twist (High Level)
Negative Twist (Low Level)
CW AC Characteristic (Vdd=5V,Ta=+25 C)
CHARACTERISTIC
CW sensitivity
Sensitivity @SNR 20dB
Low Tone Frequency 2130Hz
High Tone Frequency 2750Hz
CW twist
Twist
(Tins+20)/N
16
Min
Typ
-40
-48
0
-51
Max
Unit
dB
dB
dB
dB
Typ
-38
±1.2
±1.2
±7
Unit
%
us
ns
ms
ns
ms
dBm
dBm
dBm
+10
+10
-6
-6
Min
Max
55
Max
Unit
dBm
%
%
dB
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
DTMFr (DTMF receiver) AC Characteristic (Vdd=5V,Ta=+25 C)
CHARACTERISTIC
Min Typ Max
DTMFr
Low Level Signal Sensitivity
-36
High Level Signal Sensitivity
0
Low Tone Frequency
±2
High Tone Frequency
±2
DTMFr noise endurance
Signal to noise ratio
15
Timing characteristic (Vdd=5V,Ta=+25 C)
Description
Oscillator timing characteristic
OSC start up
Unit
dBm
dBm
%
%
dB
Symbol Min Typ
32.768kHz
Tosc
3.579MHz PLL
FSK timing characteristic
Carrier detect low
Tcdl
-10
Data out to Carrier det low
Tdoc
-10
Power up to FSK(setup time)
Tsup
-15
End of FSK to Carrier Detect high
Tcdh
CW timing characteristic
CAS input signal length
Tcasi
80
(2130 ,2750 Hz @ -20dBm )
Call waiting data detect delay time
Tcwd
42
Call waiting data release time
Tcwr
26
DTMF receiver timing characteristic
Tone Present Detection Time
Tdp
(ps1)
the guard-times for tone-present
Tgtp
30
(C=0.1uF, R=300K)
the guard-times for tone-absent
Tgta
30
(C=0.1uF, R=300K)
Propagation Delay (St to Q)
Tpq
8
Tone Absent Detection Time
Tda
(ps2)
SPI timing characteristic (CPU clock 3.58MHz and Fsco = 3.58Mhz /2)
/SS set-up time
Tcss
560
/SS hold time
Tcsh
250
SCLK high time
Thi
250
SCLK low time
Tlo
250
SCLK rising time
Tr
15
SCLK falling time
Tf
15
SDI set-up time to the reading edge of SCLK
Tisu
25
SDI hold time to the reading edge of SCLK
Tihd
25
SDO disable time
Tdis
(ps1) : Controlled by software
(ps2) : Controlled by RC circuit.
Max
Unit
500
10
ms
20
20
20
5
ms
ns
ms
ms
ms
ms
ms
ms
mS
us
ms
ns
30
30
560
ns
ns
ns
ns
ns
ns
ns
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
SDT characteristic
Min
SDT characteristic
Input sensitivity Tip & Ring pins, VDD=5.0V
Input frequency tolerance
SDT timing characteristic
SDT signal detect delay time
SDT signal release tme
Typ
Max
Unit
-38
2.0
dBm
%
30
30
ms
ms
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
XI. Timing Diagrams
Figure 30, AC test timing
p lu g
on
events
CAS
Tc a s i
in
hook
in use
normal
Tc w d
Tc w r
CAS
CW PW R
pow er off
pow er on
Figure 31, Call waiting timing
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
XII. Application Circuit
Using 78P915 build-in LCD driver
LCD
pannel
SEGMEN
T
COMMO
N
Key
matrix
SEGx/Px
VDD
27p
VDD,AVD
D
XI
N
32.768k
XOU
T
27p
0.1u
PLL
C
SEGx/Px
SEGx/Px
EM78P915
SEGx/Px
AVSS,GN
D
P70
EGIN2
TI
LIN P
E RIN
G
4700p
47K
4700p
47K
4700p
47K
4700p
47K
TES
T
EGIN1
TI
P
RIN
G
CWG
P71
P72
P73
VDD
STG
T
ES
T
S
CWI
N
47p
150K
39K
Line
Interface
4700p
Speech
Network
Figure 32, Use 78915 build-in LCD driver circuit
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
XIII. Program Pins location of EM78P915
Port
Name
Note
P70
ACLK
P71
DINCLK
P72
PGMB
P73
OEB
P77
Data I/O
Table 28, program pin location
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
Appendix
A. Operational/special purpose/code option registers location
Operational register
R0……………………………………………………………………………………………12
R1……………………………………………………………………………………………12
R2……………………………………………………………………………………………12
R3……………………………………………………………………………………………12
R4……………………………………………………………………………………………13
R5……………………………………………………………………………………………16
R6……………………………………………………………………………………………17
R7……………………………………………………………………………………………17
R8……………………………………………………………………………………………17
R9……………………………………………………………………………………………18
RA……………………………………………………………………………………………18
RB……………………………………………………………………………………………21
RC……………………………………………………………………………………………22
RD……………………………………………………………………………………………22
RE……………………………………………………………………………………………24
RF……………………………………………………………………………………………26
Special purpose registers
CONT……………………………………………………………………………………………28
IOC5 ……………………………………………………… ……… …………………………… 29
IOC6 ……………………………………………………… ……… …………………………… 31
IOC7 ……………………………………………………… ……… …………………………… 33
IOC8 ……………………………………………………… ……… …………………………… 33
IOC9 ……………………………………………………… ……… …………………………… 33
IOCA……………………………………………………………………………………………36
IOCB……………………………………………………………………………………………36
IOCC……………………………………………………………………………………………37
I O C D … … … … … … … … … … … … … … … … … … … … … … … … … … … … … … … … … … … . 38
IOCE……………………………………………………………………………………………3 8
IOCF……………………………………………………………………………………………40
Code option registers
Code option register1………………………………………………………………………………………45
PAD option register1………………………………………………………………………………………45
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
B. Figure/table list
Figure list
Figure 1, Register overview description……………………………………………………………………2
Figure 2, Pin assignment……………………………………………………………………………………6
Figure 3, Block diagram…………………………………………………………………………………7
Figure 4, operational registers overview…………………………………………………………………10
Figure 5, Special purpose registers overview………………………………………………………………10
Figure 6, general purpose registers 10 ~ 1F………………………………………………………………11
Figure 7, general purpose registers 20 ~ 3F in Bank0/1/2/3………………………………………………11
Figure 8, program counter organization……………………………………………………………………12
Figure 9, Single SPI Master / Salve Communication……………………………………………………14
Figure 10, SPI structure……………………………………………………………………………………15
Figure 11, SPI timing………………………………………………………………………………………16
Figure 12, the relation between bit 1 ~ bit 3 of FSK in RA…………………………………………………19
Figure 13, the relation between 32.768kHz and PLL………………………………………………………20
Figure 14, Comparator timing………………………………………………………………………………23
Figure 15, Comparator circuit………………………………………………………………………………23
Figure 16, key scan waveform for 1/8, 1/16 duty………………………………………………………25
Figure 17, KEYSCAN and segments……………………………………………………………………25
Figure 18, TCC/WDT structure……………………………………………………………………………..29
Figure 19, TCC timing………………………………………………………………………………………29
Figure 20, LCD waveform (1/4 bias) for 1/8 duty, 1/16 duty………………………………………31
Figure 21, Current DA structure……………………………………………………………………………32
Figure 22, DTMF receiver delay time control………………………………………………………………35
Figure 23, DTMF receiver timing…………………………………………………………………………..35
Figure 24, counter1 structure………………………………………………………………………………..38
Figure 25, The circuit of I/O port and I/O control register…………………………………………………41
Figure 26, Reset timing……………………………………………………………………………………..42
Figure 27, Call Waiting Block Diagram……………………………………………………………………46
Figure 29, SDT block………………………………………………………………………………….48
Figure 30, AC test timing…………………………………………………………………………………...52
Figure 31, Call waiting timing………………………………………………………………………………52
Figure 32, Use 78915 build-in LCD driver circuit…………………………………………………………53
Table list
Table 1, initial setting reference in using ICE915……………………………………………………………2
Table 2, Event for power down bit and timer out bit……………………………………………………13
Table 3, relation with IOCP1S bit and IOCPAGE bit…………………………………………………13
Table 4, SPI baud rate selection…………………………………………………………………………14
Table 5, program page selection…………………………………………………………………………16
Table 6, main clock selection……………………………………………………………………………19
Table 7, sleep/green/normal modes with wake up signal………………………………………………20
Table 8, Common/Segment signal…………………………………………………………………………21
Table 9, channel selection of CMP………………………………………………………………………22
Table 10, LCD common mode……………………………………………………………………………24
Table 11, LCD operation function define…………………………………………………………………24
Table 12, relation with Duty mode and COM……………………………………………………………24
Table 13, interrupt trigger…………………………………………………………………………………27
Table 14, pre-scale of TCC and WDT……………………………………………………………………28
Table 15, LCD operation voltage selection………………………………………………………………30
Table 16, current DA output level………………………………………………………………………32
Table 17, DTMF receiver…………………………………………………………………………………34
Table 18, Tone detection present time setup……………………………………………………………34
Table 19, counter1 scaling…………………………………………………………………………………36
Table 20, counter2 scaling…………………………………………………………………………………36
Table 21, output volume level………………………………………………………………………………37
Table 22, PORT5 switch…………………………………………………………………………………39
Table 24, registers value after reset………………………………………………………………………42
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
Table 25, instructions overview……………………………………………………………………………44
Table 26, /POVD……………………….………………………………………………………………….45
Table 28, program pin location…………………………………………………………………………54
C. EM78P915/915 family list
Type
Product NO.
Kernel
Operation voltage
Operation clockMAX
Program ROM size
OTP
P915/915
OTP
P914/914
OTP
P916/916
OTP
P880/880
Note
2.2V ~ 5.5V
10.74MHz
32K*13
2.2V ~ 5.5V
10.74MHz
32K*13
2.2V ~ 5.5V
10.74MHz
32K*13
2.2V ~ 5.5V
10.74MHz
32K*13
Internal INT*3
External INT*7
8
8-bit CNT*2
2.5K*8
Internal INT*3
External INT*5
8
8-bit CNT*2
2.5K*8
Internal INT*3
External INT*7
8
8-bit CNT*2
2.5K*8
Internal INT*3
External INT*3
8
8-bit CNT*2
2.5K*8
44 bi-direction
2.2V
2.0V
44 bi-direction
2.2V
2.0V
44 bi-direction
2.2V
2.0V
44 bi-direction
2.2V
2.0V
COM: 16
SEG: 60
Bias: 1/4
Duty: 1/8, 1/16
COM: 16
SEG: 60
Bias: 1/4
Duty: 1/8, 1/16
8-bit WDT*1
8-bit TCC*1
Interruption
Stack level
Counter
Data RAM size
Idle mode
Sleep mode
I/O PortMAX
/POVD level
POR level
Digital IP circuit
SPI
10-bit CDA
Analog IP circuit
LCD
LCD pin number
LCD bias and duty
COM: 16
SEG: 60
Bias: 1/4
Duty: 1/8, 1/16
Call waiting
FSK decode
DTMF receiver
DED
SDT decode
Comparator
Note: symbol “
” is represent the function existed. If the space is empty, the function is disabled or un-existed.
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
D. Development tool and reference document for EM78P915/915 family
Product (OTP/Mask) NO.
P915/915
P914/914
P916/916
P880/880
Development tool
ICE (ROM-Less) NO.
ICE915
ICE915
ICE915
ICE915
2.993-051004 or 2.993-051004 or
2.993-051004 or
2.993-051004 or
WICE version
above
above
above
above
Writer S/W version
3.1 or above
3.1 or above
3.1 or above
3.1 or above
Writer H/W version
3.1 or above
3.1 or above
3.1 or above
3.1 or above
Chapter 5 of
Chapter 4 of
Chapter 3 of
Chapter 2 of
Reference document ICE915 family
ICE915 family user ICE915 family user ICE915 family user
guide
guide
guide
user guide
Note: if users want to develop products by using P915/915, these tools such as ICE915, WICE, reference
documents and Writer are necessary tools for developing and debugging level.
E. ICE915 in WICE
Step1: Download WICE steup.exe file from our web site www.emc.com.tw
Step2: Setup WICE. (In this description, we only introduce about ICE915 in WICE, but more detail about WICE using, users
have to refer to WICE manual please)
Step3: Choice your ICE NO. (ICE915, ICE914, ICE916 or ICE880) and press “OK” button after executed WICE. If users
can’t find ICE NO. Please presses “Cancel” and refer to step4 to check WICE version.
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
EM78P915
8-bit Micro-controller
Step4: Check WICE version after installed, the number must be 2.993-051004 or above. If version is older than this number,
please update your WICE.
F. Program EM78P915 note
Step1: Please check your tools. It has to include WTRFI S/W and WTRFI H/W. And remember to confirm their version first.
Step2: The connection between WTRFI H/W, PC, EM78P915
Printer Port
Program Pin
WTRFI H/W
VDD
VPP
DINCLK
ACLK
PGMB
OEB
DATA
GND
WTRFI H/W
EM78P915
VDD
Reset
P71
P70
P72
P73
P77
GND
TEST1
XIN
EM78P915
Step3: After executed WTRFI S/W and choice 915, users can write/read code from EM78P915. More detail description about
WTRFI S/W and H/W, users can refer to WTRFI manual.
__________________________________________________________________________________________________________________________________________________________________
* This specification is subject to be changed without notice.
2005/12/21 (V2.0)
Similar pages