# CMOS 4-BIT SINGLE CHIP MICROCOMPUTER S1C63454 Technical Manual S1C63454 Technical Hardware # Revisions and Additions for this manual | Chapter | Section | Page | Item | Contents | |----------|---------|------|----------------------------------|-------------------------| | 7 | 7.5 | 103 | OSC1 crystal oscillation circuit | The table was revised. | | Appendix | | 111 | Appendix | The Appendix was added. | ### The information of the product number change Starting April 1, 2001, the product number has been changed as listed below. Please use the new product number when you place an order. For further information, please contact Epson sales representative. ### Configuration of product number <sup>\*1:</sup> For details about tool types, see the tables below. (In some manuals, tool types are represented by one digit.) ### Comparison table between new and previous number ### S1C63 Family processors | • | Ooo i aiiiii, | processi | |---|---------------|----------| | | Previous No. | New No. | | | E0C63158 | S1C63158 | | | E0C63256 | S1C63256 | | | E0C63358 | S1C63358 | | | E0C63P366 | S1C6P366 | | | E0C63404 | S1C63404 | | | E0C63406 | S1C63406 | | | E0C63408 | S1C63408 | | | E0C63F408 | S1C6F408 | | | E0C63454 | S1C63454 | | | E0C63455 | S1C63455 | | | E0C63458 | S1C63458 | | | E0C63466 | S1C63466 | | | E0C63P466 | S1C6P466 | | | | | | Previous No. | New No. | |--------------|----------| | E0C63467 | S1C63467 | | E0C63557 | S1C63557 | | E0C63558 | S1C63558 | | E0C63567 | S1C63567 | | E0C63F567 | S1C6F567 | | E0C63658 | S1C63658 | | E0C63666 | S1C63666 | | E0C63F666 | S1C6F666 | | E0C63A08 | S1C63A08 | | E0C63B07 | S1C63B07 | | E0C63B08 | S1C63B08 | | E0C63B58 | S1C63B58 | | | | ### S1C63 Family peripheral products | Previous No. | New No. | |--------------|----------| | E0C5250 | S1C05250 | | E0C5251 | S1C05251 | # Comparison table between new and previous number of development tools Development tools for the S1C63 Family | Previous No. | New No. | |--------------|--------------| | ADP63366 | S5U1C63366X | | ADP63466 | S5U1C63466X | | ASM63 | S5U1C63000A | | GAM63001 | S5U1C63000G | | ICE63 | S5U1C63000H1 | | PRC63001 | S5U1C63001P | | PRC63002 | S5U1C63002P | | PRC63004 | S5U1C63004P | | PRC63005 | S5U1C63005P | | PRC63006 | S5U1C63006P | | PRC63007 | S5U1C63007P | | URS63366 | S5U1C63366Y | Development tools for the S1C63/88 Family | Previous No. | New No. | |--------------|--------------| | ADS00002 | S5U1C88000X1 | | GWH00002 | S5U1C88000W2 | | URM00002 | S5U1C88000W1 | <sup>\*2:</sup> Actual versions are not written in the manuals. # **CONTENTS** | CHAPTER 1 | <i>Outline</i> | | | | | |-----------|----------------|-------------------------------------------------------------------------|----|--|--| | | 1.1 | Features | 1 | | | | | 1.2 | Block Diagram | 2 | | | | | 1.3 | Pin Layout Diagram | 3 | | | | | 1.4 | Pin Description | | | | | | 1.5 | Mask Option | | | | | CHAPTER 2 | Po | wer Supply and Initial Reset | 7 | | | | | 2.1 | Power Supply | | | | | | _,, | 2.1.1 Voltage <vd1> for oscillation circuit and internal circuits</vd1> | 8 | | | | | 2.2 | Initial Reset | 9 | | | | | | 2.2.1 Reset terminal (RESET) | | | | | | | 2.2.2 Simultaneous low input to terminals K00–K03 | | | | | | | 2.2.3 Internal register at initial resetting | | | | | | • • | 2.2.4 Terminal settings at initial resetting | | | | | | 2.3 | Test Terminal (TEST) | 11 | | | | CHAPTER 3 | CP | U, ROM, RAM | 12 | | | | | 3.1 | CPU | 12 | | | | | 3.2 | Code ROM | 12 | | | | | 3.3 | RAM | 12 | | | | | 3.4 | Data ROM | 13 | | | | CHAPTER 4 | PEI | RIPHERAL CIRCUITS AND OPERATION | 14 | | | | | 4.1 | Memory Map | | | | | | 4.2 | | | | | | | 4.2 | Watchdog Timer4.2.1 Configuration of watchdog timer | | | | | | | 4.2.2 Interrupt function | | | | | | | 4.2.3 I/O memory of watchdog timer | | | | | | | 4.2.4 Programming notes | | | | | | 4.3 | Oscillation Circuit | 21 | | | | | | 4.3.1 Configuration of oscillation circuit | | | | | | | 4.3.2 OSCI oscillation circuit | | | | | | | 4.3.3 OSC3 oscillation circuit | | | | | | | 4.3.4 Switching of operating voltage | | | | | | | 4.3.5 Clock frequency and instruction execution time | | | | | | | 4.3.6 I/O memory of oscillation circuit | | | | | | 11 | | | | | | | 4.4 | Input Ports (K00–K03) | | | | | | | 4.4.2 Interrupt function | | | | | | | 4.4.3 Mask option | | | | | | | 4.4.4 I/O memory of input ports | | | | | | | 4.4.5 Programming notes | 30 | | | | 4.5 | Output Ports (R00–R03) | 31 | |------|----------------------------------------------------------------------------------------|------| | | 4.5.1 Configuration of output ports | | | | 4.5.2 Mask option | | | | 4.5.3 High impedance control | | | | 4.5.4 Special output | | | | 4.5.5 I/O memory of output ports | | | | 4.5.6 Programming notes | | | 4.6 | I/O Ports (P00–P03 and P10–P13) | 36 | | | 4.6.1 Configuration of I/O ports | | | | 4.6.2 Mask option | | | | 4.6.3 I/O control registers and input/output mode | | | | 4.6.4 Pull-up during input mode | | | | 4.6.5 I/O memory of I/O ports | | | | 4.6.6 Programming note | | | 4.7 | LCD Driver (COM0-COM16, SEG0-SEG39) | 41 | | | 4.7.1 Configuration of LCD driver | | | | 4.7.2 Power supply for LCD driving | | | | 4.7.3 Mask option | | | | 4.7.4 LCD display control (ON/OFF) and switching of duty | | | | 4.7.5 Display memory | | | | 4.7.7 VO more of LCD driver | | | | 4.7.7 I/O memory of LCD driver 47 4.7.8 Programming notes 49 | | | 4.0 | 0 | | | 4.8 | Clock Timer | 50 | | | 4.8.1 Configuration of clock timer | | | | 4.8.2 Data reading and hold function | | | | 4.8.3 Interrupt function 51 4.8.4 I/O memory of clock timer 52 | | | | 4.8.5 Programming notes | | | 4.0 | | | | 4.9 | Stopwatch Timer | 33 | | | 4.9.1 Configuration of stopwatch timer | | | | 4.9.2 Count-up pattern | | | | 4.9.3 Interrupt function 56 4.9.4 I/O memory of stopwatch timer 57 | | | | 4.9.5 Programming notes | | | 1 10 | 0 | 50 | | 4.10 | Programmable Timer | . 39 | | | 4.10.1 Configuration of programmable timer | | | | 4.10.2 Setting of initial value and counting down | | | | 4.10.4 Interrupt function | | | | 4.10.5 Setting of TOUT output | | | | 4.10.6 Transfer rate setting for serial interface | | | | 4.10.7 I/O memory of programmable timer | | | | 4.10.8 Programming notes | | | 111 | Serial Interface (SIN, SOUT, SCLK, SRDY) | 60 | | 4.11 | 4.11.1 Configuration of serial interface | 09 | | | 4.11.2 Mask option | | | | 4.11.3 Master mode and slave mode of serial interface | | | | 4.11.4 Data input/output and interrupt function | | | | 4.11.5 I/O memory of serial interface | | | | 4 11 6 Programming notes 77 | | | | 4.12 | Sound Generator | | 78 | | | | |------------------|------------------------------------------------------------------|--------------------------------------------------------------|----|-----|-----|--|--| | | | 4.12.1 Configuration of sound generator | 78 | | | | | | | | 4.12.2 Mask option | 78 | | | | | | | | 4.12.3 Control of buzzer output | | | | | | | | | 4.12.4 Setting of buzzer frequency and sound level | | | | | | | | | 4.12.5 Digital envelope | | | | | | | | | 4.12.7 I/O memory of sound generator | | | | | | | | | 4.12.8 Programming notes | | | | | | | | 4.13 | Interrupt and HALT | | 85 | | | | | | | 4.13.1 Interrupt factor | 87 | | | | | | | | 4.13.2 Interrupt mask | | | | | | | | | 4.13.3 Interrupt vector | | | | | | | | | 4.13.4 I/O memory of interrupt | | | | | | | CHAPTER 5 | SUM | MARY OF NOTES | | | 91 | | | | | 5.1 | Notes for Low Current Consumption | | 91 | | | | | | 5.2 | Summary of Notes by Function | | 92 | | | | | | 5.3 | Notes on Mounting | | | | | | | CHAPTER 6 | BAS | IC EXTERNAL WIRING DIAGRAM | | | 98 | | | | CHAPTER 7 | ELE | CTRICAL CHARACTERISTICS | | | 99 | | | | | 7.1 | Absolute Maximum Rating | | 99 | | | | | | 7.2 | Recommended Operating Conditions | | | | | | | | 7.3 | DC Characteristics | | | ) | | | | | 7.4 | Analog Circuit Characteristics and Power Current Consumption | | 101 | | | | | | 7.5 | Oscillation Characteristics | | 103 | | | | | | 7.6 | Serial Interface AC Characteristics | | 105 | | | | | | 7.7 | Timing Chart | | 106 | | | | | CHAPTER 8 | PAC | KAGE | | _ i | 107 | | | | | 8.1 | | | 107 | r | | | | | 8.2 | Ceramic Package for Test Samples | | 108 | 1 | | | | CHAPTER 9 | PAD | LAYOUT | | _ i | 109 | | | | | 9.1 | Diagram of Pad Layout | | 109 | 1 | | | | | 9.2 | Pad Coordinates | | 110 | 1 | | | | <b>A</b> PPENDIX | S5U | VIC63000P MANUAL | | | | | | | | (Peripheral Circuit Board for S1C63404/454/455/458/466/P466) 111 | | | | | | | | | A.1 | Names and Functions of Each Part | | 111 | | | | | | A.2 | Connecting to the Target System | | 114 | | | | | | A.3 | Usage Precautions | | 116 | | | | | | | A.3.1 Operational precautions | | | | | | # CHAPTER 1 OUTLINE The S1C63454 is a microcomputer which has a high-performance 4-bit CPU S1C63000 as the core CPU, ROM (4,096 words $\times$ 13 bits), RAM (1,024 words $\times$ 4 bits), serial interface, watchdog timer, programmable timer, time base counters (2 systems), a dot-matrix LCD driver that can drive a maximum 40 segments $\times$ 17 commons and sound generator built-in. The S1C63454 features high speed operation and low current consumption in a wide operating voltage range (2.2 V to 6.4 V), this makes it suitable for applications working with batteries. It is also suitable for portable MD players. ### 1.1 Features | OSC1 oscillation circuit | 32.768 kHz (Typ.) crystal or 60 kHz (Typ.) CR oscillation circuit (*1) | |-----------------------------|--------------------------------------------------------------------------------------------------------------| | OSC3 oscillation circuit | 1.8 MHz (Typ.) CR or 4 MHz (Max.) ceramic oscillation circuit (*1) | | Instruction set | Basic instruction: 46 types (411 instructions with all)<br>Addressing mode: 8 types | | Instruction execution time | During operation at 32.768 kHz: 61 μsec 122 μsec 183 μsec | | | During operation at 60 kHz: 33 μsec 67 μsec 100 μsec | | | During operation at 4 MHz: 0.5 μsec 1.5 μsec 1.5 μsec | | ROM capacity | | | BAM 9 | Data ROM: 2,048 words × 4 bits (= 8K bits) | | RAM capacity | · · · · · · · · · · · · · · · · · · · | | Input port | Display memory: 680 bits (160 words × 4 bits + 40 × 1 bit) 4 bits (Pull-up resistors may be supplemented *1) | | Output port | 7 11 | | I/O port | 1 1 | | | output *2) | | Serial interface | | | LCD driver | 40 segments × 8, 16 or 17 commons (*2) | | | 2 systems (Clock timer, stopwatch timer) | | Programmable timer | Built-in, 2 inputs × 8 bits | | Watchdog timer | Built-in | | Sound generator | With envelope and 1-shot output functions | | External interrupt | Input port interrupt: 1 system | | Internal interrupt | · · · · · · · · · · · · · · · · · · · | | | Stopwatch timer interrupt: 2 systems | | | Programmable timer interrupt: 2 systems | | Davida a complex college | Serial interface interrupt: 1 system | | | 2.2 V to 6.4 V (Min. 1.8 V when the OSC3 oscillation circuit is not used) | | Operating temperature range | | | Current consumption (Typ.) | Single clock (OSC1: Crystal oscillation):<br>During HALT (32 kHz) | | | $3.0 \text{ V (LCD power OFF)}$ $1 \mu\text{A}$ | | | 3.0 V (LCD power ON, VC1 standard) 6 μA | | | 3.0 V (LCD power ON, Vc2 standard) 4 μA | | | During operation (32 kHz) | | | $3.0~V$ (LCD power ON, VC1 standard) $10~\mu A$ Twin clock: | | | During operation (4 MHz) | | | 3.0 V (LCD power ON, VC1 standard) 1,000 μA | | Package | | | | *1: Can be selected with mask option *2: Can be selected with software | # 1.2 Block Diagram Fig. 1.2.1 Block diagram | No. | Name | No. | Name | No. | Name | No. | Name | |-----|----------|-----|-------------------|-----|-------|-----|-------| | 1 | SEG9 | 26 | $V_{\mathrm{DD}}$ | 51 | Vc1 | 76 | SEG34 | | 2 | SEG8 | 27 | N.C. | 52 | Vc2 | 77 | SEG33 | | 3 | SEG7 | 28 | N.C. | 53 | Vc3 | 78 | SEG32 | | 4 | SEG6 | 29 | RESET | 54 | VC4 | 79 | SEG31 | | 5 | SEG5 | 30 | TEST | 55 | Vc5 | 80 | SEG30 | | 6 | SEG4 | 31 | Vref | 56 | CF | 81 | SEG29 | | 7 | SEG3 | 32 | R03 | 57 | CE | 82 | SEG28 | | 8 | SEG2 | 33 | R02 | 58 | CD | 83 | SEG27 | | 9 | SEG1 | 34 | R01 | 59 | CC | 84 | SEG26 | | 10 | SEG0 | 35 | R00 | 60 | CB | 85 | SEG25 | | 11 | COM7 | 36 | P13 | 61 | CA | 86 | SEG24 | | 12 | COM6 | 37 | P12 | 62 | COM8 | 87 | SEG23 | | 13 | COM5 | 38 | P11 | 63 | COM9 | 88 | SEG22 | | 14 | COM4 | 39 | P10 | 64 | COM10 | 89 | SEG21 | | 15 | COM3 | 40 | P03 | 65 | COM11 | 90 | SEG20 | | 16 | COM2 | 41 | P02 | 66 | COM12 | 91 | SEG19 | | 17 | COM1 | 42 | P01 | 67 | COM13 | 92 | SEG18 | | 18 | COM0 | 43 | P00 | 68 | COM14 | 93 | SEG17 | | 19 | BZ | 44 | K03 | 69 | COM15 | 94 | SEG16 | | 20 | Vss | 45 | K02 | 70 | COM16 | 95 | SEG15 | | 21 | OSC1 | 46 | K01 | 71 | SEG39 | 96 | SEG14 | | 22 | OSC2 | 47 | K00 | 72 | SEG38 | 97 | SEG13 | | 23 | $V_{D1}$ | 48 | N.C. | 73 | SEG37 | 98 | SEG12 | | 24 | OSC3 | 49 | N.C. | 74 | SEG36 | 99 | SEG11 | | 25 | OSC4 | 50 | N.C. | 75 | SEG35 | 100 | SEG10 | N.C.: No Connection Fig. 1.3.1 Pin layout diagram # 1.4 Pin Description Table 1.4.1 Pin description | Pin name | Pin No. | In/Out | Function | | |-----------------|--------------|--------|----------------------------------------------------------------|--| | VDD | 26 | _ | Power (+) supply pin | | | Vss | 20 | _ | Power (–) supply pin | | | V <sub>D1</sub> | 23 | _ | Oscillation/internal logic system regulated voltage output pin | | | VC1-VC5 | 51–55 | _ | LCD system power supply pin | | | | | | 1/4 bias generated internally, 1/5 bias supplied externally | | | | | | (selected by mask option) | | | VREF | 31 | О | LCD system power supply testing pin | | | CA-CF | 61–56 | _ | LCD system boosting/reducing capacitor connecting pin | | | OSC1 | 21 | I | Crystal or CR oscillation input pin | | | | | | (selected by mask option) | | | OSC2 | 22 | О | Crystal or CR oscillation output pin | | | | | | (selected by mask option) | | | OSC3 | 24 | I | Ceramic or CR oscillation input pin | | | | | | (selected by mask option) | | | OSC4 | 25 | О | Ceramic or CR oscillation output pin | | | | | | (selected by mask option) | | | K00-K03 | 47–44 | I | Input port | | | P00-P03 | 43–40 | I/O | I/O port | | | P10-P13 | 39–36 | I/O | I/O port | | | | | | (switching to serial I/F input/output is possible by software) | | | R00 | 35 | О | Output port | | | R01 | 34 | О | Output port | | | R02 | 33 | О | Output port | | | | | | (switching to TOUT signal output is possible by software) | | | R03 | 32 | О | Output port | | | | | | (switching to FOUT signal output is possible by software) | | | COM0-COM16 | 18–11, 62–70 | О | LCD common output pin | | | | | | (1/8, 1/16, 1/17 duty can be selected by software) | | | SEG0-SEG39 | 10–1, 100–71 | О | LCD segment output pin | | | BZ | 19 | О | Sound output pin | | | RESET | 29 | I | Initial reset input pin | | | TEST | 30 | I | Testing input pin | | # 1.5 Mask Option Mask options shown below are provided for the S1C63454. Several hardware specifications are prepared in each mask option, and one of them can be selected according to the application. The function option generator winfog, that has been prepared as the development software tool of S1C63454, is used for this selection. Mask pattern of the IC is finally generated based on the data created by the winfog. Refer to the "S5U1C63000A Manual" for the winfog. ### <Functions selectable with S1C63454 mask options> ### (1) External reset by simultaneous LOW input to the input port (K00-K03) This function resets the IC when several keys are pressed simultaneously. The mask option is used to select whether this function is used or not. Further when the function is used, a combination of the input ports (K00–K03), which are connected to the keys to be pressed simultaneously, can be selected. Refer to Section 2.2.2, "Simultaneous low input to terminals K00–K03", for details. ### (2) Time authorize circuit for the simultaneous LOW input reset function When using the external reset function (shown in 1 above), using the time authorize circuit or not can be selected by the mask option. The reset function works only when the input time of simultaneous LOW is more than the rule time if the time authorize circuit is being used. Refer to Section 2.2.2, "Simultaneous low input to terminals K00–K03", for details. ### (3) Input port pull-up resistor The mask option is used to select whether the pull-up resistor is supplemented to the input ports or not. It is possible to select for each bit of the input ports. Refer to Section 4.4.3, "Mask option", for details. ### (4) Output specification of the output port Either complementary output or N-channel open drain output can be selected as the output specification for the output ports R00–R03. The selection is done in 1-bit units. Refer to Section 4.5.2, "Mask option", for details. ### (5) Input specification / output specification / pull-up resistor of the I/O ports For the output specification when the I/O ports (P00–P03, P10–P13) are in the output mode, either complementary output or N-channel open drain output can be selected. Further, whether or not the pull-up resistors working in the input mode are supplemented can be selected. The selection is done in 4-bit units (P00–P03 and P10–P13). When using the I/O port P10–P13 as the serial interface input/output terminals, the input specification for the terminals that are used for the serial interface input can be selected from either "normal input" or "with Schmitt trigger input". This option is applied to the serial interface input terminals, and is fixed at "normal input" when the terminals are used for the I/O port P10–P13. Refer to Section 4.6.2, "Mask option", for details. #### (6) LCD drive bias Either the internal power supply (1/4 bias) or an external power supply (1/5 bias) can be selected as the LCD system power supply. Refer to Section 4.7.3, "Mask option", for details. ### (7) Synchronous clock polarity in the serial interface The polarity of the synchronous clock $\overline{SCLK}$ and the $\overline{SRDY}$ signal in slave mode of the serial interface is selected by the mask option. Either positive polarity or negative polarity can be selected. Refer to Section 4.11.2, "Mask option", for details. ### (8) Buzzer output specification of the sound generator It is possible to select the polarity of the buzzer signal output from the BZ terminal. Select either positive polarity or negative polarity according to the external drive transistor to be used. Refer to Section 4.12.2, "Mask option", for details. #### (9) OSC1 oscillation circuit Either crystal oscillation circuit or CR oscillation circuit can be selected as the OSC1 oscillation circuit. Refer to Section 4.3.2, "OSC1 oscillation circuit", for details. ### (10)OSC3 oscillation circuit Either CR oscillation circuit or ceramic oscillation circuit can be selected as the OSC3 oscillation circuit. Refer to Section 4.3.3, "OSC3 oscillation circuit", for details. ### <Mask option list> The following is the option list for the S1C63454. Multiple selections are available in each option item as indicated in the option list. Refer to Chapter 4, "Peripheral Circuits and Operation", to select the specifications that meet the application system. Be sure to select the specifications for unused functions too, according to the instruction provided. Use winfog in the S5U1C63000A package for this selection. Refer to the "S5U1C63000A Manual" for details. | 1. OSC1 SY | <b>/STEM CLOCK</b> ☐ 1. Crystal (32.768 kHz) ☐ 2. CR (60 kHz) | | |-------------------------|----------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------| | 2. OSC3 SY | <b>/STEM CLOCK</b> ☐ 1. Use < Ceramic (4 MF) ☐ 2. Use < CR (1.8 MHz) | | | 3. MULTIPL | | , K03> | | 4. MULTIPL | E KEY ENTRY RESET ☐ 1. Not Use ☐ 2. Use | TIME AUTHORIZE | | • K00<br>• K01<br>• K02 | ORT PULL UP RESIST . 1. With Resistor . 1. With Resistor . 1. With Resistor . 1. With Resistor . 1. With Resistor | OR 2. Gate Direct 2. Gate Direct 2. Gate Direct 2. Gate Direct 2. Gate Direct | | • R00<br>• R01<br>• R02 | PORT OUTPUT SPEC | IFICATION 2. Nch-OpenDrain 2. Nch-OpenDrain 2. Nch-OpenDrain 2. Nch-OpenDrain | | • P0x | COUTPUT SPECIFICATOR . □ 1. Complementary . □ 1. Complementary | TION ☐ 2. Nch-OpenDrain ☐ 2. Nch-OpenDrain | | • P0x | PULL UP RESISTOR . □ 1. With Resistor . □ 1. With Resistor | ☐ 2. Gate Direct☐ 2. Gate Direct | | 9. I/O POR1 | 「INPUT SPECIFICATION □ 1. Normal CMOS Inpu □ 2. Schmitt Trigger Inpu | ıt | | 10. LCD DR | RIVING POWER 1. Internal 2. External | | | 11. SERIAL | . <b>PORT INTERFACE PO</b> □ 1. Positive □ 2. Negative | DLARITY | | 12. SOUND | GENERATOR POLAR ☐ 1. Positive ☐ 2. Negative | ITY FOR OUTPUT | S1C63454 TECHNICAL MANUAL # CHAPTER 2 POWER SUPPLY AND INITIAL RESET # 2.1 Power Supply The S1C63454 operating power voltage is as follows: Table 2.1.1 Operating power voltage | OSC1 oscillation circuit | OSC3 oscillation circuit | Operating power voltage | |--------------------------|--------------------------|-------------------------| | Crystal oscillation | Not use | 1.8 V-6.4 V | | Crystal oscillation | Use | 2.2 V-6.4 V | | CR oscillation | _ | 2.2 V-6.4 V | The S1C63454 operates by applying a single power supply within the above range between VDD and Vss. The S1C63454 itself generates the voltage necessary for all the internal circuits by the built-in power supply circuits shown in Table 2.1.2. Table 2.1.2 Power supply circuits | Circuit | Power supply circuit | Output voltage | |-----------------------------------|--------------------------------------|-----------------| | Oscillation and internal circuits | Oscillation system voltage regulator | V <sub>D1</sub> | | LCD driver | LCD system voltage circuit | VC1-VC5 | Note: • Do not drive external loads with the output voltage from the internal power supply circuits. - Vc3 should be used only when the LCD drive voltage is supplied externally (1/5 bias); when using the internal LCD system voltage circuit (1/4 bias), short between Vc3 and Vc2 terminals. - See Chapter 7, "Electrical Characteristics", for voltage values and drive capability. Fig. 2.1.1 Configuration of power supply # 2.1.1 Voltage <VD1> for oscillation circuit and internal circuits VD1 is a voltage for the oscillation circuit and the internal logic circuits, and is generated by the oscillation system voltage regulator for stabilizing the oscillation. The S1C63454 is designed with twin clock specification; it has two types of oscillation circuits OSC1 and OSC3 built-in. Use OSC1 clock for normal operation, and switch it to OSC3 by the software when high-speed operation is necessary. When switching the clock, the operating voltage VD1 must be switched by the software to stabilize the operation of the oscillation circuit and internal circuits. The oscillation system voltage regulator can output the following two types of VD1 voltage. It should be set at the value according to the oscillation circuit and oscillation frequency by the software. Single clock operation (OSC1 crystal oscillation): VD1 = 1.3 VSingle clock operation (OSC1 CR oscillation): VD1 = 2.2 VTwin clock operation (OSC3, 4 MHz): VD1 = 2.2 V Refer to Section 4.3, "Oscillation Circuit", for the VD1 switching procedure. However, since the VD1 voltage value is fixed at 2.2 V when the CR oscillation circuit has been selected as the OSC1 oscillation circuit by mask option, it is not necessary to switch VD1 by software. ## 2.1.2 Voltage <VC1-VC5> for LCD driving VC1-VC5 are the LCD drive voltages for which either the voltage generated by the LCD system voltage circuit or voltage to be supplied from outside can be used. The built-in LCD system voltage circuit generates four voltages (1/4 bias) VC1, VC2, VC4 and VC5 (excluding VC3). These four output voltages can only be supplied to the externally expanded LCD driver. When external voltages are supplied, 1/5 bias driving can be done by inputting drive voltage to the VC1–VC5 terminals (including VC3). Either the internal generated voltages or external voltages used for the LCD drive voltage can be selected by a mask option. The LCD system voltage circuit generates VC1 or VC2 with the voltage regulator built-in, and generates three other voltages by boosting or reducing the voltage of VC1 or VC2. Table 2.1.2.1 shows the VC1, VC2, VC4 and VC5 voltage values and boost/reduce status. | LCD drive voltage | VDD = 1.8-6.4 V | VDD = 2.6-6.4 V | |-------------------|-----------------|---------------------| | Vc1 (0.975-1.2 V) | VC1 (standard) | 1/2 × Vc2 | | Vc2 (1.950-2.4 V) | 2 × Vc1 | Vc2 (standard) | | Vc4 (2.925-3.6 V) | 3 × Vc1 | $3/2 \times V_{C2}$ | | Vc5 (3.900-4.8 V) | 4 × Vc1 | $2 \times V_{C2}$ | Table 2.1.2.1 LCD drive voltage when generated internally Note: The LCD drive voltage can be adjusted by the software (see Section 4.7.6). Values in the above table are typical values. Either the VC1 or VC2 used for the standard is selected according to the supply voltage by the software. The VC2 standard improves the display quality and reduces current consumption, however, the power supply voltage VDD must be $2.6~\rm V$ or more. Refer to Section 4.7, "LCD Driver", for control of the LCD drive voltage. ### 2.2 Initial Reset To initialize the S1C63454 circuits, initial reset must be executed. There are two ways of doing this. - (1) External initial reset by the RESET terminal - (2) External initial reset by simultaneous low input to terminals K00-K03 (mask option setting) The circuits are initialized by either (1) or (2). When the power is turned on, be sure to initialize using the reset function. It is not guaranteed that the circuits are initialized by only turning the power on. Figure 2.2.1 shows the configuration of the initial reset circuit. Fig. 2.2.1 Configuration of initial reset circuit # 2.2.1 Reset terminal (RESET) Initial reset can be executed externally by setting the reset terminal to a low level (VSS). After that the initial reset is released by setting the reset terminal to a high level (VDD) and the CPU starts operation. The reset input signal is maintained by the RS latch and becomes the internal initial reset signal. The RS latch is designed to be released by a 2 Hz signal (high) that is divided by the OSC1 clock. Therefore in normal operation, a maximum of 250 msec (when fOSC1 = 32.768 kHz) is needed until the internal initial reset is released after the reset terminal goes to high level. Be sure to maintain a reset input of 0.1 msec or more. However, when turning the power on, the reset terminal should be set at a low level as in the timing shown in Figure 2.2.1.1. Fig. 2.2.1.1 Initial reset at power on The reset terminal should be set to 0.1 • VDD or less (low level) until the supply voltage becomes 1.8 V or more (until the supply voltage becomes 2.2 V or more when the CR oscillation circuit has been selected as the OSC1 oscillation circuit by mask option). After that, a level of 0.5 • VDD or less should be maintained more than 2.0 msec. S1C63454 TECHNICAL MANUAL EPSON 9 ### 2.2.2 Simultaneous low input to terminals K00-K03 Another way of executing initial reset externally is to input a low signal simultaneously to the input ports (K00–K03) selected with the mask option. Since this initial reset passes through the noise reject circuit, maintain the specified input port terminals at low level for at least 1.5 msec (when the oscillation frequency fOSC1 is 32.768 kHz) during normal operation. The noise reject circuit does not operate immediately after turning the power on until the oscillation circuit starts oscillating. Therefore, maintain the specified input port terminals at low level for at least 1.5 msec (when the oscillation frequency fOSC1 is 32.768 kHz) after oscillation starts. Table 2.2.2.1 shows the combinations of input ports (K00–K03) that can be selected with the mask option. Table 2.2.2.1 Combinations of input ports | 1 | Not use | |---|-----------------| | 2 | K00*K01*K02*K03 | | 3 | K00*K01*K02 | | 4 | K00*K01 | When, for instance, mask option 2 (K00\*K01\*K02\*K03) is selected, initial reset is executed when the signals input to the four ports K00–K03 are all low at the same time. When 3 or 4 is selected, the initial reset is done when a key entry including a combination of selected input ports is made. Further, the time authorize circuit can be selected with the mask option. The time authorize circuit checks the input time of the simultaneous low input and performs initial reset if that time is the defined time (1 to 2 sec) or more. If using this function, make sure that the specified ports do not go low at the same time during ordinary operation. ### 2.2.3 Internal register at initial resetting Initial reset initializes the CPU as shown in Table 2.2.3.1. The registers and flags which are not initialized by initial reset should be initialized in the program if necessary. In particular, the stack pointers SP1 and SP2 must be set as a pair because all the interrupts including NMI are masked after initial reset until both the SP1 and SP2 stack pointers are set with software. When data is written to the EXT register, the E flag is set and the following instruction will be executed in the extended addressing mode. If an instruction which does not permit extended operation is used as the following instruction, the operation is not guaranteed. Therefore, do not write data to the EXT register for initialization only. Refer to the "S1C63000 Core CPU Manual" for extended addressing and usable instructions. Table 2.2.3.1 Initial values | CPU core | | | | | | | | |------------------------|--------|----------------|---------------|--|--|--|--| | Name | Symbol | Number of bits | Setting value | | | | | | Data register A | A | 4 | Undefined | | | | | | Data register B | В | 4 | Undefined | | | | | | Extension register EXT | EXT | 8 | Undefined | | | | | | Index register X | X | 16 | Undefined | | | | | | Index register Y | Y | 16 | Undefined | | | | | | Program counter | PC | 16 | 0110H | | | | | | Stack pointer SP1 | SP1 | 8 | Undefined | | | | | | Stack pointer SP2 | SP2 | 8 | Undefined | | | | | | Zero flag | Z | 1 | Undefined | | | | | | Carry flag | С | 1 | Undefined | | | | | | Interrupt flag | I | 1 | 0 | | | | | | Extension flag | E | 1 | 0 | | | | | | Queue register | Q | 16 | Undefined | | | | | | Peripheral circuits | | | | | | |-----------------------------------|---|-----------|--|--|--| | Name Number of bits Setting value | | | | | | | RAM | 4 | Undefined | | | | | Display memory | 4 | Undefined | | | | | Other pheripheral circuits | _ | * | | | | <sup>\*</sup> See Section 4.1, "Memory Map". ### 2.2.4 Terminal settings at initial resetting The output port (R) terminals and I/O port (P) terminals are shared with special output terminals and input/output terminals of the serial interface. These functions are selected by the software. At initial reset, these terminals are set to the general purpose output port terminals and I/O port terminals. Set them according to the system in the initial routine. In addition, take care of the initial status of output terminals when designing a system. Table 2.2.4.1 shows the list of the shared terminal settings. Table 2.2.4.1 List of shared terminal settings | | · · | | _ | | | |----------|-----------------------------|----------------|------|------------|---------| | Terminal | Terminal status | Special output | | Serial I/F | | | name | at initial reset | TOUT | FOUT | Master | Slave | | R00 | R00 (High output) | | | | | | R01 | R01 (High output) | | | | | | R02 | R02 (High output) | TOUT | | | | | R03 | R03 (High output) | | FOUT | | | | P00-P03 | P00–P03 (Input & Pull-up *) | | | | | | P10 | P10 (Input & Pull-up *) | | | SIN(I) | SIN(I) | | P11 | P11 (Input & Pull-up *) | | | SOUT(O) | SOUT(O) | | P12 | P12 (Input & Pull-up *) | | | SCLK(O) | SCLK(I) | | P13 | P13 (Input & Pull-up *) | | | | SRDY(O) | <sup>\*</sup> When "with pull-up" is selected by mask option (high impedance when "gate direct" is selected) For setting procedure of the functions, see explanations for each of the peripheral circuits. # 2.3 Test Terminal ( $\overline{TEST}$ ) This is the terminal used for the factory inspection of the IC. During normal operation, connect the $\overline{\text{TEST}}$ terminal to VDD. # CHAPTER 3 CPU, ROM, RAM ### 3.1 *CPU* The S1C63454 has a 4-bit core CPU S1C63000 built-in as its CPU part. Refer to the "S1C63000 Core CPU Manual" for the S1C63000. Note: The SLP instruction cannot be used because the SLEEP operation is not assumed in the S1C63454. ### 3.2 Code ROM The built-in code ROM is a mask ROM for loading programs, and has a capacity of 4,096 steps $\times$ 13 bits. The core CPU can linearly access the program space up to step FFFFH from step 0000H, however, the program area of the S1C63454 is step 0000H to step 0FFFH. The program start address after initial reset is assigned to step 0110H. The non-maskable interrupt (NMI) vector and hardware interrupt vectors are allocated to step 0100H and steps 0104H–010EH, respectively. Fig. 3.2.1 Configuration of code ROM ### 3.3 RAM The RAM is a data memory for storing various kinds of data, and has a capacity of $1,024 \text{ words} \times 4 \text{ bits}$ . The RAM area is assigned to addresses 0000H to 03FFH on the data memory map. Addresses 0100H to 01FFH are 4-bit/16-bit data accessible areas and in other areas it is only possible to access 4-bit data. When programming, keep the following points in mind. - (1) Part of the RAM area is used as a stack area for subroutine call and register evacuation, so pay attention not to overlap the data area and stack area. - (2) The S1C63000 core CPU handles the stack using the stack pointer for 4-bit data (SP2) and the stack pointer for 16-bit data (SP1). - 16-bit data are accessed in stack handling by SP1, therefore, this stack area should be allocated to the area where 4-bit/16-bit access is possible (0100H to 01FFH). The stack pointers SP1 and SP2 change cyclically within their respective range: the range of SP1 is 0000H to 03FFH and the range of SP2 is 0000H to 00FFH. Therefore, pay attention to the SP1 value because it may be set to 0200H or more exceeding the 4-bit/16-bit accessible range in the S1C63454 or it may be set to 00FFH or less. Memory accesses except for stack operations by SP1 are 4-bit data access. After initial reset, all the interrupts including NMI are masked until both the stack pointers SP1 and SP2 are set by software. Further, if either SP1 or SP2 is re-set when both are set already, the interrupts including NMI are masked again until the other is re-set. Therefore, the settings of SP1 and SP2 must be done as a pair. (3) Subroutine calls use 4 words (for PC evacuation) in the stack area for 16-bit data (SP1). Interrupts use 4 words (for PC evacuation) in the stack area for 16-bit data (SP1) and 1 word (for F register evacuation) in the stack area for 4-bit data. Fig. 3.3.1 Configuration of data RAM ### 3.4 Data ROM The data ROM is a mask ROM for loading various static data such as a character generator, and has a capacity of 2,048 words $\times 4$ bits. The data ROM is assigned to addresses 8000H to 87FFH on the data memory map, and the data can be read using the same data memory access instructions as the RAM. # CHAPTER 4 PERIPHERAL CIRCUITS AND OPERATION The peripheral circuits of S1C63454 (timer, I/O, etc.) are interfaced with the CPU in the memory mapped I/O method. Thus, all the peripheral circuits can be controlled by accessing the I/O memory on the memory map using the memory operation instructions. The following sections explain the detailed operation of each peripheral circuit. # 4.1 Memory Map The S1C63454 data memory consists of 1,024-word RAM, 2,048-word data ROM, 680-bit display memory and 53-word peripheral I/O memory. Figure 4.1.1 shows the overall memory map of the S1C63454, and Tables 4.1.1(a)–(d) the peripheral circuits' (I/O space) memory maps. Fig. 4.1.1 Memory map Note: Memory is not implemented in unused areas within the memory map. Further, some non-implementation areas and unused (access prohibition) areas exist in the display memory area and the peripheral I/O area. If the program that accesses these areas is generated, its operation cannot be guaranteed. Refer to Section 4.7.5, "Display memory", for the display memory, and the I/O memory maps shown in Tables 4.1.1 (a)–(d) for the peripheral I/O area. Table 4.1.1 (a) I/O memory map (FF00H–FF44H) | | Register | | | | | | | | | | | |----------------|--------------------------------------------------|---------------|------------------------|--------------------------------------------------------------|--------------|--------------|----------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------|--------|----------------------------------------------| | Address | D3 | D2 | D1 | D0 | Name | Init *1 | 1 | 0 | Comment | | | | | | | | | CLKCHG | 0 | OSC3 | OSC1 | CPU clock switch | | | | | CLKCHG | OSCC | 0 | VDC | oscc | 0 | On | Off | OSC3 oscillation On/Off | | | | FF00H | | | _ | | 0 *3 | _ *2 | | | Unused | | | | | R/ | W | R | R/W | VDC | 0 | 2.2 V | 1.3 V | CPU operating voltage switch (1.3 V: OSC1, 2.2 V: OSC3) | | | | | FOUTE | _ | 50504 | 50500 | FOUTE | 0 | Enable | Disable | FOUT output enable | | | | FFOCL | FOUTE | 0 | FOFQ1 | FOFQ0 | 0 *3 | _ *2 | | | Unused | | | | FF06H | DAM | 0 | | 0.07 | FOFQ1 | 0 | | | FOUT Frequency FOFQ1, 0] 0 1 2 3 | | | | | R/W | R | II. | W | FOFQ0 | 0 | | | selection Frequency fosci/64 fosci/8 fosci fosci | | | | | 0 | 0 | WDEN | WDDST | 0 *3 | _ *2 | | | Unused | | | | FF07H | U | U | WDEN WDRST | | 0 *3 | - *2 | | | Unused | | | | 110/11 | F | 2 | R/W | l w | WDEN | 1 | Enable | Disable | Watchdog timer enable | | | | | | | | | WDRST*3 | Reset | Reset | Invalid | Watchdog timer reset (writing) | | | | | SIK03 | SIK02 | SIK01 | SIK00 | SIK03 | 0 | Enable | Disable | | | | | FF20H | | 0102 | 0 | 000 | SIK02 | 0 | Enable | Disable | K00–K03 interrupt selection register | | | | | | R | w | | SIK01 | 0 | Enable | Disable | | | | | | | | | | SIK00 | 0 | Enable | Disable | | | | | | K03 | K02 | K01 | K00 | K03 | _ *2<br>_ *2 | High | Low | | | | | FF21H | | | | | K02 | - *2<br>- *2 | High | Low | K00–K03 input port data | | | | | | F | 3 | | K01<br>K00 | - *2<br>- *2 | High | Low<br>Low | | | | | | | | | l | KCP03 | 1 | High | LOW | <u> </u> | | | | | KCP03 | KCP02 | KCP01 | KCP00 | KCP03 | 1 | 📩 | | | | | | FF22H | FF22H | | | | KCP01 | 1 | | | K00-K03 input comparison register | | | | | | R | W | | KCP00 | 1 | 🔭 | | | | | | | | | | | R03HIZ | 0 | High-Z | Output | R03 output high impedance control (FOUTE=0) | | | | l <sub>D</sub> | B03HIZ B02H | R03HIZ R02HIZ | B02HIZ | RHIZ BO2HIZ | R01HIZ | R00HIZ | 11001112 | ŭ | 1119112 | Output | FOUT output high impedance control (FOUTE=1) | | | 11001112 | | 11011112 | | R02HIZ | 0 | High-Z | Output | R02 output high impedance control (PTOUT=0) | | | | FF30H | | | | | | J | | TOUT output high impedance control (PTOUT=1) | | | | | | | R | W | | R01HIZ | 0 | High-Z | Output | R01 output high impedance control | | | | | | | • | | R00HIZ | 0 | High-Z | Output | R00 output high impedance control | | | | | | | | | R03 | 1 | High | Low | R03 output port data (FOUTE=0) Fix at "1" when FOUT is used | | | | FFO411 | R03 | R02 | R01 | R00 | R02 | 1 | High | Low | R02 output port data (PTOUT=0) Fix at "1" when TOUT is used | | | | FF31H | | | | | R01 | 1 | High | Low | R01 output port data | | | | | | R/ | W | | R00 | 1 | High | Low | R00 output port data | | | | | IOC03 | IOC02 | IOC01 | IOC00 | IOC03 | 0 | Output | Input | | | | | FF40H | 10003 | 10002 | 10001 | 10000 | IOC02 | 0 | Output | Input | P00–P03 I/O control register | | | | FF40H | | D | W | | IOC01 | 0 | Output | Input | 1 00–1 03 1/O control register | | | | | | 11/ | ** | | IOC00 | 0 | Output | Input | | | | | | PUL03 | PUL02 | PUL01 | PUL00 | PUL03 | 1 | On | Off | | | | | FF41H | . 5200 | 1 0202 | . 5201 | . 5200 | PUL02 | 1 | On | Off | P00–P03 pull-up control register | | | | | | R | W | | PUL01 | 1 | On | Off | | | | | | <u> </u> | | | | PUL00 | 1 | On | Off | | | | | | P03 | P02 | P01 | P00 | P03 | - *2 | High | Low | | | | | FF42H | | | | | P02 | _ *2 | High | Low | P00–P03 I/O port data | | | | | | R/ | W | | P01 | - *2<br>- *2 | High | Low | | | | | | <del> </del> | | | | P00<br>IOC13 | | High | Low | P12 I/O control register | | | | | | | | | 10013 | 0 | Output | Input | P13 I/O control register | | | | | IOC13 | IOC12 | IOC11 | IOC10 | IOC12 | 0 | Outout | Innut | functions as a general-purpose register when SIF (slave) is selected<br>P12 I/O control register (ESIF=0) | | | | | | | IOC12 0 Output Input F | functions as a general-purpose register when SIF is selected | | | | | | | | | FF44H | | | | | IOC11 | 0 | Output | Input | P11 I/O control register (ESIF=0) | | | | | | | | | | | Juipui | | functions as a general-purpose register when SIF is selected | | | | | R/W | | R/W | | IOC10 | 0 | Output | Input | P10 I/O control register (ESIF=0) | | | | | | | | | | | | | functions as a general-purpose register when SIF is selected | | | | | L | | | | | | | | as a general purpose register when our is selected | | | ### Remarks - \*1 Initial value at initial reset - \*2 Not set in the circuit - \*3 Constantly "0" when being read Table 4.1.1 (b) I/O memory map (FF45H–FF71H) | | | Do- | ister | | | | | ory ma <sub>j</sub> | · · · · · · · · · · · · · · · · · · · | |--------------|---------|---------|----------|--------|---------------|-------------|-----------------|------------------------------------------------|--------------------------------------------------------------------------------------| | Address | D3 | D2 | D1 | D0 | Name | Init *1 | 1 | 0 | Comment | | | | | | | PUL13 | 1 | On | Off | P13 pull-up control register | | | | | | | | | | | functions as a general-purpose register when SIF (slave) is selected | | | PUL13 | PUL12 | PUL11 | PUL10 | PUL12 | 1 | On | Off | P12 pull-up control register (ESIF=0) | | | | | | | | | | | functions as a general-purpose register when SIF (master) is selected | | FF45H | | | | l | - | | | | SCLK (I) pull-up control register when SIF (slave) is selected | | | | | | | PUL11 | 1 | On | Off | P11 pull-up control register (ESIF=0) | | | | R/ | W | | | | | | functions as a general-purpose register when SIF is selected | | | | | | | PUL10 | 1 | On | Off | P10 pull-up control register (ESIF=0) | | | | | 1 | | | | | | SIN pull-up control register when SIF is selected | | | | | | | P13 | - *2 | High | Low | P13 I/O port data | | | P13 | P12 | P11 | P10 | | _ | | | functions as a general-purpose register when SIF (slave) is selected | | | | | | ' ' ' | P12 | _ *2 | High | Low | P12 I/O port data (ESIF=0) | | FF46H | | | | | | . 0 | l | | functions as a general-purpose register when SIF is selected | | | | | | | P11 | _ *2 | High | Low | P11 I/O port data (ESIF=0) | | | | R/ | W | | Dio | 0 | 11: | 1 | functions as a general-purpose register when SIF is selected | | | | 1 W W W | | | P10 | <b>-</b> *2 | High | Low | P10 I/O port data (ESIF=0) | | | | | | I | LDUTY1 | 0 | | | functions as a general-purpose register when SIF is selected | | | LDUTY1 | LDUTY0 | VCCHG | LPWR | LDUTY0 | 0 | | | LCD drive duty [LDUTY1, 0] 0 1 2, 3<br>switch Duty 1/17 1/16 1/8 | | FF60H | | | | | VCCHG | 0 | V <sub>C2</sub> | Vc1 | LCD regulated voltage switch | | | | R/ | W | | LPWR | 0 | On | Off | LCD power On/Off | | | | | | | EXLCDC | 0 | Oii | Oil | General-purpose register | | | EXLCDC | ALOFF | ALON | LPAGE | ALOFF | 1 | All Off | Normal | LCD all OFF control | | FF61H | | | | | ALON | 0 | All On | Normal | LCD all ON control | | | | D. | 14/ | | LPAGE | 0 | 1 | F000-F04F | | | | | R/ | VV | | | | | | functions as a general-purpose register when 1/16, 1/17 duty is selected | | | | | | | LC3 | _ *2 | | | ☐ LCD contrast adjustment | | | LC3 | LC2 | LC1 | LC0 | LC2 | - *2 | | | [LC3-0] 0 - 15 | | FF62H | | | | | LC1 | _ *2 | | | Contrast Light – Dark | | | | R/ | W | | LC0 | _ *2 | | | | | | ENRTM | ENRST | ENON | BZE | ENRTM | 0 | 1 sec | 0.5 sec | Envelope releasing time | | FF6CH | EINLLIN | EINDOI | ENON | DZE | ENRST*3 | Reset | Reset | Invalid | Envelope reset (writing) | | 1110011 | R/W | w | R/W | | ENON | 0 | On | Off | Envelope On/Off | | | 1000 | ** | ., ., ., | | BZE | 0 | Enable | Disable | Buzzer output enable | | | 0 | DZCTD | DZCLIT | CLITDW | 0 *3 | _ *2 | | | Unused | | | 0 | BZSTP | БДОПІ | SHIPW | BZSTP*3 | 0 | Stop | Invalid | 1-shot buzzer stop (writing) | | FF6DH | | | | | BZSHT | 0 | Trigger | Invalid | 1-shot buzzer trigger (writing) | | | R | W | R/ | W | OUTDW | 0 | Busy | Ready | 1-shot buzzer status (reading) | | | | | | I | SHTPW | 0<br>- *2 | 125 msec | 31.25 msec | 1-shot buzzer pulse width setting Unused | | | 0 | BZFQ2 | BZFQ1 | BZFQ0 | 0 *3<br>BZFQ2 | - *2<br>0 | | | Buzzer [BZFQ2, 1, 0] 0 1 2 3 | | FF6EH | | | | l | BZFQ2 | 0 | | | Buzzer Frequency (Hz) 4096.0 3276.8 2730.7 2340.6 | | | R | | R/W | | BZFQ1 | 0 | | | frequency [BZFQ2, 1, 0] 4 5 6 7 selection Frequency (Hz) 2048.0 1638.4 1365.3 1170.3 | | | | | | | 0 *3 | _ *2 | | | Unused | | | 0 | BDTY2 | BDTY1 | BDTY0 | BDTY2 | 0 | | | | | FF6FH | | | <u> </u> | I | BDTY1 | 0 | | | Buzzer signal duty ratio selection | | | R | | R/W | | BDTY0 | 0 | | | (refer to main manual) | | | | | | | 0 *3 | _ *2 | | | Unused | | | 0 | 0 | SCTRG | ESIF | 0 *3 | - *2 | | | Unused | | FF70H | | | | | SCTRG | 0 | Trigger | Invalid | Serial I/F clock trigger (writing) | | ••• | R DAM | | | | | | Run | Stop | Serial I/F clock status (reading) | | | R R/W | | | ESIF | 0 | SIF | 1/0 | Serial I/F enable (P1 port function selection) | | | | | | | | SDP | 0 | MSB first | LSB first | Serial I/F data input/output permutation | | | SDP | SCPS | SCS1 | SCS0 | SCPS | 0 | | | Serial I/F clock phase selection | | <br> EE7411 | | | | | ] | | J | | -Negative polarity (mask option) | | FF71H | | | | | | | <u> </u> | Ī. | Positive polarity (mask option) -Positive polarity (mask option) SCS1, 0 0 1 | | | | R/ | W | | SCS1 | 0 | | | Serial I/F | | 1 | | | | | SCS0 | 0 | | | clock mode selection Clock OSC1/2 OSC1 | Table 4.1.1 (c) I/O memory map (FF72H–FFC6H) | | | D- | iotor | | | • • | | | p (11 / 211 11 Coll) | |---------|------------------|--------|---------|---------------|------------------|-----------------|-----------|-------------|-------------------------------------------------------------------------------------------| | Address | Da | | ister | | Nome | Init +1 | 1 | | Comment | | | D3 | D2 | D1 | D0 | Name<br>SD3 | Init *1<br>- *2 | 1<br>High | 0<br>Low | ¬ MSB | | | SD3 | SD2 | SD1 | SD0 | SD2 | _ *2 | High | Low | IVISD | | FF72H | | | | | SD1 | _ *2 | High | Low | Serial I/F transmit/receive data (low-order 4 bits) | | | | R/ | W | | SD0 | - *2 | High | Low | LSB | | | | | | 1 | SD7 | _ *2 | High | Low | □ MSB | | | SD7 | SD6 | SD5 | SD4 | SD6 | _ *2 | High | Low | MOD | | FF73H | | | | | SD5 | _ *2 | High | Low | Serial I/F transmit/receive data (high-order 4 bits) | | | | R/ | W | | SD4 | _ *2 | High | Low | LSB | | | | | | | 0 *3 | _ *2 | riigii | 2011 | Unused | | | 0 | 0 | TMRST | TMRUN | 0 *3 | - *2 | | | Unused | | FF78H | | | | | TMRST*3 | Reset | Reset | Invalid | Clock timer reset (writing) | | | F | 7 | W | R/W | TMRUN | 0 | Run | Stop | Clock timer Run/Stop | | | | | | | TM3 | 0 | | | Clock timer data (16 Hz) | | | TM3 | TM2 | TM1 | TM0 | TM2 | 0 | | | Clock timer data (32 Hz) | | FF79H | | | | | TM1 | 0 | | | Clock timer data (64 Hz) | | | | F | 3 | | TMO | 0 | | | Clock timer data (128 Hz) | | | | | | | TM7 | 0 | | | Clock timer data (1 Hz) | | | TM7 | TM6 | TM5 | TM4 | TM6 | 0 | | | Clock timer data (2 Hz) | | FF7AH | | | I | | TM5 | 0 | | | Clock timer data (4 Hz) | | | | F | 3 | | TM4 | 0 | | | Clock timer data (8 Hz) | | | | | | | 0 *3 | _ *2 | | | Unused | | | 0 | 0 | SWRST | SWRUN | 0 *3 | - *2 | | | Unused | | FF7CH | | | | | SWRST*3 | Reset | Reset | Invalid | Stopwatch timer reset (writing) | | | F | 3 | W | R/W | SWRUN | 0 | Run | Stop | Stopwatch timer Run/Stop | | | | | | | SWD3 | 0 | | | 7 | | FEZDII | SWD3 | SWD2 | SWD1 | SWD0 | SWD2 | 0 | | | Stopwatch timer data | | FF7DH | - | | | | SWD1 | 0 | | | BCD (1/100 sec) | | | | ŀ | 7 | | SWD0 | 0 | | | | | | OWDZ | OWDO | CWDE | CWD4 | SWD7 | 0 | | | | | FF7EH | SWD7 | SWD6 | SWD5 | SWD4 | SWD6 | 0 | | | Stopwatch timer data | | FF/En | | | | | SWD5 | 0 | | | BCD (1/10 sec) | | | R | | | | SWD4 | 0 | | | | | | 0 | EVCNT | FCSEL | PLPOL | 0 *3 | _ *2 | | | Unused | | FFC0H | U | LVOIVI | TOOLL | I LI OL | EVCNT | 0 | - | Timer | Timer 0 counter mode selection (Fix at "0".) | | 110011 | R R/W | | | | FCSEL | 0 | | | General-purpose register | | | R R/W | | | | PLPOL | 0 | | | General-purpose register | | | CHSEL | PTOUT | CKSEL1 | CKSFL0 | CHSEL | 0 | Timer1 | Timer0 | TOUT output channel selection | | FFC1H | OTIOLE TOOT ONCE | | 0.10221 | ONOLL! ONOLLO | | 0 | On | Off | TOUT output control | | | | R | W | | CKSEL1 | 0 | OSC3 | OSC1 | Prescaler 1 source clock selection | | | | | | | CKSEL0 | 0 | OSC3 | OSC1 | Prescaler 0 source clock selection | | | PTPS01 | PTPS00 | PTRST0 | PTRUN0 | PTPS01 | 0 | | | Prescaler 0 [PTPS01, 00] 0 1 2 3 division ratio Division ratio 1/1 1/4 1/32 1/256 | | FFC2H | ļ | | | | PTPS00 | 0 | Darri | اد!! - برما | selection Division ratio 1/1 1/4 1/32 1/230 | | | R/W | | W | R/W | PTRST0*3 | - *2<br>0 | Reset | Invalid | Timer 0 reset (reload) | | | | | | | PTRUN0 | 0 | Run | Stop | Timer 0 Run/Stop | | | PTPS11 | PTPS10 | PTRST1 | PTRUN1 | PTPS11<br>PTPS10 | 0 | | | Prescaler 1 division ratio PTPS11, 10 0 1 2 3 2 3 2 2 2 2 2 | | FFC3H | | | | | PTRST1*3 | 0<br>_*2 | Reset | Invalid | Selection Division ratio 1/1 1/4 1/32 1/230 Timer 1 reset (reload) | | | R/ | W | W | R/W | PTRUN1 | 0 | Run | | | | | | | | | RLD03 | 0 | null | Stop | Timer 1 Run/Stop ☐ MSB | | | RLD03 | RLD02 | RLD01 | RLD00 | RLD02 | 0 | | | WSD | | FFC4H | | | | <u> </u> | RLD02 | 0 | | | Programmable timer 0 reload data (low-order 4 bits) | | | | R | W | | RLD01 | 0 | | | LSB | | | | | | | RLD07 | 0 | | | □ MSB | | | RLD07 | RLD06 | RLD05 | RLD04 | RLD06 | 0 | | | | | FFC5H | | | | | RLD05 | 0 | | | Programmable timer 0 reload data (high-order 4 bits) | | | | R | W | | RLD04 | 0 | | | LSB | | | | | | | RLD13 | 0 | | | ☐ MSB | | | RLD13 | RLD12 | RLD11 | RLD10 | RLD12 | 0 | | | | | FFC6H | | | 1 | | RLD11 | 0 | | | Programmable timer 1 reload data (low-order 4 bits) | | | | R | W | | RLD10 | 0 | | | LSB | | | | | | | | - | | | 1- | Table 4.1.1 (d) I/O memory map (FFC7H–FFF7H) | | | | | 1000 | 7,1,1 | ( <i>u</i> ) 1/C | meme | y maj | p (FFC/H=FFF/H) | |---------|---------------|-------|-----------|--------|----------------|------------------|--------------|-----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------| | Address | D2 | | ister | | Nama | lmit at | 4 | _ | Comment | | | D3 | D2 | D1 | D0 | Name<br>RLD17 | Init *1 | 1 | 0 | ☐ MSB | | | RLD17 | RLD16 | RLD15 | RLD14 | RLD16 | 0 | | | | | FFC7H | | _ | | | RLD15 | 0 | | | Programmable timer 1 reload data (high-order 4 bits) | | | | R | W | | RLD14 | 0 | | | _ LSB | | | PTD03 | PTD02 | PTD01 | PTD00 | PTD03 | 0 | | | MSB | | FFC8H | P1D03 P1D02 | | 1 1001 | 1 1000 | PTD02 | 0 | | | Programmable timer 0 data (low-order 4 bits) | | | | ı | 3 | | PTD01 | 0 | | | | | | | | I | | PTD00<br>PTD07 | 0 | | | LSB | | | PTD07 | PTD06 | PTD05 | PTD04 | PTD07 | 0 | | | MSB | | FFC9H | | | | | PTD05 | 0 | | | Programmable timer 0 data (high-order 4 bits) | | | | ı | 7 | | PTD04 | 0 | | | LSB | | | DTD40 | DTD40 | DTD44 | DTD40 | PTD13 | 0 | | | ¬ MSB | | FFCAH | PTD13 | PTD12 | PTD11 | PTD10 | PTD12 | 0 | | | Programmable timer 1 data (low-order 4 bits) | | FFCAH | | | 3 | | PTD11 | 0 | | | | | | | ' | | ı | PTD10 | 0 | | | LSB | | | PTD17 | PTD16 | PTD15 | PTD14 | PTD17 | 0 | | | MSB | | FFCBH | | | | | PTD16<br>PTD15 | 0 | | | Programmable timer 1 data (high-order 4 bits) | | | | ı | 3 | | PTD13 | 0 | | | LSB | | | | | | | 0 *3 | _ *2 | | | Unused | | | 0 | 0 | EIPT1 | EIPT0 | 0 *3 | - *2 | | | Unused | | FFE2H | | , | | ΛΑ/ | EIPT1 | 0 | Enable | Mask | Interrupt mask register (Programmable timer 1) | | | R R/W | | | | EIPT0 | 0 | Enable | Mask | Interrupt mask register (Programmable timer 0) | | | 0 | 0 | 0 | EISIF | 0 *3 | - *2 | | | Unused | | FFE3H | | | | | 0 *3 | - *2<br>- *2 | | | Unused | | | R | | | R/W | 0 *3<br>EISIF | - *2<br>0 | Enable | Mask | Unused Interpret mock register (Social I/E) | | | | | | | 0 *3 | _ *2 | Enable | IVIdSK | Interrupt mask register (Serial I/F) Unused | | | 0 | 0 | 0 | EIK0 | 0 *3 | _ *2 | | | Unused | | FFE4H | | | DAM | | 0 *3 | - *2 | | | Unused | | | | R | | R/W | EIK0 | 0 | Enable | Mask | Interrupt mask register (K00–K03) | | | EIT3 | EIT2 | EIT1 | EIT0 | EIT3 | 0 | Enable | Mask | Interrupt mask register (Clock timer 1 Hz) | | FFE6H | LIIO | L112 | LIII LIIO | | EIT2 | 0 | Enable | Mask | Interrupt mask register (Clock timer 2 Hz) | | | | R | w | | EIT1 | 0 | Enable | Mask | Interrupt mask register (Clock timer 8 Hz) | | | | | | | EIT0<br>0 *3 | - *2 | Enable | Mask | Interrupt mask register (Clock timer 32 Hz) Unused | | | 0 | 0 | EISW1 | EISW10 | 0 *3 | _ *2 | | | Unused | | FFE7H | | | | | EISW1 | 0 | Enable | Mask | Interrupt mask register (Stopwatch timer 1 Hz) | | | R | | | R/W | | 0 | Enable | Mask | Interrupt mask register (Stopwatch timer 10 Hz) | | | 0 | 0 | IPT1 | IPT0 | 0 *3 | _ *2 | (R) | (R) | Unused | | FFF2H | 0 | U U | | 11 10 | 0 *3 | _ *2 | Yes | No | Unused | | | F | 3 | R/ | W | IPT1 | 0 | (W) | (W) | Interrupt factor flag (Programmable timer 1) | | | | | | | IPT0<br>0 *3 | 0<br>- *2 | Reset<br>(R) | Invalid<br>(R) | Interrupt factor flag (Programmable timer 0) Unused | | | 0 | 0 | 0 | ISIF | 0 *3 | - *2 | Yes | No | Unused | | FFF3H | | | | | | _ *2 | (W) | (W) | Unused | | | R R/W | | | R/W | ISIF | 0 | Reset | Invalid | Interrupt factor flag (Serial I/F) | | | 0 | 0 | 0 | IKO | 0 *3 | - *2 | (R) | (R) | Unused | | FFF4H | 0 | 0 | U | IK0 | 0 *3 | _ *2 | Yes | No | Unused | | | | R | | R/W | 0 *3 | _ *2 | (W) | (W) | Unused | | | | | l | | IK0 | 0 | Reset | Invalid | Interrupt factor flag (K00–K03) | | | IT3 | IT2 | IT1 | IT0 | IT3<br>IT2 | 0 | (R) | (R)<br>No | Interrupt factor flag (Clock timer 1 Hz) Interrupt factor flag (Clock timer 2 Hz) | | FFF6H | | | | IT1 | 0 | Yes<br>(W) | (W) | Interrupt factor flag (Clock timer 2 Hz) Interrupt factor flag (Clock timer 8 Hz) | | | | | R | W | | IT0 | 0 | Reset | Invalid | Interrupt factor flag (Clock timer 32 Hz) | | | | | | | 0 *3 | _ *2 | (R) | (R) | Unused | | , | 0 | 0 | ISW1 | ISW10 | 0 *3 | - *2 | Yes | No | Unused | | FFF7H | | 3 | D | w | ISW1 | 0 | (W) | (W) | Interrupt factor flag (Stopwatch timer 1 Hz) | | | | 1 | ^/ | ** | ISW10 | 0 | Reset | Invalid | Interrupt factor flag (Stopwatch timer 10 Hz) | # 4.2 Watchdog Timer ### 4.2.1 Configuration of watchdog timer The S1C63454 has a built-in watchdog timer that operates with a 256 Hz divided clock from the OSC1 as the source clock. The watchdog timer starts operating after initial reset, however, it can be stopped by the software. The watchdog timer must be reset cyclically by the software while it operates. If the watchdog timer is not reset in at least 3–4 seconds, it generates a non-maskable interrupt (NMI) to the CPU. Figure 4.2.1.1 is the block diagram of the watchdog timer. Fig. 4.2.1.1 Watchdog timer block diagram The watchdog timer contains a 10-bit binary counter, and generates the non-maskable interrupt when the last stage of the counter (0.25 Hz) overflows. Watchdog timer reset processing in the program's main routine enables detection of program overrun, such as when the main routine's watchdog timer processing is bypassed. Ordinarily this routine is incorporated where periodic processing takes place, just as for the timer interrupt routine. The watchdog timer operates in the HALT mode. If a HALT status continues for 3–4 seconds, the non-maskable interrupt releases the HALT status. ### 4.2.2 Interrupt function If the watchdog timer is not reset periodically, the non-maskable interrupt (NMI) is generated to the core CPU. Since this interrupt cannot be masked, it is accepted even in the interrupt disable status (I flag = "0"). However, it is not accepted when the CPU is in the interrupt mask state until SP1 and SP2 are set as a pair, such as after initial reset or during re-setting the stack pointer. The interrupt vector of NMI is assigned to 0100H in the program memory. ### 4.2.3 I/O memory of watchdog timer Table 4.2.3.1 shows the I/O address and control bits for the watchdog timer. Table 4.2.3.1 Control bits of watchdog timer | Address | | Reg | ister | | | | | | 0 | |---------|----|-----|-------|-------|---------|-------------|--------|---------|--------------------------------| | Address | D3 | D2 | D1 | D0 | Name | Init *1 1 0 | | | Comment | | | | | | WDDOT | 0 *3 | _ *2 | | | Unused | | FF0711 | 0 | 0 | WDEN | WDRST | 0 *3 | _ *2 | | | Unused | | FF07H | R | | D.14. | | WDEN | 1 | Enable | Disable | Watchdog timer enable | | | | | R/W | W | WDRST*3 | Reset | Reset | Invalid | Watchdog timer reset (writing) | <sup>\*1</sup> Initial value at initial reset ### WDEN: Watchdog timer enable register (FF07H•D1) Selects whether the watchdog timer is used (enabled) or not (disabled). When "1" is written: Enabled When "0" is written: Disabled Reading: Valid When "1" is written to the WDEN register, the watchdog timer starts count operation. When "0" is written, the watchdog timer does not count and does not generate the interrupt (NMI). At initial reset, this register is set to "1". ### WDRST: Watchdog timer reset (FF07H•D0) Resets the watchdog timer. When "1" is written: Watchdog timer is reset When "0" is written: No operation Reading: Always "0" When "1" is written to WDRST, the watchdog timer is reset and restarts immediately after that. When "0" is written, no operation results. This bit is dedicated for writing, and is always "0" for reading. ### 4.2.4 Programming notes - (1) When the watchdog timer is being used, the software must reset it within 3-second cycles. - (2) Because the watchdog timer is set in operation state by initial reset, set the watchdog timer to disabled state (not used) before generating an interrupt (NMI) if it is not used. <sup>\*2</sup> Not set in the circuit <sup>\*3</sup> Constantly "0" when being read ### 4.3 Oscillation Circuit ### 4.3.1 Configuration of oscillation circuit The S1C63454 has two oscillation circuits (OSC1 and OSC3). OSC1 is either a crystal or a CR oscillation circuit that supplies the operating clock to the CPU and peripheral circuits. OSC3 is either a CR or a ceramic oscillation circuit. When processing with the S1C63454 requires high-speed operation, the CPU operating clock can be switched from OSC1 to OSC3 by the software. To stabilize operation of the internal circuits, the operating voltage VD1 must be switched according to the oscillation circuit to be used. Figure 4.3.1.1 is the block diagram of this oscillation system. Fig. 4.3.1.1 Oscillation system block diagram ### 4.3.2 OSC1 oscillation circuit The OSC1 oscillation circuit generates the main clock for the CPU and the peripheral circuits. Either the crystal oscillation circuit or the CR oscillation circuit can be selected as the circuit type by mask option. The oscillation frequency of the crystal oscillation circuit is 32.768 kHz (Typ.) and the CR oscillation circuit is 60 kHz (Typ.). Figure 4.3.2.1 is the block diagram of the OSC1 oscillation circuit. (a) Crystal oscillation circuit Fig. 4.3.2.1 OSC1 oscillation circuit As shown in Figure 4.3.2.1, the crystal oscillation circuit can be configured simply by connecting the crystal oscillator (X'tal) of 32.768 kHz (Typ.) between the OSC1 and OSC2 terminals and the trimmer capacitor (CGX) between the OSC1 and Vss terminals when crystal oscillation is selected. The CR oscillation circuit can be configured simply by connecting the resistor RCR1 between the OSC1 and OSC2 terminals when CR oscillation is selected. See Chapter 7, "Electrical Characteristics" for resistance value of RCR1. Note: • The current consumption of CR oscillation is larger than crystal oscillation. Be aware that the CR oscillation frequency changes slightly. Pay special attention to the circuits that use fosc1 as the source clock, such as the timer (time lag), the LCD frame frequency (display quality, flicker in low frequency) and the sound generator (sound quality). ### 4.3.3 OSC3 oscillation circuit The S1C63454 has built-in the OSC3 oscillation circuit that generates the CPU's sub-clock (Max. 4 MHz) for high speed operation and the source clock for peripheral circuits needing a high speed clock (programmable timer, FOUT output). The mask option enables selection of either the CR or ceramic oscillation circuit. When CR oscillation is selected, only a resistance is required as an external element. When ceramic oscillation is selected, a ceramic oscillator and two capacitors (gate and drain capacitance) are required. Figure 4.3.3.1 is the block diagram of the OSC3 oscillation circuit. Fig. 4.3.3.1 OSC3 oscillation circuit As shown in Figure 4.3.3.1, the CR oscillation circuit can be configured simply by connecting the resistor RCR2 between the OSC3 and OSC4 terminals when CR oscillation is selected. See Chapter 7, "Electrical Characteristics" for resistance value of RCR2. When ceramic oscillation is selected, the ceramic oscillation circuit can be configured by connecting the ceramic oscillator (Max. 4 MHz) between the OSC3 and OSC4 terminals, capacitor CGC between the OSC3 and OSC4 terminals, and capacitor CDC between the OSC4 and VSS terminals. For both CGC and CDC, connect capacitors that are about 30 pF. To reduce current consumption of the OSC3 oscillation circuit, oscillation can be stopped by the software (OSCC register). ### 4.3.4 Switching of operating voltage ### (1) When OSC1 crystal oscillation circuit is used The CPU system clock is switched to OSC1 or OSC3 by the software (CLKCHG register). In this case, to obtain stable operation, the operating voltage VD1 for the internal circuits must be switched by the software (VDC register). OSC1 (crystal oscillation) operation: VD1 = 1.3 V (VDC = "0") OSC3 operation: VD1 = 2.2 V (VDC = "1") When OSC3 is to be used as the CPU system clock, it should be done as the following procedure using the software: first switch the operating voltage VD1, turn the OSC3 oscillation ON after waiting 2.5 msec or more for the above operation to stabilize, switch the clock after waiting 5 msec or more for oscillation stabilization. When switching from OSC3 to OSC1, turn the OSC3 oscillation circuit OFF after switching the clock then set the operating voltage VD1 to 1.3 V. #### $OSC1 \rightarrow OSC3$ - 1. Set VDC to "1" (1.3 V $\rightarrow$ 2.2 V). - 2. Maintain 2.5 msec or more. - 3. Set OSCC to "1" (OSC3 oscillation ON). - 4. Maintain 5 msec or more. - 5. Set CLKCHG to "1" (OSC1 $\rightarrow$ OSC3). ### $OSC3 \rightarrow OSC1$ - 1. Set CLKCHG to "0" (OSC3 $\rightarrow$ OSC1). - 2. Set OSCC to "0" (OSC3 oscillation OFF). - 3. Set VDC to "0" (2.2 V $\rightarrow$ 1.3 V). ### (2) When OSC1 CR oscillation circuit is used When the CR oscillation circuit has been selected as the OSC1 oscillation circuit by mask option, 2.2 V of VD1 necessary to operate with OSC1 and OSC3. OSC1 (CR oscillation) operation: VD1 = 2.2 VOSC3 operation: VD1 = 2.2 V Since the S1C63454 fixes the VD1 voltage value at 2.2 V when the CR oscillation circuit is selected as the OSC1 oscillation circuit by mask option, it is not necessary to switch the operating voltage VD1 by software (VDC register). However, software control to switch the CPU system clock using the CLKCHG register is necessary. When OSC3 is to be used as the CPU system clock, it should be done as the following procedure using the software: turn the OSC3 oscillation ON, switch the clock after waiting 5 msec or more for oscillation stabilization. When switching from OSC3 to OSC1, turn the OSC3 oscillation circuit OFF after switching the clock. $OSC1 \rightarrow OSC3$ $OSC3 \rightarrow OSC1$ - 1. Set OSCC to "1" (OSC3 oscillation ON). - 2. Maintain 5 msec or more. - 3. Set CLKCHG to "1" (OSC1 $\rightarrow$ OSC3). - 1. Set CLKCHG to "0" (OSC3 $\rightarrow$ OSC1). - 2. Set OSCC to "0" (OSC3 oscillation OFF). ### 4.3.5 Clock frequency and instruction execution time Table 4.3.5.1 shows the instruction execution time according to each frequency of the system clock. Table 4.3.5.1 Clock frequency and instruction execution time | Clask fraguency | Instruction execution time (μsec) | | | | | | | | | |------------------|-----------------------------------|---------------------|---------------------|--|--|--|--|--|--| | Clock frequency | 1-cycle instruction | 2-cycle instruction | 3-cycle instruction | | | | | | | | OSC1: 32.768 kHz | 61 | 122 | 183 | | | | | | | | OSC1: 60 kHz | 33 | 67 | 100 | | | | | | | | OSC3: 4 MHz | 0.5 | 1 | 1.5 | | | | | | | ### 4.3.6 I/O memory of oscillation circuit Table 4.3.6.1 shows the I/O address and the control bits for the oscillation circuit. Table 4.3.6.1 Control bits of oscillation circuit | Address Regi | | | ister | | | | | | 0 | | |--------------|----------|------|-------|-----|--------|---------|-------|-------|---------------------------------------------------------|--| | Address | D3 | D2 | D1 | D0 | Name | Init *1 | 1 | 0 | Comment | | | | 011(0110 | | _ | | CLKCHG | 0 | OSC3 | OSC1 | CPU clock switch | | | | CLKCHG | OSCC | 0 | VDC | oscc | 0 | On | Off | OSC3 oscillation On/Off | | | FF00H | - | | _ | | 0 *3 | _ *2 | | | Unused | | | | R/W | | R | R/W | VDC | 0 | 2.2 V | 1.3 V | CPU operating voltage switch (1.3 V: OSC1, 2.2 V: OSC3) | | <sup>\*1</sup> Initial value at initial reset ### VDC: CPU operating voltage switching register (FF00H•D0) It is used to switch the operating voltage VD1, when the crystal oscillation circuit has been selected as the OSC1 oscillation circuit by mask option. When "1" is written: 2.2~V~(for~OSC3~operation) When "0" is written: 1.3~V~(for~OSC1~operation) Reading: Valid When switching the CPU system clock, the operating voltage VD1 should also be switched according to the clock. When switching from OSC1 to OSC3, first set VD1 to 2.2 V. After that maintain 2.5 msec or more, and then turn the OSC3 oscillation ON. When switching from OSC3 to OSC1, set VD1 to 1.3 V after switching to OSC1 and turning the OSC3 oscillation OFF. When the CR oscillation circuit has been selected as the OSC1 oscillation circuit by mask option, setting of this register does not affect the operating voltage VD1, and the VD1 voltage is fixed at 2.2 V. At initial reset, this register is set to "0". ### OSCC: OSC3 oscillation control register (FF00H•D2) Controls oscillation ON/OFF for the OSC3 oscillation circuit. When "1" is written: OSC3 oscillation ON When "0" is written: OSC3 oscillation OFF Reading: Valid When it is necessary to operate the CPU at high speed, set OSCC to "1". At other times, set it to "0" to reduce current consumption. Furthermore, when the crystal oscillation circuit has been selected as the OSC1 oscillation circuit by mask option, it is necessary to switch the operating voltage VD1 when turning the OSC3 oscillation circuit ON and OFF At initial reset, this register is set to "0". ### CLKCHG: CPU system clock switching register (FF00H•D3) The CPU's operation clock is selected with this register. When "1" is written: OSC3 clock is selected When "0" is written: OSC1 clock is selected Reading: Valid When the CPU clock is to be OSC3, set CLKCHG to "1"; for OSC1, set CLKCHG to "0". After turning the OSC3 oscillation ON (OSCC = "1"), switching of the clock should be done after waiting 5 msec or more. When VD1 is 1.3 V (VDC = "0") and when OSC3 oscillation is OFF (OSCC = "0"), setting of CLKCHG = "1" becomes invalid and switching to OSC3 is not performed. When the CR oscillation circuit has been selected as the OSC1 oscillation circuit by mask option, setting VDC to "0" makes no difference. At initial reset, this register is set to "0". <sup>\*2</sup> Not set in the circuit <sup>\*3</sup> Constantly "0" when being read ### 4.3.7 Programming notes - (1) When switching the CPU system clock from OSC1 to OSC3, first set VD1. After that maintain 2.5 msec or more, and then turn the OSC3 oscillation ON. When switching from OSC3 to OSC1, set VD1 after switching to OSC1 and turning the OSC3 oscilla - tion OFF. However, when the CR oscillation circuit has been selected as the OSC1 oscillation circuit, it is not necessary to set VD1. - (2) It takes at least 5 msec from the time the OSC3 oscillation circuit goes ON until the oscillation stabilizes. Consequently, when switching the CPU operation clock from OSC1 to OSC3, do this after a minimum of 5 msec have elapsed since the OSC3 oscillation went ON. Further, the oscillation stabilization time varies depending on the external oscillator characteristics and conditions of use, so allow ample margin when setting the wait time. - (3) When switching the clock form OSC3 to OSC1, use a separate instruction for switching the OSC3 oscillation OFF. An error in the CPU operation can result if this processing is performed at the same time by the one instruction. - (4) When the CR oscillation circuit has been selected as the OSC1 oscillation circuit by mask option, it is not necessary to switch the operating voltage VD1 using the VDC register and the VD1 voltage is fixed at 2.2 V. The VD1 level does not change even if any data is written to the VDC register. # 4.4 Input Ports (K00–K03) # 4.4.1 Configuration of input ports The S1C63454 has four bits general-purpose input ports. Each of the input port terminals (K00–K03) provides internal pull-up resistor. Pull-up resistor can be selected for each bit with the mask option. Figure 4.4.1.1 shows the configuration of input port. Fig. 4.4.1.1 Configuration of input port Selection of "With pull-up resistor" with the mask option suits input from the push switch, key matrix, and so forth. When "Gate direct" is selected, the port can be used for slide switch input and interfacing with other LSIs. # 4.4.2 Interrupt function All four bits of the input ports (K00–K03) provide the interrupt function. The conditions for issuing an interrupt can be set by the software. Further, whether to mask the interrupt function can be selected by the software. Figure 4.4.2.1 shows the configuration of K00–K03 interrupt circuit. Fig. 4.4.2.1 Input interrupt circuit configuration #### CHAPTER 4: PERIPHERAL CIRCUITS AND OPERATION (Input Ports) The interrupt selection register (SIK) and input comparison register (KCP) are individually set for the input ports K00–K03, and can specify the terminals for generating interrupt and interrupt timing. The interrupt selection registers (SIK00–SIK03) select what input of K00–K03 to use for the interrupt. Writing "1" into an interrupt selection register incorporates that input port into the interrupt generation conditions. The changing the input port where the interrupt selection register has been set to "0" does not affect the generation of the interrupt. The input interrupt timing can select that the interrupt be generated at the rising edge of the input or that it be generated at the falling edge according to the set value of the input comparison registers (KCP00–KCP03). By setting these two conditions, the interrupt for K00–K03 is generated when input ports in which an interrupt has been enabled by the input selection registers and the contents of the input comparison registers have been changed from matching to no matching. The interrupt mask registers (EIK0) enable the interrupt mask to be selected for K00–K03. When the interrupt is generated, the interrupt factor flag (IK0) is set to "1". Figure 4.4.2.2 shows an example of an interrupt for K00–K03. Fig. 4.4.2.2 Example of interrupt of K00–K03 K00 interrupt is disabled by the interrupt selection register (SIK00), so that an interrupt does not occur at (2). At (3), K03 changes to "0"; the data of the terminals that are interrupt enabled no longer match the data of the input comparison registers, so that interrupt occurs. As already explained, the condition for the interrupt to occur is the change in the port data and contents of the input comparison registers from matching to no matching. Hence, in (4), when the no matching status changes to another no matching status, an interrupt does not occur. Further, terminals that have been masked for interrupt do not affect the conditions for interrupt generation. # 4.4.3 Mask option Internal pull-up resistor can be selected for each of the four bits of the input ports (K00–K03) with the input port mask option. When "Gate direct" is selected, take care that the floating status does not occur for the input. Select "With pull-up resistor" for input ports that are not being used. Interrupt factor flag (K00-K03) # 4.4.4 I/O memory of input ports Table 4.4.4.1 shows the I/O addresses and the control bits for the input ports. Register Address Comment D3 D2 D1 D0 Name Init \*1 SIK03 Enable Disable SIK03 SIK02 SIK01 SIK00 SIK02 0 Enable Disable FF20H K00-K03 interrupt selection register SIK01 0 Enable Disable R/W SIK00 0 Enable Disable K03 **-** \*2 High Low K03 K02 K01 K00 K02 \_ \*2 High Iow FF21H K00-K03 input port data \_ \*2 K01 High Low R K00 - \*2 High Low KCP03 1 KCP03 KCP02 KCP01 KCP00 KCP02 1 FF22H K00-K03 input comparison register KCP01 1 R/W KCP00 1 \_ \*2 0 \*3 Unused 0 0 0 EIK0 0 \*3 - \*2 Unused FFF4H 0 \*3 \_ \*2 Unused R R/W EIK0 0 Enable Mask Interrupt mask register (K00-K03) 0 \*3 - \*2 (R) (R) Unused 0 0 0 IK<sub>0</sub> 0 \*3 \_ \*2 Yes No Unused FFF4H 0 \*3 \_ \*2 (W) (W) Unused Table 4.4.4.1 Control bits of input ports R ## K00-K03: K0 port input port data (FF21H) Input data of the input port terminals can be read with these registers. IK0 R/W When "1" is read: High level When "0" is read: Low level Writing: Invalid The reading is "1" when the terminal voltage of the four bits of the input ports (K00–K03) goes high (VDD), and "0" when the voltage goes low (VSS). Reset These bits are dedicated for reading, so writing cannot be done. #### SIK00-SIK03: K0 port interrupt selection register (FF20H) Selects the ports to be used for the K00–K03 input interrupts. When "1" is written: Enable When "0" is written: Disable Reading: Valid Enables the interrupt for the input ports (K00–K03) for which "1" has been written into the interrupt selection registers (SIK00–SIK03). The input port set for "0" does not affect the interrupt generation condition. At initial reset, these registers are set to "0". #### KCP00-KCP03: K0 port input comparison register (FF22H) Interrupt conditions for terminals K00–K03 can be set with these registers. When "1" is written: Falling edge When "0" is written: Rising edge Reading: Valid The interrupt conditions can be set for the rising or falling edge of input for each of the four bits (K00–K03), through the input comparison registers (KCP00–KCP03). <sup>\*1</sup> Initial value at initial reset <sup>\*2</sup> Not set in the circuit <sup>\*3</sup> Constantly "0" when being read #### **CHAPTER 4: PERIPHERAL CIRCUITS AND OPERATION (Input Ports)** For KCP00–KCP03, a comparison is done only with the ports that are enabled by the interrupt among K00–K03 by means of the SIK00–SIK03 registers. At initial reset, these registers are set to "0". #### EIK0: K0 input interrupt mask register (FFE4H•D0) Masking the interrupt of the input port can be selected with this register. When "1" is written: Enable When "0" is written: Mask Reading: Valid At initial reset, this register is set to "0". #### IK0: K0 input interrupt factor flag (FFF4H•D0) This flag indicates the occurrence of input interrupt. When "1" is read: Interrupt has occurred When "0" is read: Interrupt has not occurred When "1" is written: Flag is reset When "0" is written: Invalid The interrupt factor flag IK0 is associated with K00–K03. From the status of this flag, the software can decide whether an input interrupt has occurred. The interrupt factor flag is set to "1" when the interrupt condition is established regardless of the interrupt mask register setting. However, the interrupt does not occur to the CPU when the interrupt is masked. This flag is reset to "0" by writing "1". After an interrupt occurs, the same interrupt will occur again if the interrupt enabled state (I flag = "1") is set or the RETI instruction is executed unless the interrupt factor flag is reset. Therefore, be sure to reset (write "1" to) the interrupt factor flag in the interrupt service routine before shifting to the interrupt enabled state. At initial reset, this flag is set to "0". ## 4.4.5 Programming notes (1) When input ports are changed from low to high by pull-up resistors, the rise of the waveform is delayed on account of the time constant of the pull-up resistor and input gate capacitance. Hence, when fetching input ports, set an appropriate waiting time. Particular care needs to be taken of the key scan during key matrix configuration. Make this waiting time the amount of time or more calculated by the following expression. $10 \times C \times R$ C: terminal capacitance 5 pF + parasitic capacitance ? pF R: pull-up resistance 330 k $\Omega$ (2) After an interrupt occurs, the same interrupt will occur again if the interrupt enabled state (I flag = "1") is set or the RETI instruction is executed unless the interrupt factor flag is reset. Therefore, be sure to reset (write "1" to) the interrupt factor flag in the interrupt service routine before shifting to the interrupt enabled state. # 4.5 *Output Ports (R00–R03)* # 4.5.1 Configuration of output ports The S1C63454 has 4 bits of general output ports. Output specifications of the output ports can be selected individually with the mask option. Two kinds of output specifications are available: complementary output and N-channel open drain output. Figure 4.5.1.1 shows the configuration of the output port. Fig. 4.5.1.1 Configuration of output port The R02 and R03 output terminals are shared with special output terminals (TOUT, FOUT), and this function is selected by the software. At initial reset, these are all set to the general purpose output port. Table 4.5.1.1 shows the setting of the output terminals by function selection. | There in it is a merion serior of our pur terminars | | | | | | | | |-----------------------------------------------------|-------------------|--------|---------|--|--|--|--| | Terminal | Terminal status | Specia | loutput | | | | | | name | at initial reset | TOUT | FOUT | | | | | | R00 | R00 (High output) | R00 | R00 | | | | | | R01 | R01 (High output) | R01 | R01 | | | | | | R02 | R02 (High output) | TOUT | | | | | | | R03 | R03 (High output) | | FOUT | | | | | Table 4.5.1.1 Function setting of output terminals When using the output port (R02, R03) as the special output port, the data register must be fixed at "1" and the high impedance control register must be fixed at "0" (data output). # 4.5.2 Mask option Output specifications of the output ports can be selected with the mask option. The output specifications of the output ports R00–R03 can be selected from either complementary output or N-channel open drain output individually (in 1-bit units). However, when N-channel open drain output is selected, do not apply a voltage exceeding the power supply voltage to the output port. S1C63454 TECHNICAL MANUAL EPSON 31 ## 4.5.3 High impedance control The terminal output status of the output ports can be set to a high impedance status. This control is done using the high impedance control registers. The high impedance control registers are provided to correspond with the output ports as shown below. | High impedance control register | Corresponding output port | |---------------------------------|---------------------------| | R00HIZ | R00 (1-bit) | | R01HIZ | R01 (1-bit) | | R02HIZ | R02 (1-bit) | | R03HIZ | R03 (1-bit) | When "1" is written to the high impedance control register, the corresponding output port terminal goes into high impedance status. When "0" is written, the port outputs a signal according to the data register. ## 4.5.4 Special output In addition to the regular DC output, special output can be selected for the output ports R02 and R03 as shown in Table 4.5.4.1 with the software. Figure 4.5.4.1 shows the configuration of the R02 and R03 output ports. Table 4.5.4.1 Special output | Terminal | Special output | Output control register | |----------|----------------|-------------------------| | R03 | FOUT | FOUTE | | R02 | TOUT | PTOUT | Fig. 4.5.4.1 Configuration of R02 and R03 output ports At initial reset, the output port data register is set to "1" and the high impedance control register is set to "0". Consequently, the output terminal goes high (VDD). When using the output port (R02, R03) as the special output port, fix the data register (R02, R03) at "1" and the high impedance control register (R02HIZ, R03HIZ) at "0" (data output). The respective signal should be turned ON and OFF using the special output control register. - Note: Be aware that the output terminal is fixed at a low (Vss) level the same as the DC output if "0" is written to the R02 and R03 registers when the special output has been selected. - Be aware that the output terminal shifts into high impedance status when "1" is written to the high impedance control register (R02HIZ, R03HIZ). ## • TOUT (R02) The R02 terminal can output a TOUT signal. The TOUT signal is the clock that is output from the programmable timer, and can be used to provide a clock signal to an external device. To output the TOUT signal, fix the R02 register at "1" and the R02HIZ register at "0", and turn the signal ON and OFF using the PTOUT register. It is, however, necessary to control the programmable timer. Refer to Section 4.10, "Programmable Timer" for details of the programmable timer. Note: A hazard may occur when the TOUT signal is turned ON and OFF. Figure 4.5.4.2 shows the output waveform of the TOUT signal. Fig. 4.5.4.2 Output waveform of TOUT signal #### • FOUT (R03) The R03 terminal can output a FOUT signal. The FOUT signal is a clock (fOSC1 or fOSC3) that is output from the oscillation circuit or a clock that the fOSC1 clock has divided in the internal circuit, and can be used to provide a clock signal to an external device. To output the FOUT signal, fix the R03 register at "1" and the R03HIZ register at "0", and turn the signal ON and OFF using the FOUTE register. The frequency of the output clock may be selected from among 4 types shown in Table 4.5.4.2 by setting the FOFQ0 and FOFQ1 registers. Table 4.5.4.2 FOUT clock frequency | FOFQ1 | FOFQ0 | Clock frequency | |-------|-------|--------------------| | 1 | 1 | fosc3 | | 1 | 0 | fosc1 | | 0 | 1 | $fosc1 \times 1/8$ | | 0 | 0 | fosc1 × 1/64 | fosc1: Clock that is output from the OSC1 oscillation circuit fosc3: Clock that is output from the OSC3 oscillation circuit When fOSC3 is selected for the FOUT signal frequency, it is necessary to control the OSC3 oscillation circuit before output. Refer to Section 4.3, "Oscillation Circuit", for the control and notes. Note: A hazard may occur when the FOUT signal is turned ON and OFF. Figure 4.5.4.3 shows the output waveform of the FOUT signal. Fig. 4.5.4.3 Output waveform of FOUT signal # 4.5.5 I/O memory of output ports Table 4.5.5.1 shows the I/O addresses and control bits for the output ports. Table 4.5.5.1 Control bits of output ports | | Tuote 4.5.5.1 Control ous of output ports | | | | | | | | | | |---------|-------------------------------------------|--------|------------------------|----------|---------|--------|--------|---------------------------------------------|-------------------------------------------------------------------------------------|--| | Address | | Reg | ister | | | | | | Comment | | | Address | D3 | D2 | D1 D0 Name Init *1 1 0 | | Comment | | | | | | | | FOUTE | | 50504 | 50500 | FOUTE | 0 | Enable | Disable | FOUT output enable | | | FFOCIA | FOUTE | 0 | FOFQ1 | FOFQ0 | 0 *3 | - *2 | | | Unused | | | FF06H | DAM | _ | _ | 0.47 | FOFQ1 | 0 | | | FOUT FOUT FOR FOR FOR FOR FOR FOUR FOR FOUR FOR FOUR FOR FOUR FOR FOUR FOR FOUR FOU | | | | R/W | R | H, | W | FOFQ0 | 0 | | | selection Frequency fosc1/64 fosc1/8 fosc1 fosc3 | | | | | | | R03HIZ | 0 | High-Z | Output | R03 output high impedance control (FOUTE=0) | | | | | R03HIZ | R02HIZ | R01HIZ | R00HIZ | | | | | FOUT output high impedance control (FOUTE=1) | | | ГГООЦ | | | | | R02HIZ | 0 | High-Z | Output | R02 output high impedance control (PTOUT=0) | | | FF30H | | | | | | | | | TOUT output high impedance control (PTOUT=1) | | | | R/W | | | | R01HIZ | 0 | High-Z | Output | R01 output high impedance control | | | | | | | R00HIZ | 0 | High-Z | Output | R00 output high impedance control | | | | | Doo | Doo | Dod | Doo | R03 | 1 | High | Low | R03 output port data (FOUTE=0) Fix at "1" when FOUT is used | | | FFO411 | R03 | R02 | R01 | R00 | R02 | 1 | High | Low | R02 output port data (PTOUT=0) Fix at "1" when TOUT is used | | | FF31H | | | | | R01 | 1 | High | Low | R01 output port data | | | | | H/ | W | | R00 | 1 | High | Low | R00 output port data | | | | OLIOFI | DTOUT | OKOEL 4 | 01/051.0 | CHSEL | 0 | Timer1 | Timer0 | TOUT output channel selection | | | FF0411 | CHSEL | PIOUI | UT CKSEL1 | CKSEL0 | PTOUT | 0 | On | Off | TOUT output control | | | FFC1H | | | 0.47 | | CKSEL1 | 0 | OSC3 | OSC1 | Prescaler 1 source clock selection | | | | | R/W | | CKSEL0 | 0 | OSC3 | OSC1 | Prescaler 0 source clock selection | | | <sup>\*1</sup> Initial value at initial reset #### R00HIZ-R03HIZ: R0 port high impedance control register (FF30H) Controls high impedance output of the output port. When "1" is written: High impedance When "0" is written: Data output Reading: Valid By writing "0" to the high impedance control register, the corresponding output terminal outputs according to the data register. When "1" is written, it shifts into high impedance status. When the output ports R02 and R03 are used for special output (TOUT, FOUT), fix the R02HIZ register and the R03HIZ register at "0" (data output). At initial reset, these registers are set to "0". #### R00-R03: R0 output port data register (FF31H) Set the output data for the output ports. When "1" is written: High level output When "0" is written: Low level output Reading: Valid The output port terminals output the data written in the corresponding data registers without changing it. When "1" is written to the register, the output port terminal goes high (VDD), and when "0" is written, the output port terminal goes low (VSS). When the output ports R02 and R03 are used for special output (TOUT, FOUT), fix the R02 register and the R03 register at "1". At initial reset, these registers are all set to "1". <sup>\*2</sup> Not set in the circuit <sup>\*3</sup> Constantly "0" when being read #### FOUTE: FOUT output control register (FF06H•D3) Controls the FOUT output. When "1" is written: FOUT output ON When "0" is written: FOUT output OFF Reading: Valid By writing "1" to the FOUTE register when the R03 register has been set to "1" and the R03HIZ register has been set to "0", an FOUT signal is output from the R03 terminal. When "0" is written, the R03 terminal goes high (VDD). When using the R03 output port for DC output, fix this register at "0". At initial reset, this register is set to "0". #### FOFQ0, FOFQ1: FOUT frequency selection register (FF06H•D0, D1) Selects a frequency of the FOUT signal. Table 4.5.5.2 FOUT clock frequency | FOFQ1 | FOFQ0 | Clock frequency | |-------|-------|-----------------| | 1 | 1 | fosc3 | | 1 | 0 | fosc1 | | 0 | 1 | fosc1 × 1/8 | | 0 | 0 | fosc1 × 1/64 | At initial reset, this register is set to "0". #### PTOUT: TOUT output control register (FFC1H•D2) Controls the TOUT output. When "1" is written: TOUT output ON When "0" is written: TOUT output OFF Reading: Valid By writing "1" to the PTOUT register when the R02 register has been set to "1" and the R02HIZ register has been set to "0", the TOUT signal is output from the R02 terminal. When "0" is written, the R02 terminal goes high (VDD). When using the R02 output port for DC output, fix this register at "0". At initial reset, this register is set to "0". # 4.5.6 Programming notes - (1) When using the output port (R02, R03) as the special output port, fix the data register (R02, R03) at "1" and the high impedance control register (R02HIZ, R03HIZ) at "0" (data output). Be aware that the output terminal is fixed at a low (Vss) level the same as the DC output if "0" is - Be aware that the output terminal is fixed at a low (Vss) level the same as the DC output if "0" is written to the R02 and R03 registers when the special output has been selected. - Be aware that the output terminal shifts into high impedance status when "1" is written to the high impedance control register (R02HIZ, R03HIZ). - (2) A hazard may occur when the FOUT signal and the TOUT signal are turned ON and OFF. - (3) When fOSC3 is selected for the FOUT signal frequency, it is necessary to control the OSC3 oscillation circuit before output. Refer to Section 4.3, "Oscillation Circuit", for the control and notes. # 4.6 I/O Ports (P00-P03 and P10-P13) # 4.6.1 Configuration of I/O ports The S1C63454 has eight bits of general-purpose I/O ports. Figure 4.6.1.1 shows the configuration of the I/O port. Fig. 4.6.1.1 Configuration of I/O port The I/O port terminals P10 to P13 are shared with the serial interface input/output terminals. The software can select the function to be used. When using the P10–P13 ports as the serial interface input/output terminals, the input specification of the serial input terminals P10 and P12 (slave mode) can be selected from either "normal input" or "with Schmitt trigger input" by mask option. At initial reset, these terminals are all set to the I/O port. Table 4.6.1.1 shows the setting of the input/output terminals by function selection. | | 0 0 1 | • | | |----------|-----------------------------|---------|---------| | Terminal | Terminal status | Seria | al I/F | | Terminai | at initial reset | Master | Slave | | P00-P03 | P00–P03 (Input & pull-up *) | P00-P03 | P00-P03 | | P10 | P10 (Input & pull-up *) | SIN(I) | SIN(I) | | P11 | P11 (Input & pull-up *) | SOUT(O) | SOUT(O) | | P12 | P12 (Input & pull-up *) | SCLK(O) | SCLK(I) | | P13 | P13 (Input & pull-up *) | P13 | SRDY(O) | Table 4.6.1.1 Function setting of input/output terminals When these ports are used as I/O ports, the ports can be set to either input mode or output mode individually (in 1-bit unit). Modes can be set by writing data to the I/O control registers. Refer to Section 4.11, "Serial Interface", for control of the serial interface. 36 EPSON \$1C63454 TECHNICAL MANUAL <sup>\*</sup> When "with pull-up resistor" is selected by the mask option (high impedance when "gate direct" is set) ## 4.6.2 Mask option In the I/O ports, the output specification during output mode can be selected from either complementary output or N-channel open drain output by mask option. When N-channel open drain output is selected, do not apply a voltage exceeding the power supply voltage to the port. When using the I/O port P10–P13 as the serial interface input/output terminals, the input specification for the terminals that are used for the serial interface input can be selected from either "normal input" or "with Schmitt trigger input". This option is applied to the serial interface input terminals, and is fixed at "normal input" when the terminals are used for the I/O port P10–P13. The mask option also permits selection of whether the pull-up resistor is used or not during input mode. They are selected in 4-bit units (P00–P03 and P10–P13). When "without pull-up" during the input mode is selected, take care that the floating status does not occur. The pull-up resistor for input mode and output specification (complementary output or N-channel open drain output) selected by mask option are effective even when I/O ports are used for input/output of the serial interface. # 4.6.3 I/O control registers and input/output mode Input or output mode can be set for the I/O ports by writing data into the corresponding I/O control registers IOCxx. To set the input mode, write "0" to the I/O control register. When an I/O port is set to input mode, it becomes high impedance status and works as an input port. However, when the pull-up explained in the following section has been set by software, the input line is pulled up only during this input mode. To set the output mode, write "1" is to the I/O control register. When an I/O port is set to output mode, it works as an output port, it outputs a high level (VDD) when the port output data is "1", and a low level (VSS) when the port output data is "0". If perform the read out in each mode; when output mode, the register value is read out, and when input mode, the port value is read out. At initial reset, the I/O control registers are set to "0", and the I/O ports enter the input mode. The I/O control registers of the ports that are set as input/output for the serial interface can be used as general purpose registers that do not affect the I/O control. (See Table 4.6.1.1.) ## 4.6.4 Pull-up during input mode A pull-up resistor that operates during the input mode is built into each I/O port of the S1C63454. Mask option can set the use or non-use of this pull-up. The pull-up resistor becomes effective by writing "1" to the pull-up control register PULxx that corresponds to each port, and the input line is pulled up during the input mode. When "0" has been written, no pull-up is done. At initial reset, the pull-up control registers are set to "1". The pull-up control registers of the ports in which "without pull-up" have been selected can be used as general purpose registers. Even when "with pull-up" has been selected, the pull-up control registers of the ports, that are set as output for the serial interface, can be used as general purpose registers that do not affect the pull-up control. (See Table 4.6.1.1.) The pull-up control registers of the port, that are set as input for the serial interface, function the same as the I/O port. S1C63454 TECHNICAL MANUAL EPSON 37 # 4.6.5 I/O memory of I/O ports Table 4.6.5.1 shows the I/O addresses and the control bits for the I/O ports. Table 4.6.5.1 Control bits of I/O ports | | Register | | | | | | | | | | |---------|-------------|--------|-----------|----------|---------|---------|---------|-----------------------------------|------------------------------------------------------------------------------------------------------------|--| | Address | D3 | D2 | D1 | D0 | Name | Init *1 | 1 | 1 0 Comment | | | | | | | | | IOC03 | 0 | Output | Input | ٦ | | | | IOC03 IOC02 | | IOC01 | IOC00 | IOC02 | 0 | Output | Input | | | | FF40H | | | | | IOC01 | 0 | Output | Input | P00–P03 I/O control register | | | | | R/ | W | | | Input | | | | | | | | | D. II o / | D. II 00 | PUL03 | 1 | On | Off | 7 | | | FE 4411 | PUL03 | PUL02 | PUL01 | PUL00 | PUL02 | 1 | On | Off | POO POS multima acceptant manistra | | | FF41H | | | 0.4.1 | | PUL01 | 1 | On | Off | P00–P03 pull-up control register | | | | | H/ | W | | PUL00 | 1 | On | Off | | | | | P03 | P02 | P01 | P00 | P03 | _ *2 | High | Low | | | | FF42H | P03 | P02 | PUI | P00 | P02 | _ *2 | High | Low | P00–P03 I/O port data | | | 114211 | | R | W | | P01 | - *2 | High | Low | 100-103 FO port data | | | | | 11/ | ** | | P00 | _ *2 | High | Low | | | | | | | | | IOC13 | 0 | Output | Input | P13 I/O control register | | | | IOC13 | IOC12 | IOC11 | IOC10 | | | | | functions as a general-purpose register when SIF (slave) is selected | | | | .00.0 | .00.2 | | | IOC12 | 0 | Output | Input | P12 I/O control register (ESIF=0) | | | FF44H | | | | | | _ | | l | functions as a general-purpose register when SIF is selected | | | | | | | IOC11 | 0 | Output | Input | P11 I/O control register (ESIF=0) | | | | | | R/ | w | | | | | ١ | functions as a general-purpose register when SIF is selected | | | | | | | | IOC10 | 0 | Output | Input | P10 I/O control register (ESIF=0) | | | | | | | | DIII 10 | 1 | 05 | 0" | functions as a general-purpose register when SIF is selected | | | | | | | | PUL13 | 1 | On | Off | P13 pull-up control register | | | | PUL13 | PUL12 | PUL11 | PUL10 | PUL12 | 1 | On | Off | functions as a general-purpose register when SIF (slave) is selected P12 pull-up control register (ESIF=0) | | | | . 02.0 | . 02.2 | | . 02.0 | FULIZ | ' | Oii | Oii | functions as a general-purpose register when SIF (master) is selected | | | FF45H | | | | | | | | | SCLK (I) pull-up control register when SIF (slave) is selected | | | 114511 | | | | | PUL11 | 1 | On | Off | P11 pull-up control register (ESIF=0) | | | | | _ | | | . 52 | • | 0 | 0 | functions as a general-purpose register when SIF is selected | | | | | H/ | W | | PUL10 | 1 | On | Off | P10 pull-up control register (ESIF=0) | | | | | | | | | | | | SIN pull-up control register when SIF is selected | | | | | | | | P13 | _ *2 | High | Low | P13 I/O port data | | | | | | | | | | | | functions as a general-purpose register when SIF (slave) is selected | | | | P13 | P12 | P11 | P10 | P12 | - *2 | High | Low | P12 I/O port data (ESIF=0) | | | == | | | | | | | | | functions as a general-purpose register when SIF is selected | | | FF46H | ' | | | • | P11 | _ *2 | High | Low | P11 I/O port data (ESIF=0) | | | | | | 0.4.4 | | | | | | functions as a general-purpose register when SIF is selected | | | | | H/ | W | | P10 | _ *2 | High | Low | P10 I/O port data (ESIF=0) | | | | | | | | | | | | functions as a general-purpose register when SIF is selected | | | | | | | | 0 *3 | - *2 | | | Unused | | | | 0 | 0 | SCTRG | ESIF | 0 *3 | _ *2 | | | Unused | | | FF70H | | | | | SCTRG | 0 | Trigger | Invalid | Serial I/F clock trigger (writing) | | | | F | 3 | R/ | W | | | Run | Stop | Serial I/F clock status (reading) | | | | | | | | ESIF | 0 | SIF | I/O | Serial I/F enable (P1 port function selection) | | <sup>\*1</sup> Initial value at initial reset <sup>\*2</sup> Not set in the circuit <sup>\*3</sup> Constantly "0" when being read #### (1) Selection of port function ## ESIF: Serial interface enable register (FF70H•D0) Selects function for P10-P13. When "1" is written: Serial interface input/output port When "0" is written: I/O port Reading: Valid When using the serial interface, write "1" to this register and when P10–P13 are used as the I/O port, write "0". The configuration of the terminals within P10–P13 that are used for the serial interface is decided by the mode selected with the SCS1 and SCS0 registers (see Section 4.11). In the slave mode, all the P10–P13 ports are set to the serial interface input/output port. In the master mode, P10–P12 are set to the serial interface input/output port and P13 can be used as the I/O port. At initial reset, this register is set to "0". ## (2) I/O port control P00-P03: P0 I/O port data register (FF42H) P10-P13: P1 I/O port data register (FF46H) I/O port data can be read and output data can be set through these registers. #### • When writing data When "1" is written: High level When "0" is written: Low level When an I/O port is set to the output mode, the written data is output unchanged from the I/O port terminal. When "1" is written as the port data, the port terminal goes high (VDD), and when "0" is written, the terminal goes low (VSS). Port data can be written also in the input mode. #### • When reading data When "1" is read: High level When "0" is read: Low level The terminal voltage level of the I/O port is read out. When the I/O port is in the input mode the voltage level being input to the port terminal can be read out; in the output mode the register value can be read. When the terminal voltage is high (VDD) the port data that can be read is "1", and when the terminal voltage is low (VSS) the data is "0". When "with pull-up resistor" has been selected with the mask option and the PUL register is set to "1", the built-in pull-up resister goes ON during input mode, so that the I/O port terminal is pulled up. The data registers of the port, which are set for the input/output of the serial interface (P10–P12 or P10–P13), become general-purpose registers that do not affect the input/output. Note: When in the input mode, I/O ports are changed from low to high by pull-up resistor, the rise of the waveform is delayed on account of the time constant of the pull-up resistor and input gate capacitance. Hence, when fetching input ports, set an appropriate wait time. Particular care needs to be taken of the key scan during key matrix configuration. Make this waiting time the amount of time or more calculated by the following expression. $10 \times C \times R$ C: terminal capacitance 5 pF + parasitic capacitance ? pF R: pull-up resistance 330 k $\Omega$ #### CHAPTER 4: PERIPHERAL CIRCUITS AND OPERATION (I/O Ports) # IOC00-IOC03: P0 port I/O control register (FF40H) IOC10-IOC13: P1 port I/O control register (FF44H) The input and output modes of the I/O ports are set with these registers. When "1" is written: Output mode When "0" is written: Input mode Reading: Valid The input and output modes of the I/O ports are set in 1-bit unit. Writing "1" to the I/O control register makes the corresponding I/O port enter the output mode, and writing "0" induces the input mode. At initial reset, these registers are all set to "0", so the I/O ports are in the input mode. The I/O control registers of the port, which are set for the input/output of the serial interface (P10–P12 or P10–P13), become general-purpose registers that do not affect the input/output. # PUL00-PUL03: P0 port pull-up control register (FF41H) PUL10-PUL13: P1 port pull-up control register (FF45H) The pull-up during the input mode are set with these registers. When "1" is written: Pull-up ON When "0" is written: Pull-up OFF Reading: Valid The built-in pull-up resistor which is turned ON during input mode is set to enable in 1-bit units. (The pull-up resistor is included into the ports selected by the mask option.) By writing "1" to the pull-up control register, the corresponding I/O ports are pulled up (during input mode), while writing "0" turns the pull-up function OFF. At initial reset, these registers are all set to "1", so the pull-up function is set to ON. The pull-up control registers of the ports in which the pull-up resistor is not included become the general purpose register. The registers of the ports that are set as output for the serial interface can also be used as general purpose registers that do not affect the pull-up control. The pull-up control registers of the port that are set as input for the serial interface function the same as the I/O port. # 4.6.6 Programming note When in the input mode, I/O ports are changed from low to high by pull-up resistor, the rise of the waveform is delayed on account of the time constant of the pull-up resistor and input gate capacitance. Hence, when fetching input ports, set an appropriate wait time. Particular care needs to be taken of the key scan during key matrix configuration. Make this waiting time the amount of time or more calculated by the following expression. $10 \times C \times R$ 40 C: terminal capacitance 5 pF + parasitic capacitance ? pF R: pull-up resistance 330 k $\Omega$ # 4.7 LCD Driver (COM0-COM16, SEG0-SEG39) # 4.7.1 Configuration of LCD driver The S1C63454 has 17 common terminals (COM0–COM16) and 40 segment terminals (SEG0–SEG39), so that it can drive a dot matrix type LCD with a maximum of $680 (40 \times 17)$ dots. The driving method is 1/17 duty, 1/16 duty or 1/8 duty dynamic drive with four voltages (1/4 bias), VC1, VC2, VC4 and VC5 (1/5 bias driving can be set by impressing five voltages from outside). LCD display ON/OFF can be controlled by the software. # 4.7.2 Power supply for LCD driving VC1–VC5 are driving voltages for the LCD, and for which either the voltages generated by the LCD system voltage circuit or voltages to be supplied from outside can be used. The built-in LCD system voltage circuit generates four voltages (1/4 bias) VC1, VC2, VC4 and VC5 except for VC3. These four output voltages can be supplied to the outside only for driving the externally expanded LCD driver. When external voltages are supplied, 1/5 bias driving can be made by inputting five voltages to the VC1–VC5 terminals (including VC3). Either the internal generated voltages or external voltages used for the LCD drive voltage can be selected by the mask option. Turning the LCD system voltage circuit ON or OFF is controlled with the LPWR register. This control is also necessary when supplying the voltage from outside. When LPWR is set to "1", the LCD system voltage circuit outputs the LCD drive voltages VC1–VC5 to the LCD driver. When "internal voltage" is selected by the mask option, the LCD system voltage circuit generates VC1 or VC2 with the voltage regulator incorporated in itself, and generates three other voltages by boosting or reducing the voltage VC1 or VC2. Table 4.7.2.1 shows the VC1, VC2, VC4 and VC5 voltage values and boost/reduce status. | LCD drive voltage | VDD = 1.8-6.4 V | VDD = 2.6-6.4 V | |-------------------|-----------------|---------------------| | Vc1 (0.975-1.2 V) | Vc1 (standard) | 1/2 × Vc2 | | Vc2 (1.950-2.4 V) | 2 × Vc1 | Vc2 (standard) | | Vc4 (2.925-3.6 V) | 3 × Vc1 | $3/2 \times V_{C2}$ | | Vc5 (3.900-4.8 V) | 4 × Vc1 | $2 \times V_{C2}$ | Table 4.7.2.1 LCD drive voltage when generated internally Note: The LCD drive voltage can be adjusted by the software (see Section 4.7.6). Values in the table are typical values. Select either VC1 standard or VC2 standard using the VCCHG register. When "1" is written to the VCCHG register, VC2 standard is selected and when "0" is written, VC1 standard is selected. At initial reset, VC1 standard (VCCHG = "0") is set. S1C63454 TECHNICAL MANUAL EPSON 41 ## 4.7.3 Mask option Disconnecting the internal power supply for LCD driving will enable voltages to be supplied externally. In such case, the five voltages are entered in VC1, VC2, VC3, VC4 and VC5 terminals and 1/5 bias driving may then be set. Since 1/5 bias driving provides better display quality, when low power current consumption is not required (i.e., when power is supplied from AC outlet), select external power mode. However, note that in order to maintain a stable display, power source must be one which will remain stable even when heavy load such as buzzer, etc. is driven. Moreover, in the external power mode, the contrast adjustment function cannot be used. Accommodate this limitation by utilizing the external circuit as necessary. A sample circuit of external power for LCD driving when power is supplied externally is shown in Figure 4.7.3.1. Fig. 4.7.3.1 Sample circuit of external power for LCD driving when power is supplied externally # 4.7.4 LCD display control (ON/OFF) and switching of duty #### (1) Display ON/OFF control The S1C63454 incorporates the ALON and ALOFF registers to blink display. When "1" is written to ALON, all the dots go ON, and when "1" is written to ALOFF, all the dots go OFF. At such a time, an ON waveform or an OFF waveform is output from SEG terminals. When "0" is written to these registers, normal display is performed. Furthermore, when "1" is written to both of the ALON and ALOFF, ALON (all ON) has priority over the ALOFF (all OFF). #### (2) Switching of drive duty In the S1C63454, the drive duty can be set to 1/17, 1/16 or 1/8 by the software. This setting is done using the LDUTY1 and LDUTY0 registers as shown in Table 4.7.4.1. | LDUTY1 | LDUTY0 | Drive duty | Common terminal used | Maximum segment number | |--------|--------|------------|----------------------|------------------------| | 1 | * | 1/8 | COM0-COM7 | 320 (40 × 8) | | 0 | 1 | 1/16 | COM0-COM15 | 640 (40 × 16) | 1/17 Table 4.7.4.1 LCD drive duty setting Table 4.7.4.2 shows the frame frequencies corresponding to the OSC1 oscillation frequency and drive duty. COM0-COM16 $680 (40 \times 17)$ Table 4.7.4.2 Frame frequency | OSC1 oscillation frequency | When 1/8 duty is selected | When 1/16 duty is selected | When 1/17 duty is selected | |----------------------------|---------------------------|----------------------------|----------------------------| | 32.768 kHz | 32 Hz | 32 Hz | 30.12 Hz | | 60 kHz | 58.6 Hz | 58.6 Hz | 55.2 Hz | Figures 4.7.4.1 and 4.7.4.2 show the dynamic drive waveform for 1/4 bias and 1/5 bias. Fig. 4.7.4.2 Drive waveform for 1/5 bias # 4.7.5 Display memory The display memory is allocated to F000H–F24EH in the data memory area and the addresses and the data bits correspond to COM and SEG outputs as shown in Figure 4.7.5.1. Fig. 4.7.5.1 Correspondence between display memory and LCD dot matrix #### CHAPTER 4: PERIPHERAL CIRCUITS AND OPERATION (LCD Driver) When a bit in the display memory is set to "1", the corresponding LCD dot goes ON, and when it is set to "0", the dot goes OFF. At 1/17 (1/16) duty drive, all data of COM0–COM16 (15) is output. At 1/8 duty drive, data only corresponding to COM0–COM7 is output. However, since the display memory has capacity for two screens, it is designed so that the memory for COM8–COM15 shown in Figure 4.7.5.1 (b) can also be used as COM0–COM7. Select either F000H–F04FH or F100H–F14FH for the area to be displayed (to be output from COM0–COM7 terminals) using the LPAGE register. It can switch the screen in an instant. At initial reset, the data memory content becomes undefined hence, there is need to initialize using the software. The display memory has read/write capability, and the addresses that have not been used for LCD display can be used as general purpose registers. Note: When a program that access no memory mounted area (F050H–F0FFH, F150H–F1FFH, F201H, F203H, · · · , F24FH) is made, the operation is not guaranteed. # 4.7.6 LCD contrast adjustment In the S1C63454, the LCD contrast can be adjusted by the software. It is realized by controlling the voltages VC1, VC2, VC4 and VC5 output from the LCD system voltage circuit. When these voltages are supplied to the externally expanded LCD driver, the expanded LCD contrast is adjusted at the same time. However, when the LCD drive voltage is supplied from outside by the mask option selection, this adjustment becomes invalid. The contrast can be adjusted to 16 levels as shown in Table 4.7.6.1. When VCCHG = "0", VC1 is changed within the range from 0.975 V to 1.2 V, and other voltages change according to VC1. When VCCHG = "1", VC2 is changed within the range from 1.950 V to 2.4 V, and other voltages change according to VC2. | No. | LC3 | LC2 | LC1 | LC0 | Contrast | |-----|-----|-----|-----|-----|----------| | 0 | 0 | 0 | 0 | 0 | light | | 1 | 0 | 0 | 0 | 1 | <b>↑</b> | | 2 | 0 | 0 | 1 | 0 | ' | | 3 | 0 | 0 | 1 | 1 | | | 4 | 0 | 1 | 0 | 0 | | | 5 | 0 | 1 | 0 | 1 | | | 6 | 0 | 1 | 1 | 0 | | | 7 | 0 | 1 | 1 | 1 | | | 8 | 1 | 0 | 0 | 0 | | | 9 | 1 | 0 | 0 | 1 | | | 10 | 1 | 0 | 1 | 0 | | | 11 | 1 | 0 | 1 | 1 | | | 12 | 1 | 1 | 0 | 0 | | | 13 | 1 | 1 | 0 | 1 | | | 14 | 1 | 1 | 1 | 0 | | | 15 | 1 | 1 | 1 | 1 | dark | Table 4.7.6.1 LCD contrast At room temperature, use setting number 7 or 8 as standard. Since the contents of LC0–LC3 are undefined at initial reset, initialize it by the software. # 4.7.7 I/O memory of LCD driver Table 4.7.7.1 shows the I/O addresses and the control bits for the LCD driver. Figure 4.7.7.1 shows the display memory map. | Table 4.7.7.1 ECD arriver control ous | | | | | | | | | | | |---------------------------------------|----------|--------|-------|--------|--------|---------|--------------------|--------------------------------------------------------------------------|-----------------------------------------------------------|--| | Address | Register | | | | | | | | Comment | | | | D3 | D2 | D1 | D0 | Name | Init *1 | 1 | 0 | Comment | | | FF60H | LDUTY1 | LDUTY0 | VCCHG | I DW/D | LDUTY1 | 0 | | | LCD drive duty [LDUTY1, 0] 0 1 2, 3 | | | | | | | | LDUTY0 | 0 | | | switch Duty 1/17 1/16 1/8 | | | | DAY | | | | VCCHG | 0 | Vc2 | Vc1 | LCD regulated voltage switch | | | | R/W | | | LPWR | 0 | On | Off | LCD power On/Off | | | | FF61H | EXLCDC | ALOFF | ALON | LPAGE | EXLCDC | 0 | | | General-purpose register | | | | | | | | ALOFF | 1 | All Off | Normal | LCD all OFF control | | | | | | ALON | 0 | All On | Normal | LCD all ON control | | | | | | R/W | | | | LPAGE | 0 | F100-F14F | F000-F04F | Display memory area selection (when 1/8 duty is selected) | | | | 10** | | | | | | | functions as a general-purpose register when 1/16, 1/17 duty is selected | | | | FF62H | 1.00 | 1.00 | 1.04 | 1.00 | LC3 | _ *2 | | | ☐ LCD contrast adjustment | | | | LC3 | LC2 | LC1 | LC0 | LC2 | - *2 | | | [LC3-0] 0 - 15 | | | | R/W | | | LC1 | _ *2 | | | Contrast Light – Dark | | | | | | | | LC0 | _ *2 | | | | | | Table 4.7.7.1 LCD driver control bits - \*1 Initial value at initial reset - \*2 Not set in the circuit - \*3 Constantly "0" when being read Fig. 4.7.7.1 Display memory map #### LPWR: LCD power control (ON/OFF) register (FF60H•D0) Turns the LCD system voltage circuit ON and OFF. When "1" is written: ON When "0" is written: OFF Reading: Valid When "1" is written to the LPWR register, the LCD system voltage circuit goes ON and generates the LCD drive voltage. When "0" is written, all the LCD drive voltages go to Vss level. It takes about 100 msec for the LCD drive voltage to stabilize after starting up the LCD system voltage circuit by writing "1" to the LPWR register. At initial reset, this register is set to "0". #### **CHAPTER 4: PERIPHERAL CIRCUITS AND OPERATION (LCD Driver)** #### VCCHG: LCD regulated voltage switching register (FF60H•D1) Selects the reference voltage for the LCD drive voltage. When "1" is written: VC2 When "0" is written: VC1 Reading: Valid When "1" is written to the VCCHG register, the LCD system voltage circuit generates the LCD drive voltage as VC2 standard. When "0" is written, it becomes VC1 standard. Select VC2 when power supply voltage is 2.6 V or more, otherwise, select VC1. When external power mode is selected by the mask option, this control is unnecessary. At initial reset, this register is set to "0". ## LDUTY0, LDUTY1: LCD drive duty switching register (FF60H•D2, D3) Selects the LCD drive duty. Table 4.7.7.2 Drive duty setting | LDUTY1 | LDUTY0 | Drive duty | Common terminal used | Maximum segment number | |--------|--------|------------|----------------------|------------------------| | 1 | * | 1/8 | COM0-COM7 | 320 (40 × 8) | | 0 | 1 | 1/16 | COM0-COM15 | 640 (40 × 16) | | 0 | 0 | 1/17 | COM0-COM16 | 680 (40 × 17) | At initial reset, this register is set to "0". #### ALON: LCD all ON control register (FF61H•D1) Displays the all LCD dots ON. When "1" is written: All LCD dots displayed When "0" is written: Normal display Reading: Valid By writing "1" to the ALON register, all the LCD dots goes ON, and when "0" is written, it returns to normal display. This function outputs an ON waveform to the SEG terminals, and does not affect the content of the display memory. ALON has priority over ALOFF. At initial reset, this register is set to "0". #### ALOFF: LCD all OFF control register (FF61H•D2) Fade outs the all LCD dots. When "1" is written: All LCD dots fade out When "0" is written: Normal display Reading: Valid By writing "1" to the ALOFF register, all the LCD dots goes OFF, and when "0" is written, it returns to normal display. This function outputs an OFF waveform to the SEG terminals, and does not affect the content of the display memory. At initial reset, this register is set to "1". #### LPAGE: LCD display memory selection register (FF61H•D0) Selects the display memory area at 1/8 duty drive. When "1" is written: F100H–F14FH When "0" is written: F000H–F04FH Reading: Valid By writing "1" to the LPAGE register, the data set in F100H–F14FH (the second half of the display memory) is displayed, and when "0" is written, the data set in F000H–F04FH (the first half of the display memory) is displayed. This function is valid only when 1/8 duty is selected, and when 1/16 or 1/17 duty is selected, this register can be used as a general purpose register. At initial reset, this register is set to "0". #### LC3-LC0: LCD contrast adjustment register (FF62H) Adjusts the LCD contrast. ``` LC3-LC0 = 0000B light : : LC3-LC0 = 1111B dark ``` At room temperature, use setting number 7 or 8 as standard. When the LCD drive voltage is supplied from outside by the mask option selection, this adjustment becomes invalid. At initial reset, LC0-LC3 are undefined. # 4.7.8 Programming notes - (1) When a program that access no memory mounted area (F050H–F0FFH, F150H–F1FFH, F201H, F203H, ..., F24FH) is made, the operation is not guaranteed. - (2) Because at initial reset, the contents of display memory and LC3–LC0 (LCD contrast) are undefined, there is need to initialize by the software. Furthermore, take care of the registers LPWR and ALOFF because these are set so that the display goes OFF. # 4.8 Clock Timer # 4.8.1 Configuration of clock timer The S1C63454 has a built-in clock timer that uses OSC1 (crystal oscillator) as the source oscillator. The clock timer is configured of an 8-bit binary counter that serves as the input clock, fOSC1 divided clock output from the prescaler. Timer data (128–16 Hz and 8–1 Hz) can be read out by the software. Figure 4.8.1.1 is the block diagram for the clock timer. Fig. 4.8.1.1 Block diagram for the clock timer Ordinarily, this clock timer is used for all types of timing functions such as clocks. Note: When the CR oscillation circuit is selected as the OSC1 oscillation circuit by mask option, the frequencies and times differ from the values described in this section because the oscillation frequency will be 60 kHz (Typ.). Therefore, the clock timer can not be used for the clock function. ## 4.8.2 Data reading and hold function The 8 bits timer data are allocated to the address FF79H and FF7AH. | <ff79h></ff79h> | D0: $TM0 = 128 Hz$ | D1: $TM1 = 64 Hz$ | D2: $TM2 = 32 Hz$ | D3: $TM3 = 16 Hz$ | |-----------------|--------------------|-------------------|-------------------|-------------------| | <ff7ah></ff7ah> | D0: $TM4 = 8 Hz$ | D1: $TM5 = 4 Hz$ | D2: $TM6 = 2 Hz$ | D3: TM7 = 1 Hz | Since the clock timer data has been allocated to two addresses, a carry is generated from the low-order data within the count (TM0–TM3: 128–16 Hz) to the high-order data (TM4–TM7: 8–1 Hz). When this carry is generated between the reading of the low-order data and the high-order data, a content combining the two does not become the correct value (the low-order data is read as FFH and the high-order data becomes the value that is counted up 1 from that point). The high-order data hold function in the S1C63454 is designed to operate to avoid this. This function temporarily stops the counting up of the high-order data (by carry from the low-order data) at the point where the low-order data has been read and consequently the time during which the high-order data is held is the shorter of the two indicated here following. - 1. Period until it reads the high-order data. - 2. 0.48–1.5 msec (Varies due to the read timing.) Note: Since the low-order data is not held when the high-order data has previously been read, the low-order data should be read first. 50 EPSON S1C63454 TECHNICAL MANUAL # 4.8.3 Interrupt function The clock timer can cause interrupts at the falling edge of 32 Hz, 8 Hz, 2 Hz and 1 Hz signals. Software can set whether to mask any of these frequencies. Figure 4.8.3.1 is the timing chart of the clock timer. Fig. 4.8.3.1 Timing chart of clock timer As shown in Figure 4.8.3.1, interrupt is generated at the falling edge of the frequencies (32 Hz, 8 Hz, 2 Hz, 1 Hz). At this time, the corresponding interrupt factor flag (IT0, IT1, IT2, IT3) is set to "1". Selection of whether to mask the separate interrupts can be made with the interrupt mask registers (EIT0, EIT1, EIT2, EIT3). However, regardless of the interrupt mask register setting, the interrupt factor flag is set to "1" at the falling edge of the corresponding signal. # 4.8.4 I/O memory of clock timer Table 4.8.4.1 shows the I/O addresses and the control bits for the clock timer. Table 4.8.4.1 Control bits of clock timer | Table Herrit Comment with by electronics | | | | | | | | | | |------------------------------------------|----------|------|-------|-------|---------|---------|---------|-------------------------------------------|---------------------------------------------| | Address | Register | | | | | | | | Comment | | | D3 | D2 | D1 | D0 | Name | Init *1 | 1 | 0 | Confinent | | | 0 | • | TMRST | TMRUN | 0 *3 | _ *2 | | | Unused | | FEZOLI | | 0 | | | 0 *3 | _ *2 | | | Unused | | FF78H | R | | W | R/W | TMRST*3 | Reset | Reset | Invalid | Clock timer reset (writing) | | | | | | | TMRUN | 0 | Run | Stop | Clock timer Run/Stop | | | TM3 | TM2 | TM1 | TM0 | TM3 | 0 | | | Clock timer data (16 Hz) | | FF79H | | | | | TM2 | 0 | | | Clock timer data (32 Hz) | | FF/9H | | | | | TM1 | 0 | | | Clock timer data (64 Hz) | | | R | | | | TM0 | 0 | | | Clock timer data (128 Hz) | | | TM7 | TM6 | TM5 | TM4 | TM7 | 0 | | | Clock timer data (1 Hz) | | FFZALL | | | | | TM6 | 0 | | | Clock timer data (2 Hz) | | FF7AH | | | | | TM5 | 0 | | | Clock timer data (4 Hz) | | | R | | | | TM4 | 0 | | | Clock timer data (8 Hz) | | | EIT3 | FITO | CIT4 | EIT0 | EIT3 | 0 | Enable | Mask | Interrupt mask register (Clock timer 1 Hz) | | FFFCII | | EIT2 | EIT1 | | EIT2 | 0 | Enable | Mask | Interrupt mask register (Clock timer 2 Hz) | | FFE6H | | - | 0.47 | | EIT1 | 0 | Enable | Mask | Interrupt mask register (Clock timer 8 Hz) | | | R/W | | | | EIT0 | 0 | Enable | Mask | Interrupt mask register (Clock timer 32 Hz) | | FFF6H | IT3 | ITO | IT1 | IT0 | IT3 | 0 | (R) | (R) | Interrupt factor flag (Clock timer 1 Hz) | | | | IT2 | | | IT2 | 0 | Yes | No | Interrupt factor flag (Clock timer 2 Hz) | | | R/W | | | IT1 | 0 | (W) | (W) | Interrupt factor flag (Clock timer 8 Hz) | | | | | | | IT0 | 0 | Reset | Invalid | Interrupt factor flag (Clock timer 32 Hz) | | <sup>\*1</sup> Initial value at initial reset #### TM0-TM7: Timer data (FF79H, FF7AH) The 128–1 Hz timer data of the clock timer can be read out with these registers. These eight bits are read only, and writing operations are invalid. By reading the low-order data (FF79H), the high-order data (FF7AH) is held until reading or for 0.48–1.5 msec (one of shorter of them). At initial reset, the timer data is initialized to "00H". #### TMRST: Clock timer reset (FF78H•D1) This bit resets the clock timer. When "1" is written: Clock timer reset When "0" is written: No operation Reading: Always "0" The clock timer is reset by writing "1" to TMRST. When the clock timer is reset in the RUN status, operation restarts immediately. Also, in the STOP status the reset data is maintained. No operation results when "0" is written to TMRST. This bit is write-only, and so is always "0" at reading. <sup>\*2</sup> Not set in the circuit <sup>\*3</sup> Constantly "0" when being read #### TMRUN: Clock timer RUN/STOP control register (FF78H•D0) Controls RUN/STOP of the clock timer. When "1" is written: RUN When "0" is written: STOP Reading: Valid The clock timer enters the RUN status when "1" is written to the TMRUN register, and the STOP status when "0" is written. In the STOP status, the timer data is maintained until the next RUN status or the timer is reset. Also, when the STOP status changes to the RUN status, the data that is maintained can be used for resuming the count. At initial reset, this register is set to "0". EIT0: 32 Hz interrupt mask register (FFE6H•D0) EIT1: 8 Hz interrupt mask register (FFE6H•D1) EIT2: 2 Hz interrupt mask register (FFE6H•D2) EIT3: 1 Hz interrupt mask register (FFE6H•D3) These registers are used to select whether to mask the clock timer interrupt. When "1" is written: Enabled When "0" is written: Masked Reading: Valid The interrupt mask registers (EIT0, EIT1, EIT2, EIT3) are used to select whether to mask the interrupt to the separate frequencies (32 Hz, 8 Hz, 2 Hz, 1 Hz). At initial reset, these registers are set to "0". IT0: 32 Hz interrupt factor flag (FFF6H•D0) IT1: 8 Hz interrupt factor flag (FFF6H•D1) IT2: 2 Hz interrupt factor flag (FFF6H•D2) IT3: 1 Hz interrupt factor flag (FFF6H•D3) These flags indicate the status of the clock timer interrupt. When "1" is read: Interrupt has occurred When "0" is read: Interrupt has not occurred When "1" is written: Flag is reset When "0" is written: Invalid The interrupt factor flags (IT0, IT1, IT2, IT3) correspond to the clock timer interrupts of the respective frequencies (32 Hz, 8 Hz, 2 Hz, 1 Hz). The software can judge from these flags whether there is a clock timer interrupt. However, even if the interrupt is masked, the flags are set to "1" at the falling edge of the signal. These flags are reset to "0" by writing "1" to them. After an interrupt occurs, the same interrupt will occur again if the interrupt enabled state (I flag = "1") is set or the RETI instruction is executed unless the interrupt factor flag is reset. Therefore, be sure to reset (write "1" to) the interrupt factor flag in the interrupt service routine before shifting to the interrupt enabled state. At initial reset, these flags are set to "0". #### **CHAPTER 4: PERIPHERAL CIRCUITS AND OPERATION (Clock Timer)** # 4.8.5 Programming notes - (1) Be sure to read timer data in the order of low-order data (TM0–TM3) then high-order data (TM4–TM7). - (2) After an interrupt occurs, the same interrupt will occur again if the interrupt enabled state (I flag = "1") is set or the RETI instruction is executed unless the interrupt factor flag is reset. Therefore, be sure to reset (write "1" to) the interrupt factor flag in the interrupt service routine before shifting to the interrupt enabled state. - (3) When the CR oscillation circuit is selected as the OSC1 oscillation circuit by mask option, the frequencies and times differ from the values described in this section because the oscillation frequency will be 60 kHz (Typ.). Therefore, the clock timer can not be used for the clock function. # 4.9 Stopwatch Timer # 4.9.1 Configuration of stopwatch timer The S1C63454 has 1/100 sec unit and 1/10 sec unit stopwatch timer built-in. The stopwatch timer is configured with a 2 levels 4-bit BCD counter which has an input clock approximating 100 Hz signal (signal divided from OSC1 to the closest 100 Hz) and data can be read in units of 4 bits by software. Figure 4.9.1.1 shows the configuration of the stopwatch timer. Fig. 4.9.1.1 Configuration of stopwatch timer The stopwatch timer can be used as a separate timer from the clock timer. In particular, digital watch stopwatch functions can be realized easily with software. Note: When the CR oscillation circuit is selected as the OSC1 oscillation circuit by mask option, the frequencies and times differ from the values described in this section because the oscillation frequency will be 60 kHz (Typ.). Therefore, this timer can not be used for the stopwatch function. # 4.9.2 Count-up pattern The stopwatch timer is configured of 4-bit BCD counters SWD0–SWD3 and SWD4–SWD7. The counter SWD0–SWD3, at the stage preceding the stopwatch timer, has an approximated 100 Hz signal for the input clock. It counts up every 1/100 sec, and generates an approximated 10 Hz signal. The counter SWD4–SWD7 has an approximated 10 Hz signal generated by the counter SWD0–SWD3 for the input clock. In count-up every 1/10 sec, and generated 1 Hz signal. Figure 4.9.2.1 shows the count-up pattern of the stopwatch timer. Fig. 4.9.2.1 Count-up pattern of stopwatch timer #### CHAPTER 4: PERIPHERAL CIRCUITS AND OPERATION (Stopwatch Timer) SWD0–SWD3 generates an approximated 10 Hz signal from the basic 256 Hz signal (fosc1 dividing clock). The count-up intervals are 2/256 sec and 3/256 sec, so that finally two patterns are generated: 25/256 sec and 26/256 sec intervals. Consequently, these patterns do not amount to an accurate 1/100 sec. SWD4–SWD7 counts the approximated 10 Hz signals generated by the 25/256 sec and 26/256 sec intervals in the ratio of 4:6, to generate a 1 Hz signal. The count-up intervals are 25/256 sec and 26/256 sec, which do not amount to an accurate 1/10 sec. # 4.9.3 Interrupt function The stopwatch timers SWD0–SWD3 and SWD4–SWD7, through their respective overflows, can generate 10 Hz (approximate 10 Hz) and 1 Hz interrupts. Figure 4.9.3.1 shows the timing chart for the stopwatch timer. Fig. 4.9.3.1 Timing chart for stopwatch timer The stopwatch interrupts are generated by the overflow of their respective counters SWD0–SWD3 and SWD4–SWD7 (changing "9" to "0"). At this time, the corresponding interrupt factor flags (ISW10 and ISW1) are set to "1". The respective interrupts can be masked separately using the interrupt mask registers (EISW10 and EISW1). However, regardless of the setting of the interrupt mask registers, the interrupt factor flags are set to "1" by the overflow of their corresponding counters. Interrupt mask register (Stopwatch timer 10 Hz) Interrupt factor flag (Stopwatch timer 1 Hz) Interrupt factor flag (Stopwatch timer 10 Hz) # 4.9.4 I/O memory of stopwatch timer Table 4.9.4.1 shows the I/O addresses and the control bits for the stopwatch timer. Register Address Comment D3 D1 Name Init \*1 D2 D0 0 0 \*3 \_ \*2 Unused 0 **SWRST** SWRUN 0 \*3 \_ \*2 Unused FF7CH SWRST\*3 Reset Reset Invalid Stopwatch timer reset (writing) R R/W SWRUN 0 Run Stop Stopwatch timer Run/Stop SWD3 0 SWD3 SWD2 SWD1 SWD0 SWD2 0 Stopwatch timer data FF7DH SWD1 0 BCD (1/100 sec) R SWD0 0 SWD7 0 SWD7 SWD6 SWD5 SWD4 SWD6 0 Stopwatch timer data FF7EH SWD5 0 BCD (1/10 sec) R SWD4 0 0 \*3 \_ \*2 Unused 0 0 EISW1 EISW10 0 \*3 \_ \*2 FFE7H EISW1 0 Enable Mask Interrupt mask register (Stopwatch timer 1 Hz) Table 4.9.4.1 Control bits of stopwatch timer R 0 0 FFF7H #### SWD0-SWD7: Stopwatch timer data (FF7DH, FF7EH) R/W R/W ISW1 ISW10 EISW10 0 \*3 0 \*3 ISW1 ISW10 0 \_ \*2 - \*2 0 Enable (R) Yes (W) Reset Mask (R) No (W) Invalid Unused Unused The 1/100 sec and the 1/10 sec data (BCD) can be read from SWD0–SWD3 and SWD4–SWD7, respectively. These eight bits are read only, and writing operations are invalid. At initial reset, the timer data is initialized to "00H". #### SWRST: Stopwatch timer reset (FF7CH•D1) When "1" is written: Stopwatch timer reset When "0" is written: No operation Reading: Always "0" The stopwatch timer is reset by writing "1" to SWRST. All timer data is set to "0". When the stopwatch timer is reset in the RUN status, operation restarts immediately. Also, in the STOP status the reset data is maintained. No operation results when "0" is written to SWRST. This bit is write-only, and so is always "0" at reading. #### SWRUN: Stopwatch timer RUN/STOP control register (FF7CH•D0) Controls RUN/STOP of the stopwatch timer. When "1" is written: RUN When "0" is written: STOP Reading: Valid The stopwatch timer enters the RUN status when "1" is written to the SWRUN register, and the STOP status when "0" is written. In the STOP status, the timer data is maintained until the next RUN status or the timer is reset. Also, when the STOP status changes to the RUN status, the data that is maintained can be used for resuming the count. <sup>\*1</sup> Initial value at initial reset <sup>\*2</sup> Not set in the circuit <sup>\*3</sup> Constantly "0" when being read #### CHAPTER 4: PERIPHERAL CIRCUITS AND OPERATION (Stopwatch Timer) When data of the counter is read at run mode, proper reading may not be obtained due to the carry from low-order digits (SWD0–SWD3) into high-order digits (SWD4–SWD7) (i.e., in case SWD0–SWD3 and SWD4–SWD7 reading span the timing of the carry). To avoid this occurrence, perform the reading after suspending the counter once and then set the SWRUN to "1" again. Moreover, it is required that the suspension period not exceed 976 $\mu$ sec (1/4 cycle of 256 Hz). At initial reset, this register is set to "0". # EISW10: 10Hz interrupt mask register (FFE7H•D0) EISW1: 1Hz interrupt mask register (FFE7H•D1) These registers are used to select whether to mask the stopwatch timer interrupt. When "1" is written: Enabled When "0" is written: Masked Reading: Valid The interrupt mask registers (EISW10, EISW1) are used to select whether to mask the interrupt to the separate frequencies (10 Hz, 1 Hz). At initial reset, these registers are set to "0". # ISW10: 10 Hz interrupt factor flag (FFF7H•D0) ISW1: 1 Hz interrupt factor flag (FFF7H•D1) These flags indicate the status of the stopwatch timer interrupt. When "1" is read: Interrupt has occurred When "0" is read: Interrupt has not occurred When "1" is written: Flag is reset When "0" is written: Invalid The interrupt factor flags ISW10 and ISW1 correspond to 10 Hz and 1 Hz stopwatch timer interrupts, respectively. The software can judge from these flags whether there is a stopwatch timer interrupt. However, even if the interrupt is masked, the flags are set to "1" by the overflow of the corresponding counters. These flags are reset to "0" by writing "1" to them. After an interrupt occurs, the same interrupt will occur again if the interrupt enabled state (I flag = "1") is set or the RETI instruction is executed unless the interrupt factor flag is reset. Therefore, be sure to reset (write "1" to) the interrupt factor flag in the interrupt service routine before shifting to the interrupt enabled state. At initial reset, these flags are set to "0". # 4.9.5 Programming notes - (1) When data of the counter is read at run mode, perform the reading after suspending the counter once and then set SWRUN to "1" again. Moreover, it is required that the suspension period not exceed 976 µsec (1/4 cycle of 256 Hz). - (2) After an interrupt occurs, the same interrupt will occur again if the interrupt enabled state (I flag = "1") is set or the RETI instruction is executed unless the interrupt factor flag is reset. Therefore, be sure to reset (write "1" to) the interrupt factor flag in the interrupt service routine before shifting to the interrupt enabled state. - (3) When the CR oscillation circuit is selected as the OSC1 oscillation circuit by mask option, the frequencies and times differ from the values described in this section because the oscillation frequency will be 60 kHz (Typ.). Therefore, this timer can not be used for the stopwatch function. # 4.10 Programmable Timer # 4.10.1 Configuration of programmable timer The S1C63454 has two 8-bit programmable timer systems (timer 0 and timer 1) built-in. Timer 0 and timer 1 are composed of 8-bit presettable down counters and they can be used as 8-bit $\times$ 2 channel programmable timers. Figure 4.10.1.1 shows the configuration of the programmable timer. The programmable timer is designed to count down from the initial value set in the counter with software. An underflow according to the initial value occurs by counting down and is used for the following functions: - Presetting the initial value to the counter to generate the periodical underflow signal - Generating an interrupt - Generating a TOUT signal output from the R02 output port terminal - Generating the synchronous clock source for the serial interface (timer 1 underflow is used, and it is possible to set the transfer rate) Fig. 4.10.1.1 Configuration of programmable timer ## 4.10.2 Setting of initial value and counting down Timers 0 and 1 each have a down counter and reload data register. The reload data registers RLD00–RLD07 (timer 0) and RLD10–RLD17 (timer 1) are used to set the initial value to the down counter. By writing "1" to the timer reset bit PTRST0 (timer 0) or PTRST1 (timer 1), the down counter loads the initial value set in the reload register RLD. Therefore, down-counting is executed from the stored initial value by the input clock. The registers PTRUN0 (timer 0) and PTRUN1 (timer 1) are provided to control the RUN/STOP for timers 0 and 1. By writing "1" to the register after presetting the reload data to the down counter, the down counter starts counting down. Writing "0" stops the input count clock and the down counter stops counting. This control (RUN/STOP) does not affect the counter data. The counter maintains its data while stopped, and can restart counting continuing from that data. The counter data can be read via the data buffers PTD00–PTD07 (timer 0) and PTD10–PTD17 (timer 1) in optional timing. However, the counter has the data hold function the same as the clock timer, that holds the high-order data when the low-order data is read in order to prevent the borrowing operation between low- and high-order reading, therefore be sure to read the low-order data first. The counter reloads the initial value set in the reload data register RLD when an underflow occurs through the count down. It continues counting down from the initial value after reloading. In addition to reloading the counter, this underflow signal controls the interrupt generation, pulse (TOUT signal) output and clock supplying to the serial interface. Fig. 4.10.2.1 Basic operation timing of down counter Note: The counter mode selection register EVCNT should be set to "0" when timer 0 is used as a down counter. Otherwise it will cause malfunction. 60 EPSON S1C63454 TECHNICAL MANUAL ## 4.10.3 Setting of input clock in timer mode Timer 0 and timer 1 each include a prescaler. The prescalers generate the input clock for each timer by dividing the source clock supplied from the OSC1 or OSC3 oscillation circuit. The source clock (OSC1 or OSC3) and the division ratio of the prescaler can be selected with software for timer 0 and timer 1 individually. The input clock is set in the following sequence. ## (1) Selection of source clock Select the source clock input to each prescaler from either OSC1 or OSC3. This selection is done using the source clock selection registers CKSEL0 (timer 0) and CKSEL1 (timer 1); when "0" is written to the register, OSC1 is selected and when "1" is written, OSC3 is selected. When the OSC3 oscillation clock is selected for the clock source, it is necessary to turn the OSC3 oscillation ON, prior to using the programmable timer. However the OSC3 oscillation circuit requires a time at least 5 msec from turning the circuit ON until the oscillation stabilizes. Therefore, allow an adequate interval from turning the OSC3 oscillation circuit ON to starting the programmable timer. Refer to Section 4.3, "Oscillation Circuit", for the control and notes of the OSC3 oscillation circuit. At initial reset, the OSC3 oscillation circuit is set in the OFF state. ## (2) Selection of prescaler division ratio Select the division ratio for each prescaler from among 4 types. This selection is done using the prescaler division ratio selection registers PTPS00/PTPS01 (timer 0) and PTPS10/PTPS11 (timer 1). Table 4.10.3.1 shows the correspondence between the setting value and the division ratio. | of P | | | | | | | | | |------|--------|--------|--------------------------|--|--|--|--|--| | | PTPS11 | PTPS10 | Prescaler division ratio | | | | | | | | PTPS01 | PTPS00 | Prescaler division ratio | | | | | | | | 1 | 1 | Source clock / 256 | | | | | | | | 1 | 0 | Source clock / 32 | | | | | | | | 0 | 1 | Source clock / 4 | | | | | | | | 0 | 0 | Source clock / 1 | | | | | | Table 4.10.3.1 Selection of prescaler division ratio By writing "1" to the register PTRUN0 (timer 0) or PTRUN1 (timer 1), the prescaler inputs the source clock and outputs the clock divided by the selected division ratio. The counter starts counting down by inputting the clock. # 4.10.4 Interrupt function The programmable timer can generate an interrupt due to an underflow of the timer 0 and timer 1. See Figure 4.10.2.1 for the interrupt timing. An underflow of timer 0 and timer 1 sets the corresponding interrupt factor flag IPT0 (timer 0) or IPT1 (timer 1) to "1", and generates an interrupt. The interrupt can also be masked by setting the corresponding interrupt mask register EIPT0 (timer 0) or EIPT1 (timer 1). However, the interrupt factor flag is set to "1" by an underflow of the corresponding timer regardless of the interrupt mask register setting. # 4.10.5 Setting of TOUT output The programmable timer can generate a TOUT signal due to an underflow of timer 0 or timer 1. The TOUT signal is generated by dividing the underflows in 1/2. It is possible to select which timer's underflow is to be used by the TOUT output channel selection register CHSEL. When "0" is written to the CHSEL register, timer 0 is selected and when "1" is written, timer 1 is selected. Figure 4.10.5.1 shows the TOUT signal waveform when the channel is changed. Fig. 4.10.5.1 TOUT signal waveform at channel change The TOUT signal can be output from the R02 output port terminal. Programmable clocks can be supplied to external devices. Figure 4.10.5.2 shows the configuration of the output port R02. Fig. 4.10.5.2 Configuration of R02 The output of a TOUT signal is controlled by the PTOUT register. When "1" is written to the PTOUT register, the TOUT signal is output from the R02 output port terminal and when "0" is written, the terminal goes to a high (VDD) level. However, the data register R02 must always be "1" and the high impedance control register R02HIZ must always be "0" (data output state). Since the TOUT signal is generated asynchronously from the PTOUT register, a hazard within 1/2 cycle is generated when the signal is turned ON and OFF by setting the register. Figure 4.10.5.3 shows the output waveform of the TOUT signal. ## 4.10.6 Transfer rate setting for serial interface The signal that is made from underflows of timer 1 by dividing them in 1/2, can be used as the clock source for the serial interface. The programmable timer outputs the clock to the serial interface by setting timer 1 into RUN state (PTRUN = "1"). It is not necessary to control with the PTOUT register. Fig. 4.10.6.1 Synchronous clock of serial interface A setting value for the RLD1X register according to a transfer rate is calculated by the following expression: RLD1X = fosc / (2 \* bps \* division ratio of the prescaler) - 1 fosc: Oscillation frequency (OSC1/OSC3) bps: Transfer rate (00H can be set to RLD1X) Be aware that the maximum clock frequency for the serial interface is limited to 1 MHz when OSC3 is used as the clock source. ## 4.10.7 I/O memory of programmable timer Table 4.10.7.1 shows the I/O addresses and the control bits for the programmable timer. Table 4.10.7.1 Control bits of programmable timer | | 1 | D | iotor | 1abl | e 4.10. | 7.1 CC | ntroi b | nts of p | programmable timer | | | | | |---------|--------------------|-----------------------|-----------------------------------------------------------------------------------------|----------------|------------------|-----------|--------------|-----------------------------------------------------|-------------------------------------------------------------------------------------------|--|--|--|--| | Address | D3 | D2 | ister<br>D1 | D0 | Name | Init *1 | 1 | 0 | Comment | | | | | | | | | | | 0 *3 | - *2 | | _ Ŭ | Unused | | | | | | FFC0H | 0 | EVCNT | FCSEL | PLPOL | EVCNT | 0 | - | Timer | Timer 0 counter mode selection (Fix at "0".) | | | | | | FFCUH | R | | D/M | | FCSEL | 0 | | | General-purpose register | | | | | | | n | | R/W PLPOL 0 General-purpose register CHSEL 0 Timer Timer TOUT output channel selection | | | | 1 1 0 | | | | | | | | | CHSEL PTOUT CKSEL1 | | CKSELO | CHSEL | 0 | Timer1 | Timer0 | TOUT output channel selection | | | | | | | FFC1H | OHOLL | 1 1001 | ONOLLI | ONOLLO | PTOUT | 0 | On | Off | TOUT output control | | | | | | | R/W | | | | CKSEL1 | 0 | OSC3 | OSC1 | Prescaler 1 source clock selection | | | | | | | | ı | | ı | CKSEL0<br>PTPS01 | 0 | OSC3 | OSC1 | Prescaler 0 source clock selection | | | | | | 1 | PTPS01 | PTPS00 | PTRST0 | PTRUN0 | PTPS00 | 0 | | | Prescaler 0 [PTPS01, 00] 0 1 2 3 division ratio Division ratio 1/1 1/4 1/32 1/256 | | | | | | FFC2H | | | | | PTRST0*3 | _ *2 | Reset | Invalid | Selection Division ratio 1/1 1/4 1/32 1/230 Timer 0 reset (reload) | | | | | | | R/ | W . | W | R/W | PTRUN0 | 0 | Run | Stop | Timer 0 Run/Stop | | | | | | | | | | | PTPS11 | 0 | riuii | Otop | Prescaler 1 [PTPS11, 10] 0 1 2 3 | | | | | | | PTPS11 | PTPS10 | PTRST1 | PTRUN1 | PTPS10 | 0 | | | division ratio selection Division ratio 1/1 1/4 1/32 1/256 | | | | | | FFC3H | | | | | PTRST1*3 | _ *2 | Reset | Invalid | Timer 1 reset (reload) | | | | | | | R | W | W | R/W | PTRUN1 | 0 | Run | Stop | Timer 1 Run/Stop | | | | | | | DI DOG | DI DOG | DI DO1 | DI DOO | RLD03 | 0 | | | ¬ MSB | | | | | | EECAL | RLD03 | RLD02 | RLD01 | RLD00 | RLD02 | 0 | | | Programmable times 0 relead date (low order 4 bite) | | | | | | FFC4H | | В | w | | RLD01 | 0 | | | Programmable timer 0 reload data (low-order 4 bits) | | | | | | | | | VV | | RLD00 | 0 | | | _ LSB | | | | | | | RLD07 | RLD07 RLD06 RLD05 RLD | | | RLD07 | 0 | | | MSB | | | | | | FFC5H | ALDO7 ALDO0 | | TIEBOS TIEBOT | | RLD06 | 0 | | | Programmable timer 0 reload data (high-order 4 bits) | | | | | | 110011 | R/W | | | | RLD05 | 0 | | | | | | | | | | 1011 | | | RLD04 | 0 | | | LSB | | | | | | | | RLD13 | RLD13 RLD12 RLD11 RL | | RLD10 | RLD13 | 0 | | | MSB | | | | | | FFC6H | | | | RLD12<br>RLD11 | 0 | | | Programmable timer 1 reload data (low-order 4 bits) | | | | | | | | R/W | | | RLD10 | 0 | | | LSB | | | | | | | | | | | | RLD17 | 0 | | | □ MSB | | | | | | | RLD17 RLD16 | | RLD15 | RLD14 | RLD16 0 | | | | | | | | | | FFC7H | | | | | RLD15 | 0 | | | Programmable timer 1 reload data (high-order 4 bits) | | | | | | | | R/ | W | | RLD14 | 0 | | | LSB | | | | | | | DTDOO | DTD00 | DTD04 | DTDOO | PTD03 | 0 | | | ☐ MSB | | | | | | FFC8H | PTD03 | PTD02 | PTD01 | PTD00 | PTD02 | 0 | | | Programmable timer 0 data (low-order 4 bits) | | | | | | 11 0011 | | R | | | PTD01 | 0 | | | 110grammable timer o data (low-order 4 bits) | | | | | | | | , | 1 | | PTD00 | 0 | | | LSB | | | | | | | PTD07 | PTD06 | PTD05 | PTD04 | PTD07 | 0 | | | MSB | | | | | | FFC9H | | | | | PTD06 | 0 | | | Programmable timer 0 data (high-order 4 bits) | | | | | | | | F | 3 | | PTD05<br>PTD04 | 0 | | | LSB | | | | | | | | | | | PTD13 | 0 | | | ☐ MSB | | | | | | | PTD13 | PTD12 | PTD11 | PTD10 | PTD12 | 0 | | | INDU | | | | | | FFCAH | <b>-</b> | <u> </u> | l | <u> </u> | PTD11 | 0 | | | Programmable timer 1 data (low-order 4 bits) | | | | | | | | F | 3 | | PTD10 | 0 | | | LSB | | | | | | | | | | | PTD17 | 0 | | | ☐ MSB | | | | | | FE65.: | PTD17 | PTD16 | PTD15 | PTD14 | PTD16 | 0 | | | | | | | | | FFCBH | | | | | PTD15 | 0 | | | Programmable timer 1 data (high-order 4 bits) | | | | | | | | | 7 | | PTD14 | 0 | | | LSB | | | | | | | 0 | 0 | EIPT1 | EIPT0 | 0 *3 | _ *2 | | | Unused | | | | | | FFE2H | | " | En. 11 | LII. 10 | 0 *3 | - *2 | | | Unused | | | | | | | , | 3 | R | w | EIPT1 | 0 | Enable | Mask | Interrupt mask register (Programmable timer 1) | | | | | | | <u> </u> | | 10 | | EIPT0 | 0 | Enable | Mask | Interrupt mask register (Programmable timer 0) | | | | | | | 0 | 0 | IPT1 | IPT0 | 0 *3 | - *2<br>2 | (R) | (R) | Unused | | | | | | FFF2H | | | | <u> </u> | 0 *3<br>IPT1 | - *2<br>0 | Yes | No<br> | Unused Interrupt factor flag (Programmable timer 1) | | | | | | | 1 | 3 | R | W | IPT0 | 0 | (W)<br>Reset | (W)<br>Invalid | Interrupt factor flag (Programmable timer 1) Interrupt factor flag (Programmable timer 0) | | | | | | | l . | | I | | 11 10 | U | 110001 | I IIIvaliu | merrupt ractor mag (r rogrammable timer 0) | | | | | <sup>\*1</sup> Initial value at initial reset <sup>\*2</sup> Not set in the circuit <sup>\*3</sup> Constantly "0" when being read ## CKSEL0: Prescaler 0 source clock selection register (FFC1H•D0) CKSEL1: Prescaler 1 source clock selection register (FFC1H•D1) Selects the source clock of the prescaler. When "1" is written: OSC3 clock When "0" is written: OSC1 clock Reading: Valid The source clock for the prescaler is selected from OSC1 or OSC3. When "0" is written to the CKSEL0 register, the OSC1 clock is selected as the input clock for the prescaler 0 (for timer 0) and when "1" is written, the OSC3 clock is selected. Same as above, the source clock for prescaler 1 is selected by the CKSEL1 register. When the event counter mode is selected to timer 0, the setting of the CKSEL0 register becomes invalid. At initial reset, these registers are set to "0". ## PTPS00, PTPS01: Timer 0 prescaler division ratio selection register (FFC2H•D2, D3) PTPS10, PTPS11: Timer 1 prescaler division ratio selection register (FFC3H•D2, D3) Selects the division ratio of the prescaler. Two bits of PTPS00 and PTPS01 are the prescaler division ratio selection register for timer 0, and two bits of PTPS10 and PTPS11 are for timer 1. The prescaler division ratios that can be set by these registers are shown in Table 4.10.7.2. Table 4.10.7.2 Selection of prescaler division ratio | PTPS11 | PTPS10 | Dunnandan divinina matia | | | | |--------|--------|--------------------------|--|--|--| | PTPS01 | PTPS00 | Prescaler division ratio | | | | | 1 | 1 | Source clock / 256 | | | | | 1 | 0 | Source clock / 32 | | | | | 0 | 1 | Source clock / 4 | | | | | 0 | 0 | Source clock / 1 | | | | When the event counter mode is selected to timer 0, the setting of the PTPS00 and PTPS01 becomes invalid. At initial reset, these registers are set to "0". ## EVCNT: Timer 0 counter mode selection register (FFC0H•D2) Selects a counter mode for timer 0. When "1" is written: No function (reserved) When "0" is written: Timer mode Reading: Valid The counter mode for timer 0 is selected from either no function or timer mode. When "1" is written to the EVCNT register, no function is selected and when "0" is written, the timer mode is selected. At initial reset, this register is set to "0". Note: The counter mode selection register EVCNT should be set to "0" when timer 0 is used as a down counter. Otherwise it will cause malfunction. #### **CHAPTER 4: PERIPHERAL CIRCUITS AND OPERATION (Programmable Timer)** ## RLD00-RLD07: Timer 0 reload data register (FFC4H, FFC5H) RLD10-RLD17: Timer 1 reload data register (FFC6H, FFC7H) Sets the initial value for the counter. The reload data written in this register is loaded to the respective counters. The counter counts down using the data as the initial value for counting. Reload data is loaded to the counter when the counter is reset by writing "1" to the PTRST0 or PTRST1 register, or when counter underflow occurs. At initial reset, these registers are set to "00H". ## PTD00-PTD07: Timer 0 counter data (FFC8H, FFC9H) PTD10-PTD17: Timer 1 counter data (FFCAH, FFCBH) Count data in the programmable timer can be read from these latches. The low-order 4 bits of the count data in timer 0 can be read from PTD00–PTD03, and the high-order data can be read from PTD04–PTD07. Similarly, for timer 1, the low-order 4 bits can be read from PTD10–PTD13, and the high-order data can be read from PTD14–PTD17. Since the high-order 4 bits are held by reading the low-order 4 bits, be sure to read the low-order 4 bits first. Since these latches are exclusively for reading, the writing operation is invalid. At initial reset, these counter data are set to "00H". # PTRST0: Timer 0 reset (reload) (FFC2H•D1) PTRST1: Timer 1 reset (reload) (FFC3H•D1) Resets the timer and presets reload data to the counter. When "1" is written: Reset When "0" is written: No operation Reading: Always "0" By writing "1" to PTRST0, the reload data in the reload register PLD00–PLD07 is preset to the counter in timer 0. Similarly, the reload data in PLD10–PLD17 is preset to the counter in timer 1 by PTRST1. When the counter is preset in the RUN status, the counter restarts immediately after presetting. In the case of STOP status, the reload data is preset to the counter and is maintained. No operation results when "0" is written. Since these bits are exclusively for writing, always set to "0" during reading. # PTRUN0: Timer 0 RUN/STOP control register (FFC2H•D0) PTRUN1: Timer 1 RUN/STOP control register (FFC3H•D0) Controls the RUN/STOP of the counter. When "1" is written: RUN When "0" is written: STOP Reading: Valid The counter in timer 0 starts counting down by writing "1" to the PTRUN0 register and stops by writing "0". In STOP status, the counter data is maintained until the counter is reset or is set in the next RUN status. When STOP status changes to RUN status, the data that has been maintained can be used for resuming the count. Same as above, the timer 1 counter is controlled by the PTRUN1 register. At initial reset, these registers are set to "0". ## CHSEL: TOUT output channel selection register (FFC1H•D3) Selects the channel used for TOUT signal output. When "1" is written: Timer 1 When "0" is written: Timer 0 Reading: Valid This register selects which timer's underflow (timer 0 or timer 1) is used to generate a TOUT signal. When "0" is written to the CHSEL register, timer 0 is selected and when "1" is written, timer 1 is selected. At initial reset, this register is set to "0". ## PTOUT: TOUT output control register (FFC1H•D2) Turns TOUT signal output ON and OFF. When "1" is written: ON When "0" is written: OFF Reading: Valid PTOUT is the output control register for the TOUT signal. When "1" is written to the register, the TOUT signal is output from the output port terminal R02 and when "0" is written, the terminal goes to a high (VDD) level. However, the data register R02 must always be "1" and the high impedance control register R02HIZ must always be "0" (data output state). At initial reset, this register is set to "0". ## EIPT0: Timer 0 interrupt mask register (FFE2H•D0) EIPT1: Timer 1 interrupt mask register (FFE2H•D1) These registers are used to select whether to mask the programmable timer interrupt or not. When "1" is written: Enabled When "0" is written: Masked Reading: Valid Timer 0 and timer 1 interrupts can be masked individually by the interrupt mask registers EIPT0 (timer 0) and EIPT1 (timer 1). At initial reset, these registers are set to "0". ## IPT0: Timer 0 interrupt factor flag (FFF2H•D0) ## IPT1: Timer 1 interrupt factor flag (FFF2H•D1) These flags indicate the status of the programmable timer interrupt. When "1" is read: Interrupt has occurred When "0" is read: Interrupt has not occurred When "1" is written: Flag is reset When "0" is written: Invalid The interrupt factor flags IPT0 and IPT1 correspond to timer 0 and timer 1 interrupts, respectively. The software can judge from these flags whether there is a programmable timer interrupt. However, even if the interrupt is masked, the flags are set to "1" by the underflows of the corresponding counters. These flags are reset to "0" by writing "1" to them. After an interrupt occurs, the same interrupt will occur again if the interrupt enabled state (I flag = "1") is set or the RETI instruction is executed unless the interrupt factor flag is reset. Therefore, be sure to reset (write "1" to) the interrupt factor flag in the interrupt service routine before shifting to the interrupt enabled state At initial reset, these flags are set to "0". ## 4.10.8 Programming notes - (1) When reading counter data, be sure to read the low-order 4 bits (PTD00–PTD03, PTD10–PTD13) first. Furthermore, the high-order 4 bits (PTD04–PTD07, PTD14–PTD17) should be read within 0.73 msec (when fOSC1 is 32.768 kHz) of reading the low-order 4 bits (PTD00–PTD03, PTD10–PTD13). - (2) The programmable timer actually enters RUN/STOP status in synchronization with the falling edge of the input clock after writing to the PTRUN0/PTRUN1 register. Consequently, when "0" is written to the PTRUN0/PTRUN1 register, the timer enters STOP status at the point where the counter is decremented (-1). The PTRUN0/PTRUN1 register maintains "1" for reading until the timer actually stops. Figure 4.10.8.1 shows the timing chart for the RUN/STOP control. Fig. 4.10.8.1 Timing chart for RUN/STOP control - (3) Since the TOUT signal is generated asynchronously from the PTOUT register, a hazard within 1/2 cycle is generated when the signal is turned ON and OFF by setting the register. - (4) When the OSC3 oscillation clock is selected for the clock source, it is necessary to turn the OSC3 oscillation ON, prior to using the programmable timer. However the OSC3 oscillation circuit requires a time at least 5 msec from turning the circuit ON until the oscillation stabilizes. Therefore, allow an adequate interval from turning the OSC3 oscillation circuit ON to starting the programmable timer. Refer to Section 4.3, "Oscillation Circuit", for the control and notes of the OSC3 oscillation circuit. At initial reset, the OSC3 oscillation circuit is set in the OFF state. - (5) After an interrupt occurs, the same interrupt will occur again if the interrupt enabled state (I flag = "1") is set or the RETI instruction is executed unless the interrupt factor flag is reset. Therefore, be sure to reset (write "1" to) the interrupt factor flag in the interrupt service routine before shifting to the interrupt enabled state. - (6) The counter mode selection register EVCNT should be set to "0" when timer 0 is used as a down counter. Otherwise it will cause malfunction. 68 ## 4.11 Serial Interface (SIN, SOUT, SCLK, SRDY) ## 4.11.1 Configuration of serial interface The S1C63454 has a synchronous clock type 8 bits serial interface built-in. The configuration of the serial interface is shown in Figure 4.11.1.1. The CPU, via the 8-bit shift register, can read the serial input data from the SIN terminal. Moreover, via the same 8-bit shift register, it can convert parallel data to serial data and output it to the SOUT terminal. The synchronous clock for serial data input/output may be set by selecting by software any one of three types of master mode (internal clock mode: when the S1C63454 is to be the master for serial input/output) and a type of slave mode (external clock mode: when the S1C63454 is to be the slave for serial input/output). Also, when the serial interface is used at slave mode, $\overline{SRDY}$ signal which indicates whether or not the serial interface is available to transmit or receive can be output to the $\overline{SRDY}$ terminal. The input/output ports of the serial interface are shared with the I/O ports P10–P13, and function of these ports can be selected through the software. P10–P13 terminals and serial input/output correspondence are as follows: | Master mode | Slave mode | |-----------------------------|-----------------------------| | P10 = SIN(I) | P10 = SIN(I) | | P11 = SOUT(O) | P11 = SOUT(O) | | $P12 = \overline{SCLK}$ (O) | $P12 = \overline{SCLK}$ (I) | | P13 = I/O port (I/O) | $P13 = \overline{SRDY}(O)$ | Note: At initial reset, P10-P13 are set to I/O ports. When using the serial interface, switch the function (ESIF = "1") in the initial routine. ## 4.11.2 Mask option ## (1) Terminal specification Since the input/output terminals of the serial interface is shared with the I/O ports (P10–P13), the mask option that selects the output specification for the I/O port is also applied to the serial interface. The output specification of the terminals SOUT, $\overline{SCLK}$ (during the master mode) and $\overline{SRDY}$ (during the slave mode) that are used as output in the input/output port of the serial interface is respectively selected by the mask options of P11, P12 and P13. Either complementary output or N-channel open drain output can be selected as the output specification. However, when N-channel open drain output is selected, do not apply a voltage exceeding the power supply voltage to the terminal. Furthermore, the pull-up resistor and input specification for the SIN terminal and the SCLK terminal (during slave mode) that are used as input terminals can be selected by mask option. The pull-up register can be added by the mask options of P10 and P12. When "without pull-up" is selected, take care that the floating status does not occur. For the input specification, either "normal input" or "with Schmitt trigger input" can be selected. ## (2) Polarity of synchronous clock and ready signal Polarity of the synchronous clock and the ready signal that is output in the slave mode can be selected from either positive polarity (high active, SCLK & SRDY) or negative polarity (low active, SCLK & SRDY). When operating the serial interface in the slave mode, the synchronous clock is input from a external device. Be aware that the terminal specification is pull-up only and a pull-down resistor cannot be built in if positive polarity is selected. In the following explanation, it is assumed that negative polarity (SCLK, SRDY) has been selected. ## 4.11.3 Master mode and slave mode of serial interface The serial interface of the S1C63454 has two types of operation mode: master mode and slave mode. The master mode uses an internal clock as the synchronous clock for the built-in shift register, and outputs this internal clock from the $\overline{SCLK}$ (P12) terminal to control the external (slave side) serial device. In the slave mode, the synchronous clock output from the external (master side) serial device is input from the $\overline{SCLK}$ (P12) terminal and it is used as the synchronous clock for the built-in shift register. The master mode and slave mode are selected by writing data to the SCS1 and SCS0 registers. When the master mode is selected, a synchronous clock may be selected from among 3 types as shown in Table 4.11.3.1. | Table 4.11.3.1 Synchronous clock selection | | | | | | | | | | |--------------------------------------------|------|-------------|----------------------|--|--|--|--|--|--| | SCS1 | SCS0 | Mode | Synchronous clock | | | | | | | | 1 | 1 | | OSC1 | | | | | | | | 1 | 0 | Master mode | OSC1 /2 | | | | | | | | 0 | 1 | | Programmable timer * | | | | | | | | 0 | 0 | Slave mode | External clock * | | | | | | | Table 4.11.3.1 Synchronous clock selection When the programmable timer is selected, the signal that is generated by dividing the underflow signal of the programmable timer (timer 1) in 1/2 is used as the synchronous clock. In this case, the programmable timer must be controlled before operating the serial interface. Refer to Section 4.10, "Programmable Timer" for the control of the programmable timer. At initial reset, the slave mode (external clock mode) is selected. Moreover, the synchronous clock, along with the input/output of the 8-bit serial data, is controlled as follows: - In the master mode, after output of 8 clocks from the SCLK (P12) terminal, clock output is automatically suspended and the SCLK (P12) terminal is fixed at high level. - In the slave mode, after input of 8 clocks to the SCLK (P12) terminal, subsequent clock inputs are masked. <sup>\*</sup> The maximum clock is limited to 1 MHz. A sample basic serial input/output portion connection is shown in Figure 4.11.3.1. Fig. 4.11.3.1 Sample basic connection of serial input/output section ## 4.11.4 Data input/output and interrupt function The serial interface of S1C63454 can input/output data via the internal 8-bit shift register. The shift register operates by synchronizing with either the synchronous clock output from the $\overline{SCLK}$ (P12) terminal (master mode), or the synchronous clock input to the $\overline{SCLK}$ (P12) terminal (slave mode). The serial interface generates an interrupt on completion of the 8-bit serial data input/output. Detection of serial data input/output is done by counting of the synchronous clock $\overline{SCLK}$ ; the clock completes input/output operation when 8 counts (equivalent to 8 cycles) have been made and then generates an interrupt. The serial data input/output procedure is explained below: ## (1) Serial data output procedure and interrupt Shift timing of serial data is as follows: The S1C63454 serial interface is capable of outputting parallel data as serial data, in units of 8 bits. By setting the parallel data to the data registers SD0–SD3 (FF72H) and SD4–SD7 (FF73H) and writing "1" to SCTRG bit (FF70H $\bullet$ D1), it synchronizes with the synchronous clock and the serial data is output to the SOUT (P11) terminal. The synchronous clock used here is as follows: in the master mode, internal clock which is output to the $\overline{SCLK}$ (P12) terminal while in the slave mode, external clock which is input from the $\overline{SCLK}$ (P12) terminal. ## • When negative polarity is selected for the synchronous clock (mask option): The serial data output to the SOUT (P11) terminal changes at the falling edge of the clock input or output from/to the $\overline{SCLK}$ (P12) terminal. The data in the shift register is shifted at the falling edge of the $\overline{SCLK}$ signal when the SCPS register (FF71H $\bullet$ D2) is "1" and is shifted at the rising edge of the $\overline{SCLK}$ signal when the SCPS register is "0". #### • When positive polarity is selected for the synchronous clock (mask option): The serial data output to the SOUT (P11) terminal changes at the rising edge of the clock input or output from/to the SCLK (P12) terminal. The data in the shift register is shifted at the rising edge of the SCLK signal when the SCPS register is "1" and is shifted at the falling edge of the SCLK signal when the SCPS register is "0". When the output of the 8-bit data from SD0 to SD7 is completed, the interrupt factor flag ISIF (FFF3H•D0) is set to "1" and an interrupt occurs. Moreover, the interrupt can be masked by the interrupt mask register EISIF (FFE3H•D0). However, regardless of the interrupt mask register setting, the interrupt factor flag is set to "1" after output of the 8-bit data. ## (2) Serial data input procedure and interrupt The S1C63454 serial interface is capable of inputting serial data as parallel data, in units of 8 bits. The serial data is input from the SIN (P10) terminal, synchronizes with the synchronous clock, and is sequentially read in the 8-bit shift register. As in the above item (1), the synchronous clock used here is as follows: in the master mode, internal clock which is output to the $\overline{SCLK}$ (P12) terminal while in the slave mode, external clock which is input from the $\overline{SCLK}$ (P12) terminal. Shift timing of serial data is as follows: ## • When negative polarity is selected for the synchronous clock (mask option): The serial data is read into the built-in shift register at the falling edge of the $\overline{SCLK}$ signal when the SCPS register is "1" and is read at the rising edge of the $\overline{SCLK}$ signal when the SCPS register is "0". The shift register is sequentially shifted as the data is fetched. #### • When positive polarity is selected for the synchronous clock (mask option): The serial data is read into the built-in shift register at the rising edge of the SCLK signal when the SCPS register is "1" and is read at the falling edge of the SCLK signal when the SCPS register is "0". The shift register is sequentially shifted as the data is fetched. When the input of the 8-bit data from SD0 to SD7 is completed, the interrupt factor flag ISIF is set to "1" and an interrupt is generated. Moreover, the interrupt can be masked by the interrupt mask register EISIF. However, regardless of the interrupt mask register setting, the interrupt factor flag is set to "1" after input of the 8-bit data. The data input in the shift register can be read from data registers SD0-SD7 by software. ## (3) Serial data input/output permutation The S1C63454 allows the input/output permutation of serial data to be selected by the SDP register (FF71H•D3) as to either LSB first or MSB first. The block diagram showing input/output permutation in case of LSB first and MSB first is provided in Figure 4.11.4.1. The SDP register should be set before setting data to SD0–SD7. Fig. 4.11.4.1 Serial data input/output permutation ## (4) SRDY signal When the S1C63454 serial interface is used in the slave mode (external clock mode), $\overline{SRDY}$ signal is used to indicate whether the internal serial interface is available to transmit or receive data for the master side (external) serial device. $\overline{SRDY}$ signal is output from the $\overline{SRDY}$ (P13) terminal. Output timing of $\overline{SRDY}$ signal is as follows: ## • When negative polarity is selected (mask option): SRDY signal goes "0" (low) when the S1C63454 serial interface is available to transmit or receive data; normally, it is at "1" (high). $\overline{\text{SRDY}}$ signal changes from "1" to "0" immediately after "1" is written to SCTRG and returns from "0" to "1" when "0" is input to the $\overline{\text{SCLK}}$ (P12) terminal (i.e., when the serial input/output begins transmitting or receiving data). Moreover, when high-order data is read from or written to SD4–SD7, the $\overline{\text{SRDY}}$ signal returns to "1". ## • When positive polarity is selected (mask option): SRDY signal goes "1" (high) when the S1C63454 serial interface is available to transmit or receive data; normally, it is at "0" (low). SRDY signal changes from "0" to "1" immediately after "1" is written to SCTRG and returns from "1" to "0" when "1" is input to the SCLK (P12) terminal (i.e., when the serial input/output begins transmitting or receiving data). Moreover, when high-order data is read from or written to SD4–SD7, the SRDY signal returns to "0". ## (5) Timing chart The S1C63454 serial interface timing charts are shown in Figures 4.11.4.2 and 4.11.4.3. Fig. 4.11.4.2 Serial interface timing chart (when synchronous clock is negative polarity SCLK) Fig. 4.11.4.3 Serial interface timing chart (when synchronous clock is positive polarity SCLK) ## 4.11.5 I/O memory of serial interface Table 4.11.5.1 shows the I/O addresses and the control bits for the serial interface. Table 4.11.5.1 Control bits of serial interface | A -l -l | | Reg | ister | | | | | | Comment | | | | |---------------|-------|---------|--------|----------|--------------------------------------|---------|-----------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Address | D3 | D2 | D1 | D0 | Name | Init *1 | 1 | 0 | Comment | | | | | | | | | | PUL13 | 1 | On | Off | P13 pull-up control register | | | | | | | | | PUL10 | | | | | functions as a general-purpose register when SIF (slave) is selected | | | | | | PUL13 | PUL12 | PUL11 | | PUL12 | 1 | On | Off | P12 pull-up control register (ESIF=0) | | | | | | | | | | | | | | functions as a general-purpose register when SIF (master) is selected | | | | | FF45H | | | | | | | | | SCLK (I) pull-up control register when SIF (slave) is selected | | | | | | | | | | PUL11 | 1 | On | Off | P11 pull-up control register (ESIF=0) | | | | | | | R/ | w | | | | | | functions as a general-purpose register when SIF is selected | | | | | | | | | | PUL10 | 1 | On | Off | P10 pull-up control register (ESIF=0) | | | | | | | | | | | | | | SIN pull-up control register when SIF is selected | | | | | | | • | 00700 | FOIF | 0 *3 | _ *2 | | | Unused | | | | | | 0 | 0 | SCTRG | ESIF | 0 *3 | - *2 | | | Unused | | | | | FF70H | | | | | SCTRG | 0 | Trigger | Invalid | Serial I/F clock trigger (writing) | | | | | | R R/W | | | | -0 | _ | Run | Stop | Serial I/F clock status (reading) | | | | | | | | | | ESIF | 0 | SIF | 1/0 | Serial I/F enable (P1 port function selection) | | | | | | | | | | SDP | 0 | MSB first | LSB first | Serial I/F data input/output permutation | | | | | | SDP | SCPS | SCS1 | SCS0 | SCPS | 0 | ¬ | _ | Serial I/F clock phase selection | | | | | FF71H | | | | | | | <u> </u> | - | -Negative polarity (mask option) Positive polarity (mask option) [SCS1, 0] 0 1 | | | | | | R/W | | | | SCS1 | 0 | | \ | Clock Slave PT | | | | | | | | | | SCS0 | 0 | | | | | | | | | | | | | SD3 | _ *2 | High | Low | ☐ MSB | | | | | | SD3 | SD3 SD2 | | D1 SD0 S | | _ *2 | High | Low | | | | | | FF72H | | | | | SD1 | - *2 | High | Low | Serial I/F transmit/receive data (low-order 4 bits) | | | | | | R/W | | | | SD0 | _ *2 | High | Low | LSB | | | | | | | | | | SD7 | _ *2 | High | Low | ☐ MSB | | | | | FF73H | SD7 | SD6 | SD5 | SD4 | SD6 | - *2 | High | Low | Conical VE assessment (see assigned as a design of the land | | | | | FF/3H | | | 0.4.4 | | SD5 | _ *2 | High | Low | Serial I/F transmit/receive data (high-order 4 bits) | | | | | | | H/ | W | | SD4 | _ *2 | High | Low | LSB | | | | | | 0 | 0 | 0 | EISIF | 0 *3 | -*2 | | | Unused | | | | | FFE3H | U | U | U | EISIF | 0 *3 | _*2 | | | Unused | | | | | I I LSI I | D DAM | | | 0 *3 | _*2 | | | Unused | | | | | | R R/W EISIF 0 | | | Enable | Mask | Interrupt mask register (Serial I/F) | | | | | | | | | | 0 | 0 | 0 | ISIF | 0 *3 | _ *2 | (R) | (R) | Unused | | | | | FFF3H | | Ŭ | | 1011 | 0 *3 | _ *2 | Yes | No | Unused | | | | | | R R/W | | | 0 *3 | - *2 | (W) | (W) | Unused | | | | | | | | | | | ISIF | 0 | Reset | Invalid | Interrupt factor flag (Serial I/F) | | | | <sup>\*1</sup> Initial value at initial reset ## ESIF: Serial interface enable register (P1 port function selection) (FF70H•D0) Sets P10–P13 to the input/output port for the serial interface. When "1" is written: Serial interface When "0" is written: I/O port Reading: Valid When "1" is written to the ESIF register, P10, P11, P12 and P13 function as SIN, SOUT, SCLK, SRDY, respectively. In the slave mode, the P13 terminal functions as $\overline{SRDY}$ output terminal, while in the master mode, it functions as the I/O port terminal. At initial reset, this register is set to "0". Note: After setting ESIF to "1", wait at least 10 µsec before starting actual data transfer since a hazard may be generated from the P12 (SCLK) terminal when ESIF is set to "1". <sup>\*2</sup> Not set in the circuit <sup>\*3</sup> Constantly "0" when being read ## PUL10: SIN (P10) pull-up control register (FF45H•D0) ## PUL12: SCLK (P12) pull-up control register (FF45H•D2) Sets the pull-up of the SIN terminal and the SCLK terminals (in the slave mode). When "1" is written: Pull-up ON When "0" is written: Pull-up OFF Reading: Valid Sets the pull-up resistor built into the SIN (P10) and $\overline{SCLK}$ (P12) terminals to ON or OFF. (Pull-up resistor is only built in the port selected by mask option.) SCLK pull-up is effective only in the slave mode. In the master mode, the PUL12 register can be used as a general purpose register. At initial reset, these registers are set to "1" and pull-up goes ON. ## SCS1, SCS0: Clock mode selection register (FF71H•D0, D1) Selects the synchronous clock (SCLK) for the serial interface. Table 4.11.5.2 Synchronous clock selection | SCS1 | SCS0 | Mode | Synchronous clock | |------|------|-------------|----------------------| | 1 | 1 | | OSC1 | | 1 | 0 | Master mode | OSC1 /2 | | 0 | 1 | | Programmable timer * | | 0 | 0 | Slave mode | External clock * | <sup>\*</sup> The maximum clock is limited to 1 MHz. Synchronous clock (SCLK) is selected from among the above 4 types: 3 types of internal clock and external clock. When the programmable timer is selected, the signal that is generated by dividing the underflow signal of the programmable timer (timer 1) in 1/2 is used as the synchronous clock. In this case, the programmable timer must be controlled before operating the serial interface. Refer to Section 4.10, "Programmable Timer" for the control of the programmable timer. At initial reset, external clock is selected. #### SCPS: Clock phase selection register (FF71H•D2) Selects the timing for reading in the serial data input from the SIN (P10) terminal. #### • When negative polarity is selected: When "1" is written: Falling edge of $\overline{SCLK}$ When "0" is written: Rising edge of $\overline{SCLK}$ Reading: Valid ## • When positive polarity is selected: When "1" is written: Rising edge of SCLK When "0" is written: Falling edge of SCLK Reading: Valid Select whether the fetching for the serial input data to registers (SD0–SD7) at the rising edge or falling edge of the synchronous signal. Pay attention to the polarity of the synchronous clock selected by the mask option because the selection content is different. The input data fetch timing may be selected but output timing for output data is fixed at the falling edge of $\overline{SCLK}$ (when negative polarity is selected) or at the rising edge of SCLK (when positive polarity is selected). At initial reset, this register is set to "0". #### CHAPTER 4: PERIPHERAL CIRCUITS AND OPERATION (Serial Interface) #### SDP: Data input/output permutation selection register (FF71H•D3) Selects the serial data input/output permutation. When "1" is written: MSB first When "0" is written: LSB first Reading: Valid Select whether the data input/output permutation will be MSB first or LSB first. At initial reset, this register is set to "0". ## SCTRG: Clock trigger/status (FF70H•D1) This is a trigger to start input/output of synchronous clock (SCLK). #### • When writing When "1" is written: Trigger When "0" is written: No operation When this trigger is supplied to the serial interface activating circuit, the synchronous clock (SCLK) input/output is started. As a trigger condition, it is required that data writing or reading on data registers SD0–SD7 be performed prior to writing "1" to SCTRG. (The internal circuit of the serial interface is initiated through data writing/reading on data registers SD0–SD7.) In addition, be sure to enable the serial interface with the ESIF register before setting the trigger. Supply trigger only once every time the serial interface is placed in the RUN state. Refrain from performing trigger input multiple times, as leads to malfunctioning. Moreover, when the synchronous clock $\overline{SCLK}$ is external clock, start to input the external clock after the trigger. #### • When reading When "1" is read: RUN (during input/output the synchronous clock) When "0" is read: STOP (the synchronous clock stops) Writing: Invalid When this bit is read, it indicates the status of serial interface clock. After "1" is written to SCTRG, this value is latched till serial interface clock stops (8 clock counts). Therefore, if "1" is read, it indicates that the synchronous clock is in input/output operation. When the synchronous clock input/output is completed, this latch is reset to "0". At initial reset, this bit is set to "0". ## SD0-SD3, SD4-SD7: Serial interface data register (FF72H, FF73H) These registers are used for writing and reading serial data. #### • When writing When "1" is written: High level When "0" is written: Low level Write data to be output in these registers. The register data is converted into serial data and output from the SOUT (P11) terminal; data bits set at "1" are output as high (VDD) level and data bits set at "0" are output as low (VSS) level. #### • When reading When "1" is read: High level When "0" is read: Low level The serial data input from the SIN (P10) terminal can be read from these registers. The serial data input from the SIN (P10) terminal is converted into parallel data, as a high (VDD) level bit into "1" and as a low (VSS) level bit into "0", and is loaded to these registers. Perform data reading only while the serial interface is not running (i.e., the synchronous clock is neither being input or output). At initial reset, these registers are undefined. #### EISIF: Interrupt mask register (FFE3H•D0) Masking the interrupt of the serial interface can be selected with this register. When "1" is written: Enabled When "0" is written: Masked Reading: Valid With this register, it is possible to select whether the serial interface interrupt is to be masked or not. At initial reset, this register is set to "0". ## ISIF: Interrupt factor flag (FFF3H•D0) This flag indicates the occurrence of serial interface interrupt. When "1" is read: Interrupt has occurred When "0" is read: Interrupt has not occurred When "1" is written: Flag is reset When "0" is written: Invalid From the status of this flag, the software can decide whether the serial interface interrupt. This flag is set to "1" after an 8-bit data input/output even if the interrupt is masked. This flag is reset to "0" by writing "1" to it. After an interrupt occurs, the same interrupt will occur again if the interrupt enabled state (I flag = "1") is set or the RETI instruction is executed unless the interrupt factor flag is reset. Therefore, be sure to reset (write "1" to) the interrupt factor flag in the interrupt service routine before shifting to the interrupt enabled state. At initial reset, this flag is set to "0". ## 4.11.6 Programming notes - (1) Perform data writing/reading to the data registers SD0–SD7 only while the serial interface is not running (i.e., the synchronous clock is neither being input or output). - (2) As a trigger condition, it is required that data writing or reading on data registers SD0–SD7 be performed prior to writing "1" to SCTRG. (The internal circuit of the serial interface is initiated through data writing/reading on data registers SD0–SD7.) In addition, be sure to enable the serial interface with the ESIF register before setting the trigger. Supply trigger only once every time the serial interface is placed in the RUN state. Refrain from performing trigger input multiple times, as leads to malfunctioning. Moreover, when the synchronous clock SCLK is external clock, start to input the external clock after the trigger. - (3) Setting of the input/output permutation (MSB first/LSB first) with the SDP register should be done before setting data to SD0–SD7. - (4) Be aware that the maximum clock frequency for the serial interface is limited to 1 MHz when OSC3 is used as the clock source of the programmable timer or in the slave mode. - (5) After an interrupt occurs, the same interrupt will occur again if the interrupt enabled state (I flag = "1") is set or the RETI instruction is executed unless the interrupt factor flag is reset. Therefore, be sure to reset (write "1" to) the interrupt factor flag in the interrupt service routine before shifting to the interrupt enabled state. ## 4.12 Sound Generator ## 4.12.1 Configuration of sound generator The S1C63454 has a built-in sound generator for generating buzzer signals. Hence, generated buzzer signals (BZ) can be output from the BZ terminal. Aside permitting the respective setting of the buzzer signal frequency and sound level to 8 stages, it permits the adding of a digital envelope by means of duty ratio control. It also has a one-shot output function for outputting key operated sounds. Figure 4.12.1.1 shows the configuration of the sound generator. Fig. 4.12.1.1 Configuration of sound generator Note: The buzzer signal is generated by dividing the OSC1 oscillation clock. Since the frequencies and times that are described in this section are the values in the case of crystal oscillation (32.768 kHz, Typ.), they differ when CR oscillation (60 kHz, Typ.) is selected. ## 4.12.2 Mask option Polarity of the BZ signal output from the BZ terminal can be selected as either positive polarity or negative polarity by mask option. Figure 4.12.2.1 shows each output circuit configuration and the output waveform When positive polarity is selected, the BZ terminal goes to a low (Vss) level when the BZ signal is OFF. Select positive polarity when driving a piezo buzzer by externally connecting an NPN transistor. When negative polarity is selected, the BZ terminal goes to a high (VDD) level when the BZ signal is OFF. Select negative polarity when driving a piezo buzzer by externally connecting a PNP transistor. (a) When positive polarity is selected (b) When negative polarity is selected Fig. 4.12.2.1 Configuration of output circuit ## 4.12.3 Control of buzzer output The BZ signal generated by the sound generator is output from the BZ terminal by setting "1" for the buzzer output enable register BZE. When "0" is set to BZE register, the output terminal shifts to the low (VSS) level (negative polarity) or high (VDD) level (positive polarity). Fig. 4.12.3.1 Buzzer signal output timing chart Note: Since it generates a BZ signal that is out of synchronization with the BZE register, hazards may at times be produced when the signal goes ON/OFF due to the setting of the BZE register. ## 4.12.4 Setting of buzzer frequency and sound level The divided signal of the OSC1 oscillation clock (32.768 kHz) is used for the buzzer (BZ) signal and it is set up such that 8 types of frequencies can be selected by changing this division ratio. Frequency selection is done by setting the buzzer frequency selection registers BZFQ0–BZFQ2 as shown in Table 4.12.4.1. | BZFQ2 | BZFQ1 | BZFQ0 | Buzzer frequency (Hz) | | | | |-------|-------|-------|-----------------------|--|--|--| | 0 | 0 | 0 | 4096.0 | | | | | 0 | 0 | 1 | 3276.8 | | | | | 0 | 1 | 0 | 2730.7 | | | | | 0 | 1 | 1 | 2340.6 | | | | | 1 | 0 | 0 | 2048.0 | | | | | 1 | 0 | 1 | 1638.4 | | | | | 1 | 1 | 0 | 1365.3 | | | | | 1 | 1 | 1 | 1170.3 | | | | Table 4.12.4.1 Buzzer signal frequency setting The buzzer sound level is changed by controlling the duty ratio of the buzzer signal. The duty ratio can be selected from among the 8 types shown in Table 4.12.4.2 according to the setting of the buzzer duty selection registers BDTY0–BDTY2. | | | | | Duty ratio by buzzer frequency (Hz) | | | | | | |----------------|-------|-------|-------|-------------------------------------|--------|--------|--------|--|--| | Level | BDTY2 | BDTY1 | BDTY0 | 4096.0 | 3276.8 | 2730.7 | 2340.6 | | | | | | | | 2048.0 | 1638.4 | 1365.3 | 1170.3 | | | | Level 1 (Max.) | 0 | 0 | 0 | 8/16 | 8/20 | 12/24 | 12/28 | | | | Level 2 | 0 | 0 | 1 | 7/16 | 7/20 | 11/24 | 11/28 | | | | Level 3 | 0 | 1 | 0 | 6/16 | 6/20 | 10/24 | 10/28 | | | | Level 4 | 0 | 1 | 1 | 5/16 | 5/20 | 9/24 | 9/28 | | | | Level 5 | 1 | 0 | 0 | 4/16 | 4/20 | 8/24 | 8/28 | | | | Level 6 | 1 | 0 | 1 | 3/16 | 3/20 | 7/24 | 7/28 | | | | Level 7 | 1 | 1 | 0 | 2/16 | 2/20 | 6/24 | 6/28 | | | | Level 8 (Min.) | 1 | 1 | 1 | 1/16 | 1/20 | 5/24 | 5/28 | | | Table 4.12.4.2 Duty ratio setting When the HIGH level output time has been made TH and when the LOW level output time has been made TL due to the ratio of the pulse width to the pulse synchronization, the duty ratio becomes TL/(TH+TL) for negative polarity or TH/(TH+TL) for positive polarity. When BDTY0-BDTY2 have all been set to "0", the duty ratio becomes maximum and the sound level also becomes maximum. Conversely, when BDTY0-BDTY2 have all been set to "1", the duty ratio becomes minimum and the sound level also becomes minimum. The duty ratio that can be set is different depending on the frequency that has been set, so see Table 4.12.4.2. Fig. 4.12.4.1 Duty ratio of the buzzer signal waveform Note: When a digital envelope has been added to the buzzer signal, the BDTY0–BDTY2 settings will be invalid due to the control of the duty ratio. ## 4.12.5 Digital envelope A digital envelope for duty control can be added to the buzzer signal. The envelope can be controlled by staged changing of the same duty envelope as detailed in Table 4.12.4.2 in the preceding item from level 1 (maximum) to level 8 (minimum). The addition of an envelope to the buzzer signal can be done by writing "1" into ENON, but when "0" has been written it is not added. When a buzzer signal output is begun (writing "1" into BZE) after setting ENON, the duty ratio shifts to level 1 (maximum) and changes in stages to level 8. When attenuated down to level 8 (minimum), it is retained at that level. The duty ratio can be returned to maximum, by writing "1" into register ENRST during output of a envelope attached buzzer signal. The envelope attenuation time (time for changing of the duty ratio) can be selected by the register ENRTM. The time for a 1 stage level change is 62.5 msec (16 Hz), when "0" has been written into ENRTM and 125 msec (8 Hz), when to "1" has been written. However, there is also a max. 4 msec error from envelope ON, up to the first change. Figure 4.12.5.1 shows the timing chart of the digital envelope. Fig. 4.12.5.1 Timing chart for digital envelope ## 4.12.6 One-shot output The sound generator has a one-shot output function for outputting a short duration buzzer signal for key operation sounds and similar effects. Either 125 msec or 31.25 msec can be selected by SHTPW register for one-shot buzzer signal output time. The output of the one-shot buzzer is controlled by writing "1" into the one-shot buzzer trigger BZSHT. When this trigger has been assigned, a buzzer signal in synchronization with the internal 256 Hz signal is output from the BZ terminal. Thereafter, when the set time has elapsed, a buzzer signal in synchronization with the 256 Hz signal goes off in the same manner as for the start of output. The BZSHT also permits reading. When BZSHT is "1", the one-shot output circuit is in operation (during one-shot output) and when it is "0", it shows that the circuit is in the ready (outputtable) status. In addition, it can also terminate one-shot output prior to the elapsing of the set time. This is done by writing a "1" into the one-shot buzzer stop BZSTP. In this case as well, the buzzer signal goes OFF in synchronization with the 256 Hz signal. When "1" is written to BZSHT again during a one-shot output, a new one-shot output for 125 msec or 31.25 msec starts from that point (in synchronization with the 256 Hz signal). The one-shot output cannot add an envelope for short durations. However, the sound level can be set by selecting the duty ratio, and the frequency can also be set. One-shot output is invalid during normal buzzer output (during BZE = "1"). Figure 4.12.6.1 shows timing chart for one-shot output. Fig. 4.12.6.1 Timing chart for one-shot output ## 4.12.7 I/O memory of sound generator Table 4.12.7.1 shows the I/O addresses and the control bits for the sound generator. Table 4.12.7.1 Control bits of sound generator | | | | | | | | | | Sound Senerator | | | | | |---------|------------------|---------|------------|---------|---------|---------|----------|---------------------------------|----------------------------------------------------------------------------|--|--|--|--| | Addross | Address Register | | | | | | Comment | | | | | | | | Address | D3 | D2 | D1 | D0 | Name | Init *1 | 1 | 0 | Comment | | | | | | | ENDIN | | ENION | BZE | ENRTM | 0 | 1 sec | 0.5 sec | Envelope releasing time | | | | | | FFCOLL | ENRTM | ENRST | ENON | | ENRST*3 | Reset | Reset | Invalid | Envelope reset (writing) | | | | | | FF6CH | - Davi | | | | ENON | 0 | On | Off | Envelope On/Off | | | | | | | R/W | W | H/ | W | BZE | 0 | Enable | Disable | Buzzer output enable | | | | | | | | | | | 0 *3 | - *2 | | | Unused | | | | | | | 0 | BZSTP | BZSHT | SHTPW | BZSTP*3 | 0 | Stop | Invalid | 1-shot buzzer stop (writing) | | | | | | FF6DH | | | | BZSHT | 0 | Trigger | Invalid | 1-shot buzzer trigger (writing) | | | | | | | | R | W | R/W | | | | Busy | Ready | 1-shot buzzer status (reading) | | | | | | | | | 11/ | ** | SHTPW | 0 | 125 msec | 31.25 msec | 1-shot buzzer pulse width setting | | | | | | | | BZFQ2 | ZFQ2 BZFQ1 | BZEON I | 0 *3 | _ *2 | | | Unused | | | | | | FECELL | 0 | | | | BZFQ2 | 0 | | | Buzzer [BZFQ2, 1, 0] 0 1 2 3<br>Frequency (Hz) 4096.0 3276.8 2730.7 2340.6 | | | | | | FF6EH | | | | | | 0 | | | frequency [BZFQ2, 1, 0] 4 5 6 7 | | | | | | | R | | R/W | | BZFQ0 | 0 | | | selection Frequency (Hz) 2048.0 1638.4 1365.3 1170.3 | | | | | | | _ | DDT) (0 | | DDT) (a | 0 *3 | - *2 | | | Unused | | | | | | FEOFU | 0 | BDTY2 | BDTY1 | BDTY0 | BDTY2 | 0 | | | Decree sinced data artis advation | | | | | | FF6FH | | | | | BDTY1 | 0 | | | Buzzer signal duty ratio selection | | | | | | | R | | R/W | | BDTY0 | 0 | | | (refer to main manual) | | | | | <sup>\*1</sup> Initial value at initial reset ## BZE: BZ output control register (FF6CH•D0) Controls the buzzer (BZ) signal output. When "1" is written: BZ output ON When "0" is written: BZ output OFF Reading: Valid When "1" is written to BZE, the BZ signal is output from the BZ terminal. When "0" is written, the BZ terminal goes to a high (VDD) level. At initial reset, this register is set to "0". ## BZFQ0-BZFQ2: Buzzer frequency selection register (FF6EH•D0-D2) Selects the buzzer signal frequency. Table 4.12.7.2 Buzzer signal frequency setting | BZFQ2 | BZFQ1 | BZFQ0 | Buzzer frequency (Hz) | |-------|-------|-------|-----------------------| | 0 | 0 | 0 | 4096.0 | | 0 | 0 | 1 | 3276.8 | | 0 | 1 | 0 | 2730.7 | | 0 | 1 | 1 | 2340.6 | | 1 | 0 | 0 | 2048.0 | | 1 | 0 | 1 | 1638.4 | | 1 | 1 | 0 | 1365.3 | | 1 | 1 | 1 | 1170.3 | Select the buzzer frequency from among the above 8 types that have divided the oscillation clock. At initial reset, this register is set to "0". <sup>\*2</sup> Not set in the circuit <sup>\*3</sup> Constantly "0" when being read ## BDTY0-BDTY2: Duty level selection register (FF6FH•D0-D2) Selects the duty ratio of the buzzer signal as shown in Table 4.12.7.3. Table 4.12.7.3 Duty ratio setting | | | | | Duty ratio by buzzer frequency (Hz) | | | | | |----------------|-------|-------|-------|-------------------------------------|--------|--------|--------|--| | Level | BDTY2 | BDTY1 | BDTY0 | 4096.0 | 3276.8 | 2730.7 | 2340.6 | | | | | | | 2048.0 | 1638.4 | 1365.3 | 1170.3 | | | Level 1 (Max.) | 0 | 0 | 0 | 8/16 | 8/20 | 12/24 | 12/28 | | | Level 2 | 0 | 0 | 1 | 7/16 | 7/20 | 11/24 | 11/28 | | | Level 3 | 0 | 1 | 0 | 6/16 | 6/20 | 10/24 | 10/28 | | | Level 4 | 0 | 1 | 1 | 5/16 | 5/20 | 9/24 | 9/28 | | | Level 5 | 1 | 0 | 0 | 4/16 | 4/20 | 8/24 | 8/28 | | | Level 6 | 1 | 0 | 1 | 3/16 | 3/20 | 7/24 | 7/28 | | | Level 7 | 1 | 1 | 0 | 2/16 | 2/20 | 6/24 | 6/28 | | | Level 8 (Min.) | 1 | 1 | 1 | 1/16 | 1/20 | 5/24 | 5/28 | | The sound level of this buzzer can be set by selecting this duty ratio. However, when the envelope has been set to ON (ENON = "1"), this setting becomes invalid. At initial reset, this register is set to "0". ## ENRST: Envelope reset (FF6CH•D2) Resets the envelope. When "1" is written: Reset When "0" is written: No operation Reading: Always "0" Writing "1" into ENRST resets envelope and the duty ratio becomes maximum. If an envelope has not been added (ENON = "0") and if no buzzer signal is being output, the reset becomes invalid. Writing "0" is also invalid. This bit is dedicated for writing, and is always "0" for reading. ## ENON: Envelope ON/OFF control register (FF6CH•D1) Controls the addition of an envelope onto the buzzer signal. When "1" is written: ON When "0" is written: OFF Reading: Valid Writing "1" into the ENON causes an envelope to be added during buzzer signal output. When a "0" has been written, an envelope is not added. At initial reset, this register is set to "0". #### **ENRTM:** Envelope releasing time selection register (FF6CH•D3) Selects the envelope releasing time that is added to the buzzer signal. When "1" is written: $1.0 \sec (125 \operatorname{msec} \times 7 = 875 \operatorname{msec})$ When "0" is written: $0.5 \sec (62.5 \operatorname{msec} \times 7 = 437.5 \operatorname{msec})$ Reading: Valid The releasing time of the digital envelope is determined by the time for converting the duty ratio. When "1" has been written in ENRTM, it becomes 125 msec (8 Hz) units and when "0" has been written, it becomes 62.5 msec (16 Hz) units. At initial reset, this register is set to "0". #### **CHAPTER 4: PERIPHERAL CIRCUITS AND OPERATION (Sound Generator)** ## SHTPW: One-shot buzzer pulse width setting register (FF6DH•D0) Selects the output time of the one-shot buzzer. When "1" is written: 125 msec When "0" is written: 31.25 msec Reading: Valid Writing "1" into SHTPW causes the one-short output time to be set at 125 msec, and writing "0" causes it to be set to 31.25 msec. It does not affect normal buzzer output. At initial reset, this register is set to "0". ## BZSHT: One-shot buzzer trigger/status (FF6DH•D1) Controls the one-shot buzzer output. #### • When writing When "1" is written: Trigger When "0" is written: No operation Writing "1" into BZSHT causes the one-short output circuit to operate and a buzzer signal to be output. This output is automatically turned OFF after the time set by SHTPW has elapsed. The one-shot output is only valid when the normal buzzer output is OFF (BZE = "0") and will be invalid when the normal buzzer output is ON (BZE = "1"). When a re-trigger is assigned during a one-shot output, the one-shot output time set with SHTPW is measured again from that point (time extension). #### • When reading When "1" is read: BUSY When "0" is read: READY During reading BZSHT shows the operation status of the one-shot output circuit. During one-shot output, BZSHT becomes "1" and the output goes OFF, it shifts to "0". At initial reset, this bit is set to "0". ## BZSTP: One-shot buzzer stop (FF6DH•D2) Stops the one-shot buzzer output. When "1" is written: Stop When "0" is written: No operation Reading: Always "0" Writing "1" into BZSTP permits the one-shot buzzer output to be turned OFF prior to the elapsing of the time set by SHTPW. Writing "0" is invalid and writing "1" is also invalid except during one-shot output. This bit is dedicated for writing, and is always "0" for reading. ## 4.12.8 Programming notes - (1) Since it generates a BZ signal that is out of synchronization with the BZE register, hazards may at times be produced when the signal goes ON/OFF due to the setting of the BZE register. - (2) The one-shot output is only valid when the normal buzzer output is OFF (BZE = "0") and will be invalid when the normal buzzer output is ON (BZE = "1"). - (3) The buzzer signal is generated by dividing the OSC1 oscillation clock. Since the frequencies and times that are described in this section are the values in the case of crystal oscillation (32.768 kHz, Typ.), they differ when CR oscillation (60 kHz, Typ.) is selected. ## 4.13 Interrupt and HALT ## <Interrupt types> The S1C63454 provides the following interrupt functions. External interrupt: • Input interrupt (1 system) Internal interrupt: • Watchdog timer interrupt (NMI, 1 system) Programmable timer interrupt Serial interface interrupt Timer interrupt Stopwatch timer interrupt (2 systems) (4 systems) (2 systems) To authorize interrupt, the interrupt flag must be set to "1" (EI) and the necessary related interrupt mask registers must be set to "1" (enable). When an interrupt occurs the interrupt flag is automatically reset to "0" (DI), and interrupts after that are inhibited. The watchdog timer interrupt is an NMI (non-maskable interrupt), therefore, the interrupt is generated regardless of the interrupt flag setting. Also the interrupt mask register is not provided. However, it is possible to not generate NMI since software can stop the watchdog timer operation. Figure 4.13.1 shows the configuration of the interrupt circuit. Note: After an initial reset, all the interrupts including NMI are masked until both the stack pointers SP1 and SP2 are set with the software. Be sure to set the SP1 and SP2 in the initialize routine. Further, when re-setting the stack pointer, the SP1 and SP2 must be set as a pair. When one of them is set, all the interrupts including NMI are masked and interrupts cannot be accepted until the other one is set. #### <HALT> The S1C63454 has HALT functions that considerably reduce the current consumption when it is not necessary. The CPU enters HALT status when the HALT instruction is executed. In HALT status, the operation of the CPU is stopped. However, timers continue counting since the oscillation circuit operates. Reactivating the CPU from HALT status is done by generating a hardware interrupt request including NMI. Fig. 4.13.1 Configuration of the interrupt circuit ## 4.13.1 Interrupt factor Table 4.13.1.1 shows the factors for generating interrupt requests. The interrupt flags are set to "1" depending on the corresponding interrupt factors. The CPU operation is interrupted when an interrupt factor flag is set to "1" if the following conditions are established. - The corresponding mask register is "1" (enabled) - The interrupt flag is "1" (EI) The interrupt factor flag is reset to "0" when "1" is written. At initial reset, the interrupt factor flags are reset to "0". \* Since the watchdog timer's interrupt is NMI, the interrupt is generated regardless of the setting above, and no interrupt factor flag is provided. Table 4.13.1.1 Interrupt factors | Interrupt factor | Interru | ıpt fa | |-------------------------------------------------------|---------|--------| | Programmable timer 1 (counter = 0) | IPT1 | (F | | Programmable timer 0 (counter = 0) | IPT0 | (F | | Serial interface (8-bit data input/output completion) | ISIF | (F | actor flag P FFF2H•D1) P FFF2H•D0) FFF3H•D0) K00-K03 input (falling edge or rising edge) IK0 (FFF4H•D0) Clock timer 1 Hz (falling edge) IT3 (FFF6H•D3) Clock timer 2 Hz (falling edge) IT2 (FFF6H•D2) IT1 (FFF6H•D1) Clock timer 8 Hz (falling edge) Clock timer 32 Hz (falling edge) IT0 (FFF6H•D0) Stopwatch timer (1 Hz) ISW1 (FFF7H•D1) Stopwatch timer (10 Hz) ISW10 (FFF7H•D0) Note: After an interrupt occurs, the same interrupt will occur again if the interrupt enabled state (I flag = "1") is set or the RETI instruction is executed unless the interrupt factor flag is reset. Therefore, be sure to reset (write "1" to) the interrupt factor flag in the interrupt service routine before shifting to the interrupt enabled state. ## 4.13.2 Interrupt mask The interrupt factor flags can be masked by the corresponding interrupt mask registers. The interrupt mask registers are read/write registers. They are enabled (interrupt authorized) when "1" is written to them, and masked (interrupt inhibited) when "0" is written to them. At initial reset, the interrupt mask register is set to "0". Table 4.13.2.1 shows the correspondence between interrupt mask registers and interrupt factor flags. | and the second of the second s | | | | | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-----------------------|------------|--|--|--|--| | Interrupt r | nask register | Interrupt factor flag | | | | | | | EIPT1 | (FFE2H•D1) | IPT1 | (FFF2H•D1) | | | | | | EIPT0 | (FFE2H•D0) | IPT0 | (FFF2H•D0) | | | | | | EISIF | (FFE3H•D0) | ISIF | (FFF3H•D0) | | | | | | EIK0 | (FFE4H•D0) | IK0 | (FFF4H•D0) | | | | | | EIT3 | (FFE 6H•D3) | IT3 | (FFF6H•D3) | | | | | | EIT2 | (FFE6H•D2) | IT2 | (FFF6H•D2) | | | | | | EIT1 | (FFE6H•D1) | IT1 | (FFF6H•D1) | | | | | | EIT0 | (FFE6H•D0) | IT0 | (FFF6H•D0) | | | | | | EISW1 | (FFE7H•D1) | ISW1 | (FFF7H•D1) | | | | | | EISW10 | (FFE7H•D0) | ISW10 | (FFF7H•D0) | | | | | Table 4.13.2.1 Interrupt mask registers and interrupt factor flags ## 4.13.3 Interrupt vector When an interrupt request is input to the CPU, the CPU begins interrupt processing. After the program being executed is terminated, the interrupt processing is executed in the following order. - 1 The content of the flag register is evacuated, then the I flag is reset. - 2 The address data (value of program counter) of the program to be executed next is saved in the stack area (RAM). - 3 The interrupt request causes the value of the interrupt vector (0100H–010EH) to be set in the program counter - 4 The program at the specified address is executed (execution of interrupt processing routine by software). Table 4.13.3.1 shows the correspondence of interrupt requests and interrupt vectors. | Interrupt vector | Interrupt factor | Priority | | | | |------------------|--------------------|----------|--|--|--| | 0100H | Watchdog timer | High | | | | | 0104H | Programmable timer | <b>↑</b> | | | | | 0106H | Serial interface | · | | | | | 0108H | K00-K03 input | | | | | | 010CH | Clock timer | ↓ | | | | | 010EH | Stopwatch timer | Low | | | | Table 4.13.3.1 Interrupt request and interrupt vectors The four low-order bits of the program counter are indirectly addressed through the interrupt request. ## 4.13.4 I/O memory of interrupt Table 4.13.4.1 shows the I/O addresses and the control bits for controlling interrupts. Table 4.13.4.1 Control bits of interrupt | | | Reg | ister | | | | | | | |-----------|---------|-----------|---------|--------------|----------------|--------------|------------------------------------------------|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Address | D3 | D2 | D1 | D0 | Name | Init *1 | 1 | 0 | Comment | | | | | | | SIK03 | 0 | Enable | Disable | 7 | | FF20H SI | SIK03 | SIK02 | SIK01 | SIK00 | SIK02 | 0 | Enable | Disable | Woo Wood and a state of the sta | | | | | | SIK01 | 0 | Enable | Disable | K00–K03 interrupt selection register | | | | | R/ | W | | SIK00 | 0 | Enable | Disable | | | | L/ODOO | KODOO | I/OD04 | L/ODOO | KCP03 | 1 | T_ | | 7 | | FEOOLI | KCP03 | KCP02 | KCP01 | KCP00 | KCP02 | 1 | ¬₽_ | ſ | V00 V02 input comparison register | | FF22H | R/W | | | KCP01 | 1 | Į. | | K00–K03 input comparison register | | | R | | W | | KCP00 | 1 | ا ا | 4 | | | | FFE2H | _ | 0 0 EIPT1 | | EIPT0 | 0 *3 | | | Unused | | | | U | | | EIPTU | 0 *3 | _ *2 | | | Unused | | 11 L211 | R | | R/W | | EIPT1<br>EIPT0 | 0 | Enable | Mask | Interrupt mask register (Programmable timer 1) | | | | 1 | ΠV | ri/VV | | 0 | Enable | Mask | Interrupt mask register (Programmable timer 0) | | | 0 | 0 | 0 | EISIF | 0 *3 | _ *2 | | | Unused | | FFE3H | U | 0 0 | | LIGII | 0 *3 | - *2 | | | Unused | | 111 2011 | | R | | R/W | 0 *3 | _ *2 | | | Unused | | | | | | 1000 | EISIF | 0 | Enable | Mask | Interrupt mask register (Serial I/F) | | | 0 | 0 | 0 | EIK0 | 0 *3 | - *2 | | | Unused | | FFE4H | | • | | Liito | 0 *3 | _ *2 | | | Unused | | | | R | | R/W | 0 *3 | _ *2 | | | Unused | | | | | | 1000 | EIK0 | 0 | Enable | Mask | Interrupt mask register (K00–K03) | | FFE6H EI | EIT3 | EIT2 | EIT1 | EIT0 | EIT3 | 0 | Enable | Mask | Interrupt mask register (Clock timer 1 Hz) | | | | | | | EIT2 | 0 | Enable | Mask | Interrupt mask register (Clock timer 2 Hz) | | | | R/ | W | | EIT1 | 0 | Enable | Mask | Interrupt mask register (Clock timer 8 Hz) | | | | | | | EIT0 | 0<br>_ *2 | Enable | Mask | Interrupt mask register (Clock timer 32 Hz) | | | 0 | 0 | EISW1 | EISW10 | 0 *3<br>0 *3 | - *2<br>- *2 | | | Unused | | FFE7H | | | | | EISW1 | 0 | Enable | Mask | Unused | | | R R/W | | EISW10 | 0 | Enable | Mask | Interrupt mask register (Stopwatch timer 1 Hz) | | | | | | - | | | | _ *2 | (R) | (R) | Interrupt mask register (Stopwatch timer 10 Hz) Unused | | | 0 | 0 | IPT1 | IPT0 | 0 *3<br>0 *3 | _ *2 | Yes | No | Unused | | FFF2H | | | | | | 0 | (W) | (W) | Interrupt factor flag (Programmable timer 1) | | | R R/W | | W | IPT1<br>IPT0 | 0 | Reset | Invalid | Interrupt factor flag (Programmable timer 0) | | | | | | | | 0 *3 | _ *2 | (R) | (R) | Unused | | | 0 | 0 | 0 | ISIF | 0 *3 | _ *2 | Yes | No | Unused | | FFF3H | | | | | 0 *3 | - *2 | (W) | (W) | Unused | | | R F | | R/W | ISIF | 0 | Reset | Invalid | Interrupt factor flag (Serial I/F) | | | | | | | | 0 *3 | _ *2 | (R) | (R) | Unused | | | 0 | 0 | 0 | IK0 | 0 *3 | - *2 | Yes | No | Unused | | FFF4H | | _ | | | 0 *3 | _ *2 | (W) | (W) | Unused | | | R R | | R/W | IK0 | 0 | Reset | Invalid | Interrupt factor flag (K00–K03) | | | FFF6H | ITO | ITO | IT4 | ITO | IT3 | 0 | (R) | (R) | Interrupt factor flag (Clock timer 1 Hz) | | | IT3 IT2 | | IT1 IT0 | IT2 | 0 | Yes | No | Interrupt factor flag (Clock timer 2 Hz) | | | | DM | | | IT1 | 0 | (W) | (W) | Interrupt factor flag (Clock timer 8 Hz) | | | | R/W | | | IT0 | 0 | Reset | Invalid | Interrupt factor flag (Clock timer 32 Hz) | | | | 0 | 0 | 10/1/1 | ISW10 | 0 *3 | _ *2 | (R) | (R) | Unused | | FFF7H | 0 0 | U | ISW1 | ISW10 | 0 *3 | _ *2 | Yes | No | Unused | | ' ' ' ' ' | R | | R/W | | ISW1 | 0 | (W) | (W) | Interrupt factor flag (Stopwatch timer 1 Hz) | | | | | | | ISW10 | 0 | Reset | Invalid | Interrupt factor flag (Stopwatch timer 10 Hz) | <sup>\*1</sup> Initial value at initial reset <sup>\*2</sup> Not set in the circuit <sup>\*3</sup> Constantly "0" when being read EIPT1, EIPT0: Interrupt mask registers (FFE2H•D1, D0) IPT1, IPT0: Interrupt factor flags (FFF2H•D1, D0) Refer to Section 4.10, "Programmable Timer". EISIF: Interrupt mask register (FFE3H•D0) ISIF: Interrupt factor flag (FFF3H•D0) Refer to Section 4.11, "Serial Interface". KCP03-KCP00: Input comparison registers (FF22H) SIK03-SIK00: Interrupt selection registers (FF20H) EIK0: Interrupt mask register (FFE4H•D0) IK0: Interrupt factor flag (FFF4H•D0) Refer to Section 4.4, "Input Ports". EIT3-EIT0: Interrupt mask registers (FFE6H) IT3-IT0: Interrupt factor flags (FFF6H) Refer to Section 4.8, "Clock Timer". EISW1, EISW10: Interrupt mask registers (FFE7H•D1, D0) ISW1, ISW10: Interrupt factor flags (FFF7H•D1, D0) Refer to Section 4.9, "Stopwatch Timer". ## 4.13.5 Programming notes - (1) The interrupt factor flags are set when the interrupt condition is established, even if the interrupt mask registers are set to "0". - (2) After an interrupt occurs, the same interrupt will occur again if the interrupt enabled state (I flag = "1") is set or the RETI instruction is executed unless the interrupt factor flag is reset. Therefore, be sure to reset (write "1" to) the interrupt factor flag in the interrupt service routine before shifting to the interrupt enabled state. - (3) After an initial reset, all the interrupts including NMI are masked until both the stack pointers SP1 and SP2 are set with the software. Be sure to set the SP1 and SP2 in the initialize routine. Further, when re-setting the stack pointer, the SP1 and SP2 must be set as a pair. When one of them is set, all the interrupts including NMI are masked and interrupts cannot be accepted until the other one is set. ## CHAPTER 5 SUMMARY OF NOTES ## 5.1 Notes for Low Current Consumption The S1C63454 contains control registers for each of the circuits so that current consumption can be reduced. These control registers reduce the current consumption through programs that operate the circuits at the minimum levels. The following lists the circuits that can control operation and their control registers. Refer to these when programming. Table 5.1.1 Circuits and control registers | Circuit (and item) | Control register | | |--------------------------------------|------------------|--| | CPU | HALT instruction | | | CPU operating frequency | CLKCHG, OSCC | | | Oscillation system voltage regulator | VDC | | | LCD system voltage circuit | LPWR | | Refer to Chapter 7, "Electrical Characteristics" for current consumption. Below are the circuit statuses at initial reset. CPU: Operating status **CPU operating frequency**: Low speed side (CLKCHG = "0") OSC3 oscillation circuit is in OFF status (OSCC = "0") Oscillation system voltage regulator: Low speed side 1.3 V (VDC = "0") However, it is fixed at 2.2 V when the CR oscillation circuit has been selected as the OSC1 oscillation circuit. Whether the VDC register value is "0" or "1" does not matter. **LCD system voltage circuit**: OFF status (LPWR = "0") Also, be careful about panel selection because the current consumption can differ by the order of several $\mu A$ on account of the LCD panel characteristics. ## 5.2 Summary of Notes by Function Here, the cautionary notes are summed up by function category. Keep these notes well in mind when programming. ## Memory and stack - (1) Memory is not implemented in unused areas within the memory map. Further, some non-implementation areas and unused (access prohibition) areas exist in the display memory area and the peripheral I/O area. If the program that accesses these areas is generated, its operation cannot be guaranteed. Refer to Section 4.7.5, "Display memory", for the display memory, and the I/O memory maps shown in Tables 4.1.1 (a)–(d) for the peripheral I/O area. - (2) Part of the RAM area is used as a stack area for subroutine call and register evacuation, so pay attention not to overlap the data area and stack area. - (3) The S1C63000 core CPU handles the stack using the stack pointer for 4-bit data (SP2) and the stack pointer for 16-bit data (SP1). - 16-bit data are accessed in stack handling by SP1, therefore, this stack area should be allocated to the area where 4-bit/16-bit access is possible (0100H to 01FFH). The stack pointers SP1 and SP2 change cyclically within their respective range: the range of SP1 is 0000H to 03FFH and the range of SP2 is 0000H to 00FFH. Therefore, pay attention to the SP1 value because it may be set to 0200H or more exceeding the 4-bit/16-bit accessible range in the S1C63454 or it may be set to 00FFH or less. Memory accesses except for stack operations by SP1 are 4-bit data access. - After initial reset, all the interrupts including NMI are masked until both the stack pointers SP1 and SP2 are set by software. Further, if either SP1 or SP2 is re-set when both are set already, the interrupts including NMI are masked again until the other is re-set. Therefore, the settings of SP1 and SP2 must be done as a pair. ## Watchdog timer - (1) When the watchdog timer is being used, the software must reset it within 3-second cycles. - (2) Because the watchdog timer is set in operation state by initial reset, set the watchdog timer to disabled state (not used) before generating an interrupt (NMI) if it is not used. ## **Oscillation circuit** - (1) When switching the CPU system clock from OSC1 to OSC3, first set VD1. After that maintain 2.5 msec or more, and then turn the OSC3 oscillation ON. When switching from OSC3 to OSC1, set VD1 after switching to OSC1 and turning the OSC3 oscillation OFF. However, when the CR oscillation circuit has been selected as the OSC1 oscillation circuit, it is not necessary to set VD1. - (2) It takes at least 5 msec from the time the OSC3 oscillation circuit goes ON until the oscillation stabilizes. Consequently, when switching the CPU operation clock from OSC1 to OSC3, do this after a minimum of 5 msec have elapsed since the OSC3 oscillation went ON. Further, the oscillation stabilization time varies depending on the external oscillator characteristics and conditions of use, so allow ample margin when setting the wait time. - (3) When switching the clock form OSC3 to OSC1, use a separate instruction for switching the OSC3 oscillation OFF. An error in the CPU operation can result if this processing is performed at the same time by the one instruction. - (4) When the CR oscillation circuit has been selected as the OSC1 oscillation circuit by mask option, it is not necessary to switch the operating voltage VD1 using the VDC register and the VD1 voltage is fixed at 2.2 V. The VD1 level does not change even if any data is written to the VDC register. ## Input port When input ports are changed from low to high by pull-up resistors, the rise of the waveform is delayed on account of the time constant of the pull-up resistor and input gate capacitance. Hence, when fetching input ports, set an appropriate waiting time. Particular care needs to be taken of the key scan during key matrix configuration. Make this waiting time the amount of time or more calculated by the following expression. $10 \times C \times R$ C: terminal capacitance 5 pF + parasitic capacitance ? pF R: pull-up resistance 330 k $\Omega$ ## **Output port** - (1) When using the output port (R02, R03) as the special output port, fix the data register (R02, R03) at "1" and the high impedance control register (R02HIZ, R03HIZ) at "0" (data output). Be aware that the output terminal is fixed at a low (Vss) level the same as the DC output if "0" is written to the R02 and R03 registers when the special output has been selected. Be aware that the output terminal shifts into high impedance status when "1" is written to the high impedance control register (R02HIZ, R03HIZ). - (2) A hazard may occur when the FOUT signal and the TOUT signal are turned ON and OFF. - (3) When fOSC3 is selected for the FOUT signal frequency, it is necessary to control the OSC3 oscillation circuit before output. Refer to Section 4.3, "Oscillation Circuit", for the control and notes. ## I/O port When in the input mode, I/O ports are changed from low to high by pull-up resistor, the rise of the waveform is delayed on account of the time constant of the pull-up resistor and input gate capacitance. Hence, when fetching input ports, set an appropriate wait time. Particular care needs to be taken of the key scan during key matrix configuration. Make this waiting time the amount of time or more calculated by the following expression. $10 \times C \times R$ C: terminal capacitance 5 pF + parasitic capacitance ? pF R: pull-up resistance 330 k $\Omega$ #### LCD driver - (1) When a program that access no memory mounted area (F050H–F0FFH, F150H–F1FFH, F201H, F203H, ..., F24FH) is made, the operation is not guaranteed. - (2) Because at initial reset, the contents of display memory and LC3–LC0 (LCD contrast) are undefined, there is need to initialize by the software. Furthermore, take care of the registers LPWR and ALOFF because these are set so that the display goes OFF. #### Clock timer - (1) Be sure to read timer data in the order of low-order data (TM0-TM3) then high-order data (TM4-TM7). - (2) When the CR oscillation circuit is selected as the OSC1 oscillation circuit by mask option, the frequencies and times differ from the values described in this section because the oscillation frequency will be 60 kHz (Typ.). Therefore, the clock timer can not be used for the clock function. #### Stopwatch timer - (1) When data of the counter is read at run mode, perform the reading after suspending the counter once and then set SWRUN to "1" again. Moreover, it is required that the suspension period not exceed 976 µsec (1/4 cycle of 256 Hz). - (2) When the CR oscillation circuit is selected as the OSC1 oscillation circuit by mask option, the frequencies and times differ from the values described in this section because the oscillation frequency will be 60 kHz (Typ.). Therefore, this timer can not be used for the stopwatch function. ## Programmable timer - (1) When reading counter data, be sure to read the low-order 4 bits (PTD00–PTD03, PTD10–PTD13) first. Furthermore, the high-order 4 bits (PTD04–PTD07, PTD14–PTD17) should be read within 0.73 msec (when fOSC1 is 32.768 kHz) of reading the low-order 4 bits (PTD00–PTD03, PTD10–PTD13). - (2) The programmable timer actually enters RUN/STOP status in synchronization with the falling edge of the input clock after writing to the PTRUN0/PTRUN1 register. Consequently, when "0" is written to the PTRUN0/PTRUN1 register, the timer enters STOP status at the point where the counter is decremented (-1). The PTRUN0/PTRUN1 register maintains "1" for reading until the timer actually stops. Figure 5.2.1 shows the timing chart for the RUN/STOP control. Fig. 5.2.1 Timing chart for RUN/STOP control - (3) Since the TOUT signal is generated asynchronously from the PTOUT register, a hazard within 1/2 cycle is generated when the signal is turned ON and OFF by setting the register. - (4) When the OSC3 oscillation clock is selected for the clock source, it is necessary to turn the OSC3 oscillation ON, prior to using the programmable timer. However the OSC3 oscillation circuit requires a time at least 5 msec from turning the circuit ON until the oscillation stabilizes. Therefore, allow an adequate interval from turning the OSC3 oscillation circuit ON to starting the programmable timer. Refer to Section 4.3, "Oscillation Circuit", for the control and notes of the OSC3 oscillation circuit. At initial reset, the OSC3 oscillation circuit is set in the OFF state. - (5) The counter mode selection register EVCNT should be set to "0" when timer 0 is used as a down counter. Otherwise it will cause malfunction. #### Serial interface - (1) Perform data writing/reading to the data registers SD0–SD7 only while the serial interface is halted (i.e., the synchronous clock is neither being input or output). - (2) As a trigger condition, it is required that data writing or reading on data registers SD0–SD7 be performed prior to writing "1" to SCTRG. (The internal circuit of the serial interface is initiated through data writing/reading on data registers SD0–SD7.) In addition, be sure to enable the serial interface with the ESIF register before the trigger. Supply trigger only once every time the serial interface is placed in the RUN state. Refrain from performing trigger input multiple times, as leads to malfunctioning. Moreover, when the synchronous clock SCLK is external clock, start to input the external clock after the trigger. - (3) Setting of the input/output permutation (MSB first/LSB first) with the SDP register should be done before setting data to SD0–SD7. - (4) Be aware that the maximum clock frequency for the serial interface is limited to 1 MHz when OSC3 is used as the clock source of the programmable timer or in the slave mode. #### Sound generator - (1) Since it generates a BZ signal that is out of synchronization with the BZE register, hazards may at times be produced when the signal goes ON/OFF due to the setting of the BZE register. - (2) The one-shot output is only valid when the normal buzzer output is OFF (BZE = "0") and will be invalid when the normal buzzer output is ON (BZE = "1"). - (3) The buzzer signal is generated by dividing the OSC1 oscillation clock. Since the frequencies and times that are described in this section are the values in the case of crystal oscillation (32.768 kHz, Typ.), they differ when CR oscillation (60 kHz, Typ.) is selected. ## Interrupt - (1) The interrupt factor flags are set when the interrupt condition is established, even if the interrupt mask registers are set to "0". - (2) After an interrupt occurs, the same interrupt will occur again if the interrupt enabled state (I flag = "1") is set or the RETI instruction is executed unless the interrupt factor flag is reset. Therefore, be sure to reset (write "1" to) the interrupt factor flag in the interrupt service routine before shifting to the interrupt enabled state. - (3) After an initial reset, all the interrupts including NMI are masked until both the stack pointers SP1 and SP2 are set with the software. Be sure to set the SP1 and SP2 in the initialize routine. Further, when re-setting the stack pointer, the SP1 and SP2 must be set as a pair. When one of them is set, all the interrupts including NMI are masked and interrupts cannot be accepted until the other one is set. ## 5.3 Notes on Mounting #### <Oscillation Circuit> - Oscillation characteristics change depending on conditions (board pattern, components used, etc.). In particular, when a ceramic oscillator or crystal oscillator is used, use the oscillator manufacturer's recommended values for constants such as capacitance and resistance. - Disturbances of the oscillation clock due to noise may cause a malfunction. Consider the following points to prevent this: - (1) Components which are connected to the OSC1, OSC2, OSC3 and OSC4 terminals, such as oscillators, resistors and capacitors, should be connected in the shortest line. - (2) As shown in the right hand figure, make a Vss pattern as large as possible at circumscription of the OSC1, OSC2, OSC3 and OSC4 terminals and the components connected to these terminals. Furthermore, do not use this Vss pattern for any purpose other than the oscillation system. In order to prevent unstable operation of the oscillation circuit due to current leak between OSC1/OSC3 and VDD, please keep enough distance between OSC1/OSC3 and VDD or other signals on the board pattern. #### <Reset Circuit> - The power-on reset signal which is input to the RESET terminal changes depending on conditions (power rise time, components used, board pattern, etc.). - Decide the time constant of the capacitor and resistor after enough tests have been completed with the application product. - When the built-in pull-up resistor is added to the RESET terminal by mask option, take into consideration dispersion of the resistance for setting the constant. - In order to prevent any occurrences of unnecessary resetting caused by noise during operating, components such as capacitors and resistors should be connected to the RESET terminal in the shortest line. ## <Power Supply Circuit> - Sudden power supply variation due to noise may cause malfunction. Consider the following points to prevent this: - (1) The power supply should be connected to the VDD and Vss terminal with patterns as short and large as possible. - Furthermore, similar consideration is necessary when the LCD drive voltage is supplied from outside the IC. - (2) When connecting between the VDD and Vss terminals with a bypass capacitor, the terminals should be connected as short as possible. - (3) Components which are connected to the VD1 and VC1–VC5 terminals, such as capacitors and resistors, should be connected in the shortest line. In particular, the VC1–VC5 voltage affects the display quality. - Do not connect anything to the VC1–VC5 terminals when the LCD driver is not used. ## <a>Arrangement of Signal Lines></a> - In order to prevent generation of electromagnetic induction noise caused by mutual inductance, do not arrange a large current signal line near the circuits that are sensitive to noise such as the oscillation unit. - When a signal line is parallel with a high-speed line in long distance or intersects a high-speed line, noise may generated by mutual interference between the signals and it may cause a malfunction. Do not arrange a high-speed signal line especially near circuits that are sensitive to noise such as the oscillation unit. ## <Pre><Pre>cautions for Visible Radiation (when bare chip is mounted)> - Visible radiation causes semiconductor devices to change the electrical characteristics. It may cause this IC to malfunction. When developing products which use this IC, consider the following precautions to prevent malfunctions caused by visible radiations. - (1) Design the product and implement the IC on the board so that it is shielded from visible radiation in actual use. - (2) The inspection process of the product needs an environment that shields the IC from visible radiation. - (3) As well as the face of the IC, shield the back and side too. ## CHAPTER 6 BASIC EXTERNAL WIRING DIAGRAM • When negative polarity is selected for buzzer output (mask option selection) | X'tal | Crystal oscillator | 32.768 kHz, CI (Max.) = $34$ kΩ | |-------|----------------------------------|---------------------------------| | Cgx | Trimmer capacitor | 5–25 pF | | RCR1 | Resistor for OSC1 CR oscillation | 520 kΩ (60 kHz) | | CR | Ceramic oscillator | 4 MHz (3.0 V) | | Cgc | Gate capacitor | 30 pF | | CDC | Drain capacitor | 30 pF | | RCR2 | Resistor for OSC3 CR oscillation | 34 kΩ (1.8 MHz) | | C1-C8 | Capacitor | 0.2 μF | | C9 | Capacitor | 0.1 μF | | СР | Capacitor | 3.3 μF | | CRES | RESET terminal capacitor | 0.1 μF | Note: The above table is simply an example, and is not guaranteed to work. # CHAPTER 7 ELECTRICAL CHARACTERISTICS # 7.1 Absolute Maximum Rating | | | (V | ss=0V) | |-------------------------------------|----------------|-----------------------------|--------| | Item | Symbol | Rated value | Unit | | Supply voltage | Vdd | -0.5 to 7.0 | V | | Input voltage (1) | VI | -0.5 to VDD $+0.3$ | V | | Input voltage (2) | Viosc | -0.5 to VD1 + 0.3 | V | | Permissible total output current *1 | $\Sigma I$ VDD | 10 | mA | | Operating temperature | Topr | -20 to 70 | °C | | Storage temperature | Tstg | -65 to 150 | °C | | Soldering temperature / time | Tsol | 260°C, 10sec (lead section) | | | Permissible dissipation *2 | PD | 250 | mW | <sup>\*1</sup> The permissible total output current is the sum total of the current (average current) that simultaneously flows from the output pin (or is drawn in). # 7.2 Recommended Operating Conditions | | | | | | () | Ta=-20 to | 70°C) | |-----------------------|--------|---------------------|----------------------|------|--------|-----------|-------| | Item | Symbol | | Min. | Тур. | Max. | Unit | | | Supply voltage | Vdd | Vss=0V | OSC3 oscillation OFF | 1.8 | 3.0 | 6.4 | V | | | | | OSC1 CR oscillation | 2.2 | 3.0 | 6.4 | V | | | | | OSC3 oscillation ON | 2.2 | 3.0 | 6.4 | V | | Oscillation frequency | fosc1 | Crystal oscillation | | _ | 32.768 | _ | kHz | | | | CR oscillation | | 40 | 60 | 80 | kHz | | | fosc3 | CR oscillation | | | 1,800 | | kHz | | | | Ceramic oscillation | | | | 4,100 | kHz | <sup>\*2</sup> In case of plastic package. # 7.3 DC Characteristics # Unless otherwise specified: $V_{DD}=3.0V,\ Vss=0V,\ fosc1=32.768kHz,\ Ta=25^{\circ}C,\ V_{D1}/Vc1/Vc2/Vc4/Vcs\ are\ internal\ voltage,\ C1-C8=0.2\mu F$ | Item | Symbol | | Condition | Min. | Тур. | Max. | Unit | |-------------------------------|--------|----------------|------------------------|---------------------|------|--------------------|------| | High level input voltage (1) | VIH1 | | K00-03, P00-03, P10-13 | 0.8·VDD | | Vdd | V | | High level input voltage (2) | VIH2 | | RESET, TEST, P10–13 | 0.9·V <sub>DD</sub> | | Vdd | V | | Low level input voltage (1) | VIL1 | | K00-03, P00-03, P10-13 | 0 | | 0.2·VDD | V | | Low level input voltage (2) | VIL2 | | RESET, TEST, P10–13 | 0 | | $0.1 \cdot V_{DD}$ | V | | High level input current | IIH | VIH=3.0V | K00-03, P00-03, P10-13 | 0 | | 0.5 | μΑ | | | | | RESET, TEST | | | | | | Low level input current (1) | IIL1 | VIL1=VSS | K00-03, P00-03, P10-13 | -0.5 | | 0 | μΑ | | | | No Pull-up | RESET, TEST | | | | | | Low level input current (2) | IIL2 | VIL2=VSS | K00-03, P00-03, P10-13 | -12 | -7 | -5 | μΑ | | | | With Pull-up | RESET, TEST | | | | | | High level output current (1) | Іоні | Voh1=0.9·Vdd | R00-03, P00-03, P10-13 | | | -2 | mA | | High level output current (2) | Іон2 | Voh2=0.9·Vdd | BZ | | | -2 | mA | | Low level output current (1) | IOL1 | Vol1=0.1·Vdd | R00-03, P00-03, P10-13 | 3 | | | mA | | Low level output current (2) | IOL2 | Vol2=0.1·Vdd | BZ | 3 | | | mA | | Common output current | Іон3 | VOH3=VC5-0.05V | COM0-16 | | | -25 | μΑ | | | IOL3 | Vol3=Vss+0.05V | | 25 | | | μA | | Segment output current | Іон4 | Voh4=Vc5-0.05V | SEG0-39 | | | -10 | μΑ | | | IOL4 | Vol4=Vss+0.05V | | 10 | | | μΑ | # Unless otherwise specified: $V_{DD}\!=\!5.0V,\,Vss\!=\!0V,\,fosc_1\!=\!32.768kHz,\,Ta\!=\!25^{\circ}C,\,V_{D1}/Vc_1/Vc_2/Vc_4/Vc_5\,\,are\,\,internal\,\,voltage,\,C_1-C_8\!=\!0.2\mu F$ | Item | Symbol | | Condition | Min. | Тур. | Max. | Unit | |-------------------------------|--------|----------------|------------------------|---------------------|------|---------|------| | High level input voltage (1) | VIH1 | | K00-03, P00-03, P10-13 | 0.8·Vdd | | Vdd | V | | High level input voltage (2) | VIH2 | | RESET, TEST, P10-13 | 0.9·V <sub>DD</sub> | | Vdd | V | | Low level input voltage (1) | VIL1 | | K00-03, P00-03, P10-13 | 0 | | 0.2·Vdd | V | | Low level input voltage (2) | VIL2 | | RESET, TEST, P10–13 | 0 | | 0.1·Vdd | V | | High level input current | IIH | VIH=5.0V | K00-03, P00-03, P10-13 | 0 | | 0.5 | μΑ | | | | | RESET, TEST | | | | | | Low level input current (1) | IIL1 | VIL1=VSS | K00-03, P00-03, P10-13 | -0.5 | | 0 | μΑ | | | | No Pull-up | RESET, TEST | | | | | | Low level input current (2) | IIL2 | VIL2=VSS | K00-03, P00-03, P10-13 | -20 | -12 | -9 | μA | | | | With Pull-up | RESET, TEST | | | | | | High level output current (1) | Іоні | Voh1=0.9·Vdd | R00-03, P00-03, P10-13 | | | -5 | mA | | High level output current (2) | Іон2 | Voh2=0.9·Vdd | BZ | | | -5 | mA | | Low level output current (1) | IOL1 | Vol1=0.1·Vdd | R00-03, P00-03, P10-13 | 7.5 | | | mA | | Low level output current (2) | IOL2 | Vol2=0.1·Vdd | BZ | 7.5 | | | mA | | Common output current | Іон3 | Voh3=Vc5-0.05V | COM0-16 | | | -25 | μA | | | IOL3 | Vol3=Vss+0.05V | | 25 | | | μA | | Segment output current | Іон4 | Voh4=Vc5-0.05V | SEG0-39 | | | -10 | μA | | | IOL4 | Vol4=Vss+0.05V | | 10 | | | μA | S1C63454 TECHNICAL MANUAL # 7.4 Analog Circuit Characteristics and Power Current Consumption Unless otherwise specified: $V_{DD} = 3.0 V, \ V_{SS} = 0 V, \ fosc1 = 32.768 kHz, \ C_{G} = 25 pF, \ T_{a} = 25 °C, \ V_{D1} / V_{C1} / V_{C2} / V_{C4} / V_{C5} \ are internal \ voltage, \ C_{1} - C_{8} = 0.2 \mu F$ | | 1 | Condition | ves are mem | | | | Linit | |---------------------------------|------------------------------------------------------------|-----------------------------------------------|--------------|---------------|-------|---------|-----------| | Item | Symbol | | 1.00 2 11011 | Min. | Typ. | Max. | Unit<br>V | | LCD drive voltage | VC1 | l | LC0-3="0" | | 0.975 | | V | | (when VC1 standard is selected) | | L | LC0-3="1" | | 0.990 | | | | | | l` * / | LC0-3="2" | | 1.005 | | | | | | | LC0-3="3" | | 1.020 | | | | | | l | LC0-3="4" | | 1.035 | | | | | | | LC0-3="5" | | 1.050 | | | | | | | LC0-3="6" | | 1.065 | | | | | | | LC0-3="7" | Тур. | 1.080 | Тур. | | | | | | LC0-3="8" | ×0.88 | 1.095 | ×1.12 | | | | | | LC0-3="9" | | 1.110 | | | | | | | LC0-3="10" | | 1.125 | | | | | | l | LC0-3="11" | | 1.140 | | | | | | l ⊭ | LC0-3="12" | | 1.155 | | | | | | | LC0-3="13" | | 1.170 | | | | | | <u> </u> | LC0-3="14" | | 1.185 | | | | | | L | LC0-3="15" | | 1.200 | | | | | VC2 | Connect 1 M $\Omega$ load resistor between Vs | | 2·Vc1 | 1.200 | 2·Vc1 | V | | | V C2 | | ss and vC2 | | | 2.401 | \ \ | | | <b>3</b> 7 | (without panel load) | 137 | ×0.9<br>3⋅Vc1 | | 2.37 | * 7 | | | VC4 Connect 1 M $\Omega$ load resistor between Vss and VC4 | | | | | 3.VC1 | V | | | | (without panel load) | | ×0.9 | | | | | | VC5 | Connect 1 M $\Omega$ load resistor between Vs | ss and VC5 | 4.VC1 | | 4·VC1 | V | | | | (without panel load) | | ×0.9 | | | | | LCD drive voltage | VC1 | Connect 1 M $\Omega$ load resistor between Vs | s and VC1 | 1/2·Vc2 | | 1/2·Vc2 | V | | (when Vc2 standard is selected) | | (without panel load) | | ×0.95 | | +0.1 | | | | VC2 | l | LC0-3="0" | | 1.95 | | V | | | | L | LC0-3="1" | | 1.98 | | | | | | (without panel load) | LC0-3="2" | | 2.01 | | | | | | | LC0-3="3" | | 2.04 | | | | | | | LC0-3="4" | | 2.07 | | | | | | | LC0-3="5" | | 2.10 | | | | | | | LC0-3="6" | | 2.13 | | | | | | | LC0-3="7" | Тур. | 2.16 | Тур. | | | | | <u> </u> | LC0-3="8" | ×0.88 | 2.19 | ×1.12 | | | | | l | LC0-3="9" | | 2.22 | | | | | | | LC0-3="10" | | 2.25 | | | | | | L | LC0-3="11" | | 2.28 | | | | | | L | LC0-3="12" | | 2.31 | | | | | | | LC0-3="13" | | 2.34 | | | | | | L | | | | | | | | | L | LC0-3="14" | | 2.37 | | | | | T7 | | LC0-3="15" | 2/2 1/1 | 2.40 | 2/2 1/1 | * 7 | | | VC4 | Connect 1 M $\Omega$ load resistor between Vs | ss and VC4 | 3/2·Vc2 | | 3/2·Vc2 | V | | | | (without panel load) | | ×0.95 | | | | | | VC5 | Connect 1 M $\Omega$ load resistor between Vs | ss and VC5 | 2·Vc2 | | 2·Vc2 | V | | | | (without panel load) | | ×0.95 | | | | # **CHAPTER 7: ELECTRICAL CHARACTERISTICS** # Unless otherwise specified: $VdD=3.0V,\ Vss=0V,\ fosc1=32.768kHz,\ Cg=25pF,\ Rcr1=600k\Omega,\ Rcr2=47k\Omega,\ Ta=25^{\circ}C,\ Vd1/Vc1/Vc2/Vc4/Vc5\ are\ internal\ voltage,\ C1-C8=0.2\mu F$ | Item | Symbol | Condition | Min. | Тур. | Max. | Unit | |---------------------|--------|------------------------------------------------|------|-------|-------|------| | Current consumption | IOP | During HALT (32 kHz crystal oscillation), | | 1 | 2 | μΑ | | _ | | LCD power OFF *1, *2 | | | | - | | | | During HALT (32 kHz crystal oscillation), | | 6 | 12 | μΑ | | | | LCD power ON (Vc1 standard) *1, *2 | | | | | | | | During HALT (32 kHz crystal oscillation), | | 4 | 8 | μΑ | | | | LCD power ON (Vc2 standard) *1, *2 | | | | | | | | During HALT (60 kHz CR oscillation), | | 23 | 45 | μA | | | | LCD power OFF *2 | | | | | | | | During HALT (60 kHz CR oscillation), | | 30 | 60 | μA | | | | LCD power ON (Vc1 standard) *2 | | | | | | | | During HALT (60 kHz CR oscillation), | | 26 | 50 | μΑ | | | | LCD power ON (Vc2 standard) *2 | | | | | | | | During execution (32 kHz crystal oscillation), | | 10 | 19 | μA | | | | LCD power ON (Vc1 standard) *1, *2 | | | | | | | | During execution (60 kHz CR oscillation), | | 45 | 80 | μA | | | | LCD power ON (Vc1 standard) *2 | | | | | | | | During execution (2 MHz ceramic oscillation), | | 500 | 700 | μA | | | | LCD power ON (Vc1 standard) | | | | | | | | During execution (4 MHz ceramic oscillation), | | 1,000 | 1,200 | μΑ | | | | LCD power ON (Vc1 standard) | | | | ļ . | | | | During execution (1,800 kHz CR oscillation), | | 700 | 1,000 | μΑ | | | | LCD power ON (Vc1 standard) | | | | ` | <sup>\*1</sup> VDC = "0" <sup>\*2</sup> OSCC = "0" # 7.5 Oscillation Characteristics The oscillation characteristics change depending on the conditions (components used, board pattern, etc.). Use the following characteristics as reference values. # OSC1 crystal oscillation circuit Unless otherwise specified: VDD=3.0V, Vss=0V, fosc1=32.768kHz, Cg=25pF, CD=built-in, Ta=-20 to 70°C | Item | Symbol | Co | Min. | Тур. | Max. | Unit | | |------------------------------------|--------|-------------------------------------------------------------|-----------------------|------|------|------|-----| | Oscillation start voltage | Vsta | tsta≤3sec (V <sub>DD</sub> ) | | 1.8 | | | V | | Oscillation stop voltage | Vstp | tstp≤10sec (V <sub>DD</sub> ) | | 1.8 | | | V | | Built-in capacitance (drain) | CD | Including the parasitic capacitance inside the IC (in chip) | | | 14 | | pF | | Frequency/voltage deviation | ∂f/∂V | VDD=2.2 to 6.4V | without VDC switching | | | 5 | ppm | | | | | with VDC switching | | | 10 | ppm | | Frequency/IC deviation | ∂f/∂IC | | | -10 | | 10 | ppm | | Frequency adjustment range | ∂f/∂Cg | CG=5 to 25pF | | 10 | 20 | | ppm | | Harmonic oscillation start voltage | Vhho | CG=5pF (VDD) | | 6.4 | | | V | | Permitted leak resistance | Rleak | Between OSC1 and Vss | | 200 | | | ΜΩ | ### **OSC1 CR oscillation circuit** Unless otherwise specified: VDD=3.0V, VSS=0V, RCR1=520k $\Omega$ , Ta=-20 to 70°C | Item | Symbol | Condition | Min. | Тур. | Max. | Unit | |----------------------------------|--------|-----------------|------|-------|------|------| | Oscillation frequency dispersion | fosc1 | | -30 | 60kHz | 30 | % | | Oscillation start voltage | Vsta | (VDD) | 2.2 | | | V | | Oscillation start time | tsta | VDD=2.2 to 6.4V | | | 3 | ms | | Oscillation stop voltage | Vstp | (VDD) | 2.2 | | | V | # OSC3 ceramic oscillation circuit Unless otherwise specified: VDD=3.0V, Vss=0V, Ceramic oscillator: 4MHz, CGC=CDC=30pF, Ta=-20 to 70°C | VDD=3.0 V, V33=0 V, Ceramic Oscinator. 4W112, COC=CDC=30pr, Ta=-20 to 70 C | | | | | | | | | | |----------------------------------------------------------------------------|--------|-----------------|------|------|------|------|--|--|--| | Item | Symbol | Condition | Min. | Тур. | Max. | Unit | | | | | Oscillation start voltage | Vsta | (VDD) | 2.2 | | | V | | | | | Oscillation start time | tsta | VDD=2.2 to 6.4V | | | 5 | ms | | | | | Oscillation stop voltage | Vstp | (VDD) | 2.2 | | | V | | | | # **OSC3 CR oscillation circuit** Unless otherwise specified: VDD=3.0V, Vss=0V, RCR2=34k $\Omega$ , Ta=-20 to 70°C | Item | Symbol | Condition | Min. | Тур. | Max. | Unit | |----------------------------------|--------|-----------------|------|----------|------|------| | Oscillation frequency dispersion | fosc3 | | -25 | 1,800kHz | 25 | % | | Oscillation start voltage | Vsta | (VDD) | 2.2 | | | V | | Oscillation start time | tsta | VDD=2.2 to 6.4V | | | 3 | ms | | Oscillation stop voltage | Vstp | (Vdd) | 2.2 | | | V | # OSC1 CR oscillation frequency-resistance characteristic The oscillation characteristics change depending on the conditions (components used, board pattern, etc.). Use the following characteristics as reference values and evaluate the characteristics on the actual product. # OSC3 CR oscillation frequency-resistance characteristic The oscillation characteristics change depending on the conditions (components used, board pattern, etc.). Use the following characteristics as reference values and evaluate the characteristics on the actual product. # 7.6 Serial Interface AC Characteristics # Clock synchronous master mode ### • During 32 kHz operation $\textbf{Condition: Vdd=} 3.0 \text{V, Vss=} 0 \text{V, Ta=} 25 ^{\circ} \text{C, Vihi=} 0.8 \text{Vdd, Vili=} 0.2 \text{Vdd, Voh=} 0.8 \text{Vdd, Vol=} 0.2 \text{Vdd}, \text{Vol=} \text{$ | Item | Symbol | Min. | Тур. | Max. | Unit | |-------------------------------------|--------|------|------|------|------| | Transmitting data output delay time | tsmd | | | 5 | μs | | Receiving data input set-up time | tsms | 10 | | | μs | | Receiving data input hold time | tsmh | 5 | | | μs | #### • During 1 MHz operation $\textbf{Condition: Vdd=} 3.0V, Vss=0V, Ta=25^{\circ}C, Vihi=0.8Vdd, Vill=0.2Vdd, Voh=0.8Vdd, Vol=0.2Vdd, Vol=0$ | Item | Symbol | Min. | Тур. | Max. | Unit | |-------------------------------------|--------|------|------|------|------| | Transmitting data output delay time | tsmd | | | 200 | ns | | Receiving data input set-up time | tsms | 400 | | | ns | | Receiving data input hold time | tsmh | 200 | | | ns | Note that the maximum clock frequency is limited to 1 MHz. ## Clock synchronous slave mode ### • During 32 kHz operation $\textbf{Condition: Vdd=} 3.0 \text{V, Vss=} 0 \text{V, Ta=} 25 ^{\circ} \text{C, Vihi=} 0.8 \text{Vdd, Vili=} 0.2 \text{Vdd, Voh=} 0.8 \text{Vdd, Vol=} 0.2 \text{Vdd}, \text{Vol=} 0.2 \text{Vdd} \text{Condition: Vdd=} 0.8 \text{Vdd, Vol=} 0.2 \text{Vdd}, \text{Vol=} \text{Vol=}$ | Item | Symbol | Min. | Тур. | Max. | Unit | |-------------------------------------|--------|------|------|------|------| | Transmitting data output delay time | tssd | | | 10 | μs | | Receiving data input set-up time | tsss | 10 | | | μs | | Receiving data input hold time | tssh | 5 | | | μs | ### • During 1 MHz operation $\textbf{Condition: Vdd=} 3.0V, \ Vss=0V, \ Ta=25^{\circ}C, \ Vihi=0.8Vdd, \ Vili=0.2Vdd, \ Voh=0.8Vdd, \ Vol=0.2Vdd, Vol$ | Item | Symbol | Min. | Тур. | Max. | Unit | |-------------------------------------|--------|------|------|------|------| | Transmitting data output delay time | tssd | | | 500 | ns | | Receiving data input set-up time | tsss | 400 | | | ns | | Receiving data input hold time | tssh | 200 | | | ns | Note that the maximum clock frequency is limited to 1 MHz. #### <Master mode> #### <Slave mode> # 7.7 Timing Chart # System clock switching Note: When the OSC1 oscillation circuit has been selected as the CR oscillation circuit, it is not necessary to set the VDC register. Whether the VDC register value is "1" or "0" does not matter. # CHAPTER 8 PACKAGE # 8.1 Plastic Package # QFP15-100pin (Unit: mm) The dimensions are subject to change without notice. # 8.2 Ceramic Package for Test Samples # QFP15-100pin (Unit: mm) # CHAPTER 9 PAD LAYOUT # 9.1 Diagram of Pad Layout Chip thickness: 400 μm Pad opening: 85 μm # 9.2 Pad Coordinates | | | | | | | | | | | | | | | U | nit: μm | |-----|---------------|-------|---------------|-----|----------|--------|--------|-----|----------|--------|--------|-----|-----------------|-------|---------| | No. | Pad name | Χ | Υ | No. | Pad name | Х | Υ | No. | Pad name | Χ | Υ | No. | Pad name | Χ | Υ | | 1 | RESET | 1,178 | 1,845 | 20 | Vc1 | -1,971 | 1,276 | 44 | SEG35 | -1,468 | -1,845 | 70 | SEG9 | 1,971 | -1,521 | | 2 | TEST | 1,063 | 1,845 | 21 | VC2 | -1,971 | 1,151 | 45 | SEG34 | -1,343 | -1,845 | 71 | SEG8 | 1,971 | -1,406 | | 3 | VREF | 944 | 1,845 | 22 | Vc3 | -1,971 | 1,036 | 46 | SEG33 | -1,228 | -1,845 | 72 | SEG7 | 1,971 | -1,291 | | 4 | R03 | 825 | 1,845 | 23 | VC4 | -1,971 | 921 | 47 | SEG32 | -1,113 | -1,845 | 73 | SEG6 | 1,971 | -1,176 | | 5 | R02 | 710 | 1,845 | 24 | Vc5 | -1,971 | 806 | 48 | SEG31 | -998 | -1,845 | 74 | SEG5 | 1,971 | -1,061 | | 6 | R01 | 595 | 1,845 | 25 | CF | -1,971 | 691 | 49 | SEG30 | -883 | -1,845 | 75 | SEG4 | 1,971 | -946 | | 7 | R00 | 480 | 1,845 | 26 | CE | -1,971 | 576 | 50 | SEG29 | -768 | -1,845 | 76 | SEG3 | 1,971 | -831 | | 8 | P13 | 352 | 1,845 | 27 | CD | -1,971 | 461 | 51 | SEG28 | -653 | -1,845 | 77 | SEG2 | 1,971 | -716 | | 9 | P12 | 237 | 1,845 | 28 | CC | -1,971 | 346 | 52 | SEG27 | -538 | -1,845 | 78 | SEG1 | 1,971 | -601 | | 10 | P11 | 122 | 1,845 | 29 | СВ | -1,971 | 231 | 53 | SEG26 | -423 | -1,845 | 79 | SEG0 | 1,971 | -486 | | 11 | P10 | 7 | 1,845 | 30 | CA | -1,971 | 116 | 54 | SEG25 | -308 | -1,845 | 80 | COM7 | 1,971 | -369 | | 12 | P03 | -110 | 1,845 | 31 | COM8 | -1,971 | -24 | 55 | SEG24 | -193 | -1,845 | 81 | COM6 | 1,971 | -254 | | 13 | P02 | -225 | 1,845 | 32 | COM9 | -1,971 | -139 | 56 | SEG23 | -78 | -1,845 | 82 | COM5 | 1,971 | -139 | | 14 | P01 | -340 | 1,845 | 33 | COM10 | -1,971 | -254 | 57 | SEG22 | 37 | -1,845 | 83 | COM4 | 1,971 | -24 | | 15 | P00 | -455 | 1,845 | 34 | COM11 | -1,971 | -369 | 58 | SEG21 | 152 | -1,845 | 84 | COM3 | 1,971 | 91 | | 16 | K03 | -578 | 1,845 | 35 | COM12 | -1,971 | -484 | 59 | SEG20 | 267 | -1,845 | 85 | COM2 | 1,971 | 206 | | 17 | K02 | -693 | 1,845 | 36 | COM13 | -1,971 | -599 | 60 | SEG19 | 382 | -1,845 | 86 | COM1 | 1,971 | 321 | | 18 | K01 | -808 | 1,845 | 37 | COM14 | -1,971 | -714 | 61 | SEG18 | 497 | -1,845 | 87 | COM0 | 1,971 | 436 | | 19 | K00 | -923 | 1,845 | 38 | COM15 | -1,971 | -829 | 62 | SEG17 | 612 | -1,845 | 88 | BZ | 1,971 | 639 | | | | | $\overline{}$ | 39 | COM16 | -1,971 | -944 | 63 | SEG16 | 727 | -1,845 | 89 | Vss | 1,971 | 758 | | ` | | _ | | 40 | SEG39 | -1,971 | -1,061 | 64 | SEG15 | 842 | -1,845 | 90 | OSC1 | 1,971 | 877 | | | | | | 41 | SEG38 | -1,971 | -1,176 | 65 | SEG14 | 957 | -1,845 | 91 | OSC2 | 1,971 | 992 | | | $\rightarrow$ | < | | 42 | SEG37 | -1,971 | -1,291 | 66 | SEG13 | 1,072 | -1,845 | 92 | V <sub>D1</sub> | 1,971 | 1,111 | | | | | | 43 | SEG36 | -1,971 | -1,406 | 67 | SEG12 | 1,187 | -1,845 | 93 | OSC3 | 1,971 | 1,270 | | | | | | | | | | 68 | SEG11 | 1,302 | -1,845 | 94 | OSC4 | 1,971 | 1,385 | | | | | | _ | | | | 69 | SEG10 | 1,417 | -1,845 | 95 | Vdd | 1,971 | 1,514 | # APPENDIX S5U1C63000P MANUAL (Peripheral Circuit Board for \$1C63404/454/455/458/466/P466) This manual describes how to use the Peripheral Circuit Board for the S1C63404/454/455/458/466/P466 (S5U1C63000P), which provides emulation functions when mounted on the debugging tool for the S1C63 Family of 4-bit single-chip microcomputers, the ICE (S5U1C63000H1/S5U1C63000H2). This description of the S1C63 Family Peripheral Circuit Board (S5U1C63000P) provided in this document assumes that circuit data for the S1C63404/454/455/458/466/P466 has already been downloaded to the board. For information on downloading various circuit data and on common board specifications, please see the S5U1C63000P Manual (S1C63 Family Peripheral Circuit Board) included with the product. Please refer to the user's manual provided with your ICE for detailed information on its functions and method of use. # A.1 Names and Functions of Each Part The following explains the names and functions of each part of the board (S5U1C63000P). # (1) VLCD Unused. #### (2) VSVD This control allows you to vary the power supply voltage artificially in order to verify the operation of the power supply voltage detect function (SVD). Keep in mind that a single control position indicates two voltage values. | SVD levels | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | |------------|---|---|----|----|----|----|----|----| | | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | (For example, SVD levels 0 and 8 are at the same control position.) ## (3) Register monitor LEDs These LEDs correspond one-to-one to the registers listed below. The LED lights when the data is logic "1" and goes out when the data is logic "0". VDC, OSCC, CLKCHG, SVDS0-3\*, SVDON\*, LPWR, VCCHG \* SVDS0-3, SVDON: Used for the S1C63404/458/466/P466 ## (4) Register monitor pins These pins correspond one-to-one to the registers listed below. The pin outputs a high for logic "1" and a low for logic "0". | l N | <i>l</i> lonitor | | LED | |---------|------------------|---------|----------| | Pin No. | Name | LED No. | Name | | 1 | DONE *1 | 1 | DONE *1 | | 2 | _ | 2 | _ | | 3 | VDC | 3 | VDC | | 4 | OSCC | 4 | OSCC | | 5 | CLKCHG | 5 | CLKCHG | | 6 | _ | 6 | _ | | 7 | _ | 7 | _ | | 8 | _ | 8 | _ | | 9 | _ | 9 | _ | | 10 | SVDS0 *2 | 10 | SVDS0 *2 | | 11 | SVDS1 *2 | 11 | SVDS1 *2 | | 12 | SVDS2 *2 | 12 | SVDS2 *2 | | 13 | SVDS3 *2 | 13 | SVDS3 *2 | | 14 | SVDON *2 | 14 | SVDON *2 | | 15 | LPWR | 15 | LPWR | | 16 | VCCHG | 16 | VCCHG | <sup>\*1</sup> DONE: The monitor pin outputs a high while the LED lights when initialization of this board completes without problems. Used for the S1C404/458/466/P466. # (5) CR oscillation frequency adjusting control When OSC1 and OSC3 respectively are set for a CR oscillation circuit and a CR/ceramic oscillation circuit by a mask option, this control allows you to adjust the oscillation frequency. The oscillation frequency can be adjusted in the range of approx. $20~\rm kHz$ to $500~\rm kHz$ for OSC1 and approx. $100~\rm kHz$ to $8~\rm MHz$ for OSC3. Note that the actual IC does not operate with all of these frequencies; consult the technical manual for the \$1C63404/454/455/458/466/P466 to select the appropriate operating frequency. ### (6) CR oscillation frequency monitor pins These pins allow you to monitor the clock waveform from the CR oscillation circuit with an oscilloscope. Note that these pins always output a signal waveform whether or not the oscillation circuit is operating. 112 EPSON S1C63454 TECHNICAL MANUAL <sup>\*2</sup> SVDS0-3, SVDON: #### (7) RESET switch This switch initializes the internal circuits of this board and feeds a reset signal to the ICE. # (8) Monitor pins and external part connecting socket These parts are currently unused. ## (9) IOSEL2 When downloading circuit data, set IOSEL2 to the "E" position. Otherwise, set to the "D" position. ### (10) CLK and PRG switch If power to the ICE is shut down before circuit data downloading is complete, the circuit configuration in this board will remain incomplete, and the debugger may not be able to start when you power on the ICE once again. In this case, temporarily power off the ICE and set CLK to the 32K position and the PRG switch to the Prog position, then switch on power for the ICE once again. This should allow the debugger to start up, allowing you to download circuit data. After downloading the circuit data, temporarily power off the ICE and reset CLK and PRG to the LCLK and the Norm position, respectively. Then power on the ICE once again. ## (11) VC5 This control allows fine adjustment of the LCD drive voltage when the internal LCD power supply is selected by mask option. Note, however, that only the LCD contrast register can adjust the LCD drive voltage in the actual IC. # A.2 Connecting to the Target System This section explains how to connect the S5U1C63000P to the target system. To connect this board (S5U1C63000P) to the target system, use the I/O connecting cables supplied with the board (80-pin/40-pin $\times$ 2, flat type). Take care when handling the connectors, since they conduct electrical power (VDD = +3.3 V). Fig. A.2.1 Connecting the S5U1C63000P to the target system Table A.2.1 I/O connector pin assignment | | 100te 11.2.1 1/0 com | T assignment | | | | | | |-------|----------------------|------------------------|---------------------|--|--|--|--| | 40-pi | n CN1-1 connector | 40-pin CN1-2 connector | | | | | | | No. | Pin name | No. | Pin name | | | | | | 1 | VDD (=3.3 V) | 1 | VDD (=3.3 V) | | | | | | 2 | VDD (=3.3 V) | 2 | VDD (=3.3 V) | | | | | | 3 | K00 | 3 | R00 | | | | | | 4 | K01 | 4 | R01 | | | | | | 5 | K02 | 5 | R02 | | | | | | 6 | K03 | 6 | R03 | | | | | | 7 | K10 *1 | 7 | R10 *1 | | | | | | 8 | K11 *1 | 8 | R11 *1 | | | | | | 9 | K12 *1 | 9 | R12 *1 | | | | | | 10 | K13 *1 | 10 | R13 *1 | | | | | | 11 | Vss | 11 | Vss | | | | | | 12 | Vss | 12 | Vss | | | | | | 13 | P00 | 13 | R20 *1 | | | | | | 14 | P01 | 14 | R21 *1 | | | | | | 15 | P02 | 15 | R22 *1 | | | | | | 16 | P03 | 16 | R23 *1 | | | | | | 17 | P10 | 17 | Cannot be connected | | | | | | 18 | P11 | 18 | Cannot be connected | | | | | | 19 | P12 | 19 | Cannot be connected | | | | | | 20 | P13 | 20 | Cannot be connected | | | | | | 21 | VDD (=3.3 V) | 21 | VDD (=3.3 V) | | | | | | 22 | VDD (=3.3 V) | 22 | VDD (=3.3 V) | | | | | | 23 | P20 *1 | 23 | Cannot be connected | | | | | | 24 | P21 *1 | 24 | Cannot be connected | | | | | | 25 | P22 *1 | 25 | Cannot be connected | | | | | | 26 | P23 *1 | 26 | Cannot be connected | | | | | | 27 | Cannot be connected | 27 | Cannot be connected | | | | | | 28 | Cannot be connected | 28 | Cannot be connected | | | | | | 29 | Cannot be connected | 29 | Cannot be connected | | | | | | 30 | Cannot be connected | 30 | Cannot be connected | | | | | | 31 | Vss | 31 | Vss | | | | | | 32 | Vss | 32 | Vss | | | | | | 33 | Cannot be connected | 33 | Vc1 *2 | | | | | | 34 | Cannot be connected | 34 | Vc2 *2 | | | | | | 35 | Cannot be connected | 35 | Vc3 *2 | | | | | | 36 | Cannot be connected | 36 | VC4 *2 | | | | | | 37 | Cannot be connected | 37 | Vc5 *2 | | | | | | 38 | BZ | 38 | RESET | | | | | | 39 | Vss | 39 | Vss | | | | | | 40 | Vss | 40 | Vss | | | | | | | | | | | | | | <sup>\*1:</sup> Can be used only for the S1C63404/458/466/P466 <sup>\*2:</sup> Can be used only for the S1C63404/454/458/466/P466 # A.3 Usage Precautions To ensure correct use of this board (S5U1C63000P), please observe the following precautions. # A.3.1 Operational precautions - (1) Before inserting or removing cables, turn off power to all pieces of connected equipment. - (2) Do not turn on power or load mask option data if all of the input ports (K00–K03) are held low. Doing so may activate the multiple key entry reset function. - (3) Before debugging, always be sure to load mask option data. # A.3.2 Differences with the actual IC ## (1) Differences in I/O ### <Interface power supply> This board and target system interface voltage is set to +3.3 V. To obtain the same interface voltage as in the actual IC, attach a level shifter circuit, etc. on the target system side to accommodate the required interface voltage. #### < Each output port's drive capability> The drive capability of each output port on this board is higher than that of the actual IC. When designing application system and software, refer to the technical manual for the S1C63404/454/455/458/466/P466 to confirm each output port's drive capability. ## <Each port's protective diode> All I/O ports incorporate a protective diode for VDD and Vss, and the interface signals between this board and the target system are set to +3.3 V. Therefore, this board and the target system cannot be interfaced with voltages exceeding VDD by setting the output ports for open-drain mode. #### <Pull-up resistance value> The pull-up resistance values on this board are set to 220 k $\Omega$ which differ from those for the actual IC. For the resistance values on the actual IC, refer to the technical manual for the S1C63404/454/455/458/466/P466. Note that when using pull-up resistors to pull the input pins high, the input pins may require a certain period to reach a valid high level. Exercise caution if a key matrix circuit is configured using a combination of output and input ports, since rise delay times on these input ports differ from those of the actual IC. #### (2) Differences in current consumption The amount of current consumed by this board differs significantly from that of the actual IC. Inspecting the LEDs on this board may help you keep track of approximate current consumption. The following factors/components greatly affect device current consumption: #### <Those which can be verified by LEDs and monitor pins> - a) Run and Halt execution ratio (verified by LEDs and monitor pins on the ICE) - b) CPU operating voltage select circuit (VDC) - c) OSC3 oscillation on/off circuit (OSCC) - d) CPU clock change circuit (CLKCHG) - e) SVD circuit on/off circuit (SVDON) \* Available only for the S1C63404/458/466/P466. - f) LCD power supply on/off circuit (LPWR) - g) LCD constant-voltage change circuit (VCCHG) ## <Those that can only be counteracted by system or software> - h) Current consumed by the internal pull-up resistors - i) Input ports in a floating state ## (3) Functional precautions #### <LCD power supply circuit> - There is a finite delay time from the point at which the LCD power supply circuit (LPWR) turns on until an LCD drive waveform is output. On this board, this delay is set to approx. 125 msec, which differs from that of the actual IC. Refer to the technical manual for the S1C63404/454/455/458/466/P466. - When the LCD driver is turned OFF in external power supply mode using the LPWR register, the SEG and COM terminals go to the Vss level. In this board with the LCD board, the SEG terminals go to the Vss level and the COM terminals go to the Vc1 level. #### <Oscillation circuit> - A wait time is required before oscillation stabilizes after the OSC3 oscillation control circuit (OSCC) is turned on. On this board, even when OSC3 oscillation is changed (CLKCHG) without a wait time, OSC3 will function normally. Refer to the technical manual for the S1C63404/454/455/458/466/ P466 when setting the appropriate wait time for the actual IC. - Use separate instructions to switch the clock from OSC3 to OSC1 and to turn off the OSC3 oscillation circuit. If executed simultaneously with a single instruction, these operations, although good with this board, may not function properly well with the actual IC. - Because the logic level of the oscillation circuit is high, the timing at which the oscillation starts on this board differs from that of the actual IC. - This board contains oscillation circuits for OSC1 and OSC3. Keep in mind that even though the actual IC may not have a resonator connected to its OSC3, its emulator can operate with the OSC3 circuit. - Do not turn on the OSC3 oscillation circuit when the voltage-regulating circuit for high-speed operation remains idle. #### <Access to undefined address space> If any undefined space in the S1C63404/454/455/458/466/P466's internal ROM/RAM or I/O is accessed for data read or write operations, the read/written value is indeterminate. Additionally, it is important to remain aware that indeterminate state differs between this board and the actual IC. Note that the ICE (S5U1C63000H1/S5U1C63000H2) incorporates the program break function caused by accessing to an undefined address space. ### <Reset circuit> Keep in mind that the operation sequence from when the ICE and this board are powered on until the time at which the program starts running differs from the sequence from when the actual IC is powered on till the program starts running. This is because this board becomes capable of operating as a debugging system after the user program and optional data are downloaded. When operating the ICE after placing it in free-running mode, always apply a system reset. A system reset can be performed by pressing the reset switch on this board, by a reset pin input, or by holding the input ports low simultaneously. #### <Internal power supply circuit> - Although this board contains VDC register, it does not actually exercise power supply control by this register. Be sure to refer to the technical manual for the S1C63404/454/455/458/466/P466 when setting the correct voltage. Also, when switching the control voltages, consult the technical manual to determine the appropriate wait time to be inserted. - Note that the LCD drive voltage on this board may not be identical to that on the actual IC. - Since the usable operating frequency range depends on the device's internal operating voltage, consult the technical manual for the S1C63404/454/455/458/466/P466 to ensure that the device will not be operated with an inappropriate combination of the operating frequency and the internal power supply. #### <SVD circuit>\*1 When this tool is used for the S1C63404/458/466/P466: - Although the S1C63404/458/466/P466 has a function for detecting externally sourced voltages, this board is unable to detect externally sourced voltages. The SVD function is realized by artificially varying the power supply voltage using the VSVD control on this board. - There is a finite delay time from when the power to the SVD circuit turns on until actual detection of the voltage. On this board, this delay is set to 61–92 µsec, which differs from that of the actual IC. Refer to the technical manual for the S1C63404/458/466/P466 when setting the appropriate wait time for the actual IC. ## <I/O port input circuit>\*2 When this tool is used for the S1C63454/455: This board does not support Schmitt trigger input for the I/O port that is available by mask option in the actual IC. If the target system needs Schmitt trigger input ports, it should be configured with an external circuit. #### <LCD drive circuit>\*3 When this tool is used for the S1C63455: - Be sure to set the LDUTY0 and LDUTY1 bits (FF60H•D2, D3) as LDUTY0 = 0 and LDUTY1 = 1 or LDUTY0 = 1 and LDUTY1 = 1, and maintain this status during debugging. This board is configured as a 1/17 duty LCD driver after an initial reset. - Do not change the value of the LPAGE bit (FF61H D0) initialized to 0 as rewriting cause a malfunction. - \*1: Applied when this board is used for the S1C63404/458/466/P466 - \*2: Applied when this board is used for the S1C63454/455 - \*3: Applied when this board is used for the S1C63455 # **EPSON** # **International Sales Operations** #### **AMERICA** #### **EPSON ELECTRONICS AMERICA, INC.** #### - HEADQUARTERS - 150 River Oaks Parkway San Jose, CA 95134, U.S.A. Phone: +1-408-922-0200 Fax: +1-408-922-0238 #### - SALES OFFICES - #### Wes 1960 E. Grand Avenue El Segundo, CA 90245, U.S.A. Phone: +1-310-955-5300 Fax: +1-310-955-5400 #### Central 101 Virginia Street, Suite 290 Crystal Lake, IL 60014, U.S.A. Phone: +1-815-455-7630 Fax: +1-815-455-7633 #### **Northeast** 301 Edgewater Place, Suite 120 Wakefield, MA 01880, U.S.A. Phone: +1-781-246-3600 Fax: +1-781-246-5443 #### Southeast 3010 Royal Blvd. South, Suite 170 Alpharetta, GA 30005, U.S.A. Phone: +1-877-EEA-0020 Fax: +1-770-777-2637 ### **EUROPE** #### **EPSON EUROPE ELECTRONICS GmbH** #### - HEADQUARTERS - Riesstrasse 15 80992 Munich, GERMANY Phone: +49-(0)89-14005-0 Fax: +49-(0)89-14005-110 #### **SALES OFFICE** Altstadtstrasse 176 51379 Leverkusen, GERMANY Phone: +49-(0)2171-5045-0 Fax: +49-(0)2171-5045-10 ### **UK BRANCH OFFICE** Unit 2.4, Doncastle House, Doncastle Road Bracknell, Berkshire RG12 8PE, ENGLAND Phone: +44-(0)1344-381700 Fax: +44-(0)1344-381701 #### FRENCH BRANCH OFFICE 1 Avenue de l' Atlantique, LP 915 Les Conquerants Z.A. de Courtaboeuf 2, F-91976 Les Ulis Cedex, FRANCE Phone: +33-(0)1-64862350 Fax: +33-(0)1-64862355 #### **BARCELONA BRANCH OFFICE** #### **Barcelona Design Center** Edificio Testa, Avda. Alcalde Barrils num. 64-68 E-08190 Sant Cugat del Vallès, SPAIN Phone: +34-93-544-2490 Fax: +34-93-544-2491 #### **ASIA** #### EPSON (CHINA) CO., LTD. 23F, Beijing Silver Tower 2# North RD DongSanHuan ChaoYang District, Beijing, CHINA Phone: 64106655 Fax: 64107319 #### SHANGHAI BRANCH 4F, Bldg., 27, No. 69, Gui Jing Road Caohejing, Shanghai, CHINA Phone: 21-6485-5552 Fax: 21-6485-0775 #### **EPSON HONG KONG LTD.** 20/F., Harbour Centre, 25 Harbour Road Wanchai, Hong Kong Phone: +852-2585-4600 Fax: +852-2827-4346 Telex: 65542 EPSCO HX #### **EPSON TAIWAN TECHNOLOGY & TRADING LTD.** 10F, No. 287, Nanking East Road, Sec. 3 Taipei Phone: 02-2717-7360 Fax: 02-2712-9164 Telex: 24444 EPSONTB #### **HSINCHU OFFICE** 13F-3, No. 295, Kuang-Fu Road, Sec. 2 HsinChu 300 Phone: 03-573-9900 Fax: 03-573-9169 #### **EPSON SINGAPORE PTE., LTD.** No. 1 Temasek Avenue, #36-00 Millenia Tower, SINGAPORE 039192 Phone: +65-337-7911 Fax: +65-334-2716 # SEIKO EPSON CORPORATION KOREA OFFICE 50F, KLI 63 Bldg., 60 Yoido-dong Youngdeungpo-Ku, Seoul, 150-763, KOREA Phone: 02-784-6027 Fax: 02-767-3677 # SEIKO EPSON CORPORATION ELECTRONIC DEVICES MARKETING DIVISION # **Electronic Device Marketing Department** IC Marketing & Engineering Group 421-8, Hino, Hino-shi, Tokyo 191-8501, JAPAN Phone: +81-(0)42-587-5816 Fax: +81-(0)42-587-5624 ### ED International Marketing Department Europe & U.S.A. 421-8, Hino, Hino-shi, Tokyo 191-8501, JAPAN Phone: +81-(0)42-587-5812 Fax: +81-(0)42-587-5564 #### **ED International Marketing Department Asia** 421-8, Hino, Hino-shi, Tokyo 191-8501, JAPAN Phone: +81-(0)42-587-5814 Fax: +81-(0)42-587-5110 In pursuit of "Saving" Technology, Epson electronic devices. Our lineup of semiconductors, liquid crystal displays and quartz devices assists in creating the products of our customers' dreams. Epson IS energy savings. **S1C63454** Technical Manual # SEIKO EPSON CORPORATION ELECTRONIC DEVICES MARKETING DIVISION ■ EPSON Electronic Devices Website http://www.epsondevice.com