CMOS LSI
No. 5488
LC66E5316 Four-Bit Single-Chip Microcontroller with 16 KB of On-Chip EPROM
Preliminary Overview
The LC66E5316 is an on-chip EPROM version of the LC6653XX Series CMOS 4-bit single-chip microcontrollers. The LC66E5316 provides the same functions as the LC665316A, and is pin compatible with that product. Since the LC66E5316 is provided in a window package, it can be reprogrammed repeatedly and is thus optimal for program development.
Package Dimensions
unit: mm 3225-DIC52S
[LC66E5316] 46.74 52 14.99 27 14.66 15.24
0.15 25 36 37 20.0 14.0 24
Features and Functions
• On-chip EPROM capacity of 16 kilobytes, and an onchip RAM capacity of 512 × 4 bits. • Fully supports the LC66000 Series common instruction set (128 instructions). • I/O ports: 42 pins • A sub-oscillator circuit can be used (option) This circuit allows power dissipation to be reduced by operating at lower speeds. • 8-bit serial interface: two circuits (can be connected in cascade to form a 16-bit interface) • Instruction cycle time: 0.95 to 10 µs (at 4.5 to 5.5 V) • Powerful timer functions and prescalers — Time limit timer, event counter, pulse width measurement, and square wave output using a 12-bit timer. — Time limit timer, event counter, PWM output, and square wave output using an 8-bit timer. — Time base function using a 12-bit prescaler. • Powerful interrupt system with 8 interrupt factors and 8 interrupt vector locations. — External interrupts: 3 factors/3 vector locations — Internal interrupts: 5 factors/5 vector locations • Flexible I/O functions 16-value comparator inputs, 20-mA drive outputs, inverter circuits, pull-up and open-drain circuits selectable as options. • Optional runaway detection function (watchdog timer) • 8-bit I/O functions • Power saving functions using halt and hold modes. • Packages: DIC52S (window), QFC48 (window) • Evaluation LSIs: LC66599 (evaluation chip) + EVA800/850 - TB662YXX2
1 41.94
26 2.03 1.27 4.0 8.7 1.778 1.145 SANYO: DIC52S
3.0 0.35 13 12 2.2 4.2 4.77max
0.9
0.46 44.45
unit: mm 3157-QFC48
[LC66E5316]
20.0 14.0 3.0 1.5 0.35 1.0
1.0 48 1.5 1
SANYO: QFC48
SANYO Electric Co.,Ltd. Semiconductor Bussiness Headquarters
TOKYO OFFICE Tokyo Bldg., 1-10, 1 Chome, Ueno, Taito-ku, TOKYO, 110 JAPAN
21097HA (OT) No. 5488-1/27
LC66E5316 Series Organization
Type No. LC66304A/306A/308A LC66404A/406A/408A LC66506B/508B/512B/516B LC66354A/356A/358A LC66354S/356S/358S LC66556A/558A/562A/566A LC66354B/356B/358B LC66556B/558B/562B/566B LC66354C/356C/358C LC662104A/06A/08A LC662304A/06A/08A/12A/16A LC662508A/12A/16A LC665304A/06A/08A/12A/16A LC66E308 LC66P308 LC66E408 LC66P408 LC66E516 LC66P516 LC66E2108* LC66E2316 LC66E2516 LC66E5316 LC66P2108* LC66P2316* LC66P2516 LC66P5316 Note: * Under development No. of pins 42 42 64 42 42 64 42 64 42 30 42 64 48 42 42 42 42 64 64 30 42 64 52/48 30 42 64 48 ROM capacity 4 K/6 K/8 KB 4 K/6 K/8 KB 6 K/8 K/12 K/16 KB 4 K/6 K/8 KB 4 K/6 K/8 KB 6 K/8 K/12 K/16 KB 4 K/6 K/8 KB 6 K/8 K/12 K/16 KB 4 K/6 K/8 KB 4 K/6 K/8 KB RAM capacity 512 W 512 W 512 W 512 W 512 W 512 W 512 W 512 W 512 W 384 W DIP64S DIP42S DIP64S DIP42S DIP30SD DIP42S DIP64S DIP48S DIC42S with window DIP42S DIC42S with window DIP42S DIC64S with window DIP64S DIP42S DIP42S DIP64S DIP42S Package QFP48E QFP48E QFP64A QFP48E QFP44M QFP64E QFP48E QFP64E QFP48E MFP30S QFP48E QFP64E QFP48E QFC48 with window QFP48E QFC48 with window QFP48E QFC64 with window QFP64E Window and OTP evaluation versions 4.5 to 5.5 V/0.92 µs Dual oscillator support 3.0 to 5.5 V/0.95 µs On-chip DTMF generator versions 3.0 to 5.5 V/0.95 µs Low-voltage versions 2.2 to 5.5 V/3.92 µs Low-voltage high-speed versions 3.0 to 5.5 V/0.92 µs 2.5 to 5.5 V/0.92 µs Normal versions 4.0 to 6.0 V/0.92 µs Features
4 K/6 K/8 K/12 K/16 KB 512 W 8 K/12 K/16 KB 512 W
4 K/6 K/8 K/12 K/16 KB 512 W EPROM 8 KB OTPROM 8 KB EPROM 8 KB OTPROM 8 KB EPROM 16 KB OTPROM 16 KB EPROM 8 KB EPROM 16 KB EPROM 16 KB EPROM 16 KB OTPROM 8 KB OTPROM 16 KB OTPROM 16 KB OTPROM 16 KB 512 W 512 W 512 W 512 W 512 W 512 W 384 W 512 W 512 W 512 W 384 W 512 W 512 W 512 W
DIC42S with window DIC64S with window DIC52S with window DIP30SD DIP42S DIP64S DIP48S
QFC48 with window QFC64 with window QFC48 with window MFP30S QFP48E QFP64E QFP48E
Window evaluation versions 4.5 to 5.5 V/0.92 µs
OTP 4.0 to 5.5 V/0.95 µs
No. 5488-2/27
LC66E5316 Pin Assignments
DIC52S P20/SI0/A0 P21/SO0/A1 P22/SCK0/A2 P23/INT0/A3 P30/INT1/A4 P31/POUT0/A5 P32/POUT1/A6 VSS OSC1 OSC2 VDD RES/VPP/OE PE0/XT1 PE1/XT2 TEST/EPMOD P33/HOLD P40/INV0I/A7 P41/INV0O/A8 P42/INV1I/A9 P43/INV1O/A10 P50/A11 P51/A12 P52/A13 P53/INT2/TA N. C. N. C. 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 52 51 50 49 48 47 46 45 44 43 42 41 40 39 38 37 36 35 34 33 32 31 30 29 28 27 P13/D7 P12/D6 P11/D5 P10/D4 P03/D3 P02/D2 P01/D1 P00/D0 PD3/AN4/INV4O PD2/AN3/INV4I PD1/AN2/INV3O PD0/AN1/INV3I PC3/INV2O/DASEC PC2/INV2I/CE PC1 PC0 P83 P82 P81/DS1 P80/DS0 P63/PIN1 P62/SCK1 P61/SO1 P60/SI1 N. C. N. C.
LC66E5316
QFC48 P01/D1 P00/D0 PD3/AN4/INV4O PD2/AN3/INV4I PD1/AN2/INV3O PD0/AN1/INV3I PC3/INV2O/DASEC PC2/INV2I/CE PC1 PC0 P83 P82 P02/D2 P03/D3 P10/D4 P11/D5 P12/D6 P13/D7 P20/SI0/A0 P21/SO0/A1 P22/SCK0/A2 P23/INT0/A3 P30/INT1/A4 P31/POUT0/A5 36 35 34 33 32 31 30 29 28 27 26 25 37 24 38 23 39 22 40 21 LC66E5316 41 20 42 19 43 18 44 17 45 16 46 15 47 14 48 13 1 2 3 4 5 6 7 8 9 10 11 12 P32/POUT1/A6 VSS OSC1 OSC2 VDD RES/VPP/OE PE0/XT1 PE1/XT2 TEST/EPMOD P33/HOLD P40/INV0I/A7 P41/INV0O/A8 P81/DS1 P80/DS0 P63/PIN1 P62/SCK1 P61/SO1 P60/SI1 P53/INT2/TA P52/A13 P51/A12 P50/A11 P43/INV1O/A10 P42/INV1I/A9
Top view
No. 5488-3/27
LC66E5316 Usage Notes The LC66E5316 was created for program development, product evaluation, and prototype development for products based on the LC6653XX Series microcontrollers. Keep the following points in mind when using this product. 1. After a reset The RES pin must be held low for an additional 3 instruction cycles after the oscillator stabilization period has elapsed. Also, the port output circuit types are set up during the 9 instruction cycles immediately after RES is set high. Only then is the program counter set to 0 and program execution started from that location. (The port output circuits all revert to the open-drain type during periods when RES is low.)
VDDmin VDD
OSC At least 10 ms Oscillator stabilization At least 3 instruction
RES
Program execution (PC) Open drain
Location Location 0 1
Port output type
Option switching Option specification period 9 instruction cycles
2. Notes on LC6653XX evaluation The high end of the EPROM area (locations 3FF0H to 3FFFH) are the option specification area. Option specification data must be programmed for and loaded into this area. The Sanyo specified cross assembler for this product is the program LC66S.EXE. Also, insert JMP instructions so that user programs do not attempt to execute addresses that exceed the capacity of the mask ROM, and write zeros (00H) to areas (other than 3FF0H to 3FFFH) that exceed the actual capacity of the mask ROM. 3. Always apply an opaque seal to the window on the LC66E5316 package when actually using the device. Main differences between the LC66E5316, LC66P5316, and LC6653XX Series
Item Differences in the main characteristics • Operating temperature range LC6653XX Series (mask version) –30 to +70°C 3.0 to 5.5 V/0.95 to 10 µs (When the main oscillator is operating) 3.0 to 5.5 V/25 to 127 µs (When the sub-oscillator is operating) Maximum: 1 µA Maximum: 1 µA LC66E5316 +10 to +40°C 4.5 to 5.5 V/0.95 to 10 µs (When the main oscillator is operating) 4.5 to 5.5 V/25 to 127 µs (When the sub-oscillator is operating) Typical: 10 µA (normal operation and halt mode) Hold mode: 1 µA maximum Typical: 100 µA LC66P5316 –30 to +70°C 4.0 to 5.5 V/0.95 to 10 µs (When the main oscillator is operating) 4.0 to 5.5 V/25 to 127 µs (When the sub-oscillator is operating) Typical: 10 µA (normal operation and halt mode) Hold mode: 1 µA maximum Typical: 100 µA
• Operating supply voltage/operating frequency (cycle time)
• Input high-level current (RES) • Input low-level current (RES) • Current drain (Operating at 4 MHz) (Operating at 32 kHz) (Halt mode at 4 MHz) (Halt mode at 32 kHz) (Hold mode) Port output types at reset Package
Typical: 10 nA, maximum: 10 µA
Larger than that for the mask versions Typical: 10 nA, maximum: 10 µA*
Larger than that for the mask versions Typical: 10 nA, maximum: 10 µA*
The output type specified in the options • DIP48S • QFP48E
Open-drain outputs • DIC52S window package • QFC48 window package
Open-drain outputs • DIP48S • QFP48E
Note: * Although the microcontroller will remain in hold mode if the RES pin is set low while it is in hold mode, always use the reset start sequence (after switching HOLD from low to high, switch RES from low to high) when clearing hold mode. Also a current of about 100 µA flows from the RES pin when it is low. This increases the hold mode current drain by about 100 µA.
See the data sheets for the individual products for details on other differences.
No. 5488-4/27
LC66E5316 System Block Diagram
RAM STACK (512W) SYSTEM CONTROL FLAG E DD DD SP M P P P P R HL XY C Z EPROM
(16KB)
RES TEST OSC1 OSC2 HOLD XT1 XT2 AN1 to 4 ADC PE PD PC
EPROM control
A0 to A D0 to D
CE DASEC VPP/OE EPMOD TA
E
A
ALU
PC
PRESCALER
MPX
TIMER0
SERIAL I/O 0
POUT0 SI0 SO0 SCK0 INT0 INT1, INT2
MPX INTERRUPT CONTROL SI1 SO1 SCK1 PIN1, POUT1 INVxO P0 P1 P2 P3 P4 P5 P6 P8 DS1 INVxI
(x=0 to 4)
MPX
TIMER1
SERIAL I/O 1
DS0
Pin Function Overview
Pin I/O Overview I/O ports P00 to P03 • Input or output in 4-bit or 1-bit units • P00 to P03 support the halt mode control function (This function can be specified in bit units.) • Used as data pins in EPROM mode Output driver type Options State after a Standby mode reset operation Hold mode: Output off High or low (option) Halt mode: Output retained Hold mode: Output off High or low (option) Halt mode: Output retained
P00/D0 P01/D1 P02/D2 P03/D3
I/O
• Pch: Pull-up MOS type • Nch: Intermediate sink current type
• Pull-up MOS or Nch OD output • Output level on reset
P10/D4 P11/D5 P12/D6 P13/D7
I/O
I/O ports P10 to P13 • Input or output in 4-bit or 1-bit units • Used as data pins in EPROM mode
• Pch: Pull-up MOS type • Nch: Intermediate sink current type
• Pull-up MOS or Nch OD output • Output level on reset
P20/SI0/A0 P21/SO0/A1 P22/SCK0/ A2 P23/INT0/A3
I/O
I/O ports P20 to P23 • Input or output in 4-bit or 1-bit units • P20 is also used as the serial input SI0 pin. • P21 is also used as the serial output SO0 pin. • P22 is also used as the serial clock SCK0 pin. • P23 is also used as the INT0 interrupt request pin, and also as the timer 0 event counting and pulse width measurement input. • Used as address pins in EPROM mode
Hold mode: Output off • Pch: CMOS type • Nch: Intermediate sink current type CMOS or Nch OD output
H
Hold mode: Output off
Continued on next page. No. 5488-5/27
LC66E5316
Continued from preceding page.
State after a Standby mode reset operation
Pin
I/O
Overview
Output driver type
Options
P30/INT1/A4 P31/POUT0/ A5 P32/POUT1/ A6
I/O
I/O ports P30 to P32 • Input or output in 3-bit or 1-bit units • P30 is also used as the INT1 interrupt request. • P31 is also used for the square wave output from timer 0. • P32 is also used for the square wave and PWM output from timer 1. • P31 and P32 also support 3-state outputs. • Used as address pins in EPROM mode
Hold mode: Output off • Pch: CMOS type • Nch: Intermediate sink current type CMOS or Nch OD output
H Halt mode: Output retained
P33/HOLD
I
Hold mode control input • Hold mode is set up by the HOLD instruction when HOLD is low. • In hold mode, the CPU is restarted by setting HOLD to the high level. • This pin can be used as input port P33 along with P30 to P32. • When the P33/HOLD pin is at the low level, the CPU will not be reset by a low level on the RES pin. Therefore, applications must not set P33/HOLD low when power is first applied.
P40/INV0I/ A7 P41/INV0O/ A8 P42/INV1I/ A9 P43/INV1O/ A10
I/O
I/O ports P40 to P43 • Input or output in 4-bit or 1-bit units • Input or output in 8-bit units when used in conjunction with P50 to P53. • Can be used for output of 8-bit ROM data when used in conjunction with P50 to P53. • Dedicated inverter circuit (option) • Used as address pins in EPROM mode
• Pch: Pull-up MOS type • CMOS type when the inverter circuit option is selected • Nch: Intermediate sink current type
• Pull-up MOS or Nch OD output • Output level on reset • Inverter circuit
• High or low (option) • Inverter I/O is set to the output off state.
Hold mode: Port output off, inverter output off Halt mode: Port output retained, inverter output continues
P50/A11 P51/A12 P52/A13 P53/INT2/TA
I/O
I/O ports P50 to P53 • Input or output in 4-bit or 1-bit units • Input or output in 8-bit units when used in conjunction with P40 to P43. • Can be used for output of 8-bit ROM data when used in conjunction with P40 to P43. • P53 is also used as the INT2 interrupt request. • Used as address pins in EPROM mode
Hold mode: Output off • Pch: Pull-up MOS type • Nch: Intermediate sink current type • Pull-up MOS or Nch OD output • Output level on reset High or low (option) Halt mode: Output retained
P60/SI1 P61/SO1 P62/SCK1 P63/PIN1
I/O
I/O ports P60 to P63 • Input or output in 4-bit or 1-bit units • P60 is also used as the serial input SI1 pin. • P61 is also used as the serial output SO1 pin. • P62 is also used as the serial clock SCK1 pin. • P63 is also used for the event count input to timer 1.
Hold mode: Output off • Pch: CMOS type • Nch: Intermediate sink current type • CMOS or Nch OD output
H Halt mode: Output retained
Continued on next page. No. 5488-6/27
LC66E5316
Continued from preceding page.
Pin I/O Overview Dedicated output ports P80 to P83 • Output in 4-bit or 1-bit units • The contents of the output latch are input using input instructions. • P80 is a data shaper input (options) • P81 is a data shaper output (options) Output driver type Options • CMOS or Pch OD output • Output level at reset • Data shaper circuit State after a Standby mode reset operation Hold mode: Output off High or low (option) Halt mode: Output retained Hold mode: Output off H Halt mode: Output retained
P80/DS0 P81/DS1 P82 P83
O
• Pch: CMOS type • Nch: Intermediate sink current type
PC0 PC1 PC2/INV2I/ CE PC3/INV2O/ DASEC PD0/AN1/ INV3I PD1/AN2/ INV3O PD2/AN3/ INV4I PD3/AN4/ INV4O PE0/XT1 PE1/XT2 OSC1 OSC2
I/O
I/O ports PC0 to PC3 • Output in 4-bit or 1-bit units • Dedicated inverter circuits (option) • Used as the control CE and DASEC pin in EPROM mode.
• Pch: CMOS type • Nch: Intermediate sink current type
• CMOS or Nch OD output • Inverter circuits
I
Dedicated input ports PD0 to PD3 • Can be switched in software to function as 16-value analog inputs. • Dedicated inverter circuits (option)
• Only when the inverter circuit option is selected: • Pch: CMOS type • Nch: Intermediate sink current type
Inverter circuits
Normal input
Inverter • Hold mode: Output off • Halt mode: Output continues
I I O
Dedicated input ports and sub-oscillator connections System clock oscillator connections When an external clock is used, leave OSC2 open and connect the clock signal to OSC1. System reset input • When the P33/HOLD pin is at the high level, a low level input to the RES pin will initialize the CPU. • Used as the VPP/OE pin in EPROM mode. CPU test pin This pin must be connected to VSS during normal operation. Power supply pins
Sub-oscillator/port PE selection Ceramic oscillator or external clock selection
Option selection Hold OSC stop Halt OSC cont
Option selection
RES/VPP/ OE
I
TEST/ EPMOD VDD VSS
I
Note: Pull-up MOS type: The output circuit includes a MOS transistor that pulls the pin up to VDD. CMOS output: Complementary output. OD output: Open-drain output.
Continued on next page. No. 5488-7/27
LC66E5316 User Options 1. Port 0, 1, 4, 5, and 8 output level at reset option The output levels at reset for I/O ports 0, 1, 4, 5, and 8, in independent 4-bit groups, can be selected from the following two options.
Option 1. Output high at reset 2. Output low at reset Conditions and notes The four bits of ports 0, 1, 4, 5, or 8 are set in a group The four bits of ports 0, 1, 4, 5, or 8 are set in a group
2. Oscillator circuit options • Main clock
Option Circuit Conditions and notes
1. External clock
OSC1
The input has Schmitt characteristics
C1
2. Ceramic oscillator
OSC1
Ceramic oscillator C2
OSC2
Note: There is no RC oscillator option.
• Sub-clock
Option Circuit Conditions and notes
DSB
1. Ports PE0 and PE1
Input data C1
2 Sub-oscillator (crystal oscillator)
XT1
Crystal oscillator C2
XT2
3. Watchdog timer option A runaway detection function (watchdog timer) can be selected as an option. 4. Port output type options • The output type of each bit (pin) in ports P0, P1, P2, P3 (except for the P33/HOLD pin), P4, P5, P6, and PC can be selected individually from the following two options.
Option Circuit Conditions and notes
Output data
1. Open-drain output
Input data DSB Output data
The port P2, P3, P5, and P6 inputs have Schmitt characteristics.
The port P2, P3, P5, and P6 inputs have Schmitt characteristics. The CMOS outputs (ports P2, P3, P6, and PC) and the pull-up MOS outputs (P0, P1, P4, and P5) are distinguished by the drive capacity of the p-channel transistor.
2. Output with built-in pull-up resistor
Input data DSB
No. 5488-8/27
LC66E5316 • One of the following two options can be selected for P8, in bit units.
Option Circuit Conditions and notes
1. Open-drain output
DSB
Output data
Output data
2. Output with built-in pulldown resistor (CMOS output)
DSB
5. Inverter array circuit option One of the following options can be selected for each of the following port sets: P40/P41, P42/P43, PC2/PC3, PD0/PD1, and PD2/PD3. (PDs do not use option 1 because they are dedicated to inputs)
Option Circuit Conditions and notes
Output data Input data DSB
1. Normal port I/O circuit When the open-drain output type is selected
Output data
When the built-in pull-up resistor output type is selected. The CMOS outputs (PC) and the pull-up MOS outputs (P4) are distinguished by the drive capacity of the p-channel transistor.
Input data DSB Input Output data high Input data DSB
2. Inverter I/O circuit
Output
Output data high Input data DSB
If this option is selected, the I/O circuit is disabled by the DSB signal. Also note that the open-drain port output type option and the high level at reset option must be selected.
No. 5488-9/27
LC66E5316 6. Buffer array circuit option In addition to normal port output, one of the following two options may also be selected for P80 and P81.
Option Circuit Conditions and notes
Output data DSB
When the open-drain output type is selected
1. Normal port output
Output data
When the built-in pull-down resistor output type is selected (CMOS output)
DSB
O
P80 Output data low
If this option is selected, the I/O circuit is disabled by the DSB signal. Also note that the open-drain port output type option and the low level at reset option must be selected.
2. Buffer input (P80) and buffer output (P81) circuits
P81
DSB
Output data low
P80
3. Buffer input (P80) and buffer output (P81) circuits with built-in zero-cross detection circuits
Output data low
If this option is selected, the I/O circuit is disabled by the DSB signal. Also note that the open-drain port output type option and the low level at reset option must be selected.
P81
DSB
Output data low
No. 5488-10/27
LC66E5316 LC665316 Series Option Data Area and Definitions
ROM area Bit 7 6 5 3FF0H 4 3 2 1 0 7 6 5 3FF1H 4 3 2 1 0 7 6 5 3FF2H 4 3 2 1 0 7 6 5 3FF3H 4 3 2 1 0 7 6 5 3FF4H 4 3 2 1 0 7 6 5 3FF5H 4 3 2 1 0 7 6 5 3FF6H 4 3 2 1 0 Unused This bit must be set to 0. Unused This bit must be set to 0. P83 P82 P81 P80 Output type 0 = OD, 1 = PD Unused This bit must be set to 0. P63 P62 P61 P60 Output type 0 = OD, 1 = PU Unused This bit must be set to 0. P5 P4 Option specified Output level at reset Option/data relationship 0 = high level, 1 = low level 0 = port PE, 1 = crystal oscillator 0 = external clock, 1 = ceramic oscillator
Sub-oscillator option Oscillator option P8 P1 P0 Watchdog timer option P13 P12 P11 P10 P03 P02 P01 P00 Unused P32 P31 P30 P23 P22 P21 P20 P53 P52 P51 P50 P43 P42 P41 P40 Output type Output type Output type Output type Output type Output type Output level at reset
0 = low level, 1 = high level
0 = none, 1 = yes (present)
0 = OD, 1 = PU
0 = OD, 1 = PU
This bit must be set to 0.
0 = OD, 1 = PU
0 = OD, 1 = PU
0 = OD, 1 = PU
0 = OD, 1 = PU
Continued on next page.
LC66E5316
Continued from preceding page.
ROM area Bit 7 6 5 3FF7H 4 3 2 1 0 7 6 5 3FF8H 4 3 2 1 0 7 6 5 3FF9H 4 3 2 1 0 7 6 5 3FFAH 4 3 2 1 0 7 6 5 3FFBH 4 3 2 1 0 7 6 5 3FFCH 4 3 2 1 0 7 6 5 3FFDH 4 3 2 1 0 Reserved. Must be set to predefined data values. This data is generated by the assembler. If the assembler is not used, set this data to ‘00’. Unused This bit must be set to 0. Unused This bit must be set to 0. Unused This bit must be set to 0. Unused This bit must be set to 0. Unused This bit must be set to 0. Unused This bit must be set to 0. Unused This bit must be set to 0. Unused This bit must be set to 0. PC3 PC2 PC1 PC0 Unused Buffer output Buffer output with zero-cross bias input PD3 PD1 PC3 P43 P41 Inverter output 0 = inverter output, 1 = none This bit must be set to 1. 0 = used, 1 = none 0 = used, 1 = none Output type 0 = OD, 1 = PU Unused This bit must be set to 0. Option specified Option/data relationship
Continued on next page. No. 5488-12/27
LC66E5316
Continued from preceding page.
ROM area Bit 7 6 5 3FFEH 4 3 2 1 0 7 6 5 3FFFH 4 3 2 1 0 Reserved. Must be set to predefined data values. This data is generated by the assembler. If the assembler is not used, set this data to ‘00’. Reserved. Must be set to predefined data values. This data is generated by the assembler. If the assembler is not used, set this data to ‘00’. Option specified Option/data relationship
Usage Notes 1. Option specification When using a Sanyo cross assembler with the LC66E5316, use the version called “LC66S.EXE” and specify the actual microcontroller to be evaluated with the CPU pseudo instruction in the source file. The port options must be specified in the source file. The cross assembler will create an option code list in the option specification area (locations 3FF0H to 3FFFH). It is also possible to directly set up data in the option specification area. If this is done, the options must be specified according to the option code creation table shown on the following page. 2. Writing the EPROM Use a special-purpose writing conversion board (the W66EP5316D for the DIP package, and the W66EP5316Q for the QFP package) to allow the EPROM programmers listed below to be used when writing the data created by the cross assembler to the LC66E5316. • The EPROM programmers listed below can be used.
Manufacturer Advantest Ando AVAL Minato Electronics MODEL1890A Models that can be used R4945, R4944A, R4943, or equivalent products AF9704 —
• The “27512 (VPP 12.5 V) Intel high-speed write” technique must be used to write the EPROM. Set the address range to location 0 to 3FFFH. The DASEC jumper must be off. 3. Using the data security function The data security function sets up the microcontroller in advance so that data that was written to the microcontroller EPROM cannot be read out. Use the following procedure to enable the LC66E5316 data security function. • Set the write conversion board DASEC jumper to the on position. • Write the data to the EPROM once again. At this time, since this function will operate, the EPROM programmer will issue an error. However, this error does not indicate that there was a problem in either the programmer or the LSI. Notes: 1. If the data at all addresses was “FF” at step 2, the data security function will not be activated. Notes: 2. The data security function will not be activated at step 2 if the “blank → program → verify” operation sequence is used. Notes: 3. Always return the jumper to the off position after the data security function has been activated.
No. 5488-13/27
LC66E5316 4. Erase procedure Use a general-purpose EPROM eraser to erase data written to the EPROM.
LC66E5316 (DIC)
LC66E5316 (QFC)
Cut corner
Pin 1 SW DASEC
Pin 1 Aligned to the top
SW DASEC
Pin 1
Write board (W66EP5316D)
O
Write board (W66EP5316Q)
Specifications
Absolute Maximum Ratings at Ta = 25°C, VSS = 0 V
Parameter Maximum supply voltage Input voltage Symbol VDD max VIN1 VIN2 Output voltage VOUT1 VOUT2 ION1 Output current per pin –IOP1 –IOP2 –IOP3 Σ ION1 Σ ION2 Total pin current Σ IOP1 Σ IOP2 Allowable power dissipation Operating temperature Storage temperature Pd max Topr Tstg VDD P2, P3 (except for the P33/HOLD pin), P61, and P63 All other inputs P2, P3 (except for the P33/HOLD pin), P61, and P63 All other inputs P0, P1, P2, P3 (except for the P33/HOLD pin), P4, P5, P6, P8, PC, PD1, PD3 P0, P1, P4, P5 P2, P3 (except for the P33/HOLD pin), P6,P8, and PC P41, P43, PC3, PD1, PD3, P81 P4, P5, P6, P8, PC P0, P1, P2, P3 (except for the P33/HOLD pin), PD1, PD3 P4, P5, P6, P8, PC P0, P1, P2, P3 (except for the P33/HOLD pin), PD1, PD3 Ta = –30 to +70°C: DIC42S (QFC48) Conditions Ratings –0.3 to +7.0 –0.3 to +7.0 –0.3 to VDD + 0.3 –0.3 to +7.0 –0.3 to VDD + 0.3 20 2 4 10 75 75 25 25 600 (430) +10 to +40 –55 to +125 Unit V V V V V mA mA mA mA mA mA mA mA mW °C °C 1 2 1 2 3 4 4 4 3 3 4 4 Note
Note: 1. Applies to pins with open-drain output specifications. For pins with other than open-drain output specifications, the ratings in the pin column for that pin apply. 2. For the oscillator input and output pins, levels up to the free-running oscillation level are allowed. 3. Sink current (Applies to P8 and PD when either the CMOS output specifications or the inverter array specifications have been selected.) 4. Source current (Applies to all pins except P8 and PD for which the pull-up output specifications, the CMOS output specifications, or the inverter array specifications have been selected. Applies to PD pins for which the inverter array specifications have been selected.) Contact your Sanyo representative for the electrical characteristics when the inverter array or buffer array options are specified
No. 5488-14/27
LC66E5316 Allowable Operating Ranges at Ta = +10 to +40°C, VSS = 0 V, VDD = 4.5 to 5.5 V, unless otherwise specified.
Parameter Operating supply voltage Memory retention supply voltage Symbol VDD VDDH VIH1 Input high-level voltage VIH2 VIH3 VIL1 Input low-level voltage VIL2 VIL3 VDD VDD: During hold mode P2, P3 (except for the P33/HOLD pin), P61, and P63: N-channel output transistor off P33/HOLD, RES, OSC1: N-channel output transistor off P0, P1, P4, P5, PC, PD, PE: N-channel output transistor off P2, P3 (except for the P33/HOLD pin), P6, RES, and OSC1: N-channel output transistor off P33/HOLD: VDD = 1.8 to 5.5 V P0, P1, P4, P5, PC, PD, PE, TEST: N-channel output transistor off When the main oscillator is operating Operating frequency (instruction cycle time) [External clock input conditions] OSC1: Defined by Figure 1. Input the clock signal to OSC1 and leave OSC2 open. (External clock input must be selected as the oscillator circuit option.) OSC1: Defined by Figure 1. Input the clock signal to OSC1 and leave OSC2 open. (External clock input must be selected as the oscillator circuit option.) OSC1: Defined by Figure 1. Input the clock signal to OSC1 and leave OSC2 open. (External clock input must be selected as the oscillator circuit option.) fop (Tcyc) When the sub-oscillator is operating Conditions min 4.5 1.8 0.8 VDD 0.8 VDD 0.8 VDD VSS VSS VSS 0.4 (10) 30 (133.2) 32.768 (122) typ max 5.5 5.5 +7.0 VDD VDD 0.2 VDD 0.2 VDD 0.2 VDD 4.2 (0.95) 100 (40) Unit V V V V V V V V MHz (µs ) kHz (µs) 2 2 1 Note
Frequency
fext
0.4
4.20
MHz
Pulse width
textH, textL
100
ns
Rise and fall times
textR, textF
30
ns
Note: 1. Applies to pins with open-drain specifications. However, VIH2 applies to the P33/HOLD pin. When ports P2, P3, and P6 have CMOS output specifications they cannot be used as input pins. 2. PC port pins with CMOS output specifications cannot be used as input pins. Contact your Sanyo representative for the allowable operating ranges for P4, PC, and PD when the inverter array is used, and for P8 when the buffer array is used. 3. Applies to pins with open-drain specifications. However, VIL2 applies to the P33/HOLD pin. P2, P3, and P6 port pins with CMOS output specifications cannot be used as input pins.
No. 5488-15/27
LC66E5316 Electrical Characteristics at Ta = +10 to +40°C, VSS = 0 V, VDD = 4.5 to 5.5 V unless otherwise specified.
Parameter Symbol IIH1 Conditions P2, P3 (except for the P33/HOLD pin), P61, and P63: VIN = +10.0 V, with the output Nch transistor off P0, P1, P4, P5, P6, PC, OSC1, and P33/HOLD (Does not apply to PD, PE, PC2, and PC3): VIN = VDD, with the output Nch transistor off PD, PC2, PC3, PE0 (When used as a port; does not apply when the sub-oscillator option is selected.): VIN = VDD, with the output Nch transistor off RES: VIN = VDD, operating, halt mode RES: VIN = VDD, hold mode PE1 (When used as a port; does not apply when the sub-oscillator option is selected.) VIN = VDD Input ports other than PD, PE, PC2, and PC3: VIN = VSS, with the output Nch transistor off PD, PC2, PC3, PE0 (When used as a port; does not apply when the sub-oscillator option is selected.): VIN = VSS, with the output Nch transistor off RES: VIN = VSS PE1 (When used as a port; does not apply when the sub-oscillator option is selected.): VIN = VSS P2, P3 (except for the P33/HOLD pin), P6, P8, and PC: IOH = –1 mA VDD – 1.0 V VDD – 0.5 30 100 150 0.4 1.5 5.0 1.0 –1.0 kΩ V V µA µA µA 6 6 7 4 5 3 –1.0 10 1.0 1.0 min typ max 5.0 Unit µA Note 1
IIH2
1.0
µA
1
Input high-level current IIH3 IIH4 IIH5 IIH6 IIL1
1.0
µA
1
µA µA µA µA
1 1 1 2
Input low-level current
IIL2
–1.0
µA
2
IIL3 IIL4
100 20
µA µA
1 1
Output high-level voltage
VOH1
P2, P3 (except for the P33/HOLD pin), P6, P8, and PC: IOH = –0.1 mA P0, P1, P4, P5 P0, P1, P2, P3, P4, P5, P6, P8, and PC (except for the P33/HOLD pin): IOL = 1.6 mA P0, P1, P2, P3, P4, P5, P6, P8, and PC (except for the P33/HOLD pin): IOL = 8 mA P2, P3, P61, P63: VIN = +7.0 V Does not apply to P2, P3, P61, P63, and P8.: VIN = VDD P8: VIN = VSS
Value of the output pull-up resistor
RPO VOL1
Output low-level voltage VOL2 IOFF1 Output off leakage current IOFF2 IOFF3 [Schmitt characteristics] Hysteresis voltage High-level threshold voltage Low-level threshold voltage [Ceramic oscillator] Oscillator frequency Oscillator stabilization time [Crystal oscillator] Oscillator frequency Oscillator stabilization time [Serial clock] Cycle time Input Output tCKCY tCKL tCKH tCKR, tCKF fXT fXTS fCF fCFS VHYS Vt H Vt L
0.1 VDD P2, P3, P5, P6, OSC1 (EXT), RES 0.5 VDD 0.2 VDD OSC1, OSC2: Figure 2, 4 MHz Figure 3, 4 MHz 4.0 10.0 0.8 VDD 0.5 VDD
V V V
MHz ms
XT1, XT2: Figure 2, when the sub-oscillator option is selected, 32 kHz Figure 3, when the sub-oscillator option is selected, 32 kHz
32.768 1.0 5.0
kHz s
0.9 2.0 SCK0, SCK1: With the timing of Figure 4 and the test load of Figure 5. 0.4 1.0 0.1
µs Tcyc µs Tcyc µs
Low-level and high-level Input pulse widths Output Rise an fall times [Serial input] Data setup time Data hold time Output
tICK tCKI
SI0, SI1: With the timing of Figure 4. Stipulated with respect to the rising edge (↑) of SCK0 or SCK1.
0.3 0.3
µs µs
Continued on next page.
No. 5488-16/27
LC66E5316
Continued from preceding page.
Parameter [Serial output] Output delay time [Pulse conditions] INT0: Figure 6, conditions under which the INT0 interrupt can be accepted, conditions under which the timer 0 event counter or pulse width measurement input can be accepted INT1, INT2: Figure 6, conditions under which the corresponding interrupt can be accepted PIN1: Figure 6, conditions under which the timer 1 event counter input can be accepted RES: Figure 6, conditions under which reset can be applied. tCKO SO0, SO1: With the timing of Figure 5 and the test load of Figure 5. Stipulated with respect to the falling edge (↓) of SCK0 or SCK1. 0.3 µs Symbol Conditions min typ max Unit Note
INT0 high and low-level
tIOH, tIOL
2
Tcyc
High and low-level pulse widths for interrupt inputs other than INT0 PIN1 high and low-level pulse widths RES high and low-level pulse widths
tIIH, tIIL tPINH, tPINL tRSH, tRSL
2 2 3
Tcyc Tcyc Tcyc
Operating current drain
IDD OP
VDD: 4-MHz ceramic oscillator VDD: 4-MHz external clock VDD: 4-MHz ceramic clock VDD: 32 kHz (main oscillator stopped), sub-oscillator: crystal VDD: VDD = 1.8 to 5.5 V
6.0 6.0 4 100 0.01
12 12 8 500 10
mA mA mA µA µA
8
Halt mode current drain Hold mode current drain
IDDHALT IDDHOLD
Note: 1. With the output Nch transistor off in shared I/O ports with the open-drain output specifications. These pins cannot be used as input pins if the CMOS output specifications are selected. 2. With the output Nch transistor off in shared I/O ports with the open-drain output specifications. The rating for the pull-up output specification pins is stipulated in terms of the output pull-up current IPO. These pins cannot be used as input pins if the CMOS output specifications are selected. 3. With the output Nch transistor off for CMOS output specification pins. (Also applies when the Pch open-drain option is selected for P8.) 4. With the output Nch transistor off for pull-up output specification pins. 5. When CMOS output specifications are selected for P8. 6. With the output Nch transistor off for pull-up output specification pins. 7. With the output Pch transistor off for open-drain output specification pins. 8. Reset state
Comparator Characteristics at Ta = –30 to +70°C, VSS = 0 V
Parameter Absolute precision Threshold voltage Input voltage Conversion time Symbol VCECM VTHCM VINCM TCCM Conditions AN1 to AN4: VDD = 4.5 to 5.5 V VDD = 4.5 to 5.5 V AN1 to AN4: VDD = 4.5 to 5.5 V VDD = 4.5 to 5.5 V VSS VSS min typ ±1/2 max ±1 VDD VDD 30 Unit LSB V V µs Note 1
Note: 1. Does not include the quantization error.
VDD 0.8VDD 0.2VDD VSS External clock OPEN textF textL textR 1/fext textH
OSC1
(OSC2)
Figure 1 External Clock Input Waveform
No. 5488-17/27
LC66E5316
VDD Operating VDD minimum value 0V Stable oscillation Oscillator unstable period tCFS
OSC1
OSC2 Rd C2 C1
XT1
XT2 Rd C2
OSC
C1
Ceramic oscillator
Crystal oscillatorI
Figure 2 Ceramic Oscillator Circuit
Figure 3 Oscillator Stabilization Period
Table 1 Guaranteed Ceramic Oscillator Constants External capacitor type
External capacitor type Built-in capacitor type 4 MHz (Murata Mfg. Co., Ltd.) CSA4.00MG 4 MHz (Kyocera Corporation) KBR4.0MS C1 = 33 pF ± 10% C2 = 33 pF ± 10% Rd = 220 Ω ± 5% 4 MHz (Murata Mfg. Co., Ltd.) CST4.00MG 4 MHz (Kyocera Corporation) KBR4.0MES Rd = 220 Ω ± 5% C1 = 33 pF ± 10% C2 = 33 pF ± 10% Rd = 0 Ω
Table 2 Guaranteed Crystal Oscillator Constants
32 kHz (Seiko Epson) C-002RX C1 = 18 pF ± 10% C2 = 18 pF ± 10% Rd = 470 kΩ ± 5%
tCKCY tCKL SCK0 SCK1 0.2VDD (input) 0.4VDD (output) SI0 SI1 tCK0 SO0 SO1 VDD-1 0.4VDD tCKR tCKH tCKF 0.8VDD (input) VDD-1 (output) tICK tCKI 0.8VDD 0.2VDD R=1kΩ TEST point C=50pF
Figure 4 Serial I/O Timing
tI0H tI1H tPINH tRSH 0.8VDD 0.2VDD tI0L tI1L tPINL tRSL
Figure 5 Timing Load
Figure 6 Input Timing for the INT0, INT1, INT2, PIN1, and RES pins
No. 5488-18/27
LC66E5316 LC66XXXX Series Instruction Table (by function) Abbreviations: AC: Accumulator E: E register CF: Carry flag ZF: Zero flag HL: Data pointer DPH, DPL XY: Data pointer DPX, DPY M: Data memory M (HL): Data memory pointed to by the DPH, DPL data pointer M (XY): Data memory pointed to by the DPX, DPY auxiliary data pointer M2 (HL): Two words of data memory (starting on an even address) pointed to by the DPH, DPL data pointer SP: Stack pointer M2 (SP): Two words of data memory pointed to by the stack pointer M4 (SP): Four words of data memory pointed to by the stack pointer in: n bits of immediate data t2: Bit specification
t2 Bit 11 23 10 22 01 21 00 20
PCh: PCm: PCl: Fn: TIMER0: TIMER1: SIO: P: P (i4): INT: ( ), [ ]: ←: : : : +: –: —:
Bits 8 to 11 in the PC Bits 4 to 7 in the PC Bits 0 to 3 in the PC User flag, n = 0 to 15 Timer 0 Timer 1 Serial register Port Port indicated by 4 bits of immediate data Interrupt enable flag Indicates the contents of a location Transfer direction, result Exclusive or Logical and Logical or Addition Subtraction Taking the one's complement
No. 5488-19/27
LC66E5316
Instruction code Mnemonic D 7 D6 D5 D4 D3 D2 D1 D0 [Accumulator manipulation instructions] CLA DAA Clear AC Decimal adjust AC in addition Decimal adjust AC in subtraction Clear CF Set CF Complement AC Increment AC Decrement AC Rotate AC right through CF Rotate AC left through CF Transfer AC to E Transfer E to AC Exchange AC with E 1000 1100 0010 1100 0010 0001 0001 0001 0001 0010 0001 0000 1111 0110 1111 1010 1110 1111 1000 0100 0100 0000 1 2 1 2 AC ← 0 Clear AC to 0. (Equivalent to LAI 0.) AC ← (AC) + 6 Add six to AC. (Equivalent to ADI 6.) AC ← (AC) + 10 (Equivalent to ADI 0AH.) CF ← 0 CF ← 1 AC ← (AC) AC ← (AC) + 1 AC ← (AC) – 1 AC3 ← (CF), ACn ← (ACn + 1), CF ← (AC0) AC0 ← (CF), ACn + 1 ← (ACn), CF ← (AC3) E ← (AC) AC ← (E) (AC) ↔ (E) Add 10 to AC. Clear CF to 0. Set CF to 1. Take the one’s complement of AC. Increment AC. Decrement AC. Shift AC (including CF) right. ZF ZF Has a vertical skip function. Number of bytes Number of cycles Affected status bits
Operation
Description
Note
DAS CLC STC CMA IA DA RAR
2 1 1 1 1 1 1
2 1 1 1 1 1 1
ZF CF CF ZF ZF, CF ZF, CF CF
RAL TAE TEA XAE
0000 0100 0100 0100
0001 0101 0110 0100
1 1 1 1
1 1 1 1
Shift AC (including CF) left. Transfer the contents of AC to E.
CF, ZF
Transfer the contents of E to AC. ZF Exchange the contents of AC and E.
[Memory manipulation instructions] IM DM IMDR i8 Increment M Decrement M Increment M direct 0001 0010 1100 I7 I6 I5 I4 1100 I7 I6 I5 I4 0000 0010 0010 0010 0111 I3 I2 I1 I0 0011 I3 I2 I1 I0 1 1 t1 t0 1 1 t1 t0 1 1 2 2 1 1 1 1 2 2 1 1 M (HL) ← [M (HL)] + 1 M (HL) ← [M (HL)] – 1 M (i8) ← [M (i8)] + 1 M (i8) ← [M (i8)] – 1 [M (HL), t2] ← 1 [M (HL), t2] ← 0 Increment M (HL). Decrement M (HL). Increment M (i8). Decrement M (i8). Set the bit in M (HL) specified by t0 and t1 to 1. Clear the bit in M (HL) specified by t0 and t1 to 0. ZF ZF, CF ZF, CF ZF, CF ZF, CF
DMDR i8 Decrement M direct SMB t2 RMB t2 Set M data bit Reset M data bit
[Arithmetic, logic and comparison instructions] AC ← (AC) + [M (HL)] Add the contents of AC and M (HL) as two’s complement values and store the result in AC.
AD
Add M to AC
0000
0110
1
1
ZF, CF
ADDR i8 Add M direct to AC
1100 I7 I6 I5 I4
1001 I3 I2 I1 I0
2
2
Add the contents of AC and M (i8) as two’s complement AC ← (AC) + [M (i8)] values and store the result in AC. AC ← (AC) + [M (HL)] + (CF) Add the contents of AC, M (HL) and C as two’s complement values and store the result in AC. Add the contents of AC and the immediate data as two’s complement values and store the result in AC. Subtract the contents of AC and CF from M (HL) as two’s complement values and store the result in AC. Take the logical and of AC and M (HL) and store the result in AC. Take the logical or of AC and M (HL) and store the result in AC.
ZF, CF
ADC
Add M to AC with CF 0 0 0 0
0010
1
1
ZF, CF
ADI i4
Add immediate data to AC
1100 0010
1111 I3 I2 I1 I0
2
2
AC ← (AC) + I3, I2, I1, I0
ZF
SUBC
Subtract AC from M with CF
0001
0111
1
1
AC ← [M (HL)] – (AC) – (CF) AC ← (AC) [M (HL)] AC ← (AC) [M (HL)]
ZF, CF
CF will be zero if there was a borrow and one otherwise.
ANDA
And M with AC then store AC Or M with AC then store AC
0000
0111
1
1
ZF
ORA
0000
0101
1
1
ZF
Continued on next page. No. 5488-20/27
LC66E5316
Continued from preceding page.
Instruction code Mnemonic D 7 D6 D5 D4 D3 D2 D1 D0 [Arithmetic, logic and comparison instructions] EXL Exclusive or M with AC then store AC And M with AC then store M Or M with AC then store M 0001 0101 1 1 AC ← (AC) [M (HL)] M (HL) ← (AC) [M (HL)] M (HL) ← (AC) [M (HL)] Take the logical exclusive or of AC and M (HL) and store the result in AC. Take the logical and of AC and M (HL) and store the result in M (HL). Take the logical or of AC and M (HL) and store the result in M (HL). Compare the contents of AC and M (HL) and set or clear CF and ZF according to the result. CM Compare AC with M 0001 0110 1 1 [M (HL)] + (AC) + 1 Magnitude comparison [M (HL)] > (AC) [M (HL)] = (AC) [M (HL)] < (AC) CF ZF 0 1 1 0 1 0 ZF, CF ZF Number of bytes Number of cycles Affected status bits
Operation
Description
Note
ANDM
0000
0011
1
1
ZF
ORM
0000
0100
1
1
ZF
Compare the contents of AC and the immediate data I3 I2 I1 I0 and set or clear CF and ZF according to the result. CI i4 Compare AC with immediate data 1100 1010 1111 I3 I2 I1 I0 2 2 I3 I2 I1 I0 + (AC) + 1 Magnitude comparison I3 I2 I1 I0 > AC I3 I2 I1 I0 = AC I3 I2 I1 I0 < AC ZF ← 1 if (DPL) = I3 I2 I1 I0 ZF ← 0 if (DPL) ≠ I3 I2 I1 I0 ZF ← 1 if (AC, t2) = [M (HL), t2] ZF← 0 if (AC, t2) ≠ [M (HL), t2] AC ← M (HL), E ← M (HL + 1) AC ← I3 I2 I1 I0 AC ← [M (i8)] M (HL) ← (AC) M (HL) ← (AC) M (HL + 1) ← (E) CF ZF 0 1 1 0 1 0 ZF, CF
CLI i4
Compare DPL with immediate data
1100 1011
1111 I3 I2 I1 I0
2
2
Compare the contents of DPL with the immediate data. Set ZF if identical and clear ZF if not. Compare the corresponding bits specified by t0 and t1 in AC and M (HL). Set ZF if identical and clear ZF if not.
ZF
CMB t2
Compare AC bit with M data bit
1100 1101
1111 0 0 t1 t0
2
2
ZF
[Load and store instructions] LAE LAI i4 LADR i8 S SAE Load AC and E from M2 (HL) Load AC with immediate data Load AC from M direct Store AC to M Store AC and E to M2 (HL) 0101 1000 1100 I7 I6 I5 I4 0100 0101 1100 I3 I2 I1 I0 0001 I3 I2 I1 I0 0111 1110 1 1 2 1 1 1 1 2 1 1 Load the contents of M2 (HL) into AC, E. Load the immediate data into AC. Load the contents of M (i8) into AC. Store the contents of AC into M (HL). Store the contents of AC, E into M2 (HL). Load the contents of M (reg) into AC. The reg is either HL or XY depending on t0. ZF reg HL XY T0 0 1 ZF ZF Has a vertical skip function
LA reg
Load AC from M (reg)
0100
1 0 t0 0
1
1
AC ← [M (reg)]
Continued on next page. No. 5488-21/27
LC66E5316
Continued from preceding page.
Instruction code Mnemonic D 7 D6 D5 D4 D3 D2 D1 D0 [Load and store instructions] Load the contents of M (reg) into AC. (The reg is either HL or XY.) Then increment the contents of either DPL or DPY. ZF The relationship between t0 and reg is the same as that for the LA reg instruction. Load the contents of M (reg) into AC. (The reg is either HL or XY.) Then decrement the contents of either DPL or DPY. ZF The relationship between t0 and reg is the same as that for the LA reg instruction. Exchange the contents of M (reg) and AC. The reg is either HL or XY depending on t0. reg HL XY T0 0 1 ZF is set according to the result of incrementing DPL or DPY. Number of bytes Number of cycles Affected status bits
Operation
Description
Note
LA reg, I
Load AC from M (reg) 0100 then increment reg
1 0 t0 1
1
2
AC ← [M (reg)] DPL ← (DPL) + 1 or DPY ← (DPY) + 1
Load AC from M (reg) LA reg, D 0101 then decrement reg
1 0 t0 1
1
2
AC ← [M (reg)] DPL ← (DPL) – 1 or DPY ← (DPY) – 1
ZF is set according to the result of decrementing DPL or DPY.
XA reg
Exchange AC with M (reg)
0100
1 1 t0 0
1
1
(AC) ↔ [M (reg)]
Exchange AC with XA reg, I M (reg) then increment reg
0100
1 1 t0 1
1
2
(AC) ↔ [M (reg)] DPL ← (DPL) + 1 or DPY ← (DPY) + 1
Exchange the contents of M (reg) and AC. (The reg is either HL or XY.) Then increment the contents of either DPL or DPY. The relationship between t0 and reg is the same as that for the XA reg instruction. Exchange the contents of M (reg) and AC. (The reg is either HL or XY.) Then decrement the contents of either DPL or DPY. The relationship between t0 and reg is the same as that for the XA reg instruction. Exchange the contents of AC and M (i8). Load the immediate data i8 into E, AC. Load into E, AC the ROM data at the location determined by replacing the lower 8 bits of the PC with E, AC. Output from ports 4 and 5 the ROM data at the location determined by replacing the lower 8 bits of the PC with E, AC.
ZF
ZF is set according to the result of incrementing DPL or DPY.
Exchange AC with XA reg, D M (reg) then decrement reg
0101
1 1 t0 1
1
2
(AC) ↔ [ [M (reg)] DPL ← (DPL) – 1 or DPY ← (DPY) – 1
ZF
ZF is set according to the result of decrementing DPL or DPY.
XADR i8 LEAI i8
Exchange AC with M direct Load E & AC with immediate data
1100 I7 I6 I5 I4 1100 I7 I6 I5 I4
1000 I3 I2 I1 I0 0110 I3 I2 I1 I0
2 2
2 2
(AC) ↔ [ [M (i8)] E ← I7 I6 I5 I4 AC ← I3 I2 I1 I0 E, AC ← [ROM (PCh, E, AC)]
RTBL
Read table data from 0101 program ROM
1010
1
2
RTBLP
Read table data from program ROM then 0101 output to P4, 5
1000
1
2
Port 4, 5 ← [ROM (PCh, E, AC)]
[Data pointer manipulation instructions] Load DPH with zero and DPL with immediate data respectively Load DPH with immediate data Load DPL with immediate data Load DPH, DPL with immediate data Load DPX, DPY with immediate data DPH ← 0 DPL ← I3 I2 I1 I0 DPH ← I3 I2 I1 I0 DPL ← I3 I2 I1 I0 DPH ← I7 I6 I5 I4 DPL ← I3 I2 I1 I0 DPX ← I7 I6 I5 I4 DPY ← I3 I2 I1 I0 Load zero into DPH and the immediate data i4 into DPL. Load the immediate data i4 into DPH. Load the immediate data i4 into DPL. Load the immediate data into DLH, DPL. Load the immediate data into DLX, DPY.
LDZ i4
0110
I3 I2 I1 I0 1111 I3 I2 I1 I0 1111 I3 I2 I1 I0 0000 I3 I2 I1 I0 0000 I3 I2 I1 I0
1
1
LHI i4 LLI i4 LHLI i8 LXYI i8
1100 0000 1100 0001 1100 I7 I6 I5 I4 1100 I7 I6 I5 I4
2 2 2 2
2 2 2 2
Continued on next page. No. 5488-22/27
LC66E5316
Continued from preceding page.
Instruction code Mnemonic D 7 D6 D5 D4 D3 D2 D1 D0 [Data pointer manipulation instructions] IL DL IY DY TAH THA XAH TAL TLA XAL TAX TXA XAX TAY TYA XAY Increment DPL Decrement DPL Increment DPY Decrement DPY Transfer AC to DPH Transfer DPH to AC Exchange AC with DPH Transfer AC to DPL Transfer DPL to AC Exchange AC with DPL Transfer AC to DPX Transfer DPX to AC Exchange AC with DPX Transfer AC to DPY Transfer DPY to AC Exchange AC with DPY 0001 0010 0001 0010 1100 1111 1100 1110 0100 1100 1111 1100 1110 0100 1100 1111 1100 1110 0100 1100 1111 1100 1110 0100 0001 0001 0011 0011 1111 0000 1111 0000 0000 1111 0001 1111 0001 0001 1111 0010 1111 0010 0010 1111 0011 1111 0011 0011 1 1 1 1 2 2 1 2 2 1 2 2 1 2 2 1 1 1 1 1 2 2 1 2 2 1 2 2 1 2 2 1 DPL ← (DPL) + 1 DPL ← (DPL) – 1 DPY ← (DPY) + 1 DPY ← (DPY) – 1 DPH ← (AC) AC ← (DPH) (AC) ↔ (DPH) DPL ← (AC) AC ← (DPL) (AC) ↔ (DPL) DPX ← (AC) AC ← (DPX) (AC) ↔ (DPX) DPY ← (AC) AC ← (DPY) (AC) ↔ (DPY) Increment the contents of DPL. Decrement the contents of DPL. Increment the contents of DPY. Decrement the contents of DPY. Transfer the contents of AC to DPH. Transfer the contents of DPH to AC. Exchange the contents of AC and DPH. Transfer the contents of AC to DPL. Transfer the contents of DPL to AC. Exchange the contents of AC and DPL. Transfer the contents of AC to DPX. Transfer the contents of DPX to AC. Exchange the contents of AC and DPX. Transfer the contents of AC to DPY. Transfer the contents of DPY to AC. Exchange the contents of AC and DPY. Set the flag specified by n4 to 1. Reset the flag specified by n4 to 0. ZF ZF ZF ZF ZF ZF ZF ZF ZF Number of bytes Number of cycles Affected status bits
Operation
Description
Note
[Flag manipulation instructions] SFB n4 RFB n4 Set flag bit Reset flag bit 0111 0011 n 3 n2 n1 n0 n 3 n2 n1 n0 1 1 1 1 Fn ← 1 Fn ← 0
[Jump and subroutine instructions] PC13, 12 ← PC13, 12 PC11 to 0 ← P11 to P8 PC13 to 8 ← PC13 to 8, PC7 to 4 ← (E), PC3 to 0 ← (AC) PC13 to 11 ← 0, PC10 to 0 ← P10 to P0, M4 (SP) ← (CF, ZF, PC13 to 0), SP ← (SP)-4 Jump to the location in the same bank specified by the immediate data P12. Jump to the location determined by replacing the lower 8 bits of the PC by E, AC. This becomes PC12 + (PC12) immediately following a BANK instruction.
JMP addr
Jump in the current bank
1 1 1 0 P11P10P9 P8 P7 P6 P5 P4 P3 P2 P1 P0
2
2
JPEA
Jump to the address stored at E and AC in the current page
0010
0111
1
1
CAL addr
Call subroutine
0 1 0 1 0 P10 P9 P8 P7 P6 P5 P4 P3 P2 P1 P0
2
2
Call a subroutine.
CZP addr
Call subroutine in the 1010 zero page
P3 P2 P1 P0
1
2
PC13 to 6, PC10 ← 0, PC5 to 2 ← P3 to P0, Call a subroutine on page 0 M4 (SP) ← in bank 0. (CF, ZF, PC12 to 0), SP ← SP-4 Change the memory bank and register bank.
BANK
Change bank
0001
1011
1
1
Continued on next page. No. 5488-23/27
LC66E5316
Continued from preceding page.
Instruction code Mnemonic D 7 D6 D5 D4 D3 D2 D1 D0 [Jump and subroutine instructions] Store the contents of reg in M2 (SP). Subtract 2 from SP after the store. PUSH reg Push reg on M2 (SP) 1100 1111 1111 1 i 1 i0 0 2 2 M2 (SP) ← (reg) SP ← (SP) – 2 reg HL XY AE Illegal value i1 0 0 1 1 i0 0 1 0 1 Number of bytes Number of cycles Affected status bits
Operation
Description
Note
POP reg
Pop reg off M2 (SP)
1100 1110
1111 1 i 1 i0 0
2
2
SP ← (SP) + 2 reg ← [M2 (SP)]
Add 2 to SP and then load the contents of M2(SP) into reg. The relation between i1i0 and reg is the same as that for the PUSH reg instruction. Return from a subroutine or interrupt handling routine. ZF and CF are not restored. Return from a subroutine or interrupt handling routine. ZF and CF are restored. ZF, CF
RT
Return from subroutine Return from interrupt routine
0001
1100
1
2
SP ← (SP) + 4 PC ← [M4 (SP)] SP ← (SP) + 4 PC ← [M4 (SP)] CF, ZF ← [M4 (SP)] PC7 to 0 ← P7 P6 P5 P4 P3 P2 P1 P0 if (AC, t2) = 1 PC7 to 0 ← P7 P6 P5 P4 P3 P2 P1 P0 if (AC, t2) = 0 PC7 to 0 ← P7 P6 P5 P4 P3 P2 P1 P0 if [M (HL),t2] =1 PC7 to 0 ← P7 P6 P5 P4 P3 P2 P1 P0 if [M (HL),t2] =0
RTI
0001
1101
1
2
[Branch instructions] BAt2 addr 1 1 0 1 0 0 t1 t0 P7 P6 P5 P4 P3 P2 P1 P0 Branch to the location in the same page specified by P7 to P0 if the bit in AC specified by the immediate data t1 t0 is one. Branch to the location in the same page specified by P7 to P0 if the bit in AC specified by the immediate data t1 t0 is zero. Branch to the location in the same page specified by P7 to P0 if the bit in M (HL) specified by the immediate data t1 t0 is one. Branch to the location in the same page specified by P7 to P0 if the bit in M (HL) specified by the immediate data t1 t0 is zero. Internal control registers can also be tested by executing this instruction immediately after a BANK instruction. However, this is limited to registers that can be read out. Internal control registers can also be tested by executing this instruction immediately after a BANK instruction. However, this is limited to registers that can be read out.
Branch on AC bit
2
2
BNAt2 addr
Branch on no AC bit
1 0 0 1 0 0 t1 t0 P7 P6 P5 P4 P3 P2 P1 P0
2
2
BMt2 addr
Branch on M bit
1 1 0 1 0 1 t1 t0 P7 P6 P5 P4 P3 P2 P1 P0
2
2
BNMt2 addr
Branch on no M bit
1 0 0 1 0 1 t1 t0 P7 P6 P5 P4 P3 P2 P1 P0
2
2
BPt2 addr
Branch on Port bit
1 1 0 1 1 0 t1 t0 P7 P6 P5 P4 P3 P2 P1 P0
2
2
PC7 to 0 ← P7 P6 P5 P4 P3 P2 P1 P0 if [P (DPL), t2] =1
Branch to the location in the same page specified by P7 to P0 if the bit in port (DPL) specified by the immediate data t1 t0 is one.
BNPt2 addr
1 0 0 1 1 0 t1 t0 Branch on no Port bit P7 P6 P5 P4 P3 P2 P1 P0
2
2
PC7 to 0 ← P7 P6 P5 P4 P3 P2 P1 P0 if [P (DPL), t2] =0
Branch to the location in the same page specified by P7 to P0 if the bit in port (DPL) specified by the immediate data t1 t0 is zero.
Continued on next page. No. 5488-24/27
LC66E5316
Continued from preceding page.
Instruction code Mnemonic D 7 D6 D5 D4 D3 D2 D1 D0 [Branch instructions] 1101 1100 P7 P6 P5 P4 P3 P2 P1 P0 PC7 to 0 ← P7 P6 P5 P4 P3 P2 P1 P0 if (CF) = 1 PC7 to 0 ← P7 P6 P5 P4 P3 P2 P1 P0 if (CF) = 0 PC7 to 0 ← P7 P6 P5 P4 P3 P2 P1 P0 if (ZF) = 1 PC7 to 0 ← P7 P6 P5 P4 P3 P2 P1 P0 if (ZF) = 0 PC7 to 0 ← P7 P6 P5 P4 P3 P2 P1 P0 if (Fn) = 1 PC7 to 0 ← P7 P6 P5 P4 P3 P2 P1 P0 if (Fn) = 0 Branch to the location in the same page specified by P7 to P0 if CF is one. Branch to the location in the same page specified by P7 to P0 if CF is zero. Branch to the location in the same page specified by P7 to P0 if ZF is one. Branch to the location in the same page specified by P7 to P0 if ZF is zero. Branch to the location in the same page specified by P0 to P7 if the flag (of the 16 user flags) specified by n3 n2 n1 n0 is one. Branch to the location in the same page specified by P0 to P7 if the flag (of the 16 user flags) specified by n3 n2 n1 n0 is zero. Number of bytes Number of cycles Affected status bits
Operation
Description
Note
BC addr
Branch on CF
2
2
BNC addr
Branch on no CF
1001 1100 P7 P6 P5 P4 P3 P2 P1 P0
2
2
BZ addr
Branch on ZF
1101 1101 P7 P6 P5 P4 P3 P2 P1 P0
2
2
BNZ addr
Branch on no ZF
1001 1101 P7 P6 P5 P4 P3 P2 P1 P0
2
2
BFn4 addr
Branch on flag bit
1 1 1 1 n 3 n2 n1 n0 P7 P6 P5 P4 P3 P2 P1 P0
2
2
BNFn4 addr
Branch on no flag bit
1 0 1 1 n 3 n2 n1 n0 P7 P6 P5 P4 P3 P2 P1 P0
2
2
[I/O instructions] IP0 IP IPM IPDR i4 Input port 0 to AC Input port to AC Input port to M Input port to AC direct Input port 4, 5 to E, AC respectively Output AC to port Output M to port Output AC to port direct Output E, AC to port 4, 5 respectively 0010 0010 0001 1100 0110 1100 1101 0010 0001 1100 0111 1100 1101 0000 0110 1001 1111 I3 I2 I1 I0 1111 0100 0101 1010 1111 I3 I2 I1 I0 1111 0101 1 1 1 2 1 1 1 2 AC ← (P0) AC ← [P (DPL)] M (HL) ← [P (DPL)] AC ← [P (i4)] E ← [P (4)] AC ← [P (5)] P (DPL) ← (AC) P (DPL) ← [M (HL)] P (i4) ← (AC) P (4) ← (E) P (5) ← (AC) [P (DPL), t2] ← 1 Input the contents of port 0 to AC. Input the contents of port P (DPL) to AC. Input the contents of port P (DPL) to M (HL). Input the contents of P (i4) to AC. Input the contents of ports P (4) and P (5) to E and AC respectively. Output the contents of AC to port P (DPL). Output the contents of M (HL) to port P (DPL). Output the contents of AC to P (i4). Output the contents of E and AC to ports P (4) and P (5) respectively. Set to one the bit in port P (DPL) specified by the immediate data t1 t0. Clear to zero the bit in port P (DPL) specified by the immediate data t1 t0. ZF ZF ZF ZF
IP45
2
2
OP OPM OPDR i4
1 1 2
1 1 2
OP45
2
2
SPB t2
Set port bit
0000
1 0 t1 t0
1
1
RPB t2
Reset port bit
0010
1 0 t1 t0
1
1
[P (DPL), t2] ← 0 P (P3 to P0) ← [P (P3 to P0)] I3 to I0 P (P3 to P0) ← [P (P3 to P0)] I3 to I0
And port with ANDPDR immediate data then i4, p4 output Or port with immediate data then output
1100 0101 I3 I2 I1 I0 P3 P2 P1 P0
2
2
Take the logical AND of P (P3 to P0) and the immediate data ZF I3 I2 I1 I0 and output the result to P (P3 to P0). Take the logical OR of P (P3 to P0) and the immediate data ZF I3 I2 I1 I0 and output the result to P (P3 to P0).
ORPDR i4, p4
1100 0100 I3 I2 I1 I0 P3 P2 P1 P0
2
2
Continued on next page. No. 5488-25/27
LC66E5316
Continued from preceding page.
Instruction code Mnemonic D 7 D6 D5 D4 D3 D2 D1 D0 [Timer control instructions] WTTM0 Write timer 0 1100 1010 1 2 Write the contents of M2 (HL), TIMER0 ← [M2 (HL)], AC into the timer 0 reload (AC) register. Write the contents of E, AC TIMER1 ← (E), (AC) into the timer 1 reload register A. M2 (HL), AC ← (TIMER0) E, AC ← (TIMER1) Start timer 0 counter Start timer 1 counter Stop timer 0 counter Stop timer 1 counter Read out the contents of the timer 0 counter into M2 (HL), AC. Read out the contents of the timer 1 counter into E, AC. Start the timer 0 counter. Start the timer 1 counter. Stop the timer 0 counter. Stop the timer 1 counter. Number of bytes Number of cycles Affected status bits
Operation
Description
Note
WTTM1
Write timer 1
1100 1111
1111 0100
2
2
RTIM0
Read timer 0
1100 1100 1111 1100 1110 1100 1110 1100 1111 1100 1111
1011 1111 0101 1111 0110 1111 0111 1111 0110 1111 0111
1
2
RTIM1
Read timer 1
2 2 2 2 2
2 2 2 2 2
START0 Start timer 0 START1 Start timer 1 STOP0 STOP1 Stop timer 0 Stop timer 1
[Interrupt control instructions] MSET MRESET EIH i4 EIL i4 DIH i4 DIL i4 WTSP RSP Set interrupt master enable flag Reset interrupt master enable flag Enable interrupt high Enable interrupt low Disable interrupt high Disable interrupt low Write SP Read SP 1100 0101 1100 1001 1100 0101 1100 0100 1100 1001 1100 1000 1100 1101 1100 1101 1101 0000 1101 0000 1101 I3 I2 I1 I0 1101 I3 I2 I1 I0 1101 I3 I2 I1 I0 1101 I3 I2 I1 I0 1111 1010 1111 1011 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 MSE ← 1 MSE ← 0 EDIH ← (EDIH) EDIL ← (EDIL) EDIH ← (EDIH) EDIL ← (EDIL) SP ← (E), (AC) E, AC ← (SP) i4 i4 i4 i4 Set the interrupt master enable flag to one. Clear the interrupt master enable flag to zero. Set the interrupt enable flag to one. Set the interrupt enable flag to one. Clear the interrupt enable flag to zero. Clear the interrupt enable flag to zero. Transfer the contents of E, AC to SP. Transfer the contents of SP to E, AC. ZF ZF
[Standby control instructions] HALT HOLD HALT HOLD 1100 1101 1100 1101 1111 1110 1111 1111 2 2 2 2 HALT HOLD Enter halt mode. Enter hold mode.
[Serial I/O control instructions] STARTS Start serial I O WTSIO RSIO Write serial I O Read serial I O 1100 1110 1100 1110 1100 1111 1111 1110 1111 1111 1111 1111 2 2 2 2 2 2 START SI O SIO ← (E), (AC) E, AC ← (SIO) Start SIO operation. Write the contents of E, AC to SIO. Read out the contents of SIO into E, AC.
[Other instructions] NOP No operation 0000 1100 1100 0000 1111 0 0 I1 I0 1 1 No operation PC13, PC12 ← I1 I0 Consume one machine cycle without performing any operation. Specify the memory bank.
SB i2
Select bank
2
2
No. 5488-26/27
LC66E5316
s No products described or contained herein are intended for use in surgical implants, life-support systems, aerospace equipment, nuclear power control systems, vehicles, disaster/crime-prevention equipment and the like, the failure of which may directly or indirectly cause injury, death or property loss. s Anyone purchasing any products described or contained herein for an above-mentioned use shall: Accept full responsibility and indemnify and defend SANYO ELECTRIC CO., LTD., its affiliates, subsidiaries and distributors and all their officers and employees, jointly and severally, against any and all claims and litigation and all damages, cost and expenses associated with such use: Not impose any responsibility for any fault or negligence which may be cited in any such claim or litigation on SANYO ELECTRIC CO., LTD., its affiliates, subsidiaries and distributors or any of their officers and employees jointly or severally. s Information (including circuit diagrams and circuit parameters) herein is for example only; it is not guaranteed for volume production. SANYO believes information herein is accurate and reliable, but no guarantees are made or implied regarding its use or any infringements of intellectual property rights or other rights of third parties. This catalog provides information as of February, 1997. Specifications and information herein are subject to change without notice. No. 5488-27/27